@nexus-cross/crossx-sdk-core 1.0.9 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/dist/__tests__/mocks/MockWalletProviderPort.d.ts +15 -0
  2. package/dist/__tests__/mocks/MockWalletProviderPort.d.ts.map +1 -1
  3. package/dist/adapters/confirmation/BrowserConfirmationAdapter.d.ts +37 -2
  4. package/dist/adapters/confirmation/BrowserConfirmationAdapter.d.ts.map +1 -1
  5. package/dist/adapters/crypto/JoseCryptoAdapter.d.ts +1 -1
  6. package/dist/adapters/crypto/JoseCryptoAdapter.d.ts.map +1 -1
  7. package/dist/adapters/transport/FetchTransportAdapter.d.ts.map +1 -1
  8. package/dist/adapters/wallet/MockWalletProviderAdapter.d.ts +56 -3
  9. package/dist/adapters/wallet/MockWalletProviderAdapter.d.ts.map +1 -1
  10. package/dist/adapters/wallet/RemoteWalletProviderAdapter.d.ts +56 -5
  11. package/dist/adapters/wallet/RemoteWalletProviderAdapter.d.ts.map +1 -1
  12. package/dist/adapters/wallet/types.d.ts +74 -9
  13. package/dist/adapters/wallet/types.d.ts.map +1 -1
  14. package/dist/core/i18n/messages.en.d.ts.map +1 -1
  15. package/dist/core/i18n/messages.ko.d.ts.map +1 -1
  16. package/dist/core/i18n/types.d.ts +26 -0
  17. package/dist/core/i18n/types.d.ts.map +1 -1
  18. package/dist/core/ports/ConfirmationPort.d.ts +48 -2
  19. package/dist/core/ports/ConfirmationPort.d.ts.map +1 -1
  20. package/dist/core/ports/TransportPort.d.ts.map +1 -1
  21. package/dist/core/ports/WalletProviderPort.d.ts +46 -5
  22. package/dist/core/ports/WalletProviderPort.d.ts.map +1 -1
  23. package/dist/core/services/PasswordMemoryStore.d.ts +43 -0
  24. package/dist/core/services/PasswordMemoryStore.d.ts.map +1 -0
  25. package/dist/core/services/TypedEventEmitter.d.ts.map +1 -1
  26. package/dist/core/types/caip.d.ts.map +1 -1
  27. package/dist/core/types/chain.d.ts +1 -1
  28. package/dist/core/types/chain.d.ts.map +1 -1
  29. package/dist/core/types/errors.d.ts +35 -3
  30. package/dist/core/types/errors.d.ts.map +1 -1
  31. package/dist/core/types/index.d.ts +12 -1
  32. package/dist/core/types/index.d.ts.map +1 -1
  33. package/dist/core/usecases/SignInUseCase.d.ts.map +1 -1
  34. package/dist/core/utils/logger.d.ts.map +1 -1
  35. package/dist/crossx.global +694 -107
  36. package/dist/index.cjs +695 -108
  37. package/dist/index.js +3104 -1726
  38. package/dist/sdk/CROSSxSDK.d.ts +102 -4
  39. package/dist/sdk/CROSSxSDK.d.ts.map +1 -1
  40. package/dist/sdk/EthereumProvider.d.ts.map +1 -1
  41. package/dist/sdk/factory.d.ts.map +1 -1
  42. package/package.json +1 -1
package/dist/index.cjs CHANGED
@@ -1,8 +1,8 @@
1
- "use strict";var As=Object.defineProperty;var Rs=(r,e,s)=>e in r?As(r,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[e]=s;var v=(r,e,s)=>Rs(r,typeof e!="symbol"?e+"":e,s);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Os=require("jose");var g=(r=>(r.AUTH_NOT_INITIALIZED="AUTH_NOT_INITIALIZED",r.AUTH_FAILED="AUTH_FAILED",r.AUTH_TOKEN_INVALID="AUTH_TOKEN_INVALID",r.AUTH_TOKEN_EXPIRED="AUTH_TOKEN_EXPIRED",r.AUTH_NOT_AUTHENTICATED="AUTH_NOT_AUTHENTICATED",r.WALLET_NOT_FOUND="WALLET_NOT_FOUND",r.WALLET_CREATION_FAILED="WALLET_CREATION_FAILED",r.SIGN_FAILED="SIGN_FAILED",r.SIGN_REJECTED="SIGN_REJECTED",r.TX_FAILED="TX_FAILED",r.TX_REJECTED="TX_REJECTED",r.USER_REJECTED="USER_REJECTED",r.TX_INVALID_PARAMS="TX_INVALID_PARAMS",r.NETWORK_ERROR="NETWORK_ERROR",r.NETWORK_NOT_CONFIGURED="NETWORK_NOT_CONFIGURED",r.INVALID_CHAIN="INVALID_CHAIN",r.CHAIN_NOT_SUPPORTED="CHAIN_NOT_SUPPORTED",r.CHAIN_ADAPTER_NOT_FOUND="CHAIN_ADAPTER_NOT_FOUND",r.NOT_IMPLEMENTED="NOT_IMPLEMENTED",r.SIGNATURE_FAILED="SIGNATURE_FAILED",r.TRANSACTION_FAILED="TRANSACTION_FAILED",r.PREPARE_FAILED="PREPARE_FAILED",r.PREPARE_EXPIRED="PREPARE_EXPIRED",r.PREPARE_MISMATCH="PREPARE_MISMATCH",r.MIGRATION_FAILED="MIGRATION_FAILED",r.MIGRATION_BACKUP_EXISTS="MIGRATION_BACKUP_EXISTS",r.GATEWAY_INTERNAL_ERROR="GATEWAY_INTERNAL_ERROR",r.GATEWAY_LOCK_CONFLICT="GATEWAY_LOCK_CONFLICT",r.PROJECT_ID_MISSING="PROJECT_ID_MISSING",r.ORIGIN_NOT_ALLOWED="ORIGIN_NOT_ALLOWED",r.APP_IDENTIFIER_MISSING="APP_IDENTIFIER_MISSING",r.INVALID_APP_TYPE="INVALID_APP_TYPE",r.PROJECT_NOT_REGISTERED="PROJECT_NOT_REGISTERED",r.SIGNATURE_SIGNER_MISMATCH="SIGNATURE_SIGNER_MISMATCH",r.GAS_ESTIMATION_FAILED="GAS_ESTIMATION_FAILED",r.TYPED_DATA_CHAIN_ID_MISMATCH="TYPED_DATA_CHAIN_ID_MISMATCH",r.INVALID_CONFIG="INVALID_CONFIG",r.UNKNOWN_ERROR="UNKNOWN_ERROR",r))(g||{});class x extends Error{constructor(e,s,t){super(s),this.code=e,this.details=t,this.name="CROSSxError",Object.setPrototypeOf(this,x.prototype)}toJSON(){return{name:this.name,code:this.code,message:this.message,details:this.details}}}const je={CROSS_MAINNET:{caipId:"eip155:612055",chainId:612055,name:"CROSS Mainnet",nativeCurrency:{symbol:"CROSS",decimals:18},rpcUrl:"https://mainnet.crosstoken.io:22001"},CROSS_TESTNET:{caipId:"eip155:612044",chainId:612044,name:"CROSS Testnet",nativeCurrency:{symbol:"tCROSS",decimals:18},rpcUrl:"https://testnet.crosstoken.io:22001",testnet:!0},BSC_MAINNET:{caipId:"eip155:56",chainId:56,name:"BNB Smart Chain",nativeCurrency:{symbol:"BNB",decimals:18},rpcUrl:"https://bsc-mainnet.crosstoken.io/2272489872e4f1475ff25d57ce93b51989f933c7"},BSC_TESTNET:{caipId:"eip155:97",chainId:97,name:"BNB Smart Chain Testnet",nativeCurrency:{symbol:"BNB",decimals:18},rpcUrl:"https://bsc-testnet.crosstoken.io/110ea3628b77f244e5dbab16790d81bba874b962",testnet:!0},RONIN_MAINNET:{caipId:"eip155:2020",chainId:2020,name:"Ronin",nativeCurrency:{symbol:"RON",decimals:18},rpcUrl:"https://api.roninchain.com/rpc"},RONIN_SAIGON:{caipId:"eip155:202601",chainId:202601,name:"Ronin Saigon",nativeCurrency:{symbol:"RON",decimals:18},rpcUrl:"https://saigon-testnet.roninchain.com/rpc",testnet:!0}},Cs=Object.fromEntries(Object.entries(je).map(([r,e])=>[r,e.caipId])),ks=new Map(Object.values(je).map(r=>[r.caipId,r]));new Map(Object.values(je).map(r=>[r.chainId,r]));const Ns={symbol:"",decimals:18};function Ye(r){var e;return((e=ks.get(r))==null?void 0:e.nativeCurrency)??Ns}class Kt{constructor(e,s){this.sdk=e,this.chainId=s,this._listeners=new Map}async request({method:e,params:s=[]}){switch(e){case"eth_accounts":case"eth_requestAccounts":{const t=await this.sdk.getAddress();return t?[t.address]:[]}case"eth_chainId":return this._caip2ToHex(this.chainId);case"net_version":return this.chainId.split(":")[1]??"1";case"eth_signTransaction":{const t=this._normalizeEIP1193Tx(s[0]);return(await this.sdk.signTransaction(this.chainId,t)).signedTx}case"eth_sendTransaction":{const t=this._normalizeEIP1193Tx(s[0]);return(await this.sdk.sendTransaction(this.chainId,t)).txHash}case"personal_sign":case"eth_sign":throw new x(g.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signMessage()를 직접 사용하세요.`);case"eth_signTypedData":case"eth_signTypedData_v1":case"eth_signTypedData_v3":case"eth_signTypedData_v4":throw new x(g.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signTypedData() 또는 sdk.signTypedDataOffchain()을 직접 사용하세요.`);default:return this.sdk.walletRpc(e,s,this.chainId)}}on(e,s){return this._listeners.has(e)||this._listeners.set(e,new Set),this._listeners.get(e).add(s),this}removeListener(e,s){var t;return(t=this._listeners.get(e))==null||t.delete(s),this}emit(e,...s){var t;(t=this._listeners.get(e))==null||t.forEach(n=>n(...s))}_caip2ToHex(e){const s=e.split(":");return`0x${parseInt(s[1]??"1",10).toString(16)}`}_normalizeEIP1193Tx(e){return{from:e.from,to:e.to,value:e.value,data:e.data,gasLimit:e.gasLimit??e.gas,gasPrice:e.gasPrice,maxFeePerGas:e.maxFeePerGas,maxPriorityFeePerGas:e.maxPriorityFeePerGas,nonce:e.nonce!==void 0?parseInt(String(e.nonce),16):void 0,chainId:parseInt(this.chainId.split(":")[1]??"1",10)}}}let we=null;function wt(r){we=r}const p={log(...r){if(we){we.log(...r);return}},warn(...r){if(we){we.warn(...r);return}},error(...r){if(we){we.error(...r);return}}},Ps={confirm:"확인",cancel:"취소",close:"닫기",signMessage_title:"메시지 서명",signTypedData_title:"데이터 서명",signTransaction_title:"트랜잭션 서명",sendTransaction_title:"트랜잭션 전송",tx_pending:"트랜잭션 처리 중...",tx_success:"트랜잭션이 완료되었습니다",tx_failed:"트랜잭션이 실패했습니다",tx_timeout:"트랜잭션 확인 시간이 초과되었습니다",loginSelector_title:"로그인 방법 선택",loginSelector_google:"Google로 계속하기",loginSelector_apple:"Apple로 계속하기",migration_foundTitle:"기존 지갑 발견",migration_foundDescription:"기존 CROSSx 지갑이 발견되었습니다. 복구하시겠습니까?",migration_recoverButton:"복구하기",migration_skipButton:"건너뛰기",pinInput_title:"PIN 입력",pinInput_placeholder:"4자리 PIN을 입력하세요",pinInput_error:"PIN이 올바르지 않습니다. 다시 시도해 주세요.",walletSelector_title:"지갑 선택",walletSelector_addButton:"지갑 추가",walletSelector_selected:"선택됨"},zt={confirm:"Confirm",cancel:"Cancel",close:"Close",signMessage_title:"Sign Message",signTypedData_title:"Sign Data",signTransaction_title:"Sign Transaction",sendTransaction_title:"Send Transaction",tx_pending:"Processing transaction...",tx_success:"Transaction completed",tx_failed:"Transaction failed",tx_timeout:"Transaction confirmation timed out",loginSelector_title:"Choose a sign-in method",loginSelector_google:"Continue with Google",loginSelector_apple:"Continue with Apple",migration_foundTitle:"Existing Wallet Found",migration_foundDescription:"An existing CROSSx wallet was found. Would you like to recover it?",migration_recoverButton:"Recover",migration_skipButton:"Skip",pinInput_title:"Enter PIN",pinInput_placeholder:"Enter your 4-digit PIN",pinInput_error:"Incorrect PIN. Please try again.",walletSelector_title:"Select Wallet",walletSelector_addButton:"Add Wallet",walletSelector_selected:"Selected"},Ls={ko:Ps,en:zt};function yt(r="en",e){return Ls[r]??zt}const Ze="crossx_access_token",Ne="crossx_refresh_token",Pe="crossx_user_info";class Ds{constructor(e,s,t,n,o,i,a){this.config=e,this.storage=s,this.crypto=t,this.oauth=n,this.transport=o,this.walletProvider=i,this.tokenStore=a,this._refreshPromise=null}get useCookieAuth(){return this.config.authMode==="cookie"}checkResponseError(e,s){if(e!=null&&e.code&&e.code!==200&&e.code>0)throw new x(g.AUTH_FAILED,`${s} 실패 (코드 ${e.code}): ${e.message}`);const t=e==null?void 0:e.data;if(typeof t=="object"&&t!==null&&"code"in t){const n=t;if(n.code&&n.code!==200&&n.code>0)throw new x(g.AUTH_FAILED,`${s} 실패 (코드 ${n.code}): ${n.message}`)}}async execute(e){var n,o,i,a;let s,t=!1;try{const c=e==null?void 0:e.provider;let l="/login";c==="google"?l="/google":c==="apple"&&(l="/apple");const{oauthServiceUrl:d,authApiUrl:f}=this.config,w=`${d}${l}`;p.log(`[CROSSx] OAuth 팝업 열기 (${c||"일반"} 로그인):`,w);const _=await this.oauth.openAuth({authUrl:w,expectedOrigin:new URL(d).origin});p.log("[CROSSx] OAuth Firebase 토큰 받음 (length:",_.length,")");const{accessToken:m,refreshToken:A}=await this.exchangeFirebaseToken(_,f);let y,T;try{const F=this.crypto.decodeJWT(_);T=(n=F.firebase)==null?void 0:n.sign_in_provider;const $=((o=F.firebase)==null?void 0:o.identities)??{};T==="google.com"?y=(i=$["google.com"])==null?void 0:i[0]:T==="apple.com"&&(y=(a=$["apple.com"])==null?void 0:a[0]),p.log("[CROSSx] OAuth provider sub 추출 — provider:",T,"hasProviderSub:",!!y)}catch{p.warn("[CROSSx] firebaseToken에서 providerSub 추출 실패")}if(m){const F=this.crypto.decodeJWT(m);p.log("[CROSSx] access_token 디코딩 — sub:",F.sub,"exp:",F.exp);const $=await this.crypto.verifyJWT(m);if(t=$.signatureVerified??!1,!$.valid)throw p.error("[CROSSx] access_token 검증 실패"),new Error("유효하지 않은 access token");const B=$.payload;s={id:B.sub,email:B.email,signInProvider:T,providerSub:y},this.tokenStore.set(m),this.useCookieAuth||(await this.storage.set(Ze,m),A&&await this.storage.set(Ne,A))}else{const F=this.crypto.decodeJWT(_);s={id:F.sub,email:F.email,signInProvider:T,providerSub:y},p.log("[CROSSx] Cookie 모드 — Firebase 토큰에서 사용자 정보 추출 — id:",s.id)}p.log("[CROSSx] 사용자 정보 — id:",s.id);const L=this.useCookieAuth?{id:s.id,signInProvider:s.signInProvider,providerSub:s.providerSub}:s;await this.storage.set(Pe,L),p.log("[CROSSx] 사용자 정보 저장 완료 (authMode:",this.useCookieAuth?"cookie":"token",")")}catch(c){return p.error("[CROSSx] SignIn 에러 (OAuth/토큰 교환 단계):",c),{success:!1,error:c instanceof Error?c.message:"Sign in failed"}}return p.log("[CROSSx][Migration Phase 1] OAuth 로그인 완료, 지갑 로드 시작 — userId:",s.id),this.loadWallet(s,t)}async exchangeFirebaseToken(e,s){const t=this.useCookieAuth,n=t?`${s}/cross-auth/social/login/cookie`:`${s}/cross-auth/social/login`;p.log("[CROSSx] Firebase 토큰 교환 요청:",n);const o=await this.transport.request({url:n,method:"POST",headers:{"Content-Type":"application/json"},body:{auth_code:e,login_type:"firebase"},...t?{credentials:"include"}:{}});p.log("[CROSSx] 토큰 교환 응답 — status:",o.status);const i=o.data;this.checkResponseError(i,"Token exchange");const a=this.extractAccessToken(i);if(t&&!a)return p.log("[CROSSx] Cookie 모드 — 로그인 성공 (JWT는 HttpOnly 쿠키)"),{};if(!a)throw new x(g.AUTH_FAILED,"토큰 교환 응답에서 access_token을 찾을 수 없습니다");p.log("[CROSSx] access_token 교환 성공");let c;return t||(c=this.extractRefreshToken(i)),{accessToken:a,refreshToken:c}}extractAccessToken(e){const s=(e==null?void 0:e.data)??e;if(this.isJwtString(s))return s;if(typeof s=="object"&&s!==null){const t=s;if(this.isJwtString(t.data))return t.data;if(typeof t.data=="object"&&t.data!==null){const o=t.data,i=o.access_token??o.token;if(typeof i=="string")return i}const n=t.access_token??t.token;if(typeof n=="string")return n}}extractRefreshToken(e){const s=(e==null?void 0:e.data)??e;if(typeof s!="object"||s===null)return;const t=s;if(typeof t.data=="object"&&t.data!==null){const o=t.data,i=o.refresh_token??o.refresh;if(typeof i=="string")return i}const n=t.refresh_token??t.refresh;if(typeof n=="string")return n}isJwtString(e){return typeof e=="string"&&e.split(".").length===3}async restoreSession(){try{const e=this.tokenStore.get();if(e){const t=await this.crypto.verifyJWT(e);if(t.valid){const n=await this.storage.get(Pe);if(n)return p.log("[CROSSx] restoreSession — 메모리 토큰 유효, 세션 복원"),this.loadWallet(n,t.signatureVerified)}this.tokenStore.clear()}if(this.useCookieAuth){p.log("[CROSSx] restoreSession — 쿠키 기반 silentRefresh 시도");const t=await this.silentRefresh();t&&this.tokenStore.set(t)}else{const t=await this.storage.get(Ze),n=await this.storage.get(Ne);if(p.log("[CROSSx] restoreSession — access_token:",t?"있음":"없음","refresh_token:",n?"있음":"없음"),!n)return p.log("[CROSSx] restoreSession — refresh_token 없음, 세션 복원 생략"),null;t&&this.tokenStore.set(t);const o=await this.silentRefresh(n);p.log("[CROSSx] restoreSession — silentRefresh 결과:",o?"토큰 발급 성공":"토큰 없음"),o&&this.tokenStore.set(o)}const s=await this.storage.get(Pe);if(p.log("[CROSSx] restoreSession — userInfo 조회:",s?`있음 (id: ${s.id})`:"없음"),!s)return null;p.log("[CROSSx] restoreSession — silentRefresh 성공, 세션 복원 — userId:",s.id);try{return await this.loadWallet(s,!1)}catch(t){return p.warn("[CROSSx] restoreSession — 지갑 로드 실패 (세션은 유지):",t),{success:!0,user:s,tokenSignatureVerified:!1}}}catch(e){return p.log("[CROSSx] restoreSession — 세션 복원 실패, 스토리지 정리:",e),this.tokenStore.clear(),this.useCookieAuth||await this.storage.remove(Ne),await this.storage.remove(Pe),null}}silentRefresh(e){return this._refreshPromise?this._refreshPromise:(this._refreshPromise=this._doSilentRefresh(e).finally(()=>{this._refreshPromise=null}),this._refreshPromise)}async _doSilentRefresh(e){const{authApiUrl:s}=this.config,t=this.useCookieAuth,n=`${s}/cross-auth/social/refresh/simple`,o={};if(!t){const l=this.tokenStore.get()??"";l&&(o.access_token=l),e&&(o.refresh_token=e)}const i=await this.transport.request({url:n,method:"POST",headers:{"Content-Type":"application/json"},body:o,...t?{credentials:"include"}:{}});p.log("[CROSSx] silentRefresh 응답 — status:",i.status);const a=i.data;this.checkResponseError(a,"Silent refresh");const c=this.extractAccessToken(a);if(t&&!c){p.log("[CROSSx] silentRefresh 성공 (cookie 갱신)");return}if(!c)throw new x(g.AUTH_FAILED,"토큰 자동 갱신 실패: 응답에 토큰이 없습니다");if(this.tokenStore.set(c),!t){await this.storage.set(Ze,c);const l=this.extractRefreshToken(a);l&&await this.storage.set(Ne,l)}return p.log("[CROSSx] silentRefresh 성공"),c}async loadWallet(e,s){let t,n=!1;try{p.log("[CROSSx][Migration Phase 2] POST /mnemonic/create 호출 — userId:",e.id),t=(await this.walletProvider.getOrCreateWallet(e.id)).address,p.log("[CROSSx][Migration Phase 2] 지갑 로드 완료 (기존 백업 없음) — address:",t)}catch(o){if(o instanceof x&&o.code===g.MIGRATION_BACKUP_EXISTS)p.log("[CROSSx][Migration Phase 2] Gateway -10012 감지 → needsMigration = true"),n=!0;else{if(o instanceof x&&(o.code===g.PROJECT_NOT_REGISTERED||o.code===g.PROJECT_ID_MISSING||o.code===g.ORIGIN_NOT_ALLOWED))throw p.error("[CROSSx][Migration Phase 2] 프로젝트 설정 에러:",o.message),o;p.warn("[CROSSx][Migration Phase 2] 지갑 로드 실패 (로그인은 유지):",o)}}return p.log("[CROSSx][Migration Phase 2] loadWallet 결과 — address:",t,"needsMigration:",n),{success:!0,address:t,user:e,needsMigration:n,tokenSignatureVerified:s}}}const $s="crossx_access_token",Ms="crossx_refresh_token",Bs="crossx_user_info";class Fs{constructor(e,s,t){this.config=e,this.storage=s,this.tokenStore=t}async execute(){this.tokenStore.clear(),this.config.authMode!=="cookie"&&(await this.storage.remove($s),await this.storage.remove(Ms)),await this.storage.remove(Bs)}}class Us{constructor(e,s){this.storage=e,this.walletProvider=s}async execute(e,s){if(!this.walletProvider.migrateWallet)throw new x(g.NOT_IMPLEMENTED,"현재 환경에서는 마이그레이션이 지원되지 않습니다");p.log("[CROSSx][Migration Phase 4] MigrateWalletUseCase.execute() — pin 길이:",e.length,"sub:",s);const t=await this.walletProvider.migrateWallet(e,s);return p.log("[CROSSx][Migration Phase 5] MigrateWalletUseCase 완료 — address:",t.address),{address:t.address}}}class Hs{constructor(e,s){this.chainRegistry=e,this.transport=s}async call(e,s,t){const n=await this.chainRegistry.getChain(t),o={jsonrpc:"2.0",method:e,params:s,id:Date.now()},a=(await this.transport.request({url:n.rpcUrl,method:"POST",headers:{"Content-Type":"application/json"},body:o})).data;if(a!=null&&a.error)throw new x(g.UNKNOWN_ERROR,`RPC 오류 [${e}] (${t}): ${a.error.message} (코드: ${a.error.code})`);return a==null?void 0:a.result}}class Gs{constructor(){this.listeners=new Map}on(e,s){return this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(s),()=>this.off(e,s)}off(e,s){var t;(t=this.listeners.get(e))==null||t.delete(s)}emit(e,s){var t;(t=this.listeners.get(e))==null||t.forEach(n=>n(s))}removeAllListeners(){this.listeners.clear()}}const Fe={production:{oauthServiceUrl:"https://stg-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://stg-cross-auth.crosstoken.io",walletGatewayUrl:"https://stg-embedded-wallet-gateway.crosstoken.io/api/v1"},staging:{oauthServiceUrl:"https://stg-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://stg-cross-auth.crosstoken.io",walletGatewayUrl:"https://stg-embedded-wallet-gateway.crosstoken.io/api/v1"},development:{oauthServiceUrl:"https://dev-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://dev-cross-auth.crosstoken.io",walletGatewayUrl:"https://dev-embedded-wallet-gateway.crosstoken.io/api/v1"}};function qs(r){const e=r.environment;return e&&e in Fe?Fe[e]:null}function Ws(){try{if(typeof __CROSSX_CONFIG__<"u"){const r=typeof __CROSSX_CONFIG__=="string"?JSON.parse(__CROSSX_CONFIG__):__CROSSX_CONFIG__,e=qs(r);if(e)return e}}catch{}return Fe.production}const js=2e3,bt=6e4,Vs=1e3,Ks=1e4,zs="0x77359400",vt="0x3B9ACA00",St=130,Et=6,Tt=18,Ys=0,Zs=30*1e3,X=class X extends Gs{constructor(e,s,t,n,o,i,a,c,l,d){super(),this.storage=t,this.crypto=n,this.transport=o,this.oauth=i,this.walletProvider=a,this.tokenStore=c,this.initialized=!1,this.authenticated=!1,this.userId=null,this.address=null,this.userEmail=null,this.loginType=null,this.providerSub=null,this.tokenSignatureVerified=!1,this._config=Object.freeze({...e}),this.internalConfig=e,this.adapterConfig=s,e.logger&&wt(e.logger),this.confirmation=l,this.chainRegistry=d,this.jsonRpc=new Hs(d,o),this.signInUseCase=new Ds(this.internalConfig,t,n,i,o,a,c),this.signOutUseCase=new Fs(this.internalConfig,t,c),this.migrateWalletUseCase=new Us(t,a)}get config(){return this._config}async initialize(){if(this.initialized)return this.authenticated?{success:!0,address:this.address??void 0}:null;console.log("[CROSSx SDK] v1.0.9 초기화 중..."),this.confirmation.setMessages(yt(this._config.locale));try{const e=Ws();this.internalConfig.oauthServiceUrl=e.oauthServiceUrl,this.internalConfig.authApiUrl=e.authApiUrl,this.internalConfig.walletGatewayUrl=e.walletGatewayUrl,this.adapterConfig.gatewayUrl=e.walletGatewayUrl;const s=await this.signInUseCase.restoreSession();return s!=null&&s.success&&this.applyAuthResult(s),this.initialized=!0,this.emit("initialized",{restored:!!(s!=null&&s.success)}),s??null}catch(e){throw new x(g.AUTH_NOT_INITIALIZED,"SDK 초기화에 실패했습니다",e)}}async signIn(e){this.ensureInitialized();let s=e;if(!(e!=null&&e.provider)){const t=await this.confirmation.showLoginSelector();if(t===null)return{success:!1,error:"User cancelled login"};s={...e,provider:t}}try{const t=await this.signInUseCase.execute(s);return t.success&&this.applyAuthResult(t),t}catch(t){throw new x(g.AUTH_FAILED,"로그인에 실패했습니다",t)}}async signInWithCreate(e){const s=await this.signIn(e);if(!s.success)return{...s,addresses:[]};if(s.needsMigration||!s.address){const{address:o}=await this.createWallet(),i=await this.getAddresses(),a=await this.selectWalletIfMultiple(i);return{...s,address:(a==null?void 0:a.address)??o,needsMigration:!1,addresses:i}}const t=await this.getAddresses(),n=await this.selectWalletIfMultiple(t);return{...s,address:(n==null?void 0:n.address)??s.address,addresses:t}}async signOut(){this.ensureInitialized();try{await this.signOutUseCase.execute(),this.clearAuthState()}catch(e){throw new x(g.UNKNOWN_ERROR,"로그아웃에 실패했습니다",e)}}isAuthenticated(){return this.authenticated}get currentAddress(){return this.address}get currentUserId(){return this.userId}isLoggedIn(){return this.isAuthenticated()}async ensureLoggedIn(){if(!this.initialized)return!1;if(this.authenticated)return!0;try{const e=await this.signInUseCase.restoreSession();return e!=null&&e.success?(this.applyAuthResult(e),!0):!1}catch{return!1}}async getUserInfo(){return this.ensureAuthenticated(),{id:this.userId,email:this.userEmail??void 0,loginType:this.loginType??void 0,addresses:this.address?[this.address]:[],tokenSignatureVerified:this.tokenSignatureVerified}}async migrateWallet(e){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");try{const s=await this.migrateWalletUseCase.execute(e,this.userId);return this.address=s.address,this.emit("addressChanged",{address:s.address,index:0}),p.log("[CROSSx] migrateWallet 완료 — address:",s.address),s}catch(s){throw s instanceof x?s:new x(g.MIGRATION_FAILED,"지갑 마이그레이션에 실패했습니다",s)}}async getAddress(e){if(e!==void 0){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");return{address:(await this.walletProvider.getAddress(this.userId,e)).address,index:e}}return!this.authenticated||!this.address?null:{address:this.address,index:0}}async getAddresses(){return this.ensureAuthenticated(),this.userId?this.walletProvider.getAddresses(this.userId):[]}async selectWallet(e){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const s=await this.walletProvider.getAddresses(this.userId),t=await this.confirmation.showWalletSelector(s,async()=>{const n=s.length,i={address:(await this.walletProvider.getAddress(this.userId,n)).address,index:n};return s.push(i),i},e);return t&&(this.address=t.address,this.emit("addressChanged",{address:t.address,index:t.index})),t}async selectWalletIfMultiple(e){return e.length<2?null:this.selectWallet()}async getChains(){this.ensureInitialized();try{return await this.chainRegistry.getChains()}catch(e){throw e instanceof x?e:new x(g.UNKNOWN_ERROR,"체인 목록 조회에 실패했습니다",e)}}async getChain(e){this.ensureInitialized();try{return await this.chainRegistry.getChain(e)}catch(s){throw s instanceof x?s:new x(g.CHAIN_NOT_SUPPORTED,`체인 조회에 실패했습니다: ${e}`,s)}}applyTheme(e=this._config.theme??"light",s=this._config.themeTokens??{}){this._config=Object.freeze({...this._config,theme:e,themeTokens:s}),this.confirmation.setTheme(e,s)}applyLocale(e=this._config.locale??"en"){this._config=Object.freeze({...this._config,locale:e}),this.confirmation.setMessages(yt(e))}async createWallet(){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");p.log("[CROSSx] 지갑 생성 시작");try{const e=await this.walletProvider.getOrCreateWallet(this.userId);return this.address=e.address,this.emit("addressChanged",{address:e.address,index:0}),p.log("[CROSSx] 지갑 생성 완료:",e.address),{address:e.address}}catch(e){if(e instanceof x&&e.code===g.MIGRATION_BACKUP_EXISTS){const s=this.providerSub??this.userId;p.log("[CROSSx][Migration Phase 3] createWallet() — Gateway -10012 감지, 마이그레이션 UI 시작 — migrationSub:",s);const t=await this.handleMigrationFlow(s);if(t)return this.address=t.address,this.emit("addressChanged",{address:t.address,index:0}),{address:t.address};throw new x(g.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}throw e}}async signMessage(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=t==null?void 0:t.index,o=await this.walletProvider.getAddress(this.userId,n??0);let i;if(this.walletProvider.prepare&&(i=(await this.walletProvider.prepare("sign-message",{message:s,from:o.address})).uuid),!await this.confirmation.requestConfirmation({type:"sign-message",chainId:e,from:o.address,message:s,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new x(g.USER_REJECTED,"사용자가 메시지 서명을 거부했습니다");try{const c=await this.walletProvider.signMessage(this.userId,e,s,t==null?void 0:t.index,i,o.address);return this.verifySignatureSigner(s,c.signature,o.address),{chainId:e,signature:c.signature,message:s,address:o.address}}catch(c){throw c instanceof x?c:new x(g.SIGNATURE_FAILED,`메시지 서명에 실패했습니다 (${e})`,c)}}async signTypedData(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");if(!this.walletProvider.signTypedData)throw new x(g.NOT_IMPLEMENTED,"signTypedData가 구현되어 있지 않습니다");X.validateTypedDataChainId(e,s);const n=await this.walletProvider.getAddress(this.userId,(t==null?void 0:t.index)??0);let o;if(this.walletProvider.prepare&&(o=(await this.walletProvider.prepare("sign-typed-data",{typedData:s,from:n.address})).uuid),!await this.confirmation.requestConfirmation({type:"sign-typed-data",chainId:e,from:n.address,typedData:s,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new x(g.USER_REJECTED,"사용자가 타입 데이터 서명을 거부했습니다");try{const a=await this.walletProvider.signTypedData(this.userId,e,s,t==null?void 0:t.index,o,n.address);return X.validateSignatureFormat(a.signature),{chainId:e,signature:a.signature,address:n.address}}catch(a){throw a instanceof x?a:new x(g.SIGNATURE_FAILED,`타입 데이터 서명에 실패했습니다 (${e})`,a)}}async signTypedDataOffchain(e,s){return this.signTypedData(X.OFFCHAIN_CHAIN_ID,e,s)}async signTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);let o;this.walletProvider.prepare&&(o=(await this.walletProvider.prepare("sign",{tx:n})).uuid);const i=Ye(e);if(!await this.confirmation.requestConfirmation({type:"sign",chainId:e,from:n.from,to:n.to,value:n.value,data:n.data,gasLimit:n.gasLimit,gasPrice:n.gasPrice,maxFeePerGas:n.maxFeePerGas,maxPriorityFeePerGas:n.maxPriorityFeePerGas,nativeSymbol:i.symbol,nativeDecimals:i.decimals,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new x(g.USER_REJECTED,"사용자가 트랜잭션 서명을 거부했습니다");try{const c=await this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,o);return X.validateSignedTxFormat(c.signature),{chainId:e,signedTx:c.signature,txHash:c.txHash??""}}catch(c){if(c instanceof x)throw c;const l=c instanceof Error?c.message:String(c);throw new x(g.SIGNATURE_FAILED,`트랜잭션 서명에 실패했습니다 (${e}): ${l}`,c)}}async sendTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new x(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);let o;this.walletProvider.prepare&&(o=(await this.walletProvider.prepare("send",{tx:n})).uuid);const i=Ye(e);if(!await this.confirmation.requestConfirmation({type:"send",chainId:e,from:n.from,to:n.to,value:n.value,data:n.data,gasLimit:n.gasLimit,gasPrice:n.gasPrice,maxFeePerGas:n.maxFeePerGas,maxPriorityFeePerGas:n.maxPriorityFeePerGas,nativeSymbol:i.symbol,nativeDecimals:i.decimals,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new x(g.USER_REJECTED,"사용자가 트랜잭션을 거부했습니다");try{let c;if(this.walletProvider.sendTransaction)c=(await this.walletProvider.sendTransaction(this.userId,e,n,o)).txHash;else{const l=await this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,o);c=l.txHash??l.signature}return{chainId:e,txHash:c,status:"pending"}}catch(c){const l=c instanceof Error?c.message:String(c);throw new x(g.TRANSACTION_FAILED,`트랜잭션 전송에 실패했습니다 (${e}): ${l}`,c)}}async getTransactionReceipt(e,s){try{return await this.jsonRpc.call("eth_getTransactionReceipt",[e],s)??null}catch{return null}}async waitForTxAndGetReceipt(e,s,t={}){const n=t.intervalMs??Vs,o=Ks,i=t.timeoutMs??bt,a=Date.now()+i;let c=n;for(;Date.now()<a;){const l=await this.getTransactionReceipt(e,s);if(l)return l;await new Promise(d=>setTimeout(d,c)),c=Math.min(c*2,o)}throw new x(g.UNKNOWN_ERROR,`트랜잭션 영수증 조회 시간이 초과되었습니다 (${e})`)}async sendTransactionWithWaitForReceipt(e,s,t={}){var A,y;const{intervalMs:n,timeoutMs:o,...i}=t,{txHash:a}=await this.sendTransaction(e,s,i),c=n??((A=this._config.receiptPolling)==null?void 0:A.intervalMs)??js,l=o??((y=this._config.receiptPolling)==null?void 0:y.timeoutMs)??bt,d=Ye(e),f=s.from??"";let w,_;const m=this.waitForTxAndGetReceipt(a,e,{intervalMs:c,timeoutMs:l}).then(T=>{w=T;const L=BigInt(T.gasUsed)*BigInt(T.effectiveGasPrice),F=s.value?BigInt(s.value):0n,$=X.formatTxAmount(s.value,d.symbol,d.decimals),B=X.formatTxAmount("0x"+L.toString(16),d.symbol,d.decimals),Q=X.formatTxAmount("0x"+(F+L).toString(16),d.symbol,d.decimals);return{chainId:e,txHash:a,from:T.from,to:T.to??s.to,amount:$,fees:B,total:Q,nativeSymbol:d.symbol,status:T.status==="0x1"?"success":"reverted"}}).catch(T=>(_=T instanceof Error?T:new Error(String(T)),{chainId:e,txHash:a,from:f,to:s.to,amount:X.formatTxAmount(s.value,d.symbol,d.decimals),nativeSymbol:d.symbol,status:"timeout"}));if(await this.confirmation.showTransactionProgress({chainId:e,txHash:a,from:f,to:s.to},m),_)throw _;return{chainId:e,txHash:a,receipt:w}}async getGasPrice(e){this.ensureAuthenticated();try{return await this.walletRpc("eth_gasPrice",[],e)}catch(s){const t=s instanceof Error?s.message:String(s);throw new x(g.GAS_ESTIMATION_FAILED,`가스 가격 조회에 실패했습니다 (${e}): ${t}`,s)}}async estimateGas(e,s){this.ensureAuthenticated();const t={};e.from&&(t.from=e.from),e.to&&(t.to=e.to),e.value&&(t.value=e.value),e.data&&(t.data=e.data),e.gasPrice&&(t.gasPrice=e.gasPrice),e.maxFeePerGas&&(t.maxFeePerGas=e.maxFeePerGas),e.maxPriorityFeePerGas&&(t.maxPriorityFeePerGas=e.maxPriorityFeePerGas),e.nonce!==void 0&&(t.nonce="0x"+e.nonce.toString(16));try{return await this.walletRpc("eth_estimateGas",[t],s)}catch(n){const o=n instanceof Error?n.message:String(n);throw new x(g.GAS_ESTIMATION_FAILED,`가스 추정에 실패했습니다 (${s}): ${o}`,n)}}async getBaseFeePerGas(e){this.ensureAuthenticated();try{const s=await this.walletRpc("eth_getBlockByNumber",["latest",!1],e);return(s==null?void 0:s.baseFeePerGas)??null}catch(s){const t=s instanceof Error?s.message:String(s);throw new x(g.GAS_ESTIMATION_FAILED,`baseFeePerGas 조회에 실패했습니다 (${e}): ${t}`,s)}}async getMaxPriorityFeePerGas(e){this.ensureAuthenticated();try{return await this.walletRpc("eth_maxPriorityFeePerGas",[],e)}catch(s){const t=s instanceof Error?s.message:String(s);throw new x(g.GAS_ESTIMATION_FAILED,`maxPriorityFeePerGas 조회에 실패했습니다 (${e}): ${t}`,s)}}async getNonce(e){this.ensureAuthenticated();const s=this.address;if(!s)return 0;try{const t=await this.jsonRpc.call("eth_getTransactionCount",[s,"pending"],e);return parseInt(t??"0x0",16)}catch(t){if(t instanceof x)throw t;const n=t instanceof Error?t.message:String(t);throw new x(g.UNKNOWN_ERROR,`Nonce 조회에 실패했습니다: ${n}`,t)}}async getBalance(e){this.ensureAuthenticated();const s=this.address;if(!s)return{wei:"0x0",formatted:"0",chainId:e};try{const n=await this.jsonRpc.call("eth_getBalance",[s,"latest"],e)??"0x0";return{wei:n,formatted:X.formatWei(n),chainId:e}}catch(t){if(t instanceof x)throw t;const n=t instanceof Error?t.message:String(t);throw new x(g.UNKNOWN_ERROR,`잔액 조회에 실패했습니다 (${e}): ${n}`,t)}}static formatWei(e){if(!e||e==="0x0"||e==="0x")return"0";try{const s=BigInt(e);if(s===0n)return"0";const t=10n**BigInt(Tt),n=s/t,i=(s%t).toString().padStart(Tt,"0").replace(/0+$/,"").slice(0,Et);return i?`${n}.${i}`:`${n}`}catch{return"?"}}getProvider(e){return this.ensureAuthenticated(),new Kt(this,e)}async walletRpc(e,s,t){this.ensureAuthenticated();try{return await this.jsonRpc.call(e,s,t)}catch(n){if(n instanceof x)throw n;const o=n instanceof Error?n.message:String(n);throw new x(g.UNKNOWN_ERROR,`walletRpc 호출에 실패했습니다 [${e}] (${t}): ${o}`,n)}}static formatTxAmount(e,s,t){if(!(!e||e==="0x"||e==="0x0"))try{const n=BigInt(e);if(n===0n)return;const o=10n**BigInt(t),i=n/o,c=(n%o).toString().padStart(t,"0").slice(0,Et).replace(/0+$/,"");return`${c?`${i}.${c}`:`${i}`} ${s}`}catch{return}}async handleMigrationFlow(e){p.log('[CROSSx][Migration Phase 3] "Wallet Found" 팝업 표시');const s=await this.confirmation.showMigrationFoundPrompt();if(p.log("[CROSSx][Migration Phase 3] 사용자 선택:",s),s==="skip")return p.log("[CROSSx][Migration Phase 3] 사용자가 마이그레이션을 건너뜀 → 종료"),null;let t,n=0;for(;;){n++,p.log(`[CROSSx][Migration Phase 4] PIN 입력 팝업 표시 (시도 #${n})`,t?`— 이전 에러: ${t}`:"");const o=await this.confirmation.showPinInputPrompt(t);if(o===null)return p.log("[CROSSx][Migration Phase 4] 사용자가 PIN 입력을 취소함 → 종료"),null;p.log(`[CROSSx][Migration Phase 4] PIN 입력 완료 (${o.length}자리), Gateway 마이그레이션 API 호출`);try{const i=await this.migrateWalletUseCase.execute(o,e);return p.log("[CROSSx][Migration Phase 5] 마이그레이션 성공 — address:",i.address),i}catch(i){if(i instanceof x&&i.code===g.MIGRATION_FAILED){p.warn(`[CROSSx][Migration Phase 4] PIN 불일치 (시도 #${n}) — 재시도 요청`),t="PIN이 올바르지 않습니다. 다시 시도해 주세요.";continue}throw p.error("[CROSSx][Migration Phase 4] 마이그레이션 실패 (복구 불가):",i),i}}}async withResolvedGasAndFee(e,s){const t=l=>!(l!=null&&l.trim()),n=e.nonce===void 0||e.nonce===null,o=t(e.gasLimit),i=t(e.gasPrice)&&t(e.maxFeePerGas),a=!t(e.maxFeePerGas)&&t(e.maxPriorityFeePerGas);if(!n&&!o&&!i&&!a)return e;const c={...e};if(n){const l=c.from??this.address;if(l){p.log("[CROSSx] nonce 비어있음 → eth_getTransactionCount 호출 (from:",l,")");const d=await this.jsonRpc.call("eth_getTransactionCount",[l,"pending"],s);c.nonce=parseInt(d??"0x0",16),p.log("[CROSSx] nonce 결과:",c.nonce)}}if(o&&(p.log("[CROSSx] gasLimit 비어있음 → eth_estimateGas 호출"),c.gasLimit=await this.estimateGas(e,s),p.log("[CROSSx] estimateGas 결과:",c.gasLimit)),i){p.log("[CROSSx] gasPrice & maxFeePerGas 비어있음 → baseFee 조회로 Dynamic/Legacy 판별");const l=await this.getBaseFeePerGas(s);if(l){const d=vt;c.maxFeePerGas="0x"+(BigInt(l)+BigInt(d)).toString(16),c.maxPriorityFeePerGas=d,p.log("[CROSSx] Dynamic 체인 감지 — baseFee:",l,"maxFeePerGas:",c.maxFeePerGas,"maxPriorityFeePerGas: 1 Gwei")}else c.gasPrice=zs,p.log("[CROSSx] Legacy 체인 감지 — gasPrice: 2 Gwei")}return!i&&a&&(c.maxPriorityFeePerGas=vt,p.log("[CROSSx] maxPriorityFeePerGas 비어있음 → 1 Gwei 기본값 적용")),c}static validateTypedDataChainId(e,s){const t=X.extractDomainChainId(s);if(e==="0"){if(t!==void 0&&t!==0)throw new x(g.TYPED_DATA_CHAIN_ID_MISMATCH,`오프체인 서명(chainId=0)에서는 typedData.domain.chainId가 없거나 0이어야 합니다. 현재 값: ${t}`);return}const n=e.match(/^eip155:(\d+)$/);if(n){const o=Number(n[1]);if(t===void 0)throw new x(g.TYPED_DATA_CHAIN_ID_MISMATCH,`온체인 서명(${e})에서는 typedData.domain.chainId가 반드시 있어야 합니다`);if(t!==o)throw new x(g.TYPED_DATA_CHAIN_ID_MISMATCH,`typedData.domain.chainId (${t})가 chainId (${e}, 예상값: ${o})와 일치하지 않습니다`)}}static extractDomainChainId(e){if(e==null||typeof e!="object")return;const s=e.domain;if(s==null||typeof s!="object")return;const t=s.chainId;if(t==null)return;const n=Number(t);return Number.isFinite(n)?n:void 0}static validateSignatureFormat(e){const s=e.startsWith("0x")?e.slice(2):e;if(!/^[0-9a-fA-F]+$/.test(s))throw new x(g.SIGNATURE_FAILED,"유효하지 않은 서명: 올바른 hex 문자열이 아닙니다");if(s.length!==St)throw new x(g.SIGNATURE_FAILED,`서명 길이가 유효하지 않습니다: ${St} hex 문자(65 바이트) 예상, 현재 ${s.length}`)}static validateSignedTxFormat(e){const s=e.startsWith("0x")?e.slice(2):e;if(!/^[0-9a-fA-F]+$/.test(s))throw new x(g.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 올바른 hex 문자열이 아닙니다");if(s.length<2)throw new x(g.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 너무 짧습니다")}verifySignatureSigner(e,s,t){if(this.crypto.recoverPersonalSignSigner)try{const n=this.crypto.recoverPersonalSignSigner(e,s);if(n.toLowerCase()!==t.toLowerCase())throw p.error("[CROSSx] 서명 검증 실패: 서명자 주소 불일치",{expected:t,recovered:n}),new x(g.SIGNATURE_SIGNER_MISMATCH,`서명자 주소가 일치하지 않습니다: 예상 ${t}, 복원된 주소 ${n}`);p.log("[CROSSx] 서명 ecrecover 검증 성공")}catch(n){if(n instanceof x)throw n;p.warn("[CROSSx] ecrecover 검증 중 예외 (무시):",n)}}applyAuthResult(e){var s,t,n,o;this.authenticated=e.success,this.userId=((s=e.user)==null?void 0:s.id)??null,this.address=e.address??null,this.userEmail=((t=e.user)==null?void 0:t.email)??null,this.providerSub=((n=e.user)==null?void 0:n.providerSub)??null,this.loginType=X.normalizeLoginType((o=e.user)==null?void 0:o.signInProvider),this.tokenSignatureVerified=e.tokenSignatureVerified??!1,this.emit("authChanged",{isAuthenticated:this.authenticated,address:this.address,userId:this.userId})}clearAuthState(){this.authenticated=!1,this.userId=null,this.address=null,this.userEmail=null,this.providerSub=null,this.loginType=null,this.tokenSignatureVerified=!1,this.emit("authChanged",{isAuthenticated:!1,address:null,userId:null})}static normalizeLoginType(e){return e?e.includes("google")?"google":e.includes("apple")?"apple":e:null}ensureInitialized(){if(!this.initialized)throw new x(g.AUTH_NOT_INITIALIZED,"SDK가 초기화되지 않았습니다. initialize()를 먼저 호출하세요.")}ensureAuthenticated(){if(this.ensureInitialized(),!this.authenticated)throw new x(g.AUTH_NOT_AUTHENTICATED,"인증되지 않은 상태입니다. signIn()을 먼저 호출하세요.")}dispose(){this.clearAuthState(),this.tokenStore.clear(),this.initialized=!1,this.removeAllListeners(),wt(null)}};X.OFFCHAIN_CHAIN_ID="0";let Ue=X;class Xs{constructor(){this.prefix="crossx_"}async set(e,s){try{const t=JSON.stringify(s);localStorage.setItem(this.prefix+e,t)}catch(t){throw p.error("Storage set error:",t),t}}async get(e){try{const s=localStorage.getItem(this.prefix+e);return s?JSON.parse(s):null}catch(s){return p.error("Storage get error:",s),null}}async remove(e){try{localStorage.removeItem(this.prefix+e)}catch(s){throw p.error("Storage remove error:",s),s}}async clear(){try{Object.keys(localStorage).forEach(s=>{s.startsWith(this.prefix)&&localStorage.removeItem(s)})}catch(e){throw p.error("Storage clear error:",e),e}}}const Js="crossx-sdk",Qs=1,Se="data",Le="keys",It="aes-primary",er=12;class At{constructor(){this.db=null,this.cryptoKey=null,this.initPromise=null}async ensureReady(){this.db&&this.cryptoKey||(this.initPromise||(this.initPromise=this.init()),await this.initPromise)}openDB(){return new Promise((e,s)=>{const t=indexedDB.open(Js,Qs);t.onupgradeneeded=()=>{const n=t.result;n.objectStoreNames.contains(Se)||n.createObjectStore(Se),n.objectStoreNames.contains(Le)||n.createObjectStore(Le)},t.onsuccess=()=>e(t.result),t.onerror=()=>s(t.error)})}idbGet(e,s){return new Promise((t,n)=>{const i=this.db.transaction(e,"readonly").objectStore(e).get(s);i.onsuccess=()=>t(i.result),i.onerror=()=>n(i.error)})}idbPut(e,s,t){return new Promise((n,o)=>{const a=this.db.transaction(e,"readwrite").objectStore(e).put(t,s);a.onsuccess=()=>n(),a.onerror=()=>o(a.error)})}idbDelete(e,s){return new Promise((t,n)=>{const i=this.db.transaction(e,"readwrite").objectStore(e).delete(s);i.onsuccess=()=>t(),i.onerror=()=>n(i.error)})}idbClear(e){return new Promise((s,t)=>{const o=this.db.transaction(e,"readwrite").objectStore(e).clear();o.onsuccess=()=>s(),o.onerror=()=>t(o.error)})}async init(){this.db=await this.openDB();const e=await this.idbGet(Le,It);if(e){this.cryptoKey=e;return}this.cryptoKey=await crypto.subtle.generateKey({name:"AES-GCM",length:256},!1,["encrypt","decrypt"]),await this.idbPut(Le,It,this.cryptoKey)}async encrypt(e){const s=new Uint8Array(er);crypto.getRandomValues(s);const t=new TextEncoder().encode(e),n=await crypto.subtle.encrypt({name:"AES-GCM",iv:s},this.cryptoKey,t);return{iv:s,ciphertext:n}}async decrypt(e){const s=new Uint8Array(e.iv),t=await crypto.subtle.decrypt({name:"AES-GCM",iv:s},this.cryptoKey,e.ciphertext);return new TextDecoder().decode(t)}async set(e,s){try{await this.ensureReady();const t=JSON.stringify(s),n=await this.encrypt(t);await this.idbPut(Se,e,n)}catch(t){throw p.error("[CROSSx] IndexedDB set error:",t),t}}async get(e){try{await this.ensureReady();const s=await this.idbGet(Se,e);if(!s)return null;const t=await this.decrypt(s);return JSON.parse(t)}catch(s){return p.error("[CROSSx] IndexedDB get error:",s),null}}async remove(e){try{await this.ensureReady(),await this.idbDelete(Se,e)}catch(s){throw p.error("[CROSSx] IndexedDB remove error:",s),s}}async clear(){try{await this.ensureReady(),await this.idbClear(Se)}catch(e){throw p.error("[CROSSx] IndexedDB clear error:",e),e}}static isAvailable(){return typeof indexedDB<"u"&&typeof crypto<"u"&&typeof crypto.subtle<"u"}}/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */function at(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ue(r,e=""){if(!Number.isSafeInteger(r)||r<0){const s=e&&`"${e}" `;throw new Error(`${s}expected integer >= 0, got ${r}`)}}function H(r,e,s=""){const t=at(r),n=r==null?void 0:r.length,o=e!==void 0;if(!t||o&&n!==e){const i=s&&`"${s}" `,a=o?` of length ${e}`:"",c=t?`length=${n}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function Yt(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");ue(r.outputLen),ue(r.blockLen)}function Te(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Zt(r,e){H(r,void 0,"digestInto() output");const s=e.outputLen;if(r.length<s)throw new Error('"digestInto() output" expected to be of length >='+s)}function tr(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function Ie(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function Xe(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function oe(r,e){return r<<32-e|r>>>e}const sr=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function rr(r){return r<<24&4278190080|r<<8&16711680|r>>>8&65280|r>>>24&255}function nr(r){for(let e=0;e<r.length;e++)r[e]=rr(r[e]);return r}const Rt=sr?r=>r:nr,Xt=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",or=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function ke(r){if(H(r),Xt)return r.toHex();let e="";for(let s=0;s<r.length;s++)e+=or[r[s]];return e}const ce={_0:48,_9:57,A:65,F:70,a:97,f:102};function Ot(r){if(r>=ce._0&&r<=ce._9)return r-ce._0;if(r>=ce.A&&r<=ce.F)return r-(ce.A-10);if(r>=ce.a&&r<=ce.f)return r-(ce.a-10)}function He(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Xt)return Uint8Array.fromHex(r);const e=r.length,s=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);const t=new Uint8Array(s);for(let n=0,o=0;n<s;n++,o+=2){const i=Ot(r.charCodeAt(o)),a=Ot(r.charCodeAt(o+1));if(i===void 0||a===void 0){const c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}t[n]=i*16+a}return t}function _e(...r){let e=0;for(let t=0;t<r.length;t++){const n=r[t];H(n),e+=n.length}const s=new Uint8Array(e);for(let t=0,n=0;t<r.length;t++){const o=r[t];s.set(o,n),n+=o.length}return s}function Jt(r,e={}){const s=(n,o)=>r(o).update(n).digest(),t=r(void 0);return s.outputLen=t.outputLen,s.blockLen=t.blockLen,s.create=n=>r(n),Object.assign(s,e),Object.freeze(s)}function Qt(r=32){const e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof(e==null?void 0:e.getRandomValues)!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(r))}const ir=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function ar(r,e,s){return r&e^~r&s}function cr(r,e,s){return r&e^r&s^e&s}class lr{constructor(e,s,t,n){v(this,"blockLen");v(this,"outputLen");v(this,"padOffset");v(this,"isLE");v(this,"buffer");v(this,"view");v(this,"finished",!1);v(this,"length",0);v(this,"pos",0);v(this,"destroyed",!1);this.blockLen=e,this.outputLen=s,this.padOffset=t,this.isLE=n,this.buffer=new Uint8Array(e),this.view=Xe(this.buffer)}update(e){Te(this),H(e);const{view:s,buffer:t,blockLen:n}=this,o=e.length;for(let i=0;i<o;){const a=Math.min(n-this.pos,o-i);if(a===n){const c=Xe(e);for(;n<=o-i;i+=n)this.process(c,i);continue}t.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===n&&(this.process(s,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Te(this),Zt(e,this),this.finished=!0;const{buffer:s,view:t,blockLen:n,isLE:o}=this;let{pos:i}=this;s[i++]=128,Ie(this.buffer.subarray(i)),this.padOffset>n-i&&(this.process(t,0),i=0);for(let f=i;f<n;f++)s[f]=0;t.setBigUint64(n-8,BigInt(this.length*8),o),this.process(t,0);const a=Xe(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");const l=c/4,d=this.get();if(l>d.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,d[f],o)}digest(){const{buffer:e,outputLen:s}=this;this.digestInto(e);const t=e.slice(0,s);return this.destroy(),t}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:s,buffer:t,length:n,finished:o,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=o,e.length=n,e.pos=a,n%s&&e.buffer.set(t),e}clone(){return this._cloneInto()}}const fe=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),De=BigInt(2**32-1),Ct=BigInt(32);function dr(r,e=!1){return e?{h:Number(r&De),l:Number(r>>Ct&De)}:{h:Number(r>>Ct&De)|0,l:Number(r&De)|0}}function ur(r,e=!1){const s=r.length;let t=new Uint32Array(s),n=new Uint32Array(s);for(let o=0;o<s;o++){const{h:i,l:a}=dr(r[o],e);[t[o],n[o]]=[i,a]}return[t,n]}const hr=(r,e,s)=>r<<s|e>>>32-s,fr=(r,e,s)=>e<<s|r>>>32-s,pr=(r,e,s)=>e<<s-32|r>>>64-s,gr=(r,e,s)=>r<<s-32|e>>>64-s,_r=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]),pe=new Uint32Array(64);class xr extends lr{constructor(e){super(64,e,8,!1)}get(){const{A:e,B:s,C:t,D:n,E:o,F:i,G:a,H:c}=this;return[e,s,t,n,o,i,a,c]}set(e,s,t,n,o,i,a,c){this.A=e|0,this.B=s|0,this.C=t|0,this.D=n|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,s){for(let f=0;f<16;f++,s+=4)pe[f]=e.getUint32(s,!1);for(let f=16;f<64;f++){const w=pe[f-15],_=pe[f-2],m=oe(w,7)^oe(w,18)^w>>>3,A=oe(_,17)^oe(_,19)^_>>>10;pe[f]=A+pe[f-7]+m+pe[f-16]|0}let{A:t,B:n,C:o,D:i,E:a,F:c,G:l,H:d}=this;for(let f=0;f<64;f++){const w=oe(a,6)^oe(a,11)^oe(a,25),_=d+w+ar(a,c,l)+_r[f]+pe[f]|0,A=(oe(t,2)^oe(t,13)^oe(t,22))+cr(t,n,o)|0;d=l,l=c,c=a,a=i+_|0,i=o,o=n,n=t,t=_+A|0}t=t+this.A|0,n=n+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,d=d+this.H|0,this.set(t,n,o,i,a,c,l,d)}roundClean(){Ie(pe)}destroy(){this.set(0,0,0,0,0,0,0,0),Ie(this.buffer)}}class mr extends xr{constructor(){super(32);v(this,"A",fe[0]|0);v(this,"B",fe[1]|0);v(this,"C",fe[2]|0);v(this,"D",fe[3]|0);v(this,"E",fe[4]|0);v(this,"F",fe[5]|0);v(this,"G",fe[6]|0);v(this,"H",fe[7]|0)}}const wr=Jt(()=>new mr,ir(1));/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const ct=BigInt(0),rt=BigInt(1);function Ge(r,e=""){if(typeof r!="boolean"){const s=e&&`"${e}" `;throw new Error(s+"expected boolean, got type="+typeof r)}return r}function es(r){if(typeof r=="bigint"){if(!Be(r))throw new Error("positive bigint expected, got "+r)}else ue(r);return r}function $e(r){const e=es(r).toString(16);return e.length&1?"0"+e:e}function ts(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ct:BigInt("0x"+r)}function Ve(r){return ts(ke(r))}function ss(r){return ts(ke(yr(H(r)).reverse()))}function lt(r,e){ue(e),r=es(r);const s=He(r.toString(16).padStart(e*2,"0"));if(s.length!==e)throw new Error("number too large");return s}function rs(r,e){return lt(r,e).reverse()}function yr(r){return Uint8Array.from(r)}const Be=r=>typeof r=="bigint"&&ct<=r;function br(r,e,s){return Be(r)&&Be(e)&&Be(s)&&e<=r&&r<s}function vr(r,e,s,t){if(!br(e,s,t))throw new Error("expected valid "+r+": "+s+" <= n < "+t+", got "+e)}function Sr(r){let e;for(e=0;r>ct;r>>=rt,e+=1);return e}const dt=r=>(rt<<BigInt(r))-rt;function Er(r,e,s){if(ue(r,"hashLen"),ue(e,"qByteLen"),typeof s!="function")throw new Error("hmacFn must be a function");const t=y=>new Uint8Array(y),n=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3;let c=t(r),l=t(r),d=0;const f=()=>{c.fill(1),l.fill(0),d=0},w=(...y)=>s(l,_e(c,...y)),_=(y=n)=>{l=w(o,y),c=w(),y.length!==0&&(l=w(i,y),c=w())},m=()=>{if(d++>=a)throw new Error("drbg: tried max amount of iterations");let y=0;const T=[];for(;y<e;){c=w();const L=c.slice();T.push(L),y+=c.length}return _e(...T)};return(y,T)=>{f(),_(y);let L;for(;!(L=T(m()));)_();return f(),L}}function ut(r,e={},s={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function t(o,i,a){const c=r[o];if(a&&c===void 0)return;const l=typeof c;if(l!==i||c===null)throw new Error(`param "${o}" is invalid: expected ${i}, got ${l}`)}const n=(o,i)=>Object.entries(o).forEach(([a,c])=>t(a,c,i));n(e,!1),n(s,!0)}function kt(r){const e=new WeakMap;return(s,...t)=>{const n=e.get(s);if(n!==void 0)return n;const o=r(s,...t);return e.set(s,o),o}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const J=BigInt(0),z=BigInt(1),ye=BigInt(2),ns=BigInt(3),os=BigInt(4),is=BigInt(5),Tr=BigInt(7),as=BigInt(8),Ir=BigInt(9),cs=BigInt(16);function re(r,e){const s=r%e;return s>=J?s:e+s}function se(r,e,s){let t=r;for(;e-- >J;)t*=t,t%=s;return t}function Nt(r,e){if(r===J)throw new Error("invert: expected non-zero number");if(e<=J)throw new Error("invert: expected positive modulus, got "+e);let s=re(r,e),t=e,n=J,o=z;for(;s!==J;){const a=t/s,c=t%s,l=n-o*a;t=s,s=c,n=o,o=l}if(t!==z)throw new Error("invert: does not exist");return re(n,e)}function ht(r,e,s){if(!r.eql(r.sqr(e),s))throw new Error("Cannot find square root")}function ls(r,e){const s=(r.ORDER+z)/os,t=r.pow(e,s);return ht(r,t,e),t}function Ar(r,e){const s=(r.ORDER-is)/as,t=r.mul(e,ye),n=r.pow(t,s),o=r.mul(e,n),i=r.mul(r.mul(o,ye),n),a=r.mul(o,r.sub(i,r.ONE));return ht(r,a,e),a}function Rr(r){const e=Ke(r),s=ds(r),t=s(e,e.neg(e.ONE)),n=s(e,t),o=s(e,e.neg(t)),i=(r+Tr)/cs;return(a,c)=>{let l=a.pow(c,i),d=a.mul(l,t);const f=a.mul(l,n),w=a.mul(l,o),_=a.eql(a.sqr(d),c),m=a.eql(a.sqr(f),c);l=a.cmov(l,d,_),d=a.cmov(w,f,m);const A=a.eql(a.sqr(d),c),y=a.cmov(l,d,A);return ht(a,y,c),y}}function ds(r){if(r<ns)throw new Error("sqrt is not defined for small field");let e=r-z,s=0;for(;e%ye===J;)e/=ye,s++;let t=ye;const n=Ke(r);for(;Pt(n,t)===1;)if(t++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(s===1)return ls;let o=n.pow(t,e);const i=(e+z)/ye;return function(c,l){if(c.is0(l))return l;if(Pt(c,l)!==1)throw new Error("Cannot find square root");let d=s,f=c.mul(c.ONE,o),w=c.pow(l,e),_=c.pow(l,i);for(;!c.eql(w,c.ONE);){if(c.is0(w))return c.ZERO;let m=1,A=c.sqr(w);for(;!c.eql(A,c.ONE);)if(m++,A=c.sqr(A),m===d)throw new Error("Cannot find square root");const y=z<<BigInt(d-m-1),T=c.pow(f,y);d=m,f=c.sqr(T),w=c.mul(w,f),_=c.mul(_,T)}return _}}function Or(r){return r%os===ns?ls:r%as===is?Ar:r%cs===Ir?Rr(r):ds(r)}const Cr=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function kr(r){const e={ORDER:"bigint",BYTES:"number",BITS:"number"},s=Cr.reduce((t,n)=>(t[n]="function",t),e);return ut(r,s),r}function Nr(r,e,s){if(s<J)throw new Error("invalid exponent, negatives unsupported");if(s===J)return r.ONE;if(s===z)return e;let t=r.ONE,n=e;for(;s>J;)s&z&&(t=r.mul(t,n)),n=r.sqr(n),s>>=z;return t}function us(r,e,s=!1){const t=new Array(e.length).fill(s?r.ZERO:void 0),n=e.reduce((i,a,c)=>r.is0(a)?i:(t[c]=i,r.mul(i,a)),r.ONE),o=r.inv(n);return e.reduceRight((i,a,c)=>r.is0(a)?i:(t[c]=r.mul(i,t[c]),r.mul(i,a)),o),t}function Pt(r,e){const s=(r.ORDER-z)/ye,t=r.pow(e,s),n=r.eql(t,r.ONE),o=r.eql(t,r.ZERO),i=r.eql(t,r.neg(r.ONE));if(!n&&!o&&!i)throw new Error("invalid Legendre symbol result");return n?1:o?0:-1}function Pr(r,e){e!==void 0&&ue(e);const s=e!==void 0?e:r.toString(2).length,t=Math.ceil(s/8);return{nBitLength:s,nByteLength:t}}class Lr{constructor(e,s={}){v(this,"ORDER");v(this,"BITS");v(this,"BYTES");v(this,"isLE");v(this,"ZERO",J);v(this,"ONE",z);v(this,"_lengths");v(this,"_sqrt");v(this,"_mod");var i;if(e<=J)throw new Error("invalid field: expected ORDER > 0, got "+e);let t;this.isLE=!1,s!=null&&typeof s=="object"&&(typeof s.BITS=="number"&&(t=s.BITS),typeof s.sqrt=="function"&&(this.sqrt=s.sqrt),typeof s.isLE=="boolean"&&(this.isLE=s.isLE),s.allowedLengths&&(this._lengths=(i=s.allowedLengths)==null?void 0:i.slice()),typeof s.modFromBytes=="boolean"&&(this._mod=s.modFromBytes));const{nBitLength:n,nByteLength:o}=Pr(e,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=n,this.BYTES=o,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return re(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return J<=e&&e<this.ORDER}is0(e){return e===J}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&z)===z}neg(e){return re(-e,this.ORDER)}eql(e,s){return e===s}sqr(e){return re(e*e,this.ORDER)}add(e,s){return re(e+s,this.ORDER)}sub(e,s){return re(e-s,this.ORDER)}mul(e,s){return re(e*s,this.ORDER)}pow(e,s){return Nr(this,e,s)}div(e,s){return re(e*Nt(s,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,s){return e+s}subN(e,s){return e-s}mulN(e,s){return e*s}inv(e){return Nt(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=Or(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?rs(e,this.BYTES):lt(e,this.BYTES)}fromBytes(e,s=!1){H(e);const{_lengths:t,BYTES:n,isLE:o,ORDER:i,_mod:a}=this;if(t){if(!t.includes(e.length)||e.length>n)throw new Error("Field.fromBytes: expected "+t+" bytes, got "+e.length);const l=new Uint8Array(n);l.set(e,o?0:l.length-e.length),e=l}if(e.length!==n)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let c=o?ss(e):Ve(e);if(a&&(c=re(c,i)),!s&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return us(this,e)}cmov(e,s,t){return t?s:e}}function Ke(r,e={}){return new Lr(r,e)}function hs(r){if(typeof r!="bigint")throw new Error("field order must be bigint");const e=r.toString(2).length;return Math.ceil(e/8)}function fs(r){const e=hs(r);return e+Math.ceil(e/2)}function Dr(r,e,s=!1){H(r);const t=r.length,n=hs(e),o=fs(e);if(t<16||t<o||t>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+t);const i=s?ss(r):Ve(r),a=re(i,e-z)+z;return s?rs(a,n):lt(a,n)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Ae=BigInt(0),be=BigInt(1);function qe(r,e){const s=e.negate();return r?s:e}function Lt(r,e){const s=us(r.Fp,e.map(t=>t.Z));return e.map((t,n)=>r.fromAffine(t.toAffine(s[n])))}function ps(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function Je(r,e){ps(r,e);const s=Math.ceil(e/r)+1,t=2**(r-1),n=2**r,o=dt(r),i=BigInt(r);return{windows:s,windowSize:t,mask:o,maxNumber:n,shiftBy:i}}function Dt(r,e,s){const{windowSize:t,mask:n,maxNumber:o,shiftBy:i}=s;let a=Number(r&n),c=r>>i;a>t&&(a-=o,c+=be);const l=e*t,d=l+Math.abs(a)-1,f=a===0,w=a<0,_=e%2!==0;return{nextN:c,offset:d,isZero:f,isNeg:w,isNegF:_,offsetF:l}}const Qe=new WeakMap,gs=new WeakMap;function et(r){return gs.get(r)||1}function $t(r){if(r!==Ae)throw new Error("invalid wNAF")}class $r{constructor(e,s){v(this,"BASE");v(this,"ZERO");v(this,"Fn");v(this,"bits");this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=s}_unsafeLadder(e,s,t=this.ZERO){let n=e;for(;s>Ae;)s&be&&(t=t.add(n)),n=n.double(),s>>=be;return t}precomputeWindow(e,s){const{windows:t,windowSize:n}=Je(s,this.bits),o=[];let i=e,a=i;for(let c=0;c<t;c++){a=i,o.push(a);for(let l=1;l<n;l++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(e,s,t){if(!this.Fn.isValid(t))throw new Error("invalid scalar");let n=this.ZERO,o=this.BASE;const i=Je(e,this.bits);for(let a=0;a<i.windows;a++){const{nextN:c,offset:l,isZero:d,isNeg:f,isNegF:w,offsetF:_}=Dt(t,a,i);t=c,d?o=o.add(qe(w,s[_])):n=n.add(qe(f,s[l]))}return $t(t),{p:n,f:o}}wNAFUnsafe(e,s,t,n=this.ZERO){const o=Je(e,this.bits);for(let i=0;i<o.windows&&t!==Ae;i++){const{nextN:a,offset:c,isZero:l,isNeg:d}=Dt(t,i,o);if(t=a,!l){const f=s[c];n=n.add(d?f.negate():f)}}return $t(t),n}getPrecomputes(e,s,t){let n=Qe.get(s);return n||(n=this.precomputeWindow(s,e),e!==1&&(typeof t=="function"&&(n=t(n)),Qe.set(s,n))),n}cached(e,s,t){const n=et(e);return this.wNAF(n,this.getPrecomputes(n,e,t),s)}unsafe(e,s,t,n){const o=et(e);return o===1?this._unsafeLadder(e,s,n):this.wNAFUnsafe(o,this.getPrecomputes(o,e,t),s,n)}createCache(e,s){ps(s,this.bits),gs.set(e,s),Qe.delete(e)}hasCache(e){return et(e)!==1}}function Mr(r,e,s,t){let n=e,o=r.ZERO,i=r.ZERO;for(;s>Ae||t>Ae;)s&be&&(o=o.add(n)),t&be&&(i=i.add(n)),n=n.double(),s>>=be,t>>=be;return{p1:o,p2:i}}function Mt(r,e,s){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return kr(e),e}else return Ke(r,{isLE:s})}function Br(r,e,s={},t){if(t===void 0&&(t=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(const c of["p","n","h"]){const l=e[c];if(!(typeof l=="bigint"&&l>Ae))throw new Error(`CURVE.${c} must be positive bigint`)}const n=Mt(e.p,s.Fp,t),o=Mt(e.n,s.Fn,t),a=["Gx","Gy","a","b"];for(const c of a)if(!n.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:n,Fn:o}}function Fr(r,e){return function(t){const n=r(t);return{secretKey:n,publicKey:e(n)}}}class _s{constructor(e,s){v(this,"oHash");v(this,"iHash");v(this,"blockLen");v(this,"outputLen");v(this,"finished",!1);v(this,"destroyed",!1);if(Yt(e),H(s,void 0,"key"),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 t=this.blockLen,n=new Uint8Array(t);n.set(s.length>t?e.create().update(s).digest():s);for(let o=0;o<n.length;o++)n[o]^=54;this.iHash.update(n),this.oHash=e.create();for(let o=0;o<n.length;o++)n[o]^=106;this.oHash.update(n),Ie(n)}update(e){return Te(this),this.iHash.update(e),this}digestInto(e){Te(this),H(e,this.outputLen,"output"),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:t,finished:n,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=n,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=s._cloneInto(e.oHash),e.iHash=t._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}const xs=(r,e,s)=>new _s(r,e).update(s).digest();xs.create=(r,e)=>new _s(r,e);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Bt=(r,e)=>(r+(r>=0?e:-e)/ms)/e;function Ur(r,e,s){const[[t,n],[o,i]]=e,a=Bt(i*r,s),c=Bt(-n*r,s);let l=r-a*t-c*o,d=-a*n-c*i;const f=l<le,w=d<le;f&&(l=-l),w&&(d=-d);const _=dt(Math.ceil(Sr(s)/2))+Ee;if(l<le||l>=_||d<le||d>=_)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:f,k1:l,k2neg:w,k2:d}}function nt(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function tt(r,e){const s={};for(let t of Object.keys(e))s[t]=r[t]===void 0?e[t]:r[t];return Ge(s.lowS,"lowS"),Ge(s.prehash,"prehash"),s.format!==void 0&&nt(s.format),s}class Hr extends Error{constructor(e=""){super(e)}}const ge={Err:Hr,_tlv:{encode:(r,e)=>{const{Err:s}=ge;if(r<0||r>256)throw new s("tlv.encode: wrong tag");if(e.length&1)throw new s("tlv.encode: unpadded data");const t=e.length/2,n=$e(t);if(n.length/2&128)throw new s("tlv.encode: long form length too big");const o=t>127?$e(n.length/2|128):"";return $e(r)+o+n+e},decode(r,e){const{Err:s}=ge;let t=0;if(r<0||r>256)throw new s("tlv.encode: wrong tag");if(e.length<2||e[t++]!==r)throw new s("tlv.decode: wrong tlv");const n=e[t++],o=!!(n&128);let i=0;if(!o)i=n;else{const c=n&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(t,t+c);if(l.length!==c)throw new s("tlv.decode: length bytes not complete");if(l[0]===0)throw new s("tlv.decode(long): zero leftmost byte");for(const d of l)i=i<<8|d;if(t+=c,i<128)throw new s("tlv.decode(long): not minimal encoding")}const a=e.subarray(t,t+i);if(a.length!==i)throw new s("tlv.decode: wrong value length");return{v:a,l:e.subarray(t+i)}}},_int:{encode(r){const{Err:e}=ge;if(r<le)throw new e("integer: negative integers are not allowed");let s=$e(r);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(r){const{Err:e}=ge;if(r[0]&128)throw new e("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Ve(r)}},toSig(r){const{Err:e,_int:s,_tlv:t}=ge,n=H(r,void 0,"signature"),{v:o,l:i}=t.decode(48,n);if(i.length)throw new e("invalid signature: left bytes after parsing");const{v:a,l:c}=t.decode(2,o),{v:l,l:d}=t.decode(2,c);if(d.length)throw new e("invalid signature: left bytes after parsing");return{r:s.decode(a),s:s.decode(l)}},hexFromSig(r){const{_tlv:e,_int:s}=ge,t=e.encode(2,s.encode(r.r)),n=e.encode(2,s.encode(r.s)),o=t+n;return e.encode(48,o)}},le=BigInt(0),Ee=BigInt(1),ms=BigInt(2),Me=BigInt(3),Gr=BigInt(4);function qr(r,e={}){const s=Br("weierstrass",r,e),{Fp:t,Fn:n}=s;let o=s.CURVE;const{h:i,n:a}=o;ut(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});const{endo:c}=e;if(c&&(!t.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');const l=ys(t,n);function d(){if(!t.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function f(P,u,h){const{x:b,y:E}=u.toAffine(),R=t.toBytes(b);if(Ge(h,"isCompressed"),h){d();const I=!t.isOdd(E);return _e(ws(I),R)}else return _e(Uint8Array.of(4),R,t.toBytes(E))}function w(P){H(P,void 0,"Point");const{publicKey:u,publicKeyUncompressed:h}=l,b=P.length,E=P[0],R=P.subarray(1);if(b===u&&(E===2||E===3)){const I=t.fromBytes(R);if(!t.isValid(I))throw new Error("bad point: is not on curve, wrong x");const O=A(I);let S;try{S=t.sqrt(O)}catch(W){const U=W instanceof Error?": "+W.message:"";throw new Error("bad point: is not on curve, sqrt error"+U)}d();const C=t.isOdd(S);return(E&1)===1!==C&&(S=t.neg(S)),{x:I,y:S}}else if(b===h&&E===4){const I=t.BYTES,O=t.fromBytes(R.subarray(0,I)),S=t.fromBytes(R.subarray(I,I*2));if(!y(O,S))throw new Error("bad point: is not on curve");return{x:O,y:S}}else throw new Error(`bad point: got length ${b}, expected compressed=${u} or uncompressed=${h}`)}const _=e.toBytes||f,m=e.fromBytes||w;function A(P){const u=t.sqr(P),h=t.mul(u,P);return t.add(t.add(h,t.mul(P,o.a)),o.b)}function y(P,u){const h=t.sqr(u),b=A(P);return t.eql(h,b)}if(!y(o.Gx,o.Gy))throw new Error("bad curve params: generator point");const T=t.mul(t.pow(o.a,Me),Gr),L=t.mul(t.sqr(o.b),BigInt(27));if(t.is0(t.add(T,L)))throw new Error("bad curve params: a or b");function F(P,u,h=!1){if(!t.isValid(u)||h&&t.is0(u))throw new Error(`bad point coordinate ${P}`);return u}function $(P){if(!(P instanceof Z))throw new Error("Weierstrass Point expected")}function B(P){if(!c||!c.basises)throw new Error("no endo");return Ur(P,c.basises,n.ORDER)}const Q=kt((P,u)=>{const{X:h,Y:b,Z:E}=P;if(t.eql(E,t.ONE))return{x:h,y:b};const R=P.is0();u==null&&(u=R?t.ONE:t.inv(E));const I=t.mul(h,u),O=t.mul(b,u),S=t.mul(E,u);if(R)return{x:t.ZERO,y:t.ZERO};if(!t.eql(S,t.ONE))throw new Error("invZ was invalid");return{x:I,y:O}}),ve=kt(P=>{if(P.is0()){if(e.allowInfinityPoint&&!t.is0(P.Y))return;throw new Error("bad point: ZERO")}const{x:u,y:h}=P.toAffine();if(!t.isValid(u)||!t.isValid(h))throw new Error("bad point: x or y not field elements");if(!y(u,h))throw new Error("bad point: equation left != right");if(!P.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function he(P,u,h,b,E){return h=new Z(t.mul(h.X,P),h.Y,h.Z),u=qe(b,u),h=qe(E,h),u.add(h)}const D=class D{constructor(u,h,b){v(this,"X");v(this,"Y");v(this,"Z");this.X=F("x",u),this.Y=F("y",h,!0),this.Z=F("z",b),Object.freeze(this)}static CURVE(){return o}static fromAffine(u){const{x:h,y:b}=u||{};if(!u||!t.isValid(h)||!t.isValid(b))throw new Error("invalid affine point");if(u instanceof D)throw new Error("projective point not allowed");return t.is0(h)&&t.is0(b)?D.ZERO:new D(h,b,t.ONE)}static fromBytes(u){const h=D.fromAffine(m(H(u,void 0,"point")));return h.assertValidity(),h}static fromHex(u){return D.fromBytes(He(u))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(u=8,h=!0){return ne.createCache(this,u),h||this.multiply(Me),this}assertValidity(){ve(this)}hasEvenY(){const{y:u}=this.toAffine();if(!t.isOdd)throw new Error("Field doesn't support isOdd");return!t.isOdd(u)}equals(u){$(u);const{X:h,Y:b,Z:E}=this,{X:R,Y:I,Z:O}=u,S=t.eql(t.mul(h,O),t.mul(R,E)),C=t.eql(t.mul(b,O),t.mul(I,E));return S&&C}negate(){return new D(this.X,t.neg(this.Y),this.Z)}double(){const{a:u,b:h}=o,b=t.mul(h,Me),{X:E,Y:R,Z:I}=this;let O=t.ZERO,S=t.ZERO,C=t.ZERO,N=t.mul(E,E),W=t.mul(R,R),U=t.mul(I,I),k=t.mul(E,R);return k=t.add(k,k),C=t.mul(E,I),C=t.add(C,C),O=t.mul(u,C),S=t.mul(b,U),S=t.add(O,S),O=t.sub(W,S),S=t.add(W,S),S=t.mul(O,S),O=t.mul(k,O),C=t.mul(b,C),U=t.mul(u,U),k=t.sub(N,U),k=t.mul(u,k),k=t.add(k,C),C=t.add(N,N),N=t.add(C,N),N=t.add(N,U),N=t.mul(N,k),S=t.add(S,N),U=t.mul(R,I),U=t.add(U,U),N=t.mul(U,k),O=t.sub(O,N),C=t.mul(U,W),C=t.add(C,C),C=t.add(C,C),new D(O,S,C)}add(u){$(u);const{X:h,Y:b,Z:E}=this,{X:R,Y:I,Z:O}=u;let S=t.ZERO,C=t.ZERO,N=t.ZERO;const W=o.a,U=t.mul(o.b,Me);let k=t.mul(h,R),j=t.mul(b,I),V=t.mul(E,O),ee=t.add(h,b),G=t.add(R,I);ee=t.mul(ee,G),G=t.add(k,j),ee=t.sub(ee,G),G=t.add(h,E);let K=t.add(R,O);return G=t.mul(G,K),K=t.add(k,V),G=t.sub(G,K),K=t.add(b,E),S=t.add(I,O),K=t.mul(K,S),S=t.add(j,V),K=t.sub(K,S),N=t.mul(W,G),S=t.mul(U,V),N=t.add(S,N),S=t.sub(j,N),N=t.add(j,N),C=t.mul(S,N),j=t.add(k,k),j=t.add(j,k),V=t.mul(W,V),G=t.mul(U,G),j=t.add(j,V),V=t.sub(k,V),V=t.mul(W,V),G=t.add(G,V),k=t.mul(j,G),C=t.add(C,k),k=t.mul(K,G),S=t.mul(ee,S),S=t.sub(S,k),k=t.mul(ee,j),N=t.mul(K,N),N=t.add(N,k),new D(S,C,N)}subtract(u){return this.add(u.negate())}is0(){return this.equals(D.ZERO)}multiply(u){const{endo:h}=e;if(!n.isValidNot0(u))throw new Error("invalid scalar: out of range");let b,E;const R=I=>ne.cached(this,I,O=>Lt(D,O));if(h){const{k1neg:I,k1:O,k2neg:S,k2:C}=B(u),{p:N,f:W}=R(O),{p:U,f:k}=R(C);E=W.add(k),b=he(h.beta,N,U,I,S)}else{const{p:I,f:O}=R(u);b=I,E=O}return Lt(D,[b,E])[0]}multiplyUnsafe(u){const{endo:h}=e,b=this;if(!n.isValid(u))throw new Error("invalid scalar: out of range");if(u===le||b.is0())return D.ZERO;if(u===Ee)return b;if(ne.hasCache(this))return this.multiply(u);if(h){const{k1neg:E,k1:R,k2neg:I,k2:O}=B(u),{p1:S,p2:C}=Mr(D,b,R,O);return he(h.beta,S,C,E,I)}else return ne.unsafe(b,u)}toAffine(u){return Q(this,u)}isTorsionFree(){const{isTorsionFree:u}=e;return i===Ee?!0:u?u(D,this):ne.unsafe(this,a).is0()}clearCofactor(){const{clearCofactor:u}=e;return i===Ee?this:u?u(D,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(u=!0){return Ge(u,"isCompressed"),this.assertValidity(),_(D,this,u)}toHex(u=!0){return ke(this.toBytes(u))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}};v(D,"BASE",new D(o.Gx,o.Gy,t.ONE)),v(D,"ZERO",new D(t.ZERO,t.ONE,t.ZERO)),v(D,"Fp",t),v(D,"Fn",n);let Z=D;const xe=n.BITS,ne=new $r(Z,e.endo?Math.ceil(xe/2):xe);return Z.BASE.precompute(8),Z}function ws(r){return Uint8Array.of(r?2:3)}function ys(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function Wr(r,e={}){const{Fn:s}=r,t=e.randomBytes||Qt,n=Object.assign(ys(r.Fp,s),{seed:fs(s.ORDER)});function o(_){try{const m=s.fromBytes(_);return s.isValidNot0(m)}catch{return!1}}function i(_,m){const{publicKey:A,publicKeyUncompressed:y}=n;try{const T=_.length;return m===!0&&T!==A||m===!1&&T!==y?!1:!!r.fromBytes(_)}catch{return!1}}function a(_=t(n.seed)){return Dr(H(_,n.seed,"seed"),s.ORDER)}function c(_,m=!0){return r.BASE.multiply(s.fromBytes(_)).toBytes(m)}function l(_){const{secretKey:m,publicKey:A,publicKeyUncompressed:y}=n;if(!at(_)||"_lengths"in s&&s._lengths||m===A)return;const T=H(_,void 0,"key").length;return T===A||T===y}function d(_,m,A=!0){if(l(_)===!0)throw new Error("first arg must be private key");if(l(m)===!1)throw new Error("second arg must be public key");const y=s.fromBytes(_);return r.fromBytes(m).multiply(y).toBytes(A)}const f={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},w=Fr(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:d,keygen:w,Point:r,utils:f,lengths:n})}function jr(r,e,s={}){Yt(e),ut(s,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),s=Object.assign({},s);const t=s.randomBytes||Qt,n=s.hmac||((u,h)=>xs(e,u,h)),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:d,getSharedSecret:f,utils:w,lengths:_}=Wr(r,s),m={prehash:!0,lowS:typeof s.lowS=="boolean"?s.lowS:!0,format:"compact",extraEntropy:!1},A=a*ms<o.ORDER;function y(u){const h=a>>Ee;return u>h}function T(u,h){if(!i.isValidNot0(h))throw new Error(`invalid signature ${u}: out of range 1..Point.Fn.ORDER`);return h}function L(){if(A)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function F(u,h){nt(h);const b=_.signature,E=h==="compact"?b:h==="recovered"?b+1:void 0;return H(u,E)}class ${constructor(h,b,E){v(this,"r");v(this,"s");v(this,"recovery");if(this.r=T("r",h),this.s=T("s",b),E!=null){if(L(),![0,1,2,3].includes(E))throw new Error("invalid recovery id");this.recovery=E}Object.freeze(this)}static fromBytes(h,b=m.format){F(h,b);let E;if(b==="der"){const{r:S,s:C}=ge.toSig(H(h));return new $(S,C)}b==="recovered"&&(E=h[0],b="compact",h=h.subarray(1));const R=_.signature/2,I=h.subarray(0,R),O=h.subarray(R,R*2);return new $(i.fromBytes(I),i.fromBytes(O),E)}static fromHex(h,b){return this.fromBytes(He(h),b)}assertRecovery(){const{recovery:h}=this;if(h==null)throw new Error("invalid recovery id: must be present");return h}addRecoveryBit(h){return new $(this.r,this.s,h)}recoverPublicKey(h){const{r:b,s:E}=this,R=this.assertRecovery(),I=R===2||R===3?b+a:b;if(!o.isValid(I))throw new Error("invalid recovery id: sig.r+curve.n != R.x");const O=o.toBytes(I),S=r.fromBytes(_e(ws((R&1)===0),O)),C=i.inv(I),N=Q(H(h,void 0,"msgHash")),W=i.create(-N*C),U=i.create(E*C),k=r.BASE.multiplyUnsafe(W).add(S.multiplyUnsafe(U));if(k.is0())throw new Error("invalid recovery: point at infinify");return k.assertValidity(),k}hasHighS(){return y(this.s)}toBytes(h=m.format){if(nt(h),h==="der")return He(ge.hexFromSig(this));const{r:b,s:E}=this,R=i.toBytes(b),I=i.toBytes(E);return h==="recovered"?(L(),_e(Uint8Array.of(this.assertRecovery()),R,I)):_e(R,I)}toHex(h){return ke(this.toBytes(h))}}const B=s.bits2int||function(h){if(h.length>8192)throw new Error("input is too large");const b=Ve(h),E=h.length*8-c;return E>0?b>>BigInt(E):b},Q=s.bits2int_modN||function(h){return i.create(B(h))},ve=dt(c);function he(u){return vr("num < 2^"+c,u,le,ve),i.toBytes(u)}function Z(u,h){return H(u,void 0,"message"),h?H(e(u),void 0,"prehashed message"):u}function xe(u,h,b){const{lowS:E,prehash:R,extraEntropy:I}=tt(b,m);u=Z(u,R);const O=Q(u),S=i.fromBytes(h);if(!i.isValidNot0(S))throw new Error("invalid private key");const C=[he(S),he(O)];if(I!=null&&I!==!1){const k=I===!0?t(_.secretKey):I;C.push(H(k,void 0,"extraEntropy"))}const N=_e(...C),W=O;function U(k){const j=B(k);if(!i.isValidNot0(j))return;const V=i.inv(j),ee=r.BASE.multiply(j).toAffine(),G=i.create(ee.x);if(G===le)return;const K=i.create(V*i.create(W+G*S));if(K===le)return;let xt=(ee.x===G?0:2)|Number(ee.y&Ee),mt=K;return E&&y(K)&&(mt=i.neg(K),xt^=1),new $(G,mt,A?void 0:xt)}return{seed:N,k2sig:U}}function ne(u,h,b={}){const{seed:E,k2sig:R}=xe(u,h,b);return Er(e.outputLen,i.BYTES,n)(E,R).toBytes(b.format)}function D(u,h,b,E={}){const{lowS:R,prehash:I,format:O}=tt(E,m);if(b=H(b,void 0,"publicKey"),h=Z(h,I),!at(u)){const S=u instanceof $?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+S)}F(u,O);try{const S=$.fromBytes(u,O),C=r.fromBytes(b);if(R&&S.hasHighS())return!1;const{r:N,s:W}=S,U=Q(h),k=i.inv(W),j=i.create(U*k),V=i.create(N*k),ee=r.BASE.multiplyUnsafe(j).add(C.multiplyUnsafe(V));return ee.is0()?!1:i.create(ee.x)===N}catch{return!1}}function P(u,h,b={}){const{prehash:E}=tt(b,m);return h=Z(h,E),$.fromBytes(u,"recovered").recoverPublicKey(h).toBytes()}return Object.freeze({keygen:l,getPublicKey:d,getSharedSecret:f,utils:w,lengths:_,Point:r,sign:ne,verify:D,recoverPublicKey:P,Signature:$,hash:e})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const ft={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Vr={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},Ft=BigInt(2);function Kr(r){const e=ft.p,s=BigInt(3),t=BigInt(6),n=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%e,d=l*l*r%e,f=se(d,s,e)*d%e,w=se(f,s,e)*d%e,_=se(w,Ft,e)*l%e,m=se(_,n,e)*_%e,A=se(m,o,e)*m%e,y=se(A,a,e)*A%e,T=se(y,c,e)*y%e,L=se(T,a,e)*A%e,F=se(L,s,e)*d%e,$=se(F,i,e)*m%e,B=se($,t,e)*l%e,Q=se(B,Ft,e);if(!ot.eql(ot.sqr(Q),r))throw new Error("Cannot find square root");return Q}const ot=Ke(ft.p,{sqrt:Kr}),zr=qr(ft,{Fp:ot,endo:Vr}),Yr=jr(zr,wr),Zr=BigInt(0),Re=BigInt(1),Xr=BigInt(2),Jr=BigInt(7),Qr=BigInt(256),en=BigInt(113),bs=[],vs=[],Ss=[];for(let r=0,e=Re,s=1,t=0;r<24;r++){[s,t]=[t,(2*s+3*t)%5],bs.push(2*(5*t+s)),vs.push((r+1)*(r+2)/2%64);let n=Zr;for(let o=0;o<7;o++)e=(e<<Re^(e>>Jr)*en)%Qr,e&Xr&&(n^=Re<<(Re<<BigInt(o))-Re);Ss.push(n)}const Es=ur(Ss,!0),tn=Es[0],sn=Es[1],Ut=(r,e,s)=>s>32?pr(r,e,s):hr(r,e,s),Ht=(r,e,s)=>s>32?gr(r,e,s):fr(r,e,s);function rn(r,e=24){const s=new Uint32Array(10);for(let t=24-e;t<24;t++){for(let i=0;i<10;i++)s[i]=r[i]^r[i+10]^r[i+20]^r[i+30]^r[i+40];for(let i=0;i<10;i+=2){const a=(i+8)%10,c=(i+2)%10,l=s[c],d=s[c+1],f=Ut(l,d,1)^s[a],w=Ht(l,d,1)^s[a+1];for(let _=0;_<50;_+=10)r[i+_]^=f,r[i+_+1]^=w}let n=r[2],o=r[3];for(let i=0;i<24;i++){const a=vs[i],c=Ut(n,o,a),l=Ht(n,o,a),d=bs[i];n=r[d],o=r[d+1],r[d]=c,r[d+1]=l}for(let i=0;i<50;i+=10){for(let a=0;a<10;a++)s[a]=r[i+a];for(let a=0;a<10;a++)r[i+a]^=~s[(a+2)%10]&s[(a+4)%10]}r[0]^=tn[t],r[1]^=sn[t]}Ie(s)}class pt{constructor(e,s,t,n=!1,o=24){v(this,"state");v(this,"pos",0);v(this,"posOut",0);v(this,"finished",!1);v(this,"state32");v(this,"destroyed",!1);v(this,"blockLen");v(this,"suffix");v(this,"outputLen");v(this,"enableXOF",!1);v(this,"rounds");if(this.blockLen=e,this.suffix=s,this.outputLen=t,this.enableXOF=n,this.rounds=o,ue(t,"outputLen"),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=tr(this.state)}clone(){return this._cloneInto()}keccak(){Rt(this.state32),rn(this.state32,this.rounds),Rt(this.state32),this.posOut=0,this.pos=0}update(e){Te(this),H(e);const{blockLen:s,state:t}=this,n=e.length;for(let o=0;o<n;){const i=Math.min(s-this.pos,n-o);for(let a=0;a<i;a++)t[this.pos++]^=e[o++];this.pos===s&&this.keccak()}return this}finish(){if(this.finished)return;this.finished=!0;const{state:e,suffix:s,pos:t,blockLen:n}=this;e[t]^=s,s&128&&t===n-1&&this.keccak(),e[n-1]^=128,this.keccak()}writeInto(e){Te(this,!1),H(e),this.finish();const s=this.state,{blockLen:t}=this;for(let n=0,o=e.length;n<o;){this.posOut>=t&&this.keccak();const i=Math.min(t-this.posOut,o-n);e.set(s.subarray(this.posOut,this.posOut+i),n),this.posOut+=i,n+=i}return e}xofInto(e){if(!this.enableXOF)throw new Error("XOF is not possible for this instance");return this.writeInto(e)}xof(e){return ue(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(Zt(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,Ie(this.state)}_cloneInto(e){const{blockLen:s,suffix:t,outputLen:n,rounds:o,enableXOF:i}=this;return e||(e=new pt(s,t,n,i,o)),e.state32.set(this.state32),e.pos=this.pos,e.posOut=this.posOut,e.finished=this.finished,e.rounds=o,e.suffix=t,e.outputLen=n,e.enableXOF=i,e.destroyed=this.destroyed,e}}const nn=(r,e,s,t={})=>Jt(()=>new pt(e,r,s),t),Gt=nn(1,136,32);class on{async verifyJWT(e,s){try{const t=this.decodeJWT(e);p.log("[CROSSx] JWT 디코딩 성공:",{sub:t.sub,exp:t.exp,iat:t.iat,"현재 시간":Math.floor(Date.now()/1e3)});const n=Math.floor(Date.now()/1e3);return t.exp&&t.exp<n?(p.warn("[CROSSx] 토큰 만료:",{exp:t.exp,now:n,만료시간:new Date(t.exp*1e3).toISOString()}),{payload:t,valid:!1,signatureVerified:!1}):t.sub?(p.log("[CROSSx] JWT 검증 성공 (서명 미검증 — JWKS 미구현)"),{payload:t,valid:!0,signatureVerified:!1}):(p.warn("[CROSSx] JWT에 sub(사용자ID) 없음"),{payload:t,valid:!1,signatureVerified:!1})}catch(t){throw p.error("[CROSSx] JWT 검증 중 에러:",t),t}}decodeJWT(e){return Os.decodeJwt(e)}recoverPersonalSignSigner(e,s){const t=new TextEncoder().encode(e),n=new TextEncoder().encode(`Ethereum Signed Message:
2
- ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);const i=Gt(o),a=s.startsWith("0x")?s.slice(2):s;if(a.length!==130)throw new Error(`서명 길이가 유효하지 않습니다: 130 hex 문자 예상, 현재 ${a.length}`);const c=an(a),l=c.slice(0,32),d=c.slice(32,64),f=c[64],w=f>=27?f-27:f,A=new Yr.Signature(qt(l),qt(d)).addRecoveryBit(w).recoverPublicKey(i).toBytes(!1).slice(1),y=Gt(A);return"0x"+ke(y.slice(12))}}function an(r){const e=new Uint8Array(r.length/2);for(let s=0;s<e.length;s++)e[s]=parseInt(r.substring(s*2,s*2+2),16);return e}function qt(r){let e="0x";for(const s of r)e+=s.toString(16).padStart(2,"0");return BigInt(e)}const cn=3e4;class ln{async request(e){const s=new AbortController,t=setTimeout(()=>s.abort(),e.timeoutMs??cn);try{const n=await fetch(e.url,{method:e.method,headers:e.headers,body:e.body?JSON.stringify(e.body):void 0,signal:s.signal,credentials:e.credentials});let o;const i=await n.text();try{o=i?JSON.parse(i):null}catch{o={_raw:i}}return{status:n.status,data:o,headers:Object.fromEntries(n.headers.entries())}}finally{clearTimeout(t)}}}class gt{static generateState(){const e=new Uint8Array(16);return crypto.getRandomValues(e),Array.from(e,s=>s.toString(16).padStart(2,"0")).join("")}openAuth(e){return new Promise((s,t)=>{const n=Math.max(e.width??500,500),o=Math.max(e.height??700,700),i=window.screenX+(window.outerWidth-n)/2,a=window.screenY+(window.outerHeight-o)/2,c=gt.generateState(),l=e.authUrl.includes("?")?"&":"?",d=`${e.authUrl}${l}state=${c}`,f=window.open(d,"CROSSx OAuth",`width=${n},height=${o},left=${i},top=${a}`);if(!f){t(new Error("팝업 창을 열 수 없습니다. 팝업 차단을 해제해 주세요."));return}const w=setTimeout(()=>{p.warn("[CROSSx] OAuth 타임아웃 (5분) — postMessage를 수신하지 못했습니다"),F(),t(new Error("Authentication timeout"))},5*60*1e3),_=10,m=30;let A=0,y=null;const T=()=>{clearInterval(L),p.warn("[CROSSx] COOP 감지 — OAuth 서버 응답을 "+m+"초간 대기합니다"),y=setTimeout(()=>{F(),t(new Error("OAuth 서버로부터 응답을 받지 못했습니다. 브라우저 보안 정책(COOP)으로 인해 팝업 통신이 차단되었을 수 있습니다. 다시 시도해 주세요."))},m*1e3)},L=setInterval(()=>{A++;try{f.closed&&(A<=_?T():(F(),t(new Error("로그인이 취소되었습니다"))))}catch{T()}},1e3),F=()=>{clearTimeout(w),clearInterval(L),y&&clearTimeout(y),window.removeEventListener("message",$)},$=B=>{var ve,he,Z,xe,ne,D,P;if(B.origin!==e.expectedOrigin)return;F(),p.log("[CROSSx] OAuth postMessage 수신 — status:",B.data.status);const Q=B.data.state??((ve=B.data.data)==null?void 0:ve.state);if(!Q||Q!==c){t(new Error("OAuth state mismatch — possible CSRF attack"));return}if(B.data.status==="success"){const u=((he=B.data.data)==null?void 0:he.accessToken)||((Z=B.data.data)==null?void 0:Z.idToken);p.log("[CROSSx] OAuth 토큰 수신:",{hasAccessToken:!!((xe=B.data.data)!=null&&xe.accessToken),hasIdToken:!!((ne=B.data.data)!=null&&ne.idToken)}),u?s(u):(p.error("[CROSSx] 토큰을 찾을 수 없음:",B.data),t(new Error("Token not found in response")))}else p.error("[CROSSx] OAuth 실패:",(D=B.data.data)==null?void 0:D.error),t(new Error(((P=B.data.data)==null?void 0:P.error)||"Authentication failed"))};window.addEventListener("message",$)})}}const Oe="crossx_wallet_data";class dn{constructor(e){this.storage=e}async getOrCreateWallet(e){try{const s=await this.storage.get(Oe);if(s)return s;const t={id:e,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};return await this.storage.set(Oe,t),t}catch(s){throw new x(g.WALLET_CREATION_FAILED,"지갑 생성에 실패했습니다",s)}}async getAddresses(e){const s=await this.storage.get(Oe);return s?[{address:s.address,index:0}]:[]}async getAddress(e,s){return{address:this.generateMockEvmAddress(),derivationPath:`m/44'/60'/0'/0/${s}`}}async prepare(e,s){const t="mock-"+crypto.randomUUID();return p.log(`[Mock] prepare action=${e} → uuid=${t}`),{uuid:t,expiresAt:new Date(Date.now()+5*6e4).toISOString()}}async signMessage(e,s,t,n=0,o,i){return p.log(`[Mock] signMessage chainId=${s} index=${n} uuid=${o} from=${i}: "${t}"`),{chainId:s,signature:this.generateMockSignature(),format:"hex"}}async signTypedData(e,s,t,n=0,o,i){return p.log(`[Mock] signTypedData chainId=${s} index=${n} uuid=${o} from=${i}`),{chainId:s,signature:this.generateMockSignature(),format:"hex"}}async signTransaction(e,s,t,n=0,o){p.log(`[Mock] signTransaction chainId=${s} index=${n} uuid=${o}:`,t);const i="0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("");return{chainId:s,signature:this.generateMockSignature(),txHash:i,format:"hex"}}async sendTransaction(e,s,t,n){return p.log(`[Mock] sendTransaction chainId=${s} uuid=${n}:`,t),{txHash:"0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}async recoverWallet(e,s){p.log("[Mock] recoverWallet");const t={id:e,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};return await this.storage.set(Oe,t),t}async migrateWallet(e,s){p.log(`[Mock] migrateWallet pin=${e} sub=${s}`);const t={id:s,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};return await this.storage.set(Oe,t),t}generateMockEvmAddress(){return"0x"+Array(40).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}generateMockSignature(){return"0x"+Array(130).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}class We{constructor(e,s,t,n){this.adapterConfig=e,this.projectId=e.projectId,this.storage=s,this.transport=t,this.tokenStore=n}get baseUrl(){return this.adapterConfig.gatewayUrl}getAuthToken(){const e=this.tokenStore.get();if(!e)throw new x(g.AUTH_NOT_AUTHENTICATED,"인증 토큰을 찾을 수 없습니다. 먼저 로그인해 주세요.");return e}async request(e,s,t){var a,c;const n=this.getAuthToken(),o=`${this.baseUrl}${s}`,i={Authorization:`Bearer ${n}`,"Content-Type":"application/json","X-Project-Id":this.projectId};try{const d=(await this.transport.request({url:o,method:e,headers:i,body:t??void 0})).data;if(d&&typeof d.code=="number"){if(d.code<0||d.code>=400){const f=d.message||d.data||"API 요청에 실패했습니다";p.error("[CROSSx] Wallet Gateway API 에러 (HTTP 200):",{code:d.code,message:f,url:o,method:e,fullResponse:d});const w=We.mapGatewayError(d.code),_=We.getGatewayErrorMessage(d.code,f),m=new x(w,_);throw m.gatewayCode=d.code,m.gatewayMessage=f,m}return p.log("[CROSSx] Wallet Gateway API 성공:",{code:d.code,url:o,method:e}),d.data??d}return d}catch(l){if(l instanceof x)throw l;if((a=l.response)!=null&&a.data){const d=l.response.data,f=d.message||d.data||"API 요청에 실패했습니다",w=d.code||"UNKNOWN";throw p.error("[CROSSx] Wallet Gateway API 에러 (HTTP 에러):",{code:w,message:f,url:o,method:e,status:(c=l.response)==null?void 0:c.status}),new x(g.UNKNOWN_ERROR,`Wallet Gateway 오류 (${w}): ${f}`)}throw l}}async getOrCreateWallet(e){var s;p.log("[CROSSx][Migration Phase 2] GET /mnemonic/addresses — 기존 지갑 조회");try{const t=await this.request("GET","/mnemonic/addresses");if(t.addresses&&t.addresses.length>0){const{address:n}=t.addresses[0];return p.log("[CROSSx][Migration Phase 2] 기존 지갑 발견 — address:",n),{id:e,address:n,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}}catch{p.log("[CROSSx][Migration Phase 2] 기존 지갑 없음, POST /mnemonic/create 진행")}p.log("[CROSSx][Migration Phase 2] POST /mnemonic/create — ignoreBackup: false");try{const t={ignoreBackup:!1},n=await this.request("POST","/mnemonic/create",t);return p.log("[CROSSx][Migration Phase 2] /mnemonic/create 성공 — address:",n.address),{id:e,address:n.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}catch(t){if((t==null?void 0:t.gatewayCode)===-10004||(s=t==null?void 0:t.message)!=null&&s.includes("-10004")){p.log("[CROSSx][Migration Phase 2] 지갑 이미 존재 (-10004), 주소 재조회");const n=await this.request("GET","/mnemonic/addresses");if(n.addresses&&n.addresses.length>0)return{id:e,address:n.addresses[0].address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}throw(t==null?void 0:t.gatewayCode)===-10012&&p.log("[CROSSx][Migration Phase 2] Gateway -10012 수신 → MIGRATION_BACKUP_EXISTS throw"),t}}async getAddresses(e){return((await this.request("GET","/mnemonic/addresses")).addresses??[]).map(t=>({address:t.address,index:t.index}))}async getAddress(e,s){try{return{address:(await this.request("GET",`/mnemonic/address?index=${s}`)).address,derivationPath:`m/44'/60'/0'/0/${s}`}}catch(t){if(t instanceof x&&this.isAddressNotFoundError(t))return p.log(`[CROSSx] index ${s} 주소 없음, 파생 중...`),{address:(await this.request("GET",`/mnemonic/address?index=${s}&derive=true`)).address,derivationPath:`m/44'/60'/0'/0/${s}`};throw t}}isAddressNotFoundError(e){const s=e.message.toLowerCase();return s.includes("404")||s.includes("not found")||s.includes("찾을 수 없")||s.includes("does not exist")||s.includes("no address")}async prepare(e,s){let t;switch(e){case"sign":case"send":if(!s.tx)throw new x(g.TX_INVALID_PARAMS,"prepare: tx가 필요합니다");t={unsignedTx:this.buildUnsignedTx(s.tx)};break;case"sign-message":if(!s.message)throw new x(g.TX_INVALID_PARAMS,"prepare: message가 필요합니다");t={message:s.message},s.from&&(t.from=s.from);break;case"sign-typed-data":if(!s.typedData)throw new x(g.TX_INVALID_PARAMS,"prepare: typedData가 필요합니다");t={typedData:s.typedData},s.from&&(t.from=s.from);break}const n={action:e,params:t},o=await this.request("POST","/mnemonic/prepare",n);return{uuid:o.uuid,expiresAt:o.expiresAt}}async signMessage(e,s,t,n,o,i){const a={message:t};o&&(a.uuid=o),i&&(a.from=i);const c=await this.request("POST","/mnemonic/sign-message",a);return{chainId:s,signature:c.signature,format:"hex"}}async signTypedData(e,s,t,n,o,i){const a={typedData:t};o&&(a.uuid=o),i&&(a.from=i);const c=await this.request("POST",`/mnemonic/sign-typed-data/${encodeURIComponent(s)}`,a);return{chainId:s,signature:c.signature,format:"hex"}}buildUnsignedTx(e){return{from:e.from,to:e.to,value:e.value,data:e.data,nonce:e.nonce!==void 0?`0x${e.nonce.toString(16)}`:void 0,gasLimit:e.gasLimit,gasPrice:e.gasPrice,maxFeePerGas:e.maxFeePerGas,maxPriorityFeePerGas:e.maxPriorityFeePerGas,chainId:e.chainId!==void 0?`0x${e.chainId.toString(16)}`:void 0}}async signTransaction(e,s,t,n,o){const i={unsignedTx:this.buildUnsignedTx(t)};o&&(i.uuid=o);const a=await this.request("POST",`/mnemonic/sign/${encodeURIComponent(s)}`,i);return{chainId:s,signature:a.signedTx,txHash:a.txHash,format:"hex"}}async sendTransaction(e,s,t,n){const o={unsignedTx:this.buildUnsignedTx(t)};return n&&(o.uuid=n),{txHash:(await this.request("POST",`/mnemonic/send/${encodeURIComponent(s)}`,o)).txHash}}async recoverWallet(e,s){const t={shareC:s},n=await this.request("POST","/mnemonic/recover",t);return{id:e,address:n.address,newShareC:n.newShareC,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}async migrateWallet(e,s){p.log("[CROSSx][Migration Phase 4] POST /mnemonic/migrate 호출 — sub:",s);const t={pin:e,sub:s},n=await this.request("POST","/mnemonic/migrate",t);return p.log("[CROSSx][Migration Phase 4] /mnemonic/migrate 완료 — address:",n.address),{id:s,address:n.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}static mapGatewayError(e){switch(e){case-10002:return g.AUTH_NOT_AUTHENTICATED;case-10001:case-10009:return g.UNKNOWN_ERROR;case-10006:return g.GATEWAY_INTERNAL_ERROR;case-10008:return g.GATEWAY_LOCK_CONFLICT;case-10010:return g.MIGRATION_FAILED;case-10012:return g.MIGRATION_BACKUP_EXISTS;case-10022:return g.PROJECT_NOT_REGISTERED;case-10023:return g.PROJECT_ID_MISSING;case-10024:return g.ORIGIN_NOT_ALLOWED;case-10026:return g.TYPED_DATA_CHAIN_ID_MISMATCH;case-10014:case-10015:case-10019:return g.PREPARE_FAILED;case-10016:return g.PREPARE_EXPIRED;case-10017:case-10018:return g.PREPARE_MISMATCH;default:return g.UNKNOWN_ERROR}}static getGatewayErrorMessage(e,s){switch(e){case-10002:return"Session expired. Please sign in again.";case-10006:return"Internal server error. Please try again later.";case-10008:return"Another operation is in progress. Please try again later.";case-10022:return"Project is not whitelisted. Verify your projectId and register the current origin in the management console.";case-10023:return"Project ID is required. Set the projectId field in SDKConfig.";case-10024:return"Origin is not in the allowed list. Register the current domain in the management console.";case-10026:return"Domain chainId mismatch: the chainId in typedData.domain does not match the request chainId.";default:return`Request failed (${e}): ${s}`}}}class Ce{constructor(e,s){this.cache=new Map,this.loadedAt=0,this.usingFallback=!1,this.adapterConfig=e,this.projectId=e.projectId,this.transport=s}get baseUrl(){return this.adapterConfig.gatewayUrl}async getChains(){if(this.isCacheValid())return Array.from(this.cache.values());try{const e=await this.request("/chains");this.handleEnvelopeError(e);const s=e.data.chains;return this.populateCache(s,!1),s}catch{const e=Ce.fallbackChains();return this.populateCache(e,!0),e}}async getChain(e){const t=(await this.getChains()).find(n=>n.chainId===e);return t||this.fallbackOrThrow(e)}invalidateCache(){this.cache.clear(),this.loadedAt=0,this.usingFallback=!1}isCacheValid(){if(this.loadedAt===0)return!1;const e=this.usingFallback?Zs:Ys;return e===0?!0:Date.now()-this.loadedAt<e}populateCache(e,s){this.cache.clear();for(const t of e)this.cache.set(t.chainId,t);this.loadedAt=Date.now(),this.usingFallback=s}async request(e){return(await this.transport.request({url:`${this.baseUrl}${e}`,method:"GET",headers:{"X-Project-Id":this.projectId}})).data}handleEnvelopeError(e){if(e.code<0){const s=typeof e.data=="string"?e.data:e.message??"체인 레지스트리 요청에 실패했습니다";throw new x(Ce.mapErrorCode(e.code),s)}}fallbackOrThrow(e){const s=Ce.fallbackChains().find(t=>t.chainId===e);if(s)return s;throw new x(g.CHAIN_NOT_SUPPORTED,`지원하지 않는 체인: ${e}`)}static fallbackChains(){return Object.values(je).map(e=>({chainId:e.caipId,rpcUrl:e.rpcUrl}))}static mapErrorCode(e){switch(e){case-10020:return g.CHAIN_NOT_SUPPORTED;case-10021:return g.INVALID_CHAIN;case-10022:return g.PROJECT_NOT_REGISTERED;case-10023:return g.PROJECT_ID_MISSING;case-10024:return g.APP_IDENTIFIER_MISSING;case-10025:return g.INVALID_APP_TYPE;default:return g.UNKNOWN_ERROR}}}const Wt="__crossx-confirm-style",te="__crossx-confirm-overlay",un={light:{bg:"#FFFFFF",border:"rgba(18,18,18,0.05)",titleColor:"#121212",subtitleColor:"rgba(18,18,18,0.7)",labelColor:"rgba(18,18,18,0.5)",valueColor:"#121212",pillBg:"rgba(18,18,18,0.05)",pillFromColor:"rgba(18,18,18,0.5)",pillAmtColor:"#121212",divider:"rgba(18,18,18,0.1)",closeColor:"#121212",closeHoverBg:"rgba(18,18,18,0.05)",copyColor:"rgba(18,18,18,0.5)",inputBg:"#FFFFFF",inputBorder:"rgba(18,18,18,0.1)",hintColor:"rgba(18,18,18,0.5)",primary:"#019D92",primaryGlow:"rgba(1,157,146,0.15)",secondary:"#E70077",onPrimary:"#FFFFFF"},dark:{bg:"#121212",border:"rgba(255,255,255,0.05)",titleColor:"#FFFFFF",subtitleColor:"rgba(255,255,255,0.7)",labelColor:"rgba(255,255,255,0.5)",valueColor:"#FFFFFF",pillBg:"rgba(255,255,255,0.05)",pillFromColor:"rgba(255,255,255,0.5)",pillAmtColor:"#FFFFFF",divider:"rgba(255,255,255,0.1)",closeColor:"#FFFFFF",closeHoverBg:"rgba(255,255,255,0.05)",copyColor:"rgba(255,255,255,0.5)",inputBg:"#121212",inputBorder:"rgba(255,255,255,0.1)",hintColor:"rgba(255,255,255,0.5)",primary:"#019D92",primaryGlow:"rgba(1,157,146,0.15)",secondary:"#E70077",onPrimary:"#FFFFFF"}};function jt(r,e){const s=un[r],t=e==null?void 0:e[r];return t?{...s,...t.primary!==void 0&&{primary:t.primary},...t.secondary!==void 0&&{secondary:t.secondary},...t.onPrimary!==void 0&&{onPrimary:t.onPrimary},...t.borderDefault!==void 0&&{border:t.borderDefault},...t.borderSubtle!==void 0&&{divider:t.borderSubtle,inputBorder:t.borderSubtle},...t.textIconPrimary!==void 0&&{titleColor:t.textIconPrimary,valueColor:t.textIconPrimary,pillAmtColor:t.textIconPrimary,closeColor:t.textIconPrimary},...t.textIconSecondary!==void 0&&{subtitleColor:t.textIconSecondary},...t.textIconTertiary!==void 0&&{labelColor:t.textIconTertiary,pillFromColor:t.textIconTertiary,copyColor:t.textIconTertiary,hintColor:t.textIconTertiary},...t.surfaceDefault!==void 0&&{pillBg:t.surfaceDefault,closeHoverBg:t.surfaceDefault},...t.bg!==void 0&&{bg:t.bg,inputBg:t.bg}}:s}const hn=`
1
+ "use strict";var Os=Object.defineProperty;var Ns=(r,e,s)=>e in r?Os(r,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[e]=s;var S=(r,e,s)=>Ns(r,typeof e!="symbol"?e+"":e,s);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Ls=require("jose");var _=(r=>(r.AUTH_NOT_INITIALIZED="AUTH_NOT_INITIALIZED",r.AUTH_FAILED="AUTH_FAILED",r.AUTH_TOKEN_INVALID="AUTH_TOKEN_INVALID",r.AUTH_TOKEN_EXPIRED="AUTH_TOKEN_EXPIRED",r.AUTH_NOT_AUTHENTICATED="AUTH_NOT_AUTHENTICATED",r.ALREADY_AUTHENTICATED="ALREADY_AUTHENTICATED",r.WALLET_NOT_FOUND="WALLET_NOT_FOUND",r.WALLET_CREATION_FAILED="WALLET_CREATION_FAILED",r.SIGN_FAILED="SIGN_FAILED",r.SIGN_REJECTED="SIGN_REJECTED",r.TX_FAILED="TX_FAILED",r.TX_REJECTED="TX_REJECTED",r.USER_REJECTED="USER_REJECTED",r.TX_INVALID_PARAMS="TX_INVALID_PARAMS",r.NETWORK_ERROR="NETWORK_ERROR",r.NETWORK_NOT_CONFIGURED="NETWORK_NOT_CONFIGURED",r.INVALID_CHAIN="INVALID_CHAIN",r.CHAIN_NOT_SUPPORTED="CHAIN_NOT_SUPPORTED",r.CHAIN_ADAPTER_NOT_FOUND="CHAIN_ADAPTER_NOT_FOUND",r.NOT_IMPLEMENTED="NOT_IMPLEMENTED",r.SIGNATURE_FAILED="SIGNATURE_FAILED",r.TRANSACTION_FAILED="TRANSACTION_FAILED",r.PREPARE_FAILED="PREPARE_FAILED",r.PREPARE_EXPIRED="PREPARE_EXPIRED",r.PREPARE_MISMATCH="PREPARE_MISMATCH",r.MIGRATION_FAILED="MIGRATION_FAILED",r.MIGRATION_BACKUP_EXISTS="MIGRATION_BACKUP_EXISTS",r.MIGRATION_PIN_LOCKED="MIGRATION_PIN_LOCKED",r.GATEWAY_INTERNAL_ERROR="GATEWAY_INTERNAL_ERROR",r.GATEWAY_LOCK_CONFLICT="GATEWAY_LOCK_CONFLICT",r.WALLET_INCONSISTENT_STATE="WALLET_INCONSISTENT_STATE",r.PROJECT_ID_MISSING="PROJECT_ID_MISSING",r.ORIGIN_NOT_ALLOWED="ORIGIN_NOT_ALLOWED",r.APP_IDENTIFIER_MISSING="APP_IDENTIFIER_MISSING",r.INVALID_APP_TYPE="INVALID_APP_TYPE",r.PROJECT_NOT_REGISTERED="PROJECT_NOT_REGISTERED",r.SIGNATURE_SIGNER_MISMATCH="SIGNATURE_SIGNER_MISMATCH",r.GAS_ESTIMATION_FAILED="GAS_ESTIMATION_FAILED",r.TYPED_DATA_CHAIN_ID_MISMATCH="TYPED_DATA_CHAIN_ID_MISMATCH",r.PASSWORD_NOT_SET="PASSWORD_NOT_SET",r.PASSWORD_WRONG="PASSWORD_WRONG",r.PASSWORD_COMPLEXITY="PASSWORD_COMPLEXITY",r.PASSWORD_CANCELLED="PASSWORD_CANCELLED",r.INVALID_CONFIG="INVALID_CONFIG",r.UNKNOWN_ERROR="UNKNOWN_ERROR",r))(_||{});class m extends Error{constructor(e,s,t){super(s),this.code=e,this.details=t,this.name="CROSSxError",Object.setPrototypeOf(this,m.prototype)}toJSON(){return{name:this.name,code:this.code,message:this.message,details:this.details}}}const je={CROSS_MAINNET:{caipId:"eip155:612055",chainId:612055,name:"CROSS Mainnet",nativeCurrency:{symbol:"CROSS",decimals:18},rpcUrl:"https://mainnet.crosstoken.io:22001"},CROSS_TESTNET:{caipId:"eip155:612044",chainId:612044,name:"CROSS Testnet",nativeCurrency:{symbol:"tCROSS",decimals:18},rpcUrl:"https://testnet.crosstoken.io:22001",testnet:!0},BSC_MAINNET:{caipId:"eip155:56",chainId:56,name:"BNB Smart Chain",nativeCurrency:{symbol:"BNB",decimals:18},rpcUrl:"https://bsc-mainnet.crosstoken.io/2272489872e4f1475ff25d57ce93b51989f933c7"},BSC_TESTNET:{caipId:"eip155:97",chainId:97,name:"BNB Smart Chain Testnet",nativeCurrency:{symbol:"BNB",decimals:18},rpcUrl:"https://bsc-testnet.crosstoken.io/110ea3628b77f244e5dbab16790d81bba874b962",testnet:!0},RONIN_MAINNET:{caipId:"eip155:2020",chainId:2020,name:"Ronin",nativeCurrency:{symbol:"RON",decimals:18},rpcUrl:"https://api.roninchain.com/rpc"},RONIN_SAIGON:{caipId:"eip155:202601",chainId:202601,name:"Ronin Saigon",nativeCurrency:{symbol:"RON",decimals:18},rpcUrl:"https://saigon-testnet.roninchain.com/rpc",testnet:!0}},Ds=Object.fromEntries(Object.entries(je).map(([r,e])=>[r,e.caipId])),Ms=new Map(Object.values(je).map(r=>[r.caipId,r]));new Map(Object.values(je).map(r=>[r.chainId,r]));const $s={symbol:"",decimals:18};function Je(r){var e;return((e=Ms.get(r))==null?void 0:e.nativeCurrency)??$s}class Xt{constructor(e,s){this.sdk=e,this.chainId=s,this._listeners=new Map}async request({method:e,params:s=[]}){switch(e){case"eth_accounts":case"eth_requestAccounts":{const t=await this.sdk.getAddress();return t?[t.address]:[]}case"eth_chainId":return this._caip2ToHex(this.chainId);case"net_version":return this.chainId.split(":")[1]??"1";case"eth_signTransaction":{const t=this._normalizeEIP1193Tx(s[0]);return(await this.sdk.signTransaction(this.chainId,t)).signedTx}case"eth_sendTransaction":{const t=this._normalizeEIP1193Tx(s[0]);return(await this.sdk.sendTransaction(this.chainId,t)).txHash}case"personal_sign":case"eth_sign":throw new m(_.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signMessage()를 직접 사용하세요.`);case"eth_signTypedData":case"eth_signTypedData_v1":case"eth_signTypedData_v3":case"eth_signTypedData_v4":throw new m(_.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signTypedData() 또는 sdk.signTypedDataOffchain()을 직접 사용하세요.`);default:return this.sdk.walletRpc(e,s,this.chainId)}}on(e,s){return this._listeners.has(e)||this._listeners.set(e,new Set),this._listeners.get(e).add(s),this}removeListener(e,s){var t;return(t=this._listeners.get(e))==null||t.delete(s),this}emit(e,...s){var t;(t=this._listeners.get(e))==null||t.forEach(o=>o(...s))}_caip2ToHex(e){const s=e.split(":");return`0x${parseInt(s[1]??"1",10).toString(16)}`}_normalizeEIP1193Tx(e){return{from:e.from,to:e.to,value:e.value,data:e.data,gasLimit:e.gasLimit??e.gas,gasPrice:e.gasPrice,maxFeePerGas:e.maxFeePerGas,maxPriorityFeePerGas:e.maxPriorityFeePerGas,nonce:e.nonce!==void 0?parseInt(String(e.nonce),16):void 0,chainId:parseInt(this.chainId.split(":")[1]??"1",10)}}}let ye=null;function St(r){ye=r}const h={log(...r){if(ye){ye.log(...r);return}},warn(...r){if(ye){ye.warn(...r);return}},error(...r){if(ye){ye.error(...r);return}}},Bs={confirm:"확인",cancel:"취소",close:"닫기",signMessage_title:"메시지 서명",signTypedData_title:"데이터 서명",signTransaction_title:"트랜잭션 서명",sendTransaction_title:"트랜잭션 전송",tx_pending:"트랜잭션 처리 중...",tx_success:"트랜잭션이 완료되었습니다",tx_failed:"트랜잭션이 실패했습니다",tx_timeout:"트랜잭션 확인 시간이 초과되었습니다",loginSelector_title:"로그인 방법 선택",loginSelector_google:"Google로 계속하기",loginSelector_apple:"Apple로 계속하기",migration_foundTitle:"기존 지갑 발견",migration_foundDescription:"기존 CROSSx 지갑이 발견되었습니다. 복구하시겠습니까?",migration_recoverButton:"복구하기",migration_skipButton:"건너뛰기",pinInput_title:"PIN 입력",pinInput_placeholder:"4자리 PIN을 입력하세요",pinInput_error:"PIN이 올바르지 않습니다. 다시 시도해 주세요.",walletSelector_title:"지갑 선택",walletSelector_addButton:"지갑 추가",walletSelector_selected:"선택됨",passwordNotice_headerSubtitle:"트랜잭션, PK/니모닉 및 계정 삭제 시 필요합니다.",passwordNotice_title:"비밀번호 설정 주의사항",passwordNotice_description:"보안을 위해 이 비밀번호는 재설정하거나 복구할 수 없습니다. 반드시 백업하거나 암기해 두시기 바랍니다.",passwordNotice_check1:"이 비밀번호는 분실 시 복구할 수 없으며, 안전하게 백업해 두었습니다.",passwordNotice_check2:"비밀번호 분실 시 계정 및 모든 관련 데이터에 영구적으로 접근이 불가능해질 수 있습니다.",passwordNotice_check3:"지원팀을 포함한 제3자는 이 비밀번호를 복구하거나 재설정해 줄 수 없습니다.",passwordNotice_nextButton:"다음",passwordNotice_submitButton:"동의합니다",passwordSetup_title:"비밀번호 만들기",passwordSetup_subtitle:"비밀번호는 자산 전송 시에만 사용됩니다.",passwordSetup_newPasswordLabel:"새 비밀번호",passwordSetup_confirmPasswordLabel:"새 비밀번호 확인",passwordSetup_rule_minLength:"8자 이상",passwordSetup_rule_uppercase:"대문자 1자 이상 포함",passwordSetup_rule_number:"숫자 1자 이상 포함",passwordSetup_rule_special:"특수문자 1자 이상 포함",passwordSetup_confirmError:"비밀번호가 일치하지 않습니다",passwordSetup_submitButton:"다음",passwordInput_title:"비밀번호 입력",passwordInput_subtitle:"계속하려면 비밀번호를 입력하세요.",passwordInput_passwordLabel:"비밀번호",passwordInput_submitButton:"확인",passwordInput_error:"비밀번호가 올바르지 않습니다. 다시 시도해 주세요.",verifyPassword_title:"비밀번호 확인",verifyPassword_subtitle:"계속하려면 현재 비밀번호를 확인해 주세요.",verifyPassword_passwordLabel:"비밀번호 확인"},Jt={confirm:"Confirm",cancel:"Cancel",close:"Close",signMessage_title:"Sign Message",signTypedData_title:"Sign Data",signTransaction_title:"Sign Transaction",sendTransaction_title:"Send Transaction",tx_pending:"Processing transaction...",tx_success:"Transaction completed",tx_failed:"Transaction failed",tx_timeout:"Transaction confirmation timed out",loginSelector_title:"Choose a sign-in method",loginSelector_google:"Continue with Google",loginSelector_apple:"Continue with Apple",migration_foundTitle:"Existing Wallet Found",migration_foundDescription:"An existing CROSSx wallet was found. Would you like to recover it?",migration_recoverButton:"Recover",migration_skipButton:"Skip",pinInput_title:"Enter PIN",pinInput_placeholder:"Enter your 4-digit PIN",pinInput_error:"Incorrect PIN. Please try again.",walletSelector_title:"Select Wallet",walletSelector_addButton:"Add Wallet",walletSelector_selected:"Selected",passwordNotice_headerSubtitle:"Required for Transactions, PK/Mnemonic & Account Deletion.",passwordNotice_title:"Password Setup Notice",passwordNotice_description:"For your security, this password cannot be reset or recovered. Please ensure you have it backed up or memorized.",passwordNotice_check1:"This password cannot be recovered if lost, and I have securely backed it up.",passwordNotice_check2:"Losing this password may result in permanent loss of access to my account and all associated data.",passwordNotice_check3:"No third party, including the support team, can recover or reset this password on my behalf.",passwordNotice_nextButton:"Next",passwordNotice_submitButton:"I Understand",passwordSetup_title:"Create Password",passwordSetup_subtitle:"Password is only used to transfer your asset.",passwordSetup_newPasswordLabel:"New Password",passwordSetup_confirmPasswordLabel:"Confirm New Password",passwordSetup_rule_minLength:"Over 8 letters",passwordSetup_rule_uppercase:"Include at least 1 uppercase letter",passwordSetup_rule_number:"Include at least 1 number",passwordSetup_rule_special:"Include at least 1 special character",passwordSetup_confirmError:"Password is incorrect",passwordSetup_submitButton:"Next",passwordInput_title:"Enter Password",passwordInput_subtitle:"Enter your password to continue.",passwordInput_passwordLabel:"Password",passwordInput_submitButton:"Confirm",passwordInput_error:"Incorrect password. Please try again.",verifyPassword_title:"Verify Your Password",verifyPassword_subtitle:"To continue, please confirm your current password",verifyPassword_passwordLabel:"Confirm Password"},Us={ko:Bs,en:Jt};function Et(r="en",e){return Us[r]??Jt}const Qe="crossx_access_token",Ne="crossx_refresh_token",Le="crossx_user_info";class Hs{constructor(e,s,t,o,n,i,a){this.config=e,this.storage=s,this.crypto=t,this.oauth=o,this.transport=n,this.walletProvider=i,this.tokenStore=a,this._refreshPromise=null}get useCookieAuth(){return this.config.authMode==="cookie"}checkResponseError(e,s){if(e!=null&&e.code&&e.code!==200&&e.code>0)throw new m(_.AUTH_FAILED,`${s} 실패 (코드 ${e.code}): ${e.message}`);const t=e==null?void 0:e.data;if(typeof t=="object"&&t!==null&&"code"in t){const o=t;if(o.code&&o.code!==200&&o.code>0)throw new m(_.AUTH_FAILED,`${s} 실패 (코드 ${o.code}): ${o.message}`)}}async execute(e){var o,n,i,a;let s,t=!1;try{const c=e==null?void 0:e.provider;let l="/login";c==="google"?l="/google":c==="apple"&&(l="/apple");const{oauthServiceUrl:d,authApiUrl:u}=this.config,g=`${d}${l}`;h.log(`[CROSSx] OAuth 팝업 열기 (${c||"일반"} 로그인)`);const f=await this.oauth.openAuth({authUrl:g,expectedOrigin:new URL(d).origin});h.log("[CROSSx] OAuth Firebase 토큰 받음 (length:",f.length,")");const{accessToken:p,refreshToken:b}=await this.exchangeFirebaseToken(f,u);let y,E;try{const U=this.crypto.decodeJWT(f);E=(o=U.firebase)==null?void 0:o.sign_in_provider;const M=((n=U.firebase)==null?void 0:n.identities)??{};E==="google.com"?y=(i=M["google.com"])==null?void 0:i[0]:E==="apple.com"&&(y=(a=M["apple.com"])==null?void 0:a[0]),h.log("[CROSSx] OAuth provider sub 추출 — provider:",E,"hasProviderSub:",!!y)}catch{h.warn("[CROSSx] firebaseToken에서 providerSub 추출 실패")}if(p){const U=this.crypto.decodeJWT(p);h.log("[CROSSx] access_token 디코딩 — sub:",U.sub,"exp:",U.exp);const M=await this.crypto.verifyJWT(p);if(t=M.signatureVerified??!1,!M.valid)throw h.error("[CROSSx] access_token 검증 실패"),new Error("유효하지 않은 access token");const B=M.payload;s={id:B.sub,email:B.email,signInProvider:E,providerSub:y},this.tokenStore.set(p),this.useCookieAuth||(await this.storage.set(Qe,p),b&&await this.storage.set(Ne,b))}else{const U=this.crypto.decodeJWT(f);s={id:U.sub,email:U.email,signInProvider:E,providerSub:y},h.log("[CROSSx] Cookie 모드 — Firebase 토큰에서 사용자 정보 추출 — id:",s.id)}h.log("[CROSSx] 사용자 정보 — id:",s.id);const D=this.useCookieAuth?{id:s.id,signInProvider:s.signInProvider,providerSub:s.providerSub}:s;await this.storage.set(Le,D),h.log("[CROSSx] 사용자 정보 저장 완료 (authMode:",this.useCookieAuth?"cookie":"token",")")}catch(c){return h.error("[CROSSx] SignIn 에러 (OAuth/토큰 교환 단계):",c),{success:!1,error:c instanceof Error?c.message:"Sign in failed"}}return h.log("[CROSSx][Migration Phase 1] OAuth 로그인 완료, 지갑 로드 시작 — userId:",s.id),this.loadWallet(s,t)}async exchangeFirebaseToken(e,s){const t=this.useCookieAuth,o=t?`${s}/cross-auth/social/login/cookie`:`${s}/cross-auth/social/login`;h.log("[CROSSx] Firebase 토큰 교환 요청");const n=await this.transport.request({url:o,method:"POST",headers:{"Content-Type":"application/json"},body:{auth_code:e,login_type:"firebase"},...t?{credentials:"include"}:{}});h.log("[CROSSx] 토큰 교환 응답 — status:",n.status);const i=n.data;this.checkResponseError(i,"Token exchange");const a=this.extractAccessToken(i);if(t&&!a)return h.log("[CROSSx] Cookie 모드 — 로그인 성공 (JWT는 HttpOnly 쿠키)"),{};if(!a)throw new m(_.AUTH_FAILED,"토큰 교환 응답에서 access_token을 찾을 수 없습니다");h.log("[CROSSx] access_token 교환 성공");let c;return t||(c=this.extractRefreshToken(i)),{accessToken:a,refreshToken:c}}extractAccessToken(e){const s=(e==null?void 0:e.data)??e;if(this.isJwtString(s))return s;if(typeof s=="object"&&s!==null){const t=s;if(this.isJwtString(t.data))return t.data;if(typeof t.data=="object"&&t.data!==null){const n=t.data,i=n.access_token??n.token;if(typeof i=="string")return i}const o=t.access_token??t.token;if(typeof o=="string")return o}}extractRefreshToken(e){const s=(e==null?void 0:e.data)??e;if(typeof s!="object"||s===null)return;const t=s;if(typeof t.data=="object"&&t.data!==null){const n=t.data,i=n.refresh_token??n.refresh;if(typeof i=="string")return i}const o=t.refresh_token??t.refresh;if(typeof o=="string")return o}isJwtString(e){return typeof e=="string"&&e.split(".").length===3}async restoreSession(){try{const e=this.tokenStore.get();if(e){const t=await this.crypto.verifyJWT(e);if(t.valid){const o=await this.storage.get(Le);if(o)return h.log("[CROSSx] restoreSession — 메모리 토큰 유효, 세션 복원"),this.loadWallet(o,t.signatureVerified)}this.tokenStore.clear()}if(this.useCookieAuth){h.log("[CROSSx] restoreSession — 쿠키 기반 silentRefresh 시도");const t=await this.silentRefresh();t&&this.tokenStore.set(t)}else{const t=await this.storage.get(Qe),o=await this.storage.get(Ne);if(h.log("[CROSSx] restoreSession — access_token:",t?"있음":"없음","refresh_token:",o?"있음":"없음"),!o)return h.log("[CROSSx] restoreSession — refresh_token 없음, 세션 복원 생략"),null;t&&this.tokenStore.set(t);const n=await this.silentRefresh(o);h.log("[CROSSx] restoreSession — silentRefresh 결과:",n?"토큰 발급 성공":"토큰 없음"),n&&this.tokenStore.set(n)}const s=await this.storage.get(Le);if(h.log("[CROSSx] restoreSession — userInfo 조회:",s?`있음 (id: ${s.id})`:"없음"),!s)return null;h.log("[CROSSx] restoreSession — silentRefresh 성공, 세션 복원 — userId:",s.id);try{return await this.loadWallet(s,!1)}catch(t){return h.warn("[CROSSx] restoreSession — 지갑 로드 실패 (세션은 유지):",t),{success:!0,user:s,tokenSignatureVerified:!1}}}catch(e){return h.log("[CROSSx] restoreSession — 세션 복원 실패, 스토리지 정리:",e),this.tokenStore.clear(),this.useCookieAuth||await this.storage.remove(Ne),await this.storage.remove(Le),null}}silentRefresh(e){return this._refreshPromise?this._refreshPromise:(this._refreshPromise=this._doSilentRefresh(e).finally(()=>{this._refreshPromise=null}),this._refreshPromise)}async _doSilentRefresh(e){const{authApiUrl:s}=this.config,t=this.useCookieAuth,o=`${s}/cross-auth/social/refresh/simple`,n={};if(!t){const l=this.tokenStore.get()??"";l&&(n.access_token=l),e&&(n.refresh_token=e)}const i=await this.transport.request({url:o,method:"POST",headers:{"Content-Type":"application/json"},body:n,...t?{credentials:"include"}:{}});h.log("[CROSSx] silentRefresh 응답 — status:",i.status);const a=i.data;this.checkResponseError(a,"Silent refresh");const c=this.extractAccessToken(a);if(t&&!c){h.log("[CROSSx] silentRefresh 성공 (cookie 갱신)");return}if(!c)throw new m(_.AUTH_FAILED,"토큰 자동 갱신 실패: 응답에 토큰이 없습니다");if(this.tokenStore.set(c),!t){await this.storage.set(Qe,c);const l=this.extractRefreshToken(a);l&&await this.storage.set(Ne,l)}return h.log("[CROSSx] silentRefresh 성공"),c}async loadWallet(e,s){let t,o=!1;try{if(typeof this.walletProvider.checkWallet=="function"){h.log("[CROSSx] GET /mnemonic/check — 지갑 상태 확인 (비밀번호 불필요)");const n=await this.walletProvider.checkWallet();if(h.log("[CROSSx] 지갑 상태:",n),n==="migration_required")h.log("[CROSSx] migration_required → needsMigration = true"),o=!0;else if(n==="exists")try{const i=await this.walletProvider.getAddresses(e.id);i.length>0?(t=i[0].address,h.log("[CROSSx] 캐시된 주소 로드 완료 (비밀번호 불필요):",t)):h.log("[CROSSx] 주소 캐시 없음 — createWallet 단계에서 비밀번호 입력 후 로드")}catch(i){h.warn("[CROSSx] getAddresses 실패, createWallet 단계에서 재시도:",i)}}else h.log("[CROSSx] getOrCreateWallet 직접 호출 (폴백)"),t=(await this.walletProvider.getOrCreateWallet(e.id)).address,h.log("[CROSSx] 지갑 로드 완료 — address:",t)}catch(n){if(n instanceof m&&n.code===_.MIGRATION_BACKUP_EXISTS)h.log("[CROSSx] MIGRATION_BACKUP_EXISTS 감지 → needsMigration = true"),o=!0;else{if(n instanceof m&&(n.code===_.PROJECT_NOT_REGISTERED||n.code===_.PROJECT_ID_MISSING||n.code===_.ORIGIN_NOT_ALLOWED))throw h.error("[CROSSx] 프로젝트 설정 에러:",n.message),n;h.warn("[CROSSx] 지갑 상태 확인 실패 (로그인은 유지):",n)}}return h.log("[CROSSx] loadWallet 결과 — address:",t,"needsMigration:",o),{success:!0,address:t,user:e,needsMigration:o,tokenSignatureVerified:s}}}const Fs="crossx_access_token",Gs="crossx_refresh_token",Ws="crossx_user_info";class qs{constructor(e,s,t){this.config=e,this.storage=s,this.tokenStore=t}async execute(){this.tokenStore.clear(),this.config.authMode!=="cookie"&&(await this.storage.remove(Fs),await this.storage.remove(Gs)),await this.storage.remove(Ws)}}class Vs{constructor(e,s){this.storage=e,this.walletProvider=s}async execute(e,s){if(!this.walletProvider.migrateWallet)throw new m(_.NOT_IMPLEMENTED,"현재 환경에서는 마이그레이션이 지원되지 않습니다");h.log("[CROSSx][Migration Phase 4] MigrateWalletUseCase.execute() — pin 길이:",e.length,"sub:",s);const t=await this.walletProvider.migrateWallet(e,s);return h.log("[CROSSx][Migration Phase 5] MigrateWalletUseCase 완료 — address:",t.address),{address:t.address}}}class Qt{constructor(){this.encryptedBytes=null,this.xorKey=null}set(e){this.clear();const s=new TextEncoder().encode(e),t=new Uint8Array(s.length);crypto.getRandomValues(t);const o=new Uint8Array(s.length);for(let n=0;n<s.length;n++)o[n]=s[n]^t[n];s.fill(0),this.xorKey=t,this.encryptedBytes=o}get(){if(!this.encryptedBytes||!this.xorKey)return null;const e=new Uint8Array(this.encryptedBytes.length);for(let t=0;t<this.encryptedBytes.length;t++)e[t]=this.encryptedBytes[t]^this.xorKey[t];const s=new TextDecoder().decode(e);return e.fill(0),s}clear(){var e,s;(e=this.encryptedBytes)==null||e.fill(0),(s=this.xorKey)==null||s.fill(0),this.encryptedBytes=null,this.xorKey=null}has(){return this.encryptedBytes!==null}}class Ks{constructor(e,s){this.chainRegistry=e,this.transport=s}async call(e,s,t){const o=await this.chainRegistry.getChain(t),n={jsonrpc:"2.0",method:e,params:s,id:Date.now()},a=(await this.transport.request({url:o.rpcUrl,method:"POST",headers:{"Content-Type":"application/json"},body:n})).data;if(a!=null&&a.error)throw new m(_.UNKNOWN_ERROR,`RPC 오류 [${e}] (${t}): ${a.error.message} (코드: ${a.error.code})`);return a==null?void 0:a.result}}class zs{constructor(){this.listeners=new Map}on(e,s){return this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(s),()=>this.off(e,s)}off(e,s){var t;(t=this.listeners.get(e))==null||t.delete(s)}emit(e,s){var t;(t=this.listeners.get(e))==null||t.forEach(o=>o(s))}removeAllListeners(){this.listeners.clear()}}const Fe={production:{oauthServiceUrl:"https://stg-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://stg-cross-auth.crosstoken.io",walletGatewayUrl:"https://stg-embedded-wallet-gateway.crosstoken.io/api/v1"},staging:{oauthServiceUrl:"https://stg-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://stg-cross-auth.crosstoken.io",walletGatewayUrl:"https://stg-embedded-wallet-gateway.crosstoken.io/api/v1"},development:{oauthServiceUrl:"https://dev-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://dev-cross-auth.crosstoken.io",walletGatewayUrl:"https://dev-embedded-wallet-gateway.crosstoken.io/api/v1"}};function js(r){const e=r.environment;return e&&e in Fe?Fe[e]:null}function Ys(){try{if(typeof __CROSSX_CONFIG__<"u"){const r=typeof __CROSSX_CONFIG__=="string"?JSON.parse(__CROSSX_CONFIG__):__CROSSX_CONFIG__,e=js(r);if(e)return e}}catch{}return Fe.production}const Zs=2e3,It=6e4,Xs=1e3,Js=1e4,Qs="0x77359400",At="0x3B9ACA00",Tt=130,Ct=6,kt=18,er=0,tr=30*1e3,Q=class Q extends zs{constructor(e,s,t,o,n,i,a,c,l,d,u){super(),this.storage=t,this.crypto=o,this.transport=n,this.oauth=i,this.walletProvider=a,this.tokenStore=c,this.initialized=!1,this._initPromise=null,this.authenticated=!1,this.userId=null,this.address=null,this.activeWalletIndex=0,this.userEmail=null,this.loginType=null,this.providerSub=null,this.tokenSignatureVerified=!1,this._verifyPasswordMutex=null,this._config=Object.freeze({...e}),this.internalConfig=e,this.adapterConfig=s,e.logger&&St(e.logger),this.confirmation=l,this.passwordStore=u??new Qt,this.chainRegistry=d,this.jsonRpc=new Ks(d,n),this.signInUseCase=new Hs(this.internalConfig,t,o,i,n,a,c),this.signOutUseCase=new qs(this.internalConfig,t,c),this.migrateWalletUseCase=new Vs(t,a)}get config(){return this._config}async initialize(e){return this.initialized?this.authenticated?{success:!0,address:this.address??void 0}:null:this._initPromise?this._initPromise:(this._initPromise=this._doInitialize(e).finally(()=>{this._initPromise=null}),this._initPromise)}async _doInitialize(e){console.log("[CROSSx SDK] v1.1.0 초기화 중..."),this.confirmation.setMessages(Et(this._config.locale));try{const s=Ys();this.internalConfig.oauthServiceUrl=s.oauthServiceUrl,this.internalConfig.authApiUrl=s.authApiUrl,this.internalConfig.walletGatewayUrl=s.walletGatewayUrl,this.adapterConfig.gatewayUrl=s.walletGatewayUrl;const t=await this.signInUseCase.restoreSession();if(t!=null&&t.success){this.applyAuthResult(t);try{await this.loadWalletAfterAuth(e==null?void 0:e.preferredWalletIndex)}catch(o){if(!(o instanceof m&&o.code===_.PASSWORD_CANCELLED))throw o;h.log("[CROSSx] initialize: 비밀번호 입력 취소 — 지갑 미로드 상태로 계속")}}return this.initialized=!0,this.emit("initialized",{restored:!!(t!=null&&t.success)}),t??null}catch(s){throw new m(_.AUTH_NOT_INITIALIZED,"SDK 초기화에 실패했습니다",s)}}async signIn(e){if(this.ensureInitialized(),this.authenticated)throw new m(_.ALREADY_AUTHENTICATED,"이미 로그인된 상태입니다. signOut()을 먼저 호출하세요.");let s=e;if(!(e!=null&&e.provider)){const t=await this.confirmation.showLoginSelector();if(t===null)return{success:!1,error:"User cancelled login"};s={...e,provider:t}}try{const t=await this.signInUseCase.execute(s);return t.success&&this.applyAuthResult(t),t}catch(t){throw new m(_.AUTH_FAILED,"로그인에 실패했습니다",t)}}async signInWithCreate(e){const s=await this.signIn(e);if(!s.success)return{...s,addresses:[]};try{if(s.needsMigration||!s.address){const{address:n}=await this.createWallet(),i=await this.getAddresses(),a=await this.selectWalletIfMultiple(i);return{...s,address:(a==null?void 0:a.address)??n,needsMigration:!1,addresses:i}}const t=await this.getAddresses(),o=await this.selectWalletIfMultiple(t);return{...s,address:(o==null?void 0:o.address)??s.address,addresses:t}}catch(t){throw t instanceof m&&t.code===_.PASSWORD_CANCELLED&&(h.log("[CROSSx] signInWithCreate: 비밀번호 설정 취소 — 자동 로그아웃 진행"),await this.signOut().catch(o=>h.warn("[CROSSx] signInWithCreate: 자동 로그아웃 실패",o))),t}}async signOut(){this.ensureInitialized();try{await this.signOutUseCase.execute(),this.clearAuthState()}catch(e){throw new m(_.UNKNOWN_ERROR,"로그아웃에 실패했습니다",e)}}isAuthenticated(){return this.authenticated}get currentAddress(){return this.address}get currentUserId(){return this.userId}isLoggedIn(){return this.isAuthenticated()}async ensureLoggedIn(){if(!this.initialized)return!1;if(this.authenticated)return!0;try{const e=await this.signInUseCase.restoreSession();if(e!=null&&e.success){this.applyAuthResult(e);try{await this.loadWalletAfterAuth()}catch(s){s instanceof m&&s.code===_.PASSWORD_CANCELLED||h.warn("[CROSSx] ensureLoggedIn: loadWalletAfterAuth 실패:",s)}return!0}return!1}catch{return!1}}async getUserInfo(){return this.ensureAuthenticated(),{id:this.userId,email:this.userEmail??void 0,loginType:this.loginType??void 0,addresses:this.address?[this.address]:[],tokenSignatureVerified:this.tokenSignatureVerified}}async migrateWallet(e){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");try{const s=await this.migrateWalletUseCase.execute(e,this.userId);return this.address=s.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:s.address,index:0}),h.log("[CROSSx] migrateWallet 완료 — address:",s.address),s}catch(s){throw s instanceof m?s:new m(_.MIGRATION_FAILED,"지갑 마이그레이션에 실패했습니다",s)}}async getAddress(e){if(e!==void 0){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");return{address:(await this.walletProvider.getAddress(this.userId,e)).address,index:e}}return!this.authenticated||!this.address?null:{address:this.address,index:this.activeWalletIndex}}async getAddresses(){if(this.ensureAuthenticated(),!this.userId)return[];const e=await this.walletProvider.getAddresses(this.userId);return e.length===0&&this.address?[{address:this.address,index:0}]:e}async selectWallet(e){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");let s=await this.walletProvider.getAddresses(this.userId);s.length===0&&this.address&&(s=[{address:this.address,index:0}]);const t=await this.confirmation.showWalletSelector(s,async()=>{await this.ensurePasswordForSigning();const o=s.length,i={address:(await this.walletProvider.getAddress(this.userId,o)).address,index:o};return s.push(i),i},e);return t&&(this.address=t.address,this.activeWalletIndex=t.index,this.emit("addressChanged",{address:t.address,index:t.index})),t}async selectWalletIfMultiple(e){return e.length<2?null:this.selectWallet()}async getChains(){this.ensureInitialized();try{return await this.chainRegistry.getChains()}catch(e){throw e instanceof m?e:new m(_.UNKNOWN_ERROR,"체인 목록 조회에 실패했습니다",e)}}async getChain(e){this.ensureInitialized();try{return await this.chainRegistry.getChain(e)}catch(s){throw s instanceof m?s:new m(_.CHAIN_NOT_SUPPORTED,`체인 조회에 실패했습니다: ${e}`,s)}}applyTheme(e=this._config.theme??"light",s=this._config.themeTokens??{}){this._config=Object.freeze({...this._config,theme:e,themeTokens:s}),this.confirmation.setTheme(e,s)}applyLocale(e=this._config.locale??"en"){this._config=Object.freeze({...this._config,locale:e}),this.confirmation.setMessages(Et(e))}async createWallet(){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");h.log("[CROSSx] createWallet 시작");const e=await this.fetchWalletStatus();if(h.log("[CROSSx] 지갑 상태:",e),e==="migration_required"){const s=this.providerSub??this.userId;h.log("[CROSSx] migration_required → 마이그레이션 UI 시작 — sub:",s);const t=await this.handleMigrationFlow(s);if(t)return this.address=t.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:t.address,index:0}),{address:t.address};throw new m(_.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}e==="exists"?await this.ensureVerifiedPassword():await this.ensurePasswordSetup();try{const s=await this.walletProvider.getOrCreateWallet(this.userId);return this.address=s.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:s.address,index:0}),h.log("[CROSSx] 지갑 준비 완료:",s.address),{address:s.address}}catch(s){if(s instanceof m&&s.code===_.MIGRATION_BACKUP_EXISTS){const t=this.providerSub??this.userId;h.log("[CROSSx] MIGRATION_BACKUP_EXISTS (폴백) → 마이그레이션 UI 시작");const o=await this.handleMigrationFlow(t);if(o)return this.address=o.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:o.address,index:0}),{address:o.address};throw new m(_.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}throw s}}async fetchWalletStatus(){if(typeof this.walletProvider.checkWallet=="function")try{return await this.walletProvider.checkWallet()}catch(e){return h.warn("[CROSSx] checkWallet 실패 (폴백: not_found 처리):",e),"not_found"}return null}async signMessage(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");await this.ensurePasswordForSigning();const o=t==null?void 0:t.index,n=await this.walletProvider.getAddress(this.userId,o??0);let i;if(this.walletProvider.prepare&&(i=(await this.walletProvider.prepare("sign-message",{message:s,from:n.address})).uuid),!await this.confirmation.requestConfirmation({type:"sign-message",chainId:e,from:n.address,message:s,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new m(_.USER_REJECTED,"사용자가 메시지 서명을 거부했습니다");try{const c=await this.withPasswordRetry(()=>this.walletProvider.signMessage(this.userId,e,s,t==null?void 0:t.index,i,n.address));return this.verifySignatureSigner(s,c.signature,n.address),{chainId:e,signature:c.signature,message:s,address:n.address}}catch(c){throw c instanceof m?c:new m(_.SIGNATURE_FAILED,`메시지 서명에 실패했습니다 (${e})`,c)}}async signTypedData(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");if(!this.walletProvider.signTypedData)throw new m(_.NOT_IMPLEMENTED,"signTypedData가 구현되어 있지 않습니다");await this.ensurePasswordForSigning(),Q.validateTypedDataChainId(e,s);const o=await this.walletProvider.getAddress(this.userId,(t==null?void 0:t.index)??0);let n;if(this.walletProvider.prepare&&(n=(await this.walletProvider.prepare("sign-typed-data",{typedData:s,from:o.address})).uuid),!await this.confirmation.requestConfirmation({type:"sign-typed-data",chainId:e,from:o.address,typedData:s,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new m(_.USER_REJECTED,"사용자가 타입 데이터 서명을 거부했습니다");try{const a=await this.withPasswordRetry(()=>this.walletProvider.signTypedData(this.userId,e,s,t==null?void 0:t.index,n,o.address));return Q.validateSignatureFormat(a.signature),{chainId:e,signature:a.signature,address:o.address}}catch(a){throw a instanceof m?a:new m(_.SIGNATURE_FAILED,`타입 데이터 서명에 실패했습니다 (${e})`,a)}}async signTypedDataOffchain(e,s){return this.signTypedData(Q.OFFCHAIN_CHAIN_ID,e,s)}async signTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");await this.ensurePasswordForSigning();const o=await this.withResolvedGasAndFee(s,e);let n;this.walletProvider.prepare&&(n=(await this.walletProvider.prepare("sign",{tx:o})).uuid);const i=Je(e);if(!await this.confirmation.requestConfirmation({type:"sign",chainId:e,from:o.from,to:o.to,value:o.value,data:o.data,gasLimit:o.gasLimit,gasPrice:o.gasPrice,maxFeePerGas:o.maxFeePerGas,maxPriorityFeePerGas:o.maxPriorityFeePerGas,nativeSymbol:i.symbol,nativeDecimals:i.decimals,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new m(_.USER_REJECTED,"사용자가 트랜잭션 서명을 거부했습니다");try{const c=await this.withPasswordRetry(()=>this.walletProvider.signTransaction(this.userId,e,o,t==null?void 0:t.index,n));return Q.validateSignedTxFormat(c.signature),{chainId:e,signedTx:c.signature,txHash:c.txHash??""}}catch(c){if(c instanceof m)throw c;const l=c instanceof Error?c.message:String(c);throw new m(_.SIGNATURE_FAILED,`트랜잭션 서명에 실패했습니다 (${e}): ${l}`,c)}}async sendTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(_.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");await this.ensurePasswordForSigning();const o=await this.withResolvedGasAndFee(s,e);let n;this.walletProvider.prepare&&(n=(await this.walletProvider.prepare("send",{tx:o})).uuid);const i=Je(e);if(!await this.confirmation.requestConfirmation({type:"send",chainId:e,from:o.from,to:o.to,value:o.value,data:o.data,gasLimit:o.gasLimit,gasPrice:o.gasPrice,maxFeePerGas:o.maxFeePerGas,maxPriorityFeePerGas:o.maxPriorityFeePerGas,nativeSymbol:i.symbol,nativeDecimals:i.decimals,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new m(_.USER_REJECTED,"사용자가 트랜잭션을 거부했습니다");try{const c=await this.withPasswordRetry(async()=>{if(this.walletProvider.sendTransaction)return(await this.walletProvider.sendTransaction(this.userId,e,o,n)).txHash;const l=await this.walletProvider.signTransaction(this.userId,e,o,t==null?void 0:t.index,n);return l.txHash??l.signature});return{chainId:e,txHash:c,status:"pending"}}catch(c){if(c instanceof m)throw c;const l=c instanceof Error?c.message:String(c);throw new m(_.TRANSACTION_FAILED,`트랜잭션 전송에 실패했습니다 (${e}): ${l}`,c)}}async getTransactionReceipt(e,s){try{return await this.jsonRpc.call("eth_getTransactionReceipt",[e],s)??null}catch{return null}}async waitForTxAndGetReceipt(e,s,t={}){const o=t.intervalMs??Xs,n=Js,i=t.timeoutMs??It,a=Date.now()+i;let c=o;for(;Date.now()<a;){const l=await this.getTransactionReceipt(e,s);if(l)return l;await new Promise(d=>setTimeout(d,c)),c=Math.min(c*2,n)}throw new m(_.UNKNOWN_ERROR,`트랜잭션 영수증 조회 시간이 초과되었습니다 (${e})`)}async sendTransactionWithWaitForReceipt(e,s,t={}){var b,y;const{intervalMs:o,timeoutMs:n,...i}=t,{txHash:a}=await this.sendTransaction(e,s,i),c=o??((b=this._config.receiptPolling)==null?void 0:b.intervalMs)??Zs,l=n??((y=this._config.receiptPolling)==null?void 0:y.timeoutMs)??It,d=Je(e),u=s.from??"";let g,f;const p=this.waitForTxAndGetReceipt(a,e,{intervalMs:c,timeoutMs:l}).then(E=>{g=E;const D=BigInt(E.gasUsed)*BigInt(E.effectiveGasPrice),U=s.value?BigInt(s.value):0n,M=Q.formatTxAmount(s.value,d.symbol,d.decimals),B=Q.formatTxAmount("0x"+D.toString(16),d.symbol,d.decimals),K=Q.formatTxAmount("0x"+(U+D).toString(16),d.symbol,d.decimals);return{chainId:e,txHash:a,from:E.from,to:E.to??s.to,amount:M,fees:B,total:K,nativeSymbol:d.symbol,status:E.status==="0x1"?"success":"reverted"}}).catch(E=>(f=E instanceof Error?E:new Error(String(E)),{chainId:e,txHash:a,from:u,to:s.to,amount:Q.formatTxAmount(s.value,d.symbol,d.decimals),nativeSymbol:d.symbol,status:"timeout"}));if(await this.confirmation.showTransactionProgress({chainId:e,txHash:a,from:u,to:s.to},p),f)throw f;return{chainId:e,txHash:a,receipt:g}}setPassword(e){this.passwordStore.set(e)}clearPassword(){this.passwordStore.clear()}hasPassword(){return this.passwordStore.has()}async changePassword(e,s){this.ensureAuthenticated();const t=this.walletProvider;if(typeof t.changePassword!="function")throw new m(_.NOT_IMPLEMENTED,"changePassword가 구현되어 있지 않습니다");this.passwordStore.set(e);try{await t.changePassword(e,s),this.passwordStore.set(s),h.log("[CROSSx] 비밀번호 변경 완료")}catch(o){throw o instanceof m?o:new m(_.UNKNOWN_ERROR,"비밀번호 변경에 실패했습니다",o)}}async getGasPrice(e){this.ensureAuthenticated();try{return await this.walletRpc("eth_gasPrice",[],e)}catch(s){const t=s instanceof Error?s.message:String(s);throw new m(_.GAS_ESTIMATION_FAILED,`가스 가격 조회에 실패했습니다 (${e}): ${t}`,s)}}async estimateGas(e,s){this.ensureAuthenticated();const t={};e.from&&(t.from=e.from),e.to&&(t.to=e.to),e.value&&(t.value=e.value),e.data&&(t.data=e.data),e.gasPrice&&(t.gasPrice=e.gasPrice),e.maxFeePerGas&&(t.maxFeePerGas=e.maxFeePerGas),e.maxPriorityFeePerGas&&(t.maxPriorityFeePerGas=e.maxPriorityFeePerGas),e.nonce!==void 0&&(t.nonce="0x"+e.nonce.toString(16));try{return await this.walletRpc("eth_estimateGas",[t],s)}catch(o){const n=o instanceof Error?o.message:String(o);throw new m(_.GAS_ESTIMATION_FAILED,`가스 추정에 실패했습니다 (${s}): ${n}`,o)}}async getBaseFeePerGas(e){this.ensureAuthenticated();try{const s=await this.walletRpc("eth_getBlockByNumber",["latest",!1],e);return(s==null?void 0:s.baseFeePerGas)??null}catch(s){const t=s instanceof Error?s.message:String(s);throw new m(_.GAS_ESTIMATION_FAILED,`baseFeePerGas 조회에 실패했습니다 (${e}): ${t}`,s)}}async getMaxPriorityFeePerGas(e){this.ensureAuthenticated();try{return await this.walletRpc("eth_maxPriorityFeePerGas",[],e)}catch(s){const t=s instanceof Error?s.message:String(s);throw new m(_.GAS_ESTIMATION_FAILED,`maxPriorityFeePerGas 조회에 실패했습니다 (${e}): ${t}`,s)}}async getNonce(e){this.ensureAuthenticated();const s=this.address;if(!s)return 0;try{const t=await this.jsonRpc.call("eth_getTransactionCount",[s,"pending"],e);return parseInt(t??"0x0",16)}catch(t){if(t instanceof m)throw t;const o=t instanceof Error?t.message:String(t);throw new m(_.UNKNOWN_ERROR,`Nonce 조회에 실패했습니다: ${o}`,t)}}async getBalance(e){this.ensureAuthenticated();const s=this.address;if(!s)return{wei:"0x0",formatted:"0",chainId:e};try{const o=await this.jsonRpc.call("eth_getBalance",[s,"latest"],e)??"0x0";return{wei:o,formatted:Q.formatWei(o),chainId:e}}catch(t){if(t instanceof m)throw t;const o=t instanceof Error?t.message:String(t);throw new m(_.UNKNOWN_ERROR,`잔액 조회에 실패했습니다 (${e}): ${o}`,t)}}static formatWei(e){if(!e||e==="0x0"||e==="0x")return"0";try{const s=BigInt(e);if(s===0n)return"0";const t=10n**BigInt(kt),o=s/t,i=(s%t).toString().padStart(kt,"0").replace(/0+$/,"").slice(0,Ct);return i?`${o}.${i}`:`${o}`}catch{return"?"}}getProvider(e){return this.ensureAuthenticated(),new Xt(this,e)}async walletRpc(e,s,t){this.ensureAuthenticated();try{return await this.jsonRpc.call(e,s,t)}catch(o){if(o instanceof m)throw o;const n=o instanceof Error?o.message:String(o);throw new m(_.UNKNOWN_ERROR,`walletRpc 호출에 실패했습니다 [${e}] (${t}): ${n}`,o)}}static formatTxAmount(e,s,t){if(!(!e||e==="0x"||e==="0x0"))try{const o=BigInt(e);if(o===0n)return;const n=10n**BigInt(t),i=o/n,c=(o%n).toString().padStart(t,"0").slice(0,Ct).replace(/0+$/,"");return`${c?`${i}.${c}`:`${i}`} ${s}`}catch{return}}async handleMigrationFlow(e){var a,c;h.log('[CROSSx][Migration Phase 3] "Wallet Found" 팝업 표시');const s=await this.confirmation.showMigrationFoundPrompt();if(h.log("[CROSSx][Migration Phase 3] 사용자 선택:",s),s==="skip")return h.log("[CROSSx][Migration Phase 3] 사용자가 마이그레이션을 건너뜀 → 종료"),null;let t,o=0,n=5,i=null;for(;;){o++,h.log(`[CROSSx][Migration Phase 4] PIN 입력 팝업 표시 (시도 #${o}/${n})`,t?`— 이전 메시지: ${t}`:"");const l=await this.confirmation.showPinInputPrompt({errorMessage:t,attemptCount:o>1?o-1:void 0,maxAttempts:n});if(l===null)return h.log("[CROSSx][Migration Phase 4] 사용자가 PIN 입력을 취소함 → 종료"),null;h.log(`[CROSSx][Migration Phase 4] PIN 입력 완료 (${l.length}자리) — verify-pin API 호출`),t=void 0;try{const d=await((c=(a=this.walletProvider).verifyPin)==null?void 0:c.call(a,l,e));if(!d){h.log("[CROSSx][Migration Phase 4] verifyPin 미지원 — PIN 검증 생략"),i=l;break}if(d.valid){h.log("[CROSSx][Migration Phase 4] PIN 검증 성공"),i=l;break}const u=d.pinStatus;if(n=u.maxAttempts,o=n-u.remainingAttempts,u.remainingAttempts===0&&u.lockExpiresAt){const g=u.lockExpiresAt*1e3,f=Math.max(1,Math.round((g-Date.now())/1e3)),p=f<=1800?"Too many failed attempts. Please try again in 30 minutes.":"Too many failed attempts. Please try again in 24 hours.";h.warn(`[CROSSx][Migration Phase 4] verify-pin 잠금 — ${f}초, 메시지: ${p}`),await this.confirmation.showPinLockedPrompt(f,p),o=0,t="Your account lock has been lifted. You may try again."}else h.warn(`[CROSSx][Migration Phase 4] PIN 불일치 (시도 ${o}/${n})`),t="Incorrect PIN."}catch(d){if(!(d instanceof m))throw d;if(d.code===_.MIGRATION_PIN_LOCKED){const u=d.details;if(n=(u==null?void 0:u.maxAttempts)??5,(u==null?void 0:u.permanent)===!0)return h.warn("[CROSSx][Migration Phase 4] PIN 영구 잠금 (verify-pin)"),await this.confirmation.showPinLockedPrompt(0,"Your account has been permanently locked due to too many failed attempts."),null;const g=((u==null?void 0:u.lockExpiresAt)??0)*1e3,f=Math.max(1,Math.round((g-Date.now())/1e3)),p=f<=1800?"Too many failed attempts. Please try again in 30 minutes.":"Too many failed attempts. Please try again in 24 hours.";h.warn(`[CROSSx][Migration Phase 4] verify-pin 이미 잠금 — ${f}초`),await this.confirmation.showPinLockedPrompt(f,p),o=0,t="Your account lock has been lifted. You may try again."}else throw h.error("[CROSSx][Migration Phase 4] verify-pin 실패 (복구 불가):",d),d}}h.log("[CROSSx][Migration Phase 5] PIN 검증 완료 — 비밀번호 설정 및 마이그레이션 진행");try{await this.ensurePasswordSetup();const l=await this.migrateWalletUseCase.execute(i,e);return h.log("[CROSSx][Migration Phase 5] 마이그레이션 성공 — address:",l.address),l}catch(l){if(l instanceof m&&l.code===_.MIGRATION_FAILED)return h.warn("[CROSSx][Migration Phase 5] migrate PIN 불일치 (경합) — 처음부터 재시도"),this.handleMigrationFlow(e);throw h.error("[CROSSx][Migration Phase 5] 마이그레이션 실패 (복구 불가):",l),l}}async withResolvedGasAndFee(e,s){const t=l=>!(l!=null&&l.trim()),o=e.nonce===void 0||e.nonce===null,n=t(e.gasLimit),i=t(e.gasPrice)&&t(e.maxFeePerGas),a=!t(e.maxFeePerGas)&&t(e.maxPriorityFeePerGas);if(!o&&!n&&!i&&!a)return e;const c={...e};if(o){const l=c.from??this.address;if(l){h.log("[CROSSx] nonce 비어있음 → eth_getTransactionCount 호출 (from:",l,")");const d=await this.jsonRpc.call("eth_getTransactionCount",[l,"pending"],s);c.nonce=parseInt(d??"0x0",16),h.log("[CROSSx] nonce 결과:",c.nonce)}}if(n&&(h.log("[CROSSx] gasLimit 비어있음 → eth_estimateGas 호출"),c.gasLimit=await this.estimateGas(e,s),h.log("[CROSSx] estimateGas 결과:",c.gasLimit)),i){h.log("[CROSSx] gasPrice & maxFeePerGas 비어있음 → baseFee 조회로 Dynamic/Legacy 판별");const l=await this.getBaseFeePerGas(s);if(l){const d=At;c.maxFeePerGas="0x"+(BigInt(l)+BigInt(d)).toString(16),c.maxPriorityFeePerGas=d,h.log("[CROSSx] Dynamic 체인 감지 — baseFee:",l,"maxFeePerGas:",c.maxFeePerGas,"maxPriorityFeePerGas: 1 Gwei")}else c.gasPrice=Qs,h.log("[CROSSx] Legacy 체인 감지 — gasPrice: 2 Gwei")}return!i&&a&&(c.maxPriorityFeePerGas=At,h.log("[CROSSx] maxPriorityFeePerGas 비어있음 → 1 Gwei 기본값 적용")),c}static validateTypedDataChainId(e,s){const t=Q.extractDomainChainId(s);if(e==="0"){if(t!==void 0&&t!==0)throw new m(_.TYPED_DATA_CHAIN_ID_MISMATCH,`오프체인 서명(chainId=0)에서는 typedData.domain.chainId가 없거나 0이어야 합니다. 현재 값: ${t}`);return}const o=e.match(/^eip155:(\d+)$/);if(o){const n=Number(o[1]);if(t===void 0)throw new m(_.TYPED_DATA_CHAIN_ID_MISMATCH,`온체인 서명(${e})에서는 typedData.domain.chainId가 반드시 있어야 합니다`);if(t!==n)throw new m(_.TYPED_DATA_CHAIN_ID_MISMATCH,`typedData.domain.chainId (${t})가 chainId (${e}, 예상값: ${n})와 일치하지 않습니다`)}}static extractDomainChainId(e){if(e==null||typeof e!="object")return;const s=e.domain;if(s==null||typeof s!="object")return;const t=s.chainId;if(t==null)return;const o=Number(t);return Number.isFinite(o)?o:void 0}static validateSignatureFormat(e){const s=e.startsWith("0x")?e.slice(2):e;if(!/^[0-9a-fA-F]+$/.test(s))throw new m(_.SIGNATURE_FAILED,"유효하지 않은 서명: 올바른 hex 문자열이 아닙니다");if(s.length!==Tt)throw new m(_.SIGNATURE_FAILED,`서명 길이가 유효하지 않습니다: ${Tt} hex 문자(65 바이트) 예상, 현재 ${s.length}`)}static validateSignedTxFormat(e){const s=e.startsWith("0x")?e.slice(2):e;if(!/^[0-9a-fA-F]+$/.test(s))throw new m(_.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 올바른 hex 문자열이 아닙니다");if(s.length<2)throw new m(_.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 너무 짧습니다")}verifySignatureSigner(e,s,t){if(this.crypto.recoverPersonalSignSigner)try{const o=this.crypto.recoverPersonalSignSigner(e,s);if(o.toLowerCase()!==t.toLowerCase())throw h.error("[CROSSx] 서명 검증 실패: 서명자 주소 불일치",{expected:t,recovered:o}),new m(_.SIGNATURE_SIGNER_MISMATCH,`서명자 주소가 일치하지 않습니다: 예상 ${t}, 복원된 주소 ${o}`);h.log("[CROSSx] 서명 ecrecover 검증 성공")}catch(o){if(o instanceof m)throw o;h.warn("[CROSSx] ecrecover 검증 중 예외 (무시):",o)}}applyAuthResult(e){var s,t,o,n;this.authenticated=e.success,this.userId=((s=e.user)==null?void 0:s.id)??null,this.address=e.address??null,this.activeWalletIndex=0,this.userEmail=((t=e.user)==null?void 0:t.email)??null,this.providerSub=((o=e.user)==null?void 0:o.providerSub)??null,this.loginType=Q.normalizeLoginType((n=e.user)==null?void 0:n.signInProvider),this.tokenSignatureVerified=e.tokenSignatureVerified??!1,this.emit("authChanged",{isAuthenticated:this.authenticated,address:this.address,userId:this.userId})}clearAuthState(){this.authenticated=!1,this.userId=null,this.address=null,this.activeWalletIndex=0,this.userEmail=null,this.providerSub=null,this.loginType=null,this.tokenSignatureVerified=!1,this.passwordStore.clear(),this.emit("authChanged",{isAuthenticated:!1,address:null,userId:null})}static normalizeLoginType(e){return e?e.includes("google")?"google":e.includes("apple")?"apple":e:null}async ensurePasswordSetup(){if(this.passwordStore.has())return;const e=await this.confirmation.showPasswordSetupPrompt();if(!e)throw new m(_.PASSWORD_CANCELLED,"사용자가 비밀번호 설정을 취소했습니다");this.passwordStore.set(e),h.log("[CROSSx] 비밀번호 설정 완료 (메모리 캐시)")}async ensurePasswordForSigning(e){if(this.passwordStore.has()&&!e)return;e&&this.passwordStore.clear();const s=await this.confirmation.showPasswordInputPrompt({errorMessage:e});if(!s)throw new m(_.PASSWORD_CANCELLED,"사용자가 비밀번호 입력을 취소했습니다");this.passwordStore.set(s),h.log("[CROSSx] 비밀번호 입력 완료 (메모리 캐시)")}async ensureVerifiedPassword(e){if(e)this.passwordStore.clear();else if(this.passwordStore.has())return;if(this._verifyPasswordMutex&&!e){h.log("[CROSSx] ensureVerifiedPassword: 진행 중인 검증 대기"),await this._verifyPasswordMutex;return}let s,t;this._verifyPasswordMutex=new Promise((o,n)=>{s=o,t=n});try{if(typeof this.walletProvider.verifyPassword!="function"){const n=await this.confirmation.showPasswordInputPrompt({verifyMode:!0,errorMessage:e});if(!n)throw new m(_.PASSWORD_CANCELLED,"사용자가 비밀번호 입력을 취소했습니다");this.passwordStore.set(n),h.log("[CROSSx] 비밀번호 캐시 완료 (verifyPassword 미지원, 로컬 전용)"),s();return}if(!await this.confirmation.showPasswordInputPrompt({verifyMode:!0,errorMessage:e,onSubmit:async n=>{this.passwordStore.set(n);try{return await this.walletProvider.verifyPassword(n)?(h.log("[CROSSx] 비밀번호 서버 검증 완료 (verify-password)"),{ok:!0}):(this.passwordStore.clear(),{ok:!1,error:"Incorrect password. Please try again."})}catch(i){if(this.passwordStore.clear(),i instanceof m&&i.code===_.PASSWORD_WRONG)return{ok:!1,error:"Incorrect password. Please try again."};throw i}}}))throw new m(_.PASSWORD_CANCELLED,"사용자가 비밀번호 입력을 취소했습니다");s()}catch(o){throw t(o),o}finally{this._verifyPasswordMutex=null}}async loadWalletAfterAuth(e){if(!this.userId)return;const s=await this.fetchWalletStatus();if(h.log("[CROSSx] loadWalletAfterAuth 지갑 상태:",s),s!=="exists")return;const t=await this.walletProvider.getAddresses(this.userId);if(t.length>0){const n=e!==void 0?t.find(i=>i.index===e)??t[0]:t[0];this.address=n.address,this.activeWalletIndex=n.index,h.log("[CROSSx] 캐시된 주소 로드 완료 (비밀번호 불필요):",this.address),this.emit("addressChanged",{address:n.address,index:n.index});return}h.log("[CROSSx] 주소 캐시 없음 — 비밀번호 확인 후 address(0) 조회"),await this.ensureVerifiedPassword();const o=await this.walletProvider.getAddress(this.userId,0);this.address=o.address,this.activeWalletIndex=0,h.log("[CROSSx] 세션 복원 후 지갑 주소 로드 완료:",this.address),this.emit("addressChanged",{address:o.address,index:0})}async withPasswordRetry(e){try{return await e()}catch(s){if(s instanceof m&&s.code===_.PASSWORD_WRONG)return h.warn("[CROSSx] 비밀번호 불일치 — 서버 검증 후 재시도"),await this.ensureVerifiedPassword("Incorrect password. Please enter your current password."),await e();throw s}}ensureInitialized(){if(!this.initialized)throw new m(_.AUTH_NOT_INITIALIZED,"SDK가 초기화되지 않았습니다. initialize()를 먼저 호출하세요.")}ensureAuthenticated(){if(this.ensureInitialized(),!this.authenticated)throw new m(_.AUTH_NOT_AUTHENTICATED,"인증되지 않은 상태입니다. signIn()을 먼저 호출하세요.")}dispose(){this.clearAuthState(),this.tokenStore.clear(),this.passwordStore.clear(),this.initialized=!1,this.removeAllListeners(),St(null)}};Q.OFFCHAIN_CHAIN_ID="0";let Ge=Q;class sr{constructor(){this.prefix="crossx_"}async set(e,s){try{const t=JSON.stringify(s);localStorage.setItem(this.prefix+e,t)}catch(t){throw h.error("Storage set error:",t),t}}async get(e){try{const s=localStorage.getItem(this.prefix+e);return s?JSON.parse(s):null}catch(s){return h.error("Storage get error:",s),null}}async remove(e){try{localStorage.removeItem(this.prefix+e)}catch(s){throw h.error("Storage remove error:",s),s}}async clear(){try{Object.keys(localStorage).forEach(s=>{s.startsWith(this.prefix)&&localStorage.removeItem(s)})}catch(e){throw h.error("Storage clear error:",e),e}}}const rr="crossx-sdk",or=1,Se="data",De="keys",Rt="aes-primary",nr=12;class Pt{constructor(){this.db=null,this.cryptoKey=null,this.initPromise=null}async ensureReady(){this.db&&this.cryptoKey||(this.initPromise||(this.initPromise=this.init()),await this.initPromise)}openDB(){return new Promise((e,s)=>{const t=indexedDB.open(rr,or);t.onupgradeneeded=()=>{const o=t.result;o.objectStoreNames.contains(Se)||o.createObjectStore(Se),o.objectStoreNames.contains(De)||o.createObjectStore(De)},t.onsuccess=()=>e(t.result),t.onerror=()=>s(t.error)})}idbGet(e,s){return new Promise((t,o)=>{const i=this.db.transaction(e,"readonly").objectStore(e).get(s);i.onsuccess=()=>t(i.result),i.onerror=()=>o(i.error)})}idbPut(e,s,t){return new Promise((o,n)=>{const a=this.db.transaction(e,"readwrite").objectStore(e).put(t,s);a.onsuccess=()=>o(),a.onerror=()=>n(a.error)})}idbDelete(e,s){return new Promise((t,o)=>{const i=this.db.transaction(e,"readwrite").objectStore(e).delete(s);i.onsuccess=()=>t(),i.onerror=()=>o(i.error)})}idbClear(e){return new Promise((s,t)=>{const n=this.db.transaction(e,"readwrite").objectStore(e).clear();n.onsuccess=()=>s(),n.onerror=()=>t(n.error)})}async init(){this.db=await this.openDB();const e=await this.idbGet(De,Rt);if(e){this.cryptoKey=e;return}this.cryptoKey=await crypto.subtle.generateKey({name:"AES-GCM",length:256},!1,["encrypt","decrypt"]),await this.idbPut(De,Rt,this.cryptoKey)}async encrypt(e){const s=new Uint8Array(nr);crypto.getRandomValues(s);const t=new TextEncoder().encode(e),o=await crypto.subtle.encrypt({name:"AES-GCM",iv:s},this.cryptoKey,t);return{iv:s,ciphertext:o}}async decrypt(e){const s=new Uint8Array(e.iv),t=await crypto.subtle.decrypt({name:"AES-GCM",iv:s},this.cryptoKey,e.ciphertext);return new TextDecoder().decode(t)}async set(e,s){try{await this.ensureReady();const t=JSON.stringify(s),o=await this.encrypt(t);await this.idbPut(Se,e,o)}catch(t){throw h.error("[CROSSx] IndexedDB set error:",t),t}}async get(e){try{await this.ensureReady();const s=await this.idbGet(Se,e);if(!s)return null;const t=await this.decrypt(s);return JSON.parse(t)}catch(s){return h.error("[CROSSx] IndexedDB get error:",s),null}}async remove(e){try{await this.ensureReady(),await this.idbDelete(Se,e)}catch(s){throw h.error("[CROSSx] IndexedDB remove error:",s),s}}async clear(){try{await this.ensureReady(),await this.idbClear(Se)}catch(e){throw h.error("[CROSSx] IndexedDB clear error:",e),e}}static isAvailable(){return typeof indexedDB<"u"&&typeof crypto<"u"&&typeof crypto.subtle<"u"}}/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */function dt(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function pe(r,e=""){if(!Number.isSafeInteger(r)||r<0){const s=e&&`"${e}" `;throw new Error(`${s}expected integer >= 0, got ${r}`)}}function F(r,e,s=""){const t=dt(r),o=r==null?void 0:r.length,n=e!==void 0;if(!t||n&&o!==e){const i=s&&`"${s}" `,a=n?` of length ${e}`:"",c=t?`length=${o}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function es(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");pe(r.outputLen),pe(r.blockLen)}function Ae(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function ts(r,e){F(r,void 0,"digestInto() output");const s=e.outputLen;if(r.length<s)throw new Error('"digestInto() output" expected to be of length >='+s)}function ir(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function Te(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function et(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function ae(r,e){return r<<32-e|r>>>e}const ar=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function cr(r){return r<<24&4278190080|r<<8&16711680|r>>>8&65280|r>>>24&255}function lr(r){for(let e=0;e<r.length;e++)r[e]=cr(r[e]);return r}const Ot=ar?r=>r:lr,ss=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",dr=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Oe(r){if(F(r),ss)return r.toHex();let e="";for(let s=0;s<r.length;s++)e+=dr[r[s]];return e}const de={_0:48,_9:57,A:65,F:70,a:97,f:102};function Nt(r){if(r>=de._0&&r<=de._9)return r-de._0;if(r>=de.A&&r<=de.F)return r-(de.A-10);if(r>=de.a&&r<=de.f)return r-(de.a-10)}function We(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ss)return Uint8Array.fromHex(r);const e=r.length,s=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);const t=new Uint8Array(s);for(let o=0,n=0;o<s;o++,n+=2){const i=Nt(r.charCodeAt(n)),a=Nt(r.charCodeAt(n+1));if(i===void 0||a===void 0){const c=r[n]+r[n+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+n)}t[o]=i*16+a}return t}function we(...r){let e=0;for(let t=0;t<r.length;t++){const o=r[t];F(o),e+=o.length}const s=new Uint8Array(e);for(let t=0,o=0;t<r.length;t++){const n=r[t];s.set(n,o),o+=n.length}return s}function rs(r,e={}){const s=(o,n)=>r(n).update(o).digest(),t=r(void 0);return s.outputLen=t.outputLen,s.blockLen=t.blockLen,s.create=o=>r(o),Object.assign(s,e),Object.freeze(s)}function os(r=32){const e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof(e==null?void 0:e.getRandomValues)!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(r))}const ur=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function hr(r,e,s){return r&e^~r&s}function pr(r,e,s){return r&e^r&s^e&s}class fr{constructor(e,s,t,o){S(this,"blockLen");S(this,"outputLen");S(this,"padOffset");S(this,"isLE");S(this,"buffer");S(this,"view");S(this,"finished",!1);S(this,"length",0);S(this,"pos",0);S(this,"destroyed",!1);this.blockLen=e,this.outputLen=s,this.padOffset=t,this.isLE=o,this.buffer=new Uint8Array(e),this.view=et(this.buffer)}update(e){Ae(this),F(e);const{view:s,buffer:t,blockLen:o}=this,n=e.length;for(let i=0;i<n;){const a=Math.min(o-this.pos,n-i);if(a===o){const c=et(e);for(;o<=n-i;i+=o)this.process(c,i);continue}t.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(s,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Ae(this),ts(e,this),this.finished=!0;const{buffer:s,view:t,blockLen:o,isLE:n}=this;let{pos:i}=this;s[i++]=128,Te(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(t,0),i=0);for(let u=i;u<o;u++)s[u]=0;t.setBigUint64(o-8,BigInt(this.length*8),n),this.process(t,0);const a=et(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");const l=c/4,d=this.get();if(l>d.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,d[u],n)}digest(){const{buffer:e,outputLen:s}=this;this.digestInto(e);const t=e.slice(0,s);return this.destroy(),t}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:s,buffer:t,length:o,finished:n,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=n,e.length=o,e.pos=a,o%s&&e.buffer.set(t),e}clone(){return this._cloneInto()}}const _e=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Me=BigInt(2**32-1),Lt=BigInt(32);function _r(r,e=!1){return e?{h:Number(r&Me),l:Number(r>>Lt&Me)}:{h:Number(r>>Lt&Me)|0,l:Number(r&Me)|0}}function gr(r,e=!1){const s=r.length;let t=new Uint32Array(s),o=new Uint32Array(s);for(let n=0;n<s;n++){const{h:i,l:a}=_r(r[n],e);[t[n],o[n]]=[i,a]}return[t,o]}const xr=(r,e,s)=>r<<s|e>>>32-s,wr=(r,e,s)=>e<<s|r>>>32-s,mr=(r,e,s)=>e<<s-32|r>>>64-s,yr=(r,e,s)=>r<<s-32|e>>>64-s,br=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]),ge=new Uint32Array(64);class vr extends fr{constructor(e){super(64,e,8,!1)}get(){const{A:e,B:s,C:t,D:o,E:n,F:i,G:a,H:c}=this;return[e,s,t,o,n,i,a,c]}set(e,s,t,o,n,i,a,c){this.A=e|0,this.B=s|0,this.C=t|0,this.D=o|0,this.E=n|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,s){for(let u=0;u<16;u++,s+=4)ge[u]=e.getUint32(s,!1);for(let u=16;u<64;u++){const g=ge[u-15],f=ge[u-2],p=ae(g,7)^ae(g,18)^g>>>3,b=ae(f,17)^ae(f,19)^f>>>10;ge[u]=b+ge[u-7]+p+ge[u-16]|0}let{A:t,B:o,C:n,D:i,E:a,F:c,G:l,H:d}=this;for(let u=0;u<64;u++){const g=ae(a,6)^ae(a,11)^ae(a,25),f=d+g+hr(a,c,l)+br[u]+ge[u]|0,b=(ae(t,2)^ae(t,13)^ae(t,22))+pr(t,o,n)|0;d=l,l=c,c=a,a=i+f|0,i=n,n=o,o=t,t=f+b|0}t=t+this.A|0,o=o+this.B|0,n=n+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,d=d+this.H|0,this.set(t,o,n,i,a,c,l,d)}roundClean(){Te(ge)}destroy(){this.set(0,0,0,0,0,0,0,0),Te(this.buffer)}}class Sr extends vr{constructor(){super(32);S(this,"A",_e[0]|0);S(this,"B",_e[1]|0);S(this,"C",_e[2]|0);S(this,"D",_e[3]|0);S(this,"E",_e[4]|0);S(this,"F",_e[5]|0);S(this,"G",_e[6]|0);S(this,"H",_e[7]|0)}}const Er=rs(()=>new Sr,ur(1));/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const ut=BigInt(0),it=BigInt(1);function qe(r,e=""){if(typeof r!="boolean"){const s=e&&`"${e}" `;throw new Error(s+"expected boolean, got type="+typeof r)}return r}function ns(r){if(typeof r=="bigint"){if(!He(r))throw new Error("positive bigint expected, got "+r)}else pe(r);return r}function $e(r){const e=ns(r).toString(16);return e.length&1?"0"+e:e}function is(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ut:BigInt("0x"+r)}function Ye(r){return is(Oe(r))}function as(r){return is(Oe(Ir(F(r)).reverse()))}function ht(r,e){pe(e),r=ns(r);const s=We(r.toString(16).padStart(e*2,"0"));if(s.length!==e)throw new Error("number too large");return s}function cs(r,e){return ht(r,e).reverse()}function Ir(r){return Uint8Array.from(r)}const He=r=>typeof r=="bigint"&&ut<=r;function Ar(r,e,s){return He(r)&&He(e)&&He(s)&&e<=r&&r<s}function Tr(r,e,s,t){if(!Ar(e,s,t))throw new Error("expected valid "+r+": "+s+" <= n < "+t+", got "+e)}function Cr(r){let e;for(e=0;r>ut;r>>=it,e+=1);return e}const pt=r=>(it<<BigInt(r))-it;function kr(r,e,s){if(pe(r,"hashLen"),pe(e,"qByteLen"),typeof s!="function")throw new Error("hmacFn must be a function");const t=y=>new Uint8Array(y),o=Uint8Array.of(),n=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3;let c=t(r),l=t(r),d=0;const u=()=>{c.fill(1),l.fill(0),d=0},g=(...y)=>s(l,we(c,...y)),f=(y=o)=>{l=g(n,y),c=g(),y.length!==0&&(l=g(i,y),c=g())},p=()=>{if(d++>=a)throw new Error("drbg: tried max amount of iterations");let y=0;const E=[];for(;y<e;){c=g();const D=c.slice();E.push(D),y+=c.length}return we(...E)};return(y,E)=>{u(),f(y);let D;for(;!(D=E(p()));)f();return u(),D}}function ft(r,e={},s={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function t(n,i,a){const c=r[n];if(a&&c===void 0)return;const l=typeof c;if(l!==i||c===null)throw new Error(`param "${n}" is invalid: expected ${i}, got ${l}`)}const o=(n,i)=>Object.entries(n).forEach(([a,c])=>t(a,c,i));o(e,!1),o(s,!0)}function Dt(r){const e=new WeakMap;return(s,...t)=>{const o=e.get(s);if(o!==void 0)return o;const n=r(s,...t);return e.set(s,n),n}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const ee=BigInt(0),Z=BigInt(1),be=BigInt(2),ls=BigInt(3),ds=BigInt(4),us=BigInt(5),Rr=BigInt(7),hs=BigInt(8),Pr=BigInt(9),ps=BigInt(16);function ne(r,e){const s=r%e;return s>=ee?s:e+s}function oe(r,e,s){let t=r;for(;e-- >ee;)t*=t,t%=s;return t}function Mt(r,e){if(r===ee)throw new Error("invert: expected non-zero number");if(e<=ee)throw new Error("invert: expected positive modulus, got "+e);let s=ne(r,e),t=e,o=ee,n=Z;for(;s!==ee;){const a=t/s,c=t%s,l=o-n*a;t=s,s=c,o=n,n=l}if(t!==Z)throw new Error("invert: does not exist");return ne(o,e)}function _t(r,e,s){if(!r.eql(r.sqr(e),s))throw new Error("Cannot find square root")}function fs(r,e){const s=(r.ORDER+Z)/ds,t=r.pow(e,s);return _t(r,t,e),t}function Or(r,e){const s=(r.ORDER-us)/hs,t=r.mul(e,be),o=r.pow(t,s),n=r.mul(e,o),i=r.mul(r.mul(n,be),o),a=r.mul(n,r.sub(i,r.ONE));return _t(r,a,e),a}function Nr(r){const e=Ze(r),s=_s(r),t=s(e,e.neg(e.ONE)),o=s(e,t),n=s(e,e.neg(t)),i=(r+Rr)/ps;return(a,c)=>{let l=a.pow(c,i),d=a.mul(l,t);const u=a.mul(l,o),g=a.mul(l,n),f=a.eql(a.sqr(d),c),p=a.eql(a.sqr(u),c);l=a.cmov(l,d,f),d=a.cmov(g,u,p);const b=a.eql(a.sqr(d),c),y=a.cmov(l,d,b);return _t(a,y,c),y}}function _s(r){if(r<ls)throw new Error("sqrt is not defined for small field");let e=r-Z,s=0;for(;e%be===ee;)e/=be,s++;let t=be;const o=Ze(r);for(;$t(o,t)===1;)if(t++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(s===1)return fs;let n=o.pow(t,e);const i=(e+Z)/be;return function(c,l){if(c.is0(l))return l;if($t(c,l)!==1)throw new Error("Cannot find square root");let d=s,u=c.mul(c.ONE,n),g=c.pow(l,e),f=c.pow(l,i);for(;!c.eql(g,c.ONE);){if(c.is0(g))return c.ZERO;let p=1,b=c.sqr(g);for(;!c.eql(b,c.ONE);)if(p++,b=c.sqr(b),p===d)throw new Error("Cannot find square root");const y=Z<<BigInt(d-p-1),E=c.pow(u,y);d=p,u=c.sqr(E),g=c.mul(g,u),f=c.mul(f,E)}return f}}function Lr(r){return r%ds===ls?fs:r%hs===us?Or:r%ps===Pr?Nr(r):_s(r)}const Dr=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Mr(r){const e={ORDER:"bigint",BYTES:"number",BITS:"number"},s=Dr.reduce((t,o)=>(t[o]="function",t),e);return ft(r,s),r}function $r(r,e,s){if(s<ee)throw new Error("invalid exponent, negatives unsupported");if(s===ee)return r.ONE;if(s===Z)return e;let t=r.ONE,o=e;for(;s>ee;)s&Z&&(t=r.mul(t,o)),o=r.sqr(o),s>>=Z;return t}function gs(r,e,s=!1){const t=new Array(e.length).fill(s?r.ZERO:void 0),o=e.reduce((i,a,c)=>r.is0(a)?i:(t[c]=i,r.mul(i,a)),r.ONE),n=r.inv(o);return e.reduceRight((i,a,c)=>r.is0(a)?i:(t[c]=r.mul(i,t[c]),r.mul(i,a)),n),t}function $t(r,e){const s=(r.ORDER-Z)/be,t=r.pow(e,s),o=r.eql(t,r.ONE),n=r.eql(t,r.ZERO),i=r.eql(t,r.neg(r.ONE));if(!o&&!n&&!i)throw new Error("invalid Legendre symbol result");return o?1:n?0:-1}function Br(r,e){e!==void 0&&pe(e);const s=e!==void 0?e:r.toString(2).length,t=Math.ceil(s/8);return{nBitLength:s,nByteLength:t}}class Ur{constructor(e,s={}){S(this,"ORDER");S(this,"BITS");S(this,"BYTES");S(this,"isLE");S(this,"ZERO",ee);S(this,"ONE",Z);S(this,"_lengths");S(this,"_sqrt");S(this,"_mod");var i;if(e<=ee)throw new Error("invalid field: expected ORDER > 0, got "+e);let t;this.isLE=!1,s!=null&&typeof s=="object"&&(typeof s.BITS=="number"&&(t=s.BITS),typeof s.sqrt=="function"&&(this.sqrt=s.sqrt),typeof s.isLE=="boolean"&&(this.isLE=s.isLE),s.allowedLengths&&(this._lengths=(i=s.allowedLengths)==null?void 0:i.slice()),typeof s.modFromBytes=="boolean"&&(this._mod=s.modFromBytes));const{nBitLength:o,nByteLength:n}=Br(e,t);if(n>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=o,this.BYTES=n,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return ne(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return ee<=e&&e<this.ORDER}is0(e){return e===ee}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&Z)===Z}neg(e){return ne(-e,this.ORDER)}eql(e,s){return e===s}sqr(e){return ne(e*e,this.ORDER)}add(e,s){return ne(e+s,this.ORDER)}sub(e,s){return ne(e-s,this.ORDER)}mul(e,s){return ne(e*s,this.ORDER)}pow(e,s){return $r(this,e,s)}div(e,s){return ne(e*Mt(s,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,s){return e+s}subN(e,s){return e-s}mulN(e,s){return e*s}inv(e){return Mt(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=Lr(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?cs(e,this.BYTES):ht(e,this.BYTES)}fromBytes(e,s=!1){F(e);const{_lengths:t,BYTES:o,isLE:n,ORDER:i,_mod:a}=this;if(t){if(!t.includes(e.length)||e.length>o)throw new Error("Field.fromBytes: expected "+t+" bytes, got "+e.length);const l=new Uint8Array(o);l.set(e,n?0:l.length-e.length),e=l}if(e.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+e.length);let c=n?as(e):Ye(e);if(a&&(c=ne(c,i)),!s&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return gs(this,e)}cmov(e,s,t){return t?s:e}}function Ze(r,e={}){return new Ur(r,e)}function xs(r){if(typeof r!="bigint")throw new Error("field order must be bigint");const e=r.toString(2).length;return Math.ceil(e/8)}function ws(r){const e=xs(r);return e+Math.ceil(e/2)}function Hr(r,e,s=!1){F(r);const t=r.length,o=xs(e),n=ws(e);if(t<16||t<n||t>1024)throw new Error("expected "+n+"-1024 bytes of input, got "+t);const i=s?as(r):Ye(r),a=ne(i,e-Z)+Z;return s?cs(a,o):ht(a,o)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Ce=BigInt(0),ve=BigInt(1);function Ve(r,e){const s=e.negate();return r?s:e}function Bt(r,e){const s=gs(r.Fp,e.map(t=>t.Z));return e.map((t,o)=>r.fromAffine(t.toAffine(s[o])))}function ms(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function tt(r,e){ms(r,e);const s=Math.ceil(e/r)+1,t=2**(r-1),o=2**r,n=pt(r),i=BigInt(r);return{windows:s,windowSize:t,mask:n,maxNumber:o,shiftBy:i}}function Ut(r,e,s){const{windowSize:t,mask:o,maxNumber:n,shiftBy:i}=s;let a=Number(r&o),c=r>>i;a>t&&(a-=n,c+=ve);const l=e*t,d=l+Math.abs(a)-1,u=a===0,g=a<0,f=e%2!==0;return{nextN:c,offset:d,isZero:u,isNeg:g,isNegF:f,offsetF:l}}const st=new WeakMap,ys=new WeakMap;function rt(r){return ys.get(r)||1}function Ht(r){if(r!==Ce)throw new Error("invalid wNAF")}class Fr{constructor(e,s){S(this,"BASE");S(this,"ZERO");S(this,"Fn");S(this,"bits");this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=s}_unsafeLadder(e,s,t=this.ZERO){let o=e;for(;s>Ce;)s&ve&&(t=t.add(o)),o=o.double(),s>>=ve;return t}precomputeWindow(e,s){const{windows:t,windowSize:o}=tt(s,this.bits),n=[];let i=e,a=i;for(let c=0;c<t;c++){a=i,n.push(a);for(let l=1;l<o;l++)a=a.add(i),n.push(a);i=a.double()}return n}wNAF(e,s,t){if(!this.Fn.isValid(t))throw new Error("invalid scalar");let o=this.ZERO,n=this.BASE;const i=tt(e,this.bits);for(let a=0;a<i.windows;a++){const{nextN:c,offset:l,isZero:d,isNeg:u,isNegF:g,offsetF:f}=Ut(t,a,i);t=c,d?n=n.add(Ve(g,s[f])):o=o.add(Ve(u,s[l]))}return Ht(t),{p:o,f:n}}wNAFUnsafe(e,s,t,o=this.ZERO){const n=tt(e,this.bits);for(let i=0;i<n.windows&&t!==Ce;i++){const{nextN:a,offset:c,isZero:l,isNeg:d}=Ut(t,i,n);if(t=a,!l){const u=s[c];o=o.add(d?u.negate():u)}}return Ht(t),o}getPrecomputes(e,s,t){let o=st.get(s);return o||(o=this.precomputeWindow(s,e),e!==1&&(typeof t=="function"&&(o=t(o)),st.set(s,o))),o}cached(e,s,t){const o=rt(e);return this.wNAF(o,this.getPrecomputes(o,e,t),s)}unsafe(e,s,t,o){const n=rt(e);return n===1?this._unsafeLadder(e,s,o):this.wNAFUnsafe(n,this.getPrecomputes(n,e,t),s,o)}createCache(e,s){ms(s,this.bits),ys.set(e,s),st.delete(e)}hasCache(e){return rt(e)!==1}}function Gr(r,e,s,t){let o=e,n=r.ZERO,i=r.ZERO;for(;s>Ce||t>Ce;)s&ve&&(n=n.add(o)),t&ve&&(i=i.add(o)),o=o.double(),s>>=ve,t>>=ve;return{p1:n,p2:i}}function Ft(r,e,s){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Mr(e),e}else return Ze(r,{isLE:s})}function Wr(r,e,s={},t){if(t===void 0&&(t=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(const c of["p","n","h"]){const l=e[c];if(!(typeof l=="bigint"&&l>Ce))throw new Error(`CURVE.${c} must be positive bigint`)}const o=Ft(e.p,s.Fp,t),n=Ft(e.n,s.Fn,t),a=["Gx","Gy","a","b"];for(const c of a)if(!o.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:o,Fn:n}}function qr(r,e){return function(t){const o=r(t);return{secretKey:o,publicKey:e(o)}}}class bs{constructor(e,s){S(this,"oHash");S(this,"iHash");S(this,"blockLen");S(this,"outputLen");S(this,"finished",!1);S(this,"destroyed",!1);if(es(e),F(s,void 0,"key"),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 t=this.blockLen,o=new Uint8Array(t);o.set(s.length>t?e.create().update(s).digest():s);for(let n=0;n<o.length;n++)o[n]^=54;this.iHash.update(o),this.oHash=e.create();for(let n=0;n<o.length;n++)o[n]^=106;this.oHash.update(o),Te(o)}update(e){return Ae(this),this.iHash.update(e),this}digestInto(e){Ae(this),F(e,this.outputLen,"output"),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:t,finished:o,destroyed:n,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=n,e.blockLen=i,e.outputLen=a,e.oHash=s._cloneInto(e.oHash),e.iHash=t._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}const vs=(r,e,s)=>new bs(r,e).update(s).digest();vs.create=(r,e)=>new bs(r,e);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Gt=(r,e)=>(r+(r>=0?e:-e)/Ss)/e;function Vr(r,e,s){const[[t,o],[n,i]]=e,a=Gt(i*r,s),c=Gt(-o*r,s);let l=r-a*t-c*n,d=-a*o-c*i;const u=l<ue,g=d<ue;u&&(l=-l),g&&(d=-d);const f=pt(Math.ceil(Cr(s)/2))+Ie;if(l<ue||l>=f||d<ue||d>=f)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:u,k1:l,k2neg:g,k2:d}}function at(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function ot(r,e){const s={};for(let t of Object.keys(e))s[t]=r[t]===void 0?e[t]:r[t];return qe(s.lowS,"lowS"),qe(s.prehash,"prehash"),s.format!==void 0&&at(s.format),s}class Kr extends Error{constructor(e=""){super(e)}}const xe={Err:Kr,_tlv:{encode:(r,e)=>{const{Err:s}=xe;if(r<0||r>256)throw new s("tlv.encode: wrong tag");if(e.length&1)throw new s("tlv.encode: unpadded data");const t=e.length/2,o=$e(t);if(o.length/2&128)throw new s("tlv.encode: long form length too big");const n=t>127?$e(o.length/2|128):"";return $e(r)+n+o+e},decode(r,e){const{Err:s}=xe;let t=0;if(r<0||r>256)throw new s("tlv.encode: wrong tag");if(e.length<2||e[t++]!==r)throw new s("tlv.decode: wrong tlv");const o=e[t++],n=!!(o&128);let i=0;if(!n)i=o;else{const c=o&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(t,t+c);if(l.length!==c)throw new s("tlv.decode: length bytes not complete");if(l[0]===0)throw new s("tlv.decode(long): zero leftmost byte");for(const d of l)i=i<<8|d;if(t+=c,i<128)throw new s("tlv.decode(long): not minimal encoding")}const a=e.subarray(t,t+i);if(a.length!==i)throw new s("tlv.decode: wrong value length");return{v:a,l:e.subarray(t+i)}}},_int:{encode(r){const{Err:e}=xe;if(r<ue)throw new e("integer: negative integers are not allowed");let s=$e(r);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(r){const{Err:e}=xe;if(r[0]&128)throw new e("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Ye(r)}},toSig(r){const{Err:e,_int:s,_tlv:t}=xe,o=F(r,void 0,"signature"),{v:n,l:i}=t.decode(48,o);if(i.length)throw new e("invalid signature: left bytes after parsing");const{v:a,l:c}=t.decode(2,n),{v:l,l:d}=t.decode(2,c);if(d.length)throw new e("invalid signature: left bytes after parsing");return{r:s.decode(a),s:s.decode(l)}},hexFromSig(r){const{_tlv:e,_int:s}=xe,t=e.encode(2,s.encode(r.r)),o=e.encode(2,s.encode(r.s)),n=t+o;return e.encode(48,n)}},ue=BigInt(0),Ie=BigInt(1),Ss=BigInt(2),Be=BigInt(3),zr=BigInt(4);function jr(r,e={}){const s=Wr("weierstrass",r,e),{Fp:t,Fn:o}=s;let n=s.CURVE;const{h:i,n:a}=n;ft(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});const{endo:c}=e;if(c&&(!t.is0(n.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');const l=Is(t,o);function d(){if(!t.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(L,x,w){const{x:v,y:A}=x.toAffine(),k=t.toBytes(v);if(qe(w,"isCompressed"),w){d();const C=!t.isOdd(A);return we(Es(C),k)}else return we(Uint8Array.of(4),k,t.toBytes(A))}function g(L){F(L,void 0,"Point");const{publicKey:x,publicKeyUncompressed:w}=l,v=L.length,A=L[0],k=L.subarray(1);if(v===x&&(A===2||A===3)){const C=t.fromBytes(k);if(!t.isValid(C))throw new Error("bad point: is not on curve, wrong x");const R=b(C);let I;try{I=t.sqrt(R)}catch(q){const H=q instanceof Error?": "+q.message:"";throw new Error("bad point: is not on curve, sqrt error"+H)}d();const P=t.isOdd(I);return(A&1)===1!==P&&(I=t.neg(I)),{x:C,y:I}}else if(v===w&&A===4){const C=t.BYTES,R=t.fromBytes(k.subarray(0,C)),I=t.fromBytes(k.subarray(C,C*2));if(!y(R,I))throw new Error("bad point: is not on curve");return{x:R,y:I}}else throw new Error(`bad point: got length ${v}, expected compressed=${x} or uncompressed=${w}`)}const f=e.toBytes||u,p=e.fromBytes||g;function b(L){const x=t.sqr(L),w=t.mul(x,L);return t.add(t.add(w,t.mul(L,n.a)),n.b)}function y(L,x){const w=t.sqr(x),v=b(L);return t.eql(w,v)}if(!y(n.Gx,n.Gy))throw new Error("bad curve params: generator point");const E=t.mul(t.pow(n.a,Be),zr),D=t.mul(t.sqr(n.b),BigInt(27));if(t.is0(t.add(E,D)))throw new Error("bad curve params: a or b");function U(L,x,w=!1){if(!t.isValid(x)||w&&t.is0(x))throw new Error(`bad point coordinate ${L}`);return x}function M(L){if(!(L instanceof J))throw new Error("Weierstrass Point expected")}function B(L){if(!c||!c.basises)throw new Error("no endo");return Vr(L,c.basises,o.ORDER)}const K=Dt((L,x)=>{const{X:w,Y:v,Z:A}=L;if(t.eql(A,t.ONE))return{x:w,y:v};const k=L.is0();x==null&&(x=k?t.ONE:t.inv(A));const C=t.mul(w,x),R=t.mul(v,x),I=t.mul(A,x);if(k)return{x:t.ZERO,y:t.ZERO};if(!t.eql(I,t.ONE))throw new Error("invZ was invalid");return{x:C,y:R}}),le=Dt(L=>{if(L.is0()){if(e.allowInfinityPoint&&!t.is0(L.Y))return;throw new Error("bad point: ZERO")}const{x,y:w}=L.toAffine();if(!t.isValid(x)||!t.isValid(w))throw new Error("bad point: x or y not field elements");if(!y(x,w))throw new Error("bad point: equation left != right");if(!L.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function fe(L,x,w,v,A){return w=new J(t.mul(w.X,L),w.Y,w.Z),x=Ve(v,x),w=Ve(A,w),x.add(w)}const $=class ${constructor(x,w,v){S(this,"X");S(this,"Y");S(this,"Z");this.X=U("x",x),this.Y=U("y",w,!0),this.Z=U("z",v),Object.freeze(this)}static CURVE(){return n}static fromAffine(x){const{x:w,y:v}=x||{};if(!x||!t.isValid(w)||!t.isValid(v))throw new Error("invalid affine point");if(x instanceof $)throw new Error("projective point not allowed");return t.is0(w)&&t.is0(v)?$.ZERO:new $(w,v,t.ONE)}static fromBytes(x){const w=$.fromAffine(p(F(x,void 0,"point")));return w.assertValidity(),w}static fromHex(x){return $.fromBytes(We(x))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(x=8,w=!0){return ie.createCache(this,x),w||this.multiply(Be),this}assertValidity(){le(this)}hasEvenY(){const{y:x}=this.toAffine();if(!t.isOdd)throw new Error("Field doesn't support isOdd");return!t.isOdd(x)}equals(x){M(x);const{X:w,Y:v,Z:A}=this,{X:k,Y:C,Z:R}=x,I=t.eql(t.mul(w,R),t.mul(k,A)),P=t.eql(t.mul(v,R),t.mul(C,A));return I&&P}negate(){return new $(this.X,t.neg(this.Y),this.Z)}double(){const{a:x,b:w}=n,v=t.mul(w,Be),{X:A,Y:k,Z:C}=this;let R=t.ZERO,I=t.ZERO,P=t.ZERO,N=t.mul(A,A),q=t.mul(k,k),H=t.mul(C,C),O=t.mul(A,k);return O=t.add(O,O),P=t.mul(A,C),P=t.add(P,P),R=t.mul(x,P),I=t.mul(v,H),I=t.add(R,I),R=t.sub(q,I),I=t.add(q,I),I=t.mul(R,I),R=t.mul(O,R),P=t.mul(v,P),H=t.mul(x,H),O=t.sub(N,H),O=t.mul(x,O),O=t.add(O,P),P=t.add(N,N),N=t.add(P,N),N=t.add(N,H),N=t.mul(N,O),I=t.add(I,N),H=t.mul(k,C),H=t.add(H,H),N=t.mul(H,O),R=t.sub(R,N),P=t.mul(H,q),P=t.add(P,P),P=t.add(P,P),new $(R,I,P)}add(x){M(x);const{X:w,Y:v,Z:A}=this,{X:k,Y:C,Z:R}=x;let I=t.ZERO,P=t.ZERO,N=t.ZERO;const q=n.a,H=t.mul(n.b,Be);let O=t.mul(w,k),V=t.mul(v,C),j=t.mul(A,R),se=t.add(w,v),G=t.add(k,C);se=t.mul(se,G),G=t.add(O,V),se=t.sub(se,G),G=t.add(w,A);let Y=t.add(k,R);return G=t.mul(G,Y),Y=t.add(O,j),G=t.sub(G,Y),Y=t.add(v,A),I=t.add(C,R),Y=t.mul(Y,I),I=t.add(V,j),Y=t.sub(Y,I),N=t.mul(q,G),I=t.mul(H,j),N=t.add(I,N),I=t.sub(V,N),N=t.add(V,N),P=t.mul(I,N),V=t.add(O,O),V=t.add(V,O),j=t.mul(q,j),G=t.mul(H,G),V=t.add(V,j),j=t.sub(O,j),j=t.mul(q,j),G=t.add(G,j),O=t.mul(V,G),P=t.add(P,O),O=t.mul(Y,G),I=t.mul(se,I),I=t.sub(I,O),O=t.mul(se,V),N=t.mul(Y,N),N=t.add(N,O),new $(I,P,N)}subtract(x){return this.add(x.negate())}is0(){return this.equals($.ZERO)}multiply(x){const{endo:w}=e;if(!o.isValidNot0(x))throw new Error("invalid scalar: out of range");let v,A;const k=C=>ie.cached(this,C,R=>Bt($,R));if(w){const{k1neg:C,k1:R,k2neg:I,k2:P}=B(x),{p:N,f:q}=k(R),{p:H,f:O}=k(P);A=q.add(O),v=fe(w.beta,N,H,C,I)}else{const{p:C,f:R}=k(x);v=C,A=R}return Bt($,[v,A])[0]}multiplyUnsafe(x){const{endo:w}=e,v=this;if(!o.isValid(x))throw new Error("invalid scalar: out of range");if(x===ue||v.is0())return $.ZERO;if(x===Ie)return v;if(ie.hasCache(this))return this.multiply(x);if(w){const{k1neg:A,k1:k,k2neg:C,k2:R}=B(x),{p1:I,p2:P}=Gr($,v,k,R);return fe(w.beta,I,P,A,C)}else return ie.unsafe(v,x)}toAffine(x){return K(this,x)}isTorsionFree(){const{isTorsionFree:x}=e;return i===Ie?!0:x?x($,this):ie.unsafe(this,a).is0()}clearCofactor(){const{clearCofactor:x}=e;return i===Ie?this:x?x($,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(x=!0){return qe(x,"isCompressed"),this.assertValidity(),f($,this,x)}toHex(x=!0){return Oe(this.toBytes(x))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}};S($,"BASE",new $(n.Gx,n.Gy,t.ONE)),S($,"ZERO",new $(t.ZERO,t.ONE,t.ZERO)),S($,"Fp",t),S($,"Fn",o);let J=$;const me=o.BITS,ie=new Fr(J,e.endo?Math.ceil(me/2):me);return J.BASE.precompute(8),J}function Es(r){return Uint8Array.of(r?2:3)}function Is(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function Yr(r,e={}){const{Fn:s}=r,t=e.randomBytes||os,o=Object.assign(Is(r.Fp,s),{seed:ws(s.ORDER)});function n(f){try{const p=s.fromBytes(f);return s.isValidNot0(p)}catch{return!1}}function i(f,p){const{publicKey:b,publicKeyUncompressed:y}=o;try{const E=f.length;return p===!0&&E!==b||p===!1&&E!==y?!1:!!r.fromBytes(f)}catch{return!1}}function a(f=t(o.seed)){return Hr(F(f,o.seed,"seed"),s.ORDER)}function c(f,p=!0){return r.BASE.multiply(s.fromBytes(f)).toBytes(p)}function l(f){const{secretKey:p,publicKey:b,publicKeyUncompressed:y}=o;if(!dt(f)||"_lengths"in s&&s._lengths||p===b)return;const E=F(f,void 0,"key").length;return E===b||E===y}function d(f,p,b=!0){if(l(f)===!0)throw new Error("first arg must be private key");if(l(p)===!1)throw new Error("second arg must be public key");const y=s.fromBytes(f);return r.fromBytes(p).multiply(y).toBytes(b)}const u={isValidSecretKey:n,isValidPublicKey:i,randomSecretKey:a},g=qr(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:d,keygen:g,Point:r,utils:u,lengths:o})}function Zr(r,e,s={}){es(e),ft(s,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),s=Object.assign({},s);const t=s.randomBytes||os,o=s.hmac||((x,w)=>vs(e,x,w)),{Fp:n,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:d,getSharedSecret:u,utils:g,lengths:f}=Yr(r,s),p={prehash:!0,lowS:typeof s.lowS=="boolean"?s.lowS:!0,format:"compact",extraEntropy:!1},b=a*Ss<n.ORDER;function y(x){const w=a>>Ie;return x>w}function E(x,w){if(!i.isValidNot0(w))throw new Error(`invalid signature ${x}: out of range 1..Point.Fn.ORDER`);return w}function D(){if(b)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function U(x,w){at(w);const v=f.signature,A=w==="compact"?v:w==="recovered"?v+1:void 0;return F(x,A)}class M{constructor(w,v,A){S(this,"r");S(this,"s");S(this,"recovery");if(this.r=E("r",w),this.s=E("s",v),A!=null){if(D(),![0,1,2,3].includes(A))throw new Error("invalid recovery id");this.recovery=A}Object.freeze(this)}static fromBytes(w,v=p.format){U(w,v);let A;if(v==="der"){const{r:I,s:P}=xe.toSig(F(w));return new M(I,P)}v==="recovered"&&(A=w[0],v="compact",w=w.subarray(1));const k=f.signature/2,C=w.subarray(0,k),R=w.subarray(k,k*2);return new M(i.fromBytes(C),i.fromBytes(R),A)}static fromHex(w,v){return this.fromBytes(We(w),v)}assertRecovery(){const{recovery:w}=this;if(w==null)throw new Error("invalid recovery id: must be present");return w}addRecoveryBit(w){return new M(this.r,this.s,w)}recoverPublicKey(w){const{r:v,s:A}=this,k=this.assertRecovery(),C=k===2||k===3?v+a:v;if(!n.isValid(C))throw new Error("invalid recovery id: sig.r+curve.n != R.x");const R=n.toBytes(C),I=r.fromBytes(we(Es((k&1)===0),R)),P=i.inv(C),N=K(F(w,void 0,"msgHash")),q=i.create(-N*P),H=i.create(A*P),O=r.BASE.multiplyUnsafe(q).add(I.multiplyUnsafe(H));if(O.is0())throw new Error("invalid recovery: point at infinify");return O.assertValidity(),O}hasHighS(){return y(this.s)}toBytes(w=p.format){if(at(w),w==="der")return We(xe.hexFromSig(this));const{r:v,s:A}=this,k=i.toBytes(v),C=i.toBytes(A);return w==="recovered"?(D(),we(Uint8Array.of(this.assertRecovery()),k,C)):we(k,C)}toHex(w){return Oe(this.toBytes(w))}}const B=s.bits2int||function(w){if(w.length>8192)throw new Error("input is too large");const v=Ye(w),A=w.length*8-c;return A>0?v>>BigInt(A):v},K=s.bits2int_modN||function(w){return i.create(B(w))},le=pt(c);function fe(x){return Tr("num < 2^"+c,x,ue,le),i.toBytes(x)}function J(x,w){return F(x,void 0,"message"),w?F(e(x),void 0,"prehashed message"):x}function me(x,w,v){const{lowS:A,prehash:k,extraEntropy:C}=ot(v,p);x=J(x,k);const R=K(x),I=i.fromBytes(w);if(!i.isValidNot0(I))throw new Error("invalid private key");const P=[fe(I),fe(R)];if(C!=null&&C!==!1){const O=C===!0?t(f.secretKey):C;P.push(F(O,void 0,"extraEntropy"))}const N=we(...P),q=R;function H(O){const V=B(O);if(!i.isValidNot0(V))return;const j=i.inv(V),se=r.BASE.multiply(V).toAffine(),G=i.create(se.x);if(G===ue)return;const Y=i.create(j*i.create(q+G*I));if(Y===ue)return;let bt=(se.x===G?0:2)|Number(se.y&Ie),vt=Y;return A&&y(Y)&&(vt=i.neg(Y),bt^=1),new M(G,vt,b?void 0:bt)}return{seed:N,k2sig:H}}function ie(x,w,v={}){const{seed:A,k2sig:k}=me(x,w,v);return kr(e.outputLen,i.BYTES,o)(A,k).toBytes(v.format)}function $(x,w,v,A={}){const{lowS:k,prehash:C,format:R}=ot(A,p);if(v=F(v,void 0,"publicKey"),w=J(w,C),!dt(x)){const I=x instanceof M?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+I)}U(x,R);try{const I=M.fromBytes(x,R),P=r.fromBytes(v);if(k&&I.hasHighS())return!1;const{r:N,s:q}=I,H=K(w),O=i.inv(q),V=i.create(H*O),j=i.create(N*O),se=r.BASE.multiplyUnsafe(V).add(P.multiplyUnsafe(j));return se.is0()?!1:i.create(se.x)===N}catch{return!1}}function L(x,w,v={}){const{prehash:A}=ot(v,p);return w=J(w,A),M.fromBytes(x,"recovered").recoverPublicKey(w).toBytes()}return Object.freeze({keygen:l,getPublicKey:d,getSharedSecret:u,utils:g,lengths:f,Point:r,sign:ie,verify:$,recoverPublicKey:L,Signature:M,hash:e})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const gt={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Xr={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},Wt=BigInt(2);function Jr(r){const e=gt.p,s=BigInt(3),t=BigInt(6),o=BigInt(11),n=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%e,d=l*l*r%e,u=oe(d,s,e)*d%e,g=oe(u,s,e)*d%e,f=oe(g,Wt,e)*l%e,p=oe(f,o,e)*f%e,b=oe(p,n,e)*p%e,y=oe(b,a,e)*b%e,E=oe(y,c,e)*y%e,D=oe(E,a,e)*b%e,U=oe(D,s,e)*d%e,M=oe(U,i,e)*p%e,B=oe(M,t,e)*l%e,K=oe(B,Wt,e);if(!ct.eql(ct.sqr(K),r))throw new Error("Cannot find square root");return K}const ct=Ze(gt.p,{sqrt:Jr}),Qr=jr(gt,{Fp:ct,endo:Xr}),eo=Zr(Qr,Er),to=BigInt(0),ke=BigInt(1),so=BigInt(2),ro=BigInt(7),oo=BigInt(256),no=BigInt(113),As=[],Ts=[],Cs=[];for(let r=0,e=ke,s=1,t=0;r<24;r++){[s,t]=[t,(2*s+3*t)%5],As.push(2*(5*t+s)),Ts.push((r+1)*(r+2)/2%64);let o=to;for(let n=0;n<7;n++)e=(e<<ke^(e>>ro)*no)%oo,e&so&&(o^=ke<<(ke<<BigInt(n))-ke);Cs.push(o)}const ks=gr(Cs,!0),io=ks[0],ao=ks[1],qt=(r,e,s)=>s>32?mr(r,e,s):xr(r,e,s),Vt=(r,e,s)=>s>32?yr(r,e,s):wr(r,e,s);function co(r,e=24){const s=new Uint32Array(10);for(let t=24-e;t<24;t++){for(let i=0;i<10;i++)s[i]=r[i]^r[i+10]^r[i+20]^r[i+30]^r[i+40];for(let i=0;i<10;i+=2){const a=(i+8)%10,c=(i+2)%10,l=s[c],d=s[c+1],u=qt(l,d,1)^s[a],g=Vt(l,d,1)^s[a+1];for(let f=0;f<50;f+=10)r[i+f]^=u,r[i+f+1]^=g}let o=r[2],n=r[3];for(let i=0;i<24;i++){const a=Ts[i],c=qt(o,n,a),l=Vt(o,n,a),d=As[i];o=r[d],n=r[d+1],r[d]=c,r[d+1]=l}for(let i=0;i<50;i+=10){for(let a=0;a<10;a++)s[a]=r[i+a];for(let a=0;a<10;a++)r[i+a]^=~s[(a+2)%10]&s[(a+4)%10]}r[0]^=io[t],r[1]^=ao[t]}Te(s)}class xt{constructor(e,s,t,o=!1,n=24){S(this,"state");S(this,"pos",0);S(this,"posOut",0);S(this,"finished",!1);S(this,"state32");S(this,"destroyed",!1);S(this,"blockLen");S(this,"suffix");S(this,"outputLen");S(this,"enableXOF",!1);S(this,"rounds");if(this.blockLen=e,this.suffix=s,this.outputLen=t,this.enableXOF=o,this.rounds=n,pe(t,"outputLen"),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=ir(this.state)}clone(){return this._cloneInto()}keccak(){Ot(this.state32),co(this.state32,this.rounds),Ot(this.state32),this.posOut=0,this.pos=0}update(e){Ae(this),F(e);const{blockLen:s,state:t}=this,o=e.length;for(let n=0;n<o;){const i=Math.min(s-this.pos,o-n);for(let a=0;a<i;a++)t[this.pos++]^=e[n++];this.pos===s&&this.keccak()}return this}finish(){if(this.finished)return;this.finished=!0;const{state:e,suffix:s,pos:t,blockLen:o}=this;e[t]^=s,s&128&&t===o-1&&this.keccak(),e[o-1]^=128,this.keccak()}writeInto(e){Ae(this,!1),F(e),this.finish();const s=this.state,{blockLen:t}=this;for(let o=0,n=e.length;o<n;){this.posOut>=t&&this.keccak();const i=Math.min(t-this.posOut,n-o);e.set(s.subarray(this.posOut,this.posOut+i),o),this.posOut+=i,o+=i}return e}xofInto(e){if(!this.enableXOF)throw new Error("XOF is not possible for this instance");return this.writeInto(e)}xof(e){return pe(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(ts(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,Te(this.state)}_cloneInto(e){const{blockLen:s,suffix:t,outputLen:o,rounds:n,enableXOF:i}=this;return e||(e=new xt(s,t,o,i,n)),e.state32.set(this.state32),e.pos=this.pos,e.posOut=this.posOut,e.finished=this.finished,e.rounds=n,e.suffix=t,e.outputLen=o,e.enableXOF=i,e.destroyed=this.destroyed,e}}const lo=(r,e,s,t={})=>rs(()=>new xt(e,r,s),t),Kt=lo(1,136,32);class uo{async verifyJWT(e,s){try{const t=this.decodeJWT(e);h.log("[CROSSx] JWT 디코딩 성공:",{sub:t.sub,exp:t.exp,iat:t.iat,"현재 시간":Math.floor(Date.now()/1e3)});const o=Math.floor(Date.now()/1e3);return t.exp&&t.exp<o?(h.warn("[CROSSx] 토큰 만료:",{exp:t.exp,now:o,만료시간:new Date(t.exp*1e3).toISOString()}),{payload:t,valid:!1,signatureVerified:!1}):t.sub?(h.log("[CROSSx] JWT 검증 성공 (서명 미검증 — JWKS 미구현)"),{payload:t,valid:!0,signatureVerified:!1}):(h.warn("[CROSSx] JWT에 sub(사용자ID) 없음"),{payload:t,valid:!1,signatureVerified:!1})}catch(t){throw h.error("[CROSSx] JWT 검증 중 에러:",t),t}}decodeJWT(e){return Ls.decodeJwt(e)}recoverPersonalSignSigner(e,s){const t=new TextEncoder().encode(e),o=new TextEncoder().encode(`Ethereum Signed Message:
2
+ ${t.length}`),n=new Uint8Array(o.length+t.length);n.set(o,0),n.set(t,o.length);const i=Kt(n),a=s.startsWith("0x")?s.slice(2):s;if(a.length!==130)throw new Error(`서명 길이가 유효하지 않습니다: 130 hex 문자 예상, 현재 ${a.length}`);const c=ho(a),l=c.slice(0,32),d=c.slice(32,64),u=c[64],g=u>=27?u-27:u,b=new eo.Signature(zt(l),zt(d)).addRecoveryBit(g).recoverPublicKey(i).toBytes(!1).slice(1),y=Kt(b);return"0x"+Oe(y.slice(12))}}function ho(r){const e=new Uint8Array(r.length/2);for(let s=0;s<e.length;s++)e[s]=parseInt(r.substring(s*2,s*2+2),16);return e}function zt(r){let e="0x";for(const s of r)e+=s.toString(16).padStart(2,"0");return BigInt(e)}const po=3e4;class fo{async request(e){const s=new AbortController,t=setTimeout(()=>s.abort(),e.timeoutMs??po);try{const o=await fetch(e.url,{method:e.method,headers:e.headers,body:e.body?JSON.stringify(e.body):void 0,signal:s.signal,credentials:e.credentials});let n;const i=await o.text();try{n=i?JSON.parse(i):null}catch{n={_raw:i}}return{status:o.status,data:n,headers:Object.fromEntries(o.headers.entries())}}finally{clearTimeout(t)}}}class wt{static generateState(){const e=new Uint8Array(16);return crypto.getRandomValues(e),Array.from(e,s=>s.toString(16).padStart(2,"0")).join("")}openAuth(e){return new Promise((s,t)=>{const o=Math.max(e.width??500,500),n=Math.max(e.height??700,700),i=window.screenX+(window.outerWidth-o)/2,a=window.screenY+(window.outerHeight-n)/2,c=wt.generateState(),l=e.authUrl.includes("?")?"&":"?",d=`${e.authUrl}${l}state=${c}`,u=window.open(d,"CROSSx OAuth",`width=${o},height=${n},left=${i},top=${a}`);if(!u){t(new Error("팝업 창을 열 수 없습니다. 팝업 차단을 해제해 주세요."));return}const g=setTimeout(()=>{h.warn("[CROSSx] OAuth 타임아웃 (5분) — postMessage를 수신하지 못했습니다"),U(),t(new Error("Authentication timeout"))},5*60*1e3),f=10,p=30;let b=0,y=null;const E=()=>{clearInterval(D),h.warn("[CROSSx] COOP 감지 — OAuth 서버 응답을 "+p+"초간 대기합니다"),y=setTimeout(()=>{U(),t(new Error("OAuth 서버로부터 응답을 받지 못했습니다. 브라우저 보안 정책(COOP)으로 인해 팝업 통신이 차단되었을 수 있습니다. 다시 시도해 주세요."))},p*1e3)},D=setInterval(()=>{b++;try{u.closed&&(b<=f?E():(U(),t(new Error("로그인이 취소되었습니다"))))}catch{E()}},1e3),U=()=>{clearTimeout(g),clearInterval(D),y&&clearTimeout(y),window.removeEventListener("message",M)},M=B=>{var le,fe,J,me,ie,$,L;if(B.origin!==e.expectedOrigin)return;U(),h.log("[CROSSx] OAuth postMessage 수신 — status:",B.data.status);const K=B.data.state??((le=B.data.data)==null?void 0:le.state);if(!K||K!==c){t(new Error("OAuth state mismatch — possible CSRF attack"));return}if(B.data.status==="success"){const x=((fe=B.data.data)==null?void 0:fe.accessToken)||((J=B.data.data)==null?void 0:J.idToken);h.log("[CROSSx] OAuth 토큰 수신:",{hasAccessToken:!!((me=B.data.data)!=null&&me.accessToken),hasIdToken:!!((ie=B.data.data)!=null&&ie.idToken)}),x?s(x):(h.error("[CROSSx] 토큰을 찾을 수 없음:",B.data),t(new Error("Token not found in response")))}else h.error("[CROSSx] OAuth 실패:",($=B.data.data)==null?void 0:$.error),t(new Error(((L=B.data.data)==null?void 0:L.error)||"Authentication failed"))};window.addEventListener("message",M)})}}const Re="crossx_wallet_data",Ee="crossx_mock_pw_hash";class _o{constructor(e,s){this.storage=e,this.passwordStore=s??null}async checkWallet(){if(this.migrateScenario!==void 0)return h.log("[Mock] checkWallet → migration_required"),"migration_required";const s=await this.storage.get(Re)?"exists":"not_found";return h.log(`[Mock] checkWallet → ${s}`),s}async getOrCreateWallet(e){var s;try{const t=await this.storage.get(Re);if(t)return t;const o={id:e,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};await this.storage.set(Re,o);const n=(s=this.passwordStore)==null?void 0:s.get();return n&&(await this.storage.set(Ee,n),h.log("[Mock] 지갑 생성 — 비밀번호 저장됨")),o}catch(t){throw new m(_.WALLET_CREATION_FAILED,"지갑 생성에 실패했습니다",t)}}async getAddresses(e){const s=await this.storage.get(Re);return s?[{address:s.address,index:0}]:[]}async getAddress(e,s){return{address:this.generateMockEvmAddress(),derivationPath:`m/44'/60'/0'/0/${s}`}}async prepare(e,s){const t="mock-"+crypto.randomUUID();return h.log(`[Mock] prepare action=${e} → uuid=${t}`),{uuid:t,expiresAt:new Date(Date.now()+5*6e4).toISOString()}}async signMessage(e,s,t,o=0,n,i){return h.log(`[Mock] signMessage chainId=${s} index=${o} uuid=${n} from=${i}: "${t}"`),{chainId:s,signature:this.generateMockSignature(),format:"hex"}}async signTypedData(e,s,t,o=0,n,i){return h.log(`[Mock] signTypedData chainId=${s} index=${o} uuid=${n} from=${i}`),{chainId:s,signature:this.generateMockSignature(),format:"hex"}}async signTransaction(e,s,t,o=0,n){h.log(`[Mock] signTransaction chainId=${s} index=${o} uuid=${n}:`,t);const i="0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("");return{chainId:s,signature:this.generateMockSignature(),txHash:i,format:"hex"}}async sendTransaction(e,s,t,o){return h.log(`[Mock] sendTransaction chainId=${s} uuid=${o}:`,t),{txHash:"0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}async verifyPassword(e){var t;if(h.log("[Mock] verifyPassword"),this.passwordScenario==="wrong")return!1;const s=await this.storage.get(Ee);return s&&s!==e?!1:(s||await this.storage.set(Ee,e),(t=this.passwordStore)==null||t.set(e),h.log("[Mock] verifyPassword → 성공"),!0)}async changePassword(e,s){var n;if(h.log("[Mock] changePassword"),this.passwordScenario==="wrong")throw new m(_.PASSWORD_WRONG,"Incorrect password.");const t=(n=this.passwordStore)==null?void 0:n.get(),o=await this.storage.get(Ee);if(o&&t&&o!==t)throw new m(_.PASSWORD_WRONG,"Incorrect password.");await this.storage.set(Ee,s),h.log("[Mock] changePassword 완료")}async migrateWallet(e,s){var n;if(h.log(`[Mock] migrateWallet pin=${e} sub=${s}`),this.migrateScenario==="wrong_pin")throw new m(_.MIGRATION_FAILED,"Incorrect PIN.",{permanent:!1,lockExpiresAt:0,remainingAttempts:4,maxAttempts:5});if(this.migrateScenario!==void 0&&typeof this.migrateScenario=="object"&&"locked"in this.migrateScenario){const a={permanent:!1,lockExpiresAt:Math.floor(Date.now()/1e3)+1800,remainingAttempts:0,maxAttempts:5,...this.migrateScenario.locked};throw new m(_.MIGRATION_PIN_LOCKED,"Too many incorrect PIN attempts. Your account has been temporarily locked.",a)}const t={id:s,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};await this.storage.set(Re,t);const o=(n=this.passwordStore)==null?void 0:n.get();return o&&(await this.storage.set(Ee,o),h.log("[Mock] 마이그레이션 — 비밀번호 저장됨")),t}async getShareC(){return h.log("[Mock] getShareC"),"mock-share-c-"+crypto.randomUUID()}async verifyPin(e,s){return h.log("[Mock] verifyPin"),{valid:!0}}generateMockEvmAddress(){return"0x"+Array(40).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}generateMockSignature(){return"0x"+Array(130).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}class Ke{constructor(e,s,t,o,n){this._walletStatusCache=null,this.adapterConfig=e,this.projectId=e.projectId,this.storage=s,this.transport=t,this.tokenStore=o,this.passwordStore=n??null}getPassword(){var e;return((e=this.passwordStore)==null?void 0:e.get())??void 0}get baseUrl(){return this.adapterConfig.gatewayUrl}getAuthToken(){const e=this.tokenStore.get();if(!e)throw new m(_.AUTH_NOT_AUTHENTICATED,"인증 토큰을 찾을 수 없습니다. 먼저 로그인해 주세요.");return e}async request(e,s,t){var a,c;const o=this.getAuthToken(),n=`${this.baseUrl}${s}`,i={Authorization:`Bearer ${o}`,"Content-Type":"application/json","X-Project-Id":this.projectId};try{const d=(await this.transport.request({url:n,method:e,headers:i,body:t??void 0})).data;if(d&&typeof d.code=="number"){if(d.code<0||d.code>=400){const u=d.message||d.data||"API 요청에 실패했습니다";h.error("[CROSSx] Wallet Gateway API 에러 (HTTP 200):",{code:d.code,message:u,url:n,method:e,fullResponse:d});const g=Ke.mapGatewayError(d.code,d.data),f=Ke.getGatewayErrorMessage(d.code,u),p=new m(g,f,d.data??void 0);throw p.gatewayCode=d.code,p.gatewayMessage=u,p}return h.log("[CROSSx] Wallet Gateway API 성공:",{code:d.code,url:n,method:e}),d.data??d}return d}catch(l){if(l instanceof m)throw l;if((a=l.response)!=null&&a.data){const d=l.response.data,u=d.message||d.data||"API 요청에 실패했습니다",g=d.code||"UNKNOWN";throw h.error("[CROSSx] Wallet Gateway API 에러 (HTTP 에러):",{code:g,message:u,url:n,method:e,status:(c=l.response)==null?void 0:c.status}),new m(_.UNKNOWN_ERROR,`Wallet Gateway 오류 (${g}): ${u}`)}throw l}}async checkWallet(){h.log("[CROSSx] GET /mnemonic/check");const e=await this.request("GET","/mnemonic/check");return h.log("[CROSSx] /mnemonic/check 결과:",e.result),this._walletStatusCache=e.result,e.result}async getOrCreateWallet(e){let s;if(this._walletStatusCache!==null?(s=this._walletStatusCache,this._walletStatusCache=null,h.log("[CROSSx] getOrCreateWallet — 캐시된 상태 사용:",s)):(h.log("[CROSSx] GET /mnemonic/check — 지갑 상태 확인"),s=await this.checkWallet(),this._walletStatusCache=null),s==="migration_required")throw h.log("[CROSSx] migration_required → MIGRATION_BACKUP_EXISTS throw"),new m(_.MIGRATION_BACKUP_EXISTS,"CROSSx 백업이 존재합니다. 마이그레이션을 진행해 주세요.");if(s==="exists"){h.log("[CROSSx] 기존 지갑 발견 — POST /mnemonic/address(0)로 주소 조회");const n=await this.getAddress(e,0);return h.log("[CROSSx] 주소 조회 완료 — address:",n.address),{id:e,address:n.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}h.log("[CROSSx] POST /mnemonic/create — 신규 지갑 생성");const t={ignoreBackup:!1,password:this.requirePassword()},o=await this.request("POST","/mnemonic/create",t);return h.log("[CROSSx] /mnemonic/create 완료 — address:",o.address),{id:e,address:o.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}async getAddresses(e){return((await this.request("GET","/mnemonic/addresses")).addresses??[]).map(t=>({address:t.address,index:t.index}))}async getAddress(e,s){const t={password:this.requirePassword(),index:s};return{address:(await this.request("POST","/mnemonic/address",t)).address,derivationPath:`m/44'/60'/0'/0/${s}`}}async prepare(e,s){let t;switch(e){case"sign":case"send":if(!s.tx)throw new m(_.TX_INVALID_PARAMS,"prepare: tx가 필요합니다");t={unsignedTx:this.buildUnsignedTx(s.tx)};break;case"sign-message":if(!s.message)throw new m(_.TX_INVALID_PARAMS,"prepare: message가 필요합니다");t={message:s.message},s.from&&(t.from=s.from);break;case"sign-typed-data":if(!s.typedData)throw new m(_.TX_INVALID_PARAMS,"prepare: typedData가 필요합니다");t={typedData:s.typedData},s.from&&(t.from=s.from);break}const o={action:e,params:t},n=await this.request("POST","/mnemonic/prepare",o);return{uuid:n.uuid,expiresAt:n.expiresAt}}async signMessage(e,s,t,o,n,i){const a={message:t,password:this.requirePassword()};n&&(a.uuid=n),i&&(a.from=i);const c=await this.request("POST","/mnemonic/sign-message",a);return{chainId:s,signature:c.signature,format:"hex"}}async signTypedData(e,s,t,o,n,i){const a={typedData:t,password:this.requirePassword()};n&&(a.uuid=n),i&&(a.from=i);const c=await this.request("POST",`/mnemonic/sign-typed-data/${encodeURIComponent(s)}`,a);return{chainId:s,signature:c.signature,format:"hex"}}buildUnsignedTx(e){return{from:e.from,to:e.to,value:e.value,data:e.data,nonce:e.nonce!==void 0?`0x${e.nonce.toString(16)}`:void 0,gasLimit:e.gasLimit,gasPrice:e.gasPrice,maxFeePerGas:e.maxFeePerGas,maxPriorityFeePerGas:e.maxPriorityFeePerGas,chainId:e.chainId!==void 0?`0x${e.chainId.toString(16)}`:void 0}}async signTransaction(e,s,t,o,n){const i={unsignedTx:this.buildUnsignedTx(t),password:this.requirePassword()};n&&(i.uuid=n);const a=await this.request("POST",`/mnemonic/sign/${encodeURIComponent(s)}`,i);return{chainId:s,signature:a.signedTx,txHash:a.txHash,format:"hex"}}async sendTransaction(e,s,t,o){const n={unsignedTx:this.buildUnsignedTx(t),password:this.requirePassword()};return o&&(n.uuid=o),{txHash:(await this.request("POST",`/mnemonic/send/${encodeURIComponent(s)}`,n)).txHash}}async migrateWallet(e,s){h.log("[CROSSx][Migration Phase 4] POST /mnemonic/migrate 호출 — sub:",s);const t={recoveryPin:e,sub:s,password:this.requirePassword()},o=await this.request("POST","/mnemonic/migrate",t);return h.log("[CROSSx][Migration Phase 4] /mnemonic/migrate 완료 — address:",o.address),{id:s,address:o.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}async withdrawWallet(e){const s={confirmation:e,password:this.requirePassword()};await this.request("POST","/mnemonic/withdraw",s)}async verifyPassword(e){const s={password:e};return(await this.request("POST","/mnemonic/verify-password",s)).verified}async changePassword(e,s){const t={password:this.requirePassword(),newPassword:s};await this.request("POST","/mnemonic/change-password",t)}async getShareC(){const e={password:this.requirePassword()};return(await this.request("POST","/mnemonic/share-c",e)).shareC}async verifyPin(e,s){const t={recoveryPin:e,sub:s};return this.request("POST","/mnemonic/verify-recovery-pin",t)}requirePassword(){const e=this.getPassword();if(!e)throw new m(_.PASSWORD_NOT_SET,"비밀번호가 설정되지 않았습니다. 비밀번호를 입력해 주세요.");return e}static mapGatewayError(e,s){switch(e){case-10002:return _.AUTH_NOT_AUTHENTICATED;case-10001:case-10009:return _.UNKNOWN_ERROR;case-10006:return _.GATEWAY_INTERNAL_ERROR;case-10008:return _.GATEWAY_LOCK_CONFLICT;case-10010:return _.MIGRATION_FAILED;case-10012:return _.MIGRATION_BACKUP_EXISTS;case-10027:return _.MIGRATION_PIN_LOCKED;case-10022:return _.PROJECT_NOT_REGISTERED;case-10023:return _.PROJECT_ID_MISSING;case-10024:return _.ORIGIN_NOT_ALLOWED;case-10028:return _.PASSWORD_WRONG;case-10029:return _.PASSWORD_COMPLEXITY;case-10030:return _.WALLET_INCONSISTENT_STATE;case-10026:return _.TYPED_DATA_CHAIN_ID_MISMATCH;case-10014:case-10015:case-10019:return _.PREPARE_FAILED;case-10016:return _.PREPARE_EXPIRED;case-10017:case-10018:return _.PREPARE_MISMATCH;default:return _.UNKNOWN_ERROR}}static getGatewayErrorMessage(e,s){switch(e){case-10002:return"Session expired. Please sign in again.";case-10006:return"Internal server error. Please try again later.";case-10008:return"Another operation is in progress. Please try again later.";case-10022:return"Project is not whitelisted. Verify your projectId and register the current origin in the management console.";case-10023:return"Project ID is required. Set the projectId field in SDKConfig.";case-10024:return"Origin is not in the allowed list. Register the current domain in the management console.";case-10026:return"Domain chainId mismatch: the chainId in typedData.domain does not match the request chainId.";case-10028:return"Incorrect password. Please try again.";case-10029:return"Password does not meet complexity requirements. Please use a stronger password.";case-10027:return"Too many incorrect PIN attempts. Your account has been temporarily locked.";case-10030:return"Wallet is in an inconsistent state. Please contact support.";default:return`Request failed (${e}): ${s}`}}}class Pe{constructor(e,s){this.cache=new Map,this.loadedAt=0,this.usingFallback=!1,this.adapterConfig=e,this.projectId=e.projectId,this.transport=s}get baseUrl(){return this.adapterConfig.gatewayUrl}async getChains(){if(this.isCacheValid())return Array.from(this.cache.values());try{const e=await this.request("/chains");this.handleEnvelopeError(e);const s=e.data.chains;return this.populateCache(s,!1),s}catch{const e=Pe.fallbackChains();return this.populateCache(e,!0),e}}async getChain(e){const t=(await this.getChains()).find(o=>o.chainId===e);return t||this.fallbackOrThrow(e)}invalidateCache(){this.cache.clear(),this.loadedAt=0,this.usingFallback=!1}isCacheValid(){if(this.loadedAt===0)return!1;const e=this.usingFallback?tr:er;return e===0?!0:Date.now()-this.loadedAt<e}populateCache(e,s){this.cache.clear();for(const t of e)this.cache.set(t.chainId,t);this.loadedAt=Date.now(),this.usingFallback=s}async request(e){return(await this.transport.request({url:`${this.baseUrl}${e}`,method:"GET",headers:{"X-Project-Id":this.projectId}})).data}handleEnvelopeError(e){if(e.code<0){const s=typeof e.data=="string"?e.data:e.message??"체인 레지스트리 요청에 실패했습니다";throw new m(Pe.mapErrorCode(e.code),s)}}fallbackOrThrow(e){const s=Pe.fallbackChains().find(t=>t.chainId===e);if(s)return s;throw new m(_.CHAIN_NOT_SUPPORTED,`지원하지 않는 체인: ${e}`)}static fallbackChains(){return Object.values(je).map(e=>({chainId:e.caipId,rpcUrl:e.rpcUrl}))}static mapErrorCode(e){switch(e){case-10020:return _.CHAIN_NOT_SUPPORTED;case-10021:return _.INVALID_CHAIN;case-10022:return _.PROJECT_NOT_REGISTERED;case-10023:return _.PROJECT_ID_MISSING;case-10024:return _.APP_IDENTIFIER_MISSING;case-10025:return _.INVALID_APP_TYPE;default:return _.UNKNOWN_ERROR}}}const jt="__crossx-confirm-style",z="__crossx-confirm-overlay",go={light:{bg:"#FFFFFF",border:"rgba(18,18,18,0.05)",titleColor:"#121212",subtitleColor:"rgba(18,18,18,0.7)",labelColor:"rgba(18,18,18,0.5)",valueColor:"#121212",pillBg:"rgba(18,18,18,0.05)",pillFromColor:"rgba(18,18,18,0.5)",pillAmtColor:"#121212",divider:"rgba(18,18,18,0.1)",closeColor:"#121212",closeHoverBg:"rgba(18,18,18,0.05)",copyColor:"rgba(18,18,18,0.5)",inputBg:"rgba(18,18,18,0.05)",inputBorder:"rgba(18,18,18,0.1)",hintColor:"rgba(18,18,18,0.5)",surfaceSubtle:"rgba(18,18,18,0.1)",primary:"#019D92",primaryGlow:"rgba(1,157,146,0.15)",secondary:"#E70077",errorColor:"#E70077",onPrimary:"#FFFFFF"},dark:{bg:"#121212",border:"rgba(255,255,255,0.05)",titleColor:"#FFFFFF",subtitleColor:"rgba(255,255,255,0.7)",labelColor:"rgba(255,255,255,0.5)",valueColor:"#FFFFFF",pillBg:"rgba(255,255,255,0.05)",pillFromColor:"rgba(255,255,255,0.5)",pillAmtColor:"#FFFFFF",divider:"rgba(255,255,255,0.1)",closeColor:"#FFFFFF",closeHoverBg:"rgba(255,255,255,0.05)",copyColor:"rgba(255,255,255,0.5)",inputBg:"rgba(255,255,255,0.05)",inputBorder:"rgba(255,255,255,0.1)",hintColor:"rgba(255,255,255,0.5)",surfaceSubtle:"rgba(255,255,255,0.1)",primary:"#019D92",primaryGlow:"rgba(1,157,146,0.15)",secondary:"#E70077",errorColor:"#E70077",onPrimary:"#FFFFFF"}};function Yt(r,e){const s=go[r],t=e==null?void 0:e[r];return t?{...s,...t.primary!==void 0&&{primary:t.primary},...t.secondary!==void 0&&{secondary:t.secondary},...t.onPrimary!==void 0&&{onPrimary:t.onPrimary},...t.borderDefault!==void 0&&{border:t.borderDefault},...t.borderSubtle!==void 0&&{divider:t.borderSubtle,inputBorder:t.borderSubtle},...t.textIconPrimary!==void 0&&{titleColor:t.textIconPrimary,valueColor:t.textIconPrimary,pillAmtColor:t.textIconPrimary,closeColor:t.textIconPrimary},...t.textIconSecondary!==void 0&&{subtitleColor:t.textIconSecondary},...t.textIconTertiary!==void 0&&{labelColor:t.textIconTertiary,pillFromColor:t.textIconTertiary,copyColor:t.textIconTertiary,hintColor:t.textIconTertiary},...t.surfaceDefault!==void 0&&{pillBg:t.surfaceDefault,closeHoverBg:t.surfaceDefault,inputBg:t.surfaceDefault},...t.surfaceSubtle!==void 0&&{surfaceSubtle:t.surfaceSubtle},...t.bg!==void 0&&{bg:t.bg},...t.error!==void 0&&{errorColor:t.error}}:s}const xo=`
3
3
  @import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600&display=swap');
4
4
 
5
- #${te} {
5
+ #${z} {
6
6
  position: fixed;
7
7
  inset: 0;
8
8
  z-index: 2147483647;
@@ -207,6 +207,295 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
207
207
  }
208
208
 
209
209
 
210
+ /* ── Password Modals ───────────────────────────────────────────── */
211
+ .__crossx-card--password {
212
+ width: 560px;
213
+ display: flex;
214
+ flex-direction: column;
215
+ max-height: 90vh;
216
+ }
217
+ .__crossx-pw-body {
218
+ padding: 20px 64px 24px;
219
+ display: flex;
220
+ flex-direction: column;
221
+ gap: 24px;
222
+ overflow: hidden;
223
+ flex: 1;
224
+ min-height: 0;
225
+ }
226
+ .__crossx-pw-fields {
227
+ display: flex;
228
+ flex-direction: column;
229
+ gap: 24px;
230
+ }
231
+ .__crossx-pw-fields--setup {
232
+ flex: 1;
233
+ min-height: 0;
234
+ overflow-y: auto;
235
+ -webkit-overflow-scrolling: touch;
236
+ }
237
+ .__crossx-pw-fg--confirm {
238
+ margin-top: 8px;
239
+ }
240
+ .__crossx-pw-field-group {
241
+ display: flex;
242
+ flex-direction: column;
243
+ gap: 8px;
244
+ }
245
+ .__crossx-pw-label {
246
+ font-size: 14px;
247
+ font-weight: 400;
248
+ line-height: 1.4;
249
+ color: var(--cx-value);
250
+ }
251
+ .__crossx-pw-input-wrap {
252
+ position: relative;
253
+ display: flex;
254
+ align-items: center;
255
+ background: var(--cx-input-bg);
256
+ border: 1px solid var(--cx-input-border);
257
+ border-radius: 12px;
258
+ height: 56px;
259
+ padding: 0 16px;
260
+ transition: border-color 0.15s;
261
+ }
262
+ .__crossx-pw-input-wrap:focus-within {
263
+ border-color: var(--cx-primary);
264
+ }
265
+ .__crossx-pw-input-wrap.--error {
266
+ background: rgba(231,0,119,0.08);
267
+ border-color: var(--cx-error);
268
+ }
269
+ .__crossx-pw-input {
270
+ flex: 1;
271
+ border: none;
272
+ background: transparent;
273
+ font-size: 16px;
274
+ font-family: inherit;
275
+ color: var(--cx-value);
276
+ outline: none;
277
+ padding: 0;
278
+ min-width: 0;
279
+ }
280
+ .__crossx-pw-input::placeholder {
281
+ color: var(--cx-hint);
282
+ }
283
+ .__crossx-pw-toggle {
284
+ background: none;
285
+ border: none;
286
+ cursor: pointer;
287
+ color: var(--cx-hint);
288
+ padding: 4px;
289
+ display: flex;
290
+ align-items: center;
291
+ flex-shrink: 0;
292
+ opacity: 0.7;
293
+ }
294
+ .__crossx-pw-toggle:hover { opacity: 1; }
295
+ .__crossx-pw-rules {
296
+ display: flex;
297
+ flex-direction: column;
298
+ gap: 8px;
299
+ }
300
+ .__crossx-pw-rule {
301
+ display: flex;
302
+ align-items: center;
303
+ gap: 8px;
304
+ }
305
+ .__crossx-pw-rule-dot {
306
+ width: 16px;
307
+ height: 16px;
308
+ border-radius: 50%;
309
+ background: var(--cx-input-border);
310
+ display: flex;
311
+ align-items: center;
312
+ justify-content: center;
313
+ flex-shrink: 0;
314
+ transition: background 0.15s;
315
+ }
316
+ .__crossx-pw-rule-dot.--met {
317
+ background: var(--cx-primary);
318
+ }
319
+ .__crossx-pw-rule-dot svg {
320
+ width: 9px;
321
+ height: 7px;
322
+ }
323
+ .__crossx-pw-rule-text {
324
+ font-size: 14px;
325
+ font-weight: 400;
326
+ line-height: 1.4;
327
+ color: var(--cx-value);
328
+ }
329
+ .__crossx-pw-error-text {
330
+ font-size: 14px;
331
+ font-weight: 400;
332
+ line-height: 1.4;
333
+ color: var(--cx-error);
334
+ margin-top: 4px;
335
+ }
336
+ .__crossx-pw-confirm-group {
337
+ display: flex;
338
+ flex-direction: column;
339
+ gap: 24px;
340
+ }
341
+ .__crossx-pw-confirm-group.--has-error {
342
+ gap: 16px;
343
+ }
344
+ .__crossx-pw-lock {
345
+ display: flex;
346
+ align-items: center;
347
+ flex-shrink: 0;
348
+ color: var(--cx-hint);
349
+ opacity: 0.6;
350
+ pointer-events: none;
351
+ }
352
+ .__crossx-pw-btn {
353
+ width: 100%;
354
+ height: 56px;
355
+ border: none;
356
+ border-radius: 12px;
357
+ font-size: 16px;
358
+ font-weight: 600;
359
+ font-family: inherit;
360
+ cursor: pointer;
361
+ transition: background 0.15s, color 0.15s;
362
+ background: var(--cx-input-border);
363
+ color: var(--cx-hint);
364
+ }
365
+ .__crossx-pw-btn:not(:disabled):not(.--disabled) {
366
+ background: var(--cx-primary);
367
+ color: var(--cx-on-primary);
368
+ }
369
+ .__crossx-pw-btn.--loading {
370
+ opacity: 0.6;
371
+ cursor: not-allowed;
372
+ }
373
+ .__crossx-pw-subtitle {
374
+ font-size: 15px;
375
+ font-weight: 400;
376
+ line-height: 1.6;
377
+ color: var(--cx-subtitle);
378
+ margin: 0;
379
+ }
380
+
381
+ /* ── Password Notice (Consent) Screen ─────────────────────────── */
382
+ .__crossx-pw-notice-header {
383
+ display: flex;
384
+ flex-direction: column;
385
+ gap: 8px;
386
+ }
387
+ .__crossx-pw-notice-title-row {
388
+ display: flex;
389
+ align-items: center;
390
+ gap: 8px;
391
+ }
392
+ .__crossx-pw-notice-icon {
393
+ width: 28px;
394
+ height: 28px;
395
+ flex-shrink: 0;
396
+ color: var(--cx-error);
397
+ }
398
+ .__crossx-pw-notice-title {
399
+ font-size: 22px;
400
+ font-weight: 600;
401
+ line-height: 1.3;
402
+ color: var(--cx-error);
403
+ margin: 0;
404
+ white-space: nowrap;
405
+ }
406
+ .__crossx-pw-notice-desc {
407
+ font-size: 14px;
408
+ font-weight: 400;
409
+ line-height: 1.4;
410
+ color: var(--cx-value);
411
+ margin: 0;
412
+ }
413
+ .__crossx-pw-notice-checks {
414
+ display: flex;
415
+ flex-direction: column;
416
+ gap: 8px;
417
+ }
418
+ .__crossx-pw-notice-item {
419
+ display: flex;
420
+ align-items: center;
421
+ gap: 12px;
422
+ padding: 16px;
423
+ border-radius: 12px;
424
+ background: var(--cx-input-bg);
425
+ cursor: pointer;
426
+ user-select: none;
427
+ transition: background 0.15s;
428
+ }
429
+ .__crossx-pw-notice-item:hover {
430
+ background: var(--cx-input-border);
431
+ }
432
+ .__crossx-pw-notice-item.--highlight {
433
+ animation: __crossx-notice-pulse 0.5s ease;
434
+ }
435
+ @keyframes __crossx-notice-pulse {
436
+ 0% { background: var(--cx-input-bg); }
437
+ 40% { background: rgba(1,157,146,0.18); }
438
+ 100% { background: var(--cx-input-bg); }
439
+ }
440
+ .__crossx-pw-notice-check {
441
+ width: 20px;
442
+ height: 20px;
443
+ border-radius: 50%;
444
+ background: var(--cx-input-border);
445
+ display: flex;
446
+ align-items: center;
447
+ justify-content: center;
448
+ flex-shrink: 0;
449
+ transition: background 0.15s;
450
+ }
451
+ .__crossx-pw-notice-check.--checked {
452
+ background: var(--cx-primary);
453
+ }
454
+ .__crossx-pw-notice-check svg {
455
+ width: 11px;
456
+ height: 9px;
457
+ }
458
+ .__crossx-pw-notice-item-text {
459
+ font-size: 14px;
460
+ font-weight: 400;
461
+ line-height: 1.4;
462
+ color: var(--cx-value);
463
+ flex: 1;
464
+ }
465
+ /* Notice screen: button shows primary+opacity even when disabled (interactive guide) */
466
+ .__crossx-pw-body > .__crossx-pw-btn.--disabled {
467
+ background: var(--cx-primary);
468
+ color: var(--cx-on-primary);
469
+ opacity: 0.5;
470
+ cursor: pointer;
471
+ }
472
+ /* Home indicator bar (mobile only – shown via media query) */
473
+ .__crossx-home-indicator {
474
+ display: none;
475
+ justify-content: center;
476
+ align-items: flex-end;
477
+ padding-bottom: 8px;
478
+ height: 34px;
479
+ flex-shrink: 0;
480
+ width: 100%;
481
+ }
482
+ .__crossx-home-indicator::after {
483
+ content: '';
484
+ display: block;
485
+ width: 134px;
486
+ height: 5px;
487
+ border-radius: 16px;
488
+ background: var(--cx-value);
489
+ opacity: 0.3;
490
+ }
491
+ .__crossx-pw-subtitle--tertiary {
492
+ font-size: 14px;
493
+ font-weight: 400;
494
+ line-height: 1.3;
495
+ color: var(--cx-hint);
496
+ margin: 0;
497
+ }
498
+
210
499
  /* ── Migration Found Modal ─────────────────────────────────────── */
211
500
  .__crossx-card--migration {
212
501
  width: 560px;
@@ -342,7 +631,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
342
631
  box-shadow: 0 0 0 2px var(--cx-primary-glow);
343
632
  }
344
633
  .__crossx-pin-input.--error {
345
- border-color: var(--cx-secondary);
634
+ border-color: var(--cx-error);
346
635
  }
347
636
  .__crossx-pin-hint {
348
637
  font-size: 16px;
@@ -358,10 +647,69 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
358
647
  font-size: 14px;
359
648
  font-weight: 500;
360
649
  line-height: 1.4;
361
- color: var(--cx-secondary);
650
+ color: var(--cx-error);
362
651
  text-align: center;
363
652
  margin: 0;
364
653
  }
654
+ .__crossx-pin-attempt {
655
+ font-size: 16px;
656
+ font-weight: 500;
657
+ line-height: 1.5;
658
+ color: var(--cx-error);
659
+ text-align: center;
660
+ font-family: 'Pretendard', -apple-system, sans-serif;
661
+ letter-spacing: -0.16px;
662
+ margin: 0;
663
+ }
664
+ .__crossx-pin-warning {
665
+ font-size: 16px;
666
+ font-weight: 500;
667
+ line-height: 1.5;
668
+ color: var(--cx-error);
669
+ text-align: center;
670
+ font-family: 'Pretendard', -apple-system, sans-serif;
671
+ letter-spacing: -0.16px;
672
+ margin: 0;
673
+ }
674
+
675
+ /* ── PIN Lock Modal ─────────────────────────────────────────── */
676
+ .__crossx-pin-dot {
677
+ width: 68px;
678
+ height: 68px;
679
+ border-radius: 12px;
680
+ background: var(--cx-input-bg);
681
+ display: flex;
682
+ align-items: center;
683
+ justify-content: center;
684
+ font-size: 24px;
685
+ color: var(--cx-subtitle);
686
+ flex-shrink: 0;
687
+ }
688
+ .__crossx-pin-lock-messages {
689
+ display: flex;
690
+ flex-direction: column;
691
+ gap: 4px;
692
+ text-align: center;
693
+ width: 100%;
694
+ }
695
+ .__crossx-pin-lock-message {
696
+ font-size: 16px;
697
+ font-weight: 500;
698
+ line-height: 1.5;
699
+ color: var(--cx-error);
700
+ font-family: 'Pretendard', -apple-system, sans-serif;
701
+ letter-spacing: -0.16px;
702
+ margin: 0;
703
+ }
704
+ .__crossx-pin-lock-secondary {
705
+ font-size: 16px;
706
+ font-weight: 500;
707
+ line-height: 1.5;
708
+ color: var(--cx-subtitle);
709
+ font-family: 'Pretendard', -apple-system, sans-serif;
710
+ letter-spacing: -0.16px;
711
+ margin: 0;
712
+ }
365
713
 
366
714
  /* ── Signature Request modals (message & typed data) ───────── */
367
715
  .__crossx-sig-subtitle {
@@ -729,16 +1077,19 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
729
1077
  white-space: nowrap;
730
1078
  }
731
1079
  .__crossx-wallet-selected {
732
- font-size: 11px;
1080
+ font-size: 14px;
733
1081
  font-weight: 600;
734
- line-height: 1;
735
- color: var(--cx-primary);
736
- border: 1.5px solid var(--cx-primary);
737
- border-radius: 6px;
738
- padding: 4px 8px;
1082
+ line-height: 1.4;
1083
+ color: #ffffff;
1084
+ background: var(--cx-primary);
1085
+ border-radius: 12px;
1086
+ height: 28px;
1087
+ padding: 0 12px;
739
1088
  margin-left: auto;
740
1089
  flex-shrink: 0;
741
1090
  white-space: nowrap;
1091
+ display: flex;
1092
+ align-items: center;
742
1093
  }
743
1094
  .__crossx-wallet-add {
744
1095
  display: flex;
@@ -784,7 +1135,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
784
1135
 
785
1136
  /* ── Mobile bottom sheet ───────────────────────────────────── */
786
1137
  @media (max-width: 480px) {
787
- #${te} { align-items: flex-end; }
1138
+ #${z} { align-items: flex-end; }
788
1139
  .__crossx-card {
789
1140
  width: 100%;
790
1141
  max-width: 100%;
@@ -804,6 +1155,42 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
804
1155
  .__crossx-login-btn-label {
805
1156
  white-space: normal;
806
1157
  }
1158
+ /* ── Password card: mobile bottom sheet ── */
1159
+ .__crossx-card--password {
1160
+ width: 100% !important;
1161
+ max-width: 100% !important;
1162
+ border-radius: 20px 20px 0 0 !important;
1163
+ border: 1px solid rgba(18,18,18,0.05) !important;
1164
+ border-bottom: none !important;
1165
+ max-height: 92vh;
1166
+ overflow: hidden;
1167
+ display: flex;
1168
+ flex-direction: column;
1169
+ animation: __crossx-slide-up-mobile 0.25s ease;
1170
+ }
1171
+ .__crossx-card--password .__crossx-header {
1172
+ padding: 16px 20px;
1173
+ flex-shrink: 0;
1174
+ }
1175
+ .__crossx-card--password .__crossx-title {
1176
+ font-size: 16px;
1177
+ margin-bottom: 0;
1178
+ }
1179
+ .__crossx-card--password .__crossx-pw-subtitle,
1180
+ .__crossx-card--password .__crossx-pw-subtitle--tertiary { display: none; }
1181
+ .__crossx-card--password > .__crossx-divider { display: none; }
1182
+ .__crossx-card--password .__crossx-pw-body {
1183
+ flex: 1;
1184
+ min-height: 0;
1185
+ overflow-y: auto;
1186
+ -webkit-overflow-scrolling: touch;
1187
+ padding: 0 20px 20px;
1188
+ gap: 16px;
1189
+ }
1190
+ .__crossx-card--password .__crossx-pw-fields { gap: 16px; }
1191
+ .__crossx-card--password .__crossx-pw-notice-title { font-size: 20px; }
1192
+ .__crossx-card--password .__crossx-pw-fg--confirm { margin-top: 0; }
1193
+ .__crossx-home-indicator { display: flex; }
807
1194
  }
808
1195
  @keyframes __crossx-slide-up-mobile {
809
1196
  from { transform: translateY(100%); }
@@ -831,7 +1218,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
831
1218
 
832
1219
  /* ── Landscape for signing/transaction modals ──────────── */
833
1220
  @media (orientation: landscape) and (max-height: 500px) {
834
- #${te} { align-items: center !important; overflow: hidden; }
1221
+ #${z} { align-items: center !important; overflow: hidden; }
835
1222
  .__crossx-card--send-tx,
836
1223
  .__crossx-card--sign-tx,
837
1224
  .__crossx-card--sign-msg,
@@ -913,57 +1300,113 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
913
1300
  min-height: 0;
914
1301
  }
915
1302
  .__crossx-card--wallet-selector .__crossx-wallet-add { flex-shrink: 0; }
916
- }
917
- `;function me(){let r=document.getElementById(Wt);r||(r=document.createElement("style"),r.id=Wt,document.head.appendChild(r)),r.textContent=hn}function Y(r){return r?r.length<=13?r:`${r.slice(0,6)}…${r.slice(-4)}`:"—"}function fn(r,e="CROSS",s=18){if(!r||r==="0x"||r==="0x0")return null;try{const t=BigInt(r);if(t===0n)return null;const n=it(t,s);return n==="0"?null:`${n} ${e}`}catch{return null}}const Vt={1:"Ethereum Mainnet",5:"Goerli Testnet",11155111:"Ethereum Sepolia",17e3:"Ethereum Holesky",10:"Optimism",420:"Optimism Goerli",42161:"Arbitrum One",421614:"Arbitrum Sepolia",8453:"Base",84532:"Base Sepolia",137:"Polygon",80002:"Polygon Amoy",56:"BNB Smart Chain",97:"BNB Testnet",43114:"Avalanche C-Chain",43113:"Avalanche Fuji",250:"Fantom Opera",2020:"Ronin",202601:"Ronin Saigon",612044:"CROSS Testnet",612055:"CROSS Mainnet"};function Ts(r){const e=parseInt(r.split(":")[1]??"",10);return!isNaN(e)&&Vt[e]?Vt[e]:r}function it(r,e){if(r===0n)return"0";const s=10n**BigInt(e),t=r/s,i=(r%s).toString().padStart(e,"0").slice(0,6).replace(/0+$/,"");return i?`${t}.${i}`:`${t}`}function st(r){try{const e=BigInt(r),s=e/1000000000n,n=(e%1000000000n).toString().padStart(9,"0").slice(0,2).replace(/0+$/,"");return n?`${s}.${n}`:`${s}`}catch{return r}}function pn(r){try{return BigInt(r).toLocaleString()}catch{return r}}function gn(r){const{gasLimit:e,gasPrice:s,maxFeePerGas:t,maxPriorityFeePerGas:n,nativeSymbol:o="ETH",nativeDecimals:i=18}=r;if(!e)return null;try{const a=BigInt(e),c=pn(e);if(t){const l=a*BigInt(t);return{isDynamic:!0,estTxFee:`${it(l,i)} ${o}`,maxFeeGwei:st(t),maxPriorityFeeGwei:n?st(n):void 0,gasLimitFormatted:c}}if(s){const l=a*BigInt(s);return{isDynamic:!1,estTxFee:`${it(l,i)} ${o}`,gasPriceGwei:st(s),gasLimitFormatted:c}}return{isDynamic:!1,estTxFee:`${a.toLocaleString()} gas`,gasLimitFormatted:c}}catch{return null}}function Is(r){const e=gn(r);if(!e)return q("Estimated fee","<span>—</span>");let s=q("Est. Tx Fee",`<span>${e.estTxFee}</span>`);return e.isDynamic?(e.maxPriorityFeeGwei!==void 0&&(s+=q("Max Priority Fee",`<span>${e.maxPriorityFeeGwei} Gwei</span>`)),e.maxFeeGwei!==void 0&&(s+=q("Max Gas Fee",`<span>${e.maxFeeGwei} Gwei</span>`))):e.gasPriceGwei!==void 0&&(s+=q("Gas Price",`<span>${e.gasPriceGwei} Gwei</span>`)),e.gasLimitFormatted&&(s+=q("Gas Limit",`<span>${e.gasLimitFormatted}</span>`)),s}const de=`<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
1303
+
1304
+ /* ── Password / Notice modal landscape ─────────────────────────── */
1305
+ .__crossx-card--password {
1306
+ width: 640px;
1307
+ max-width: calc(100vw - 32px);
1308
+ border-radius: 24px;
1309
+ border-bottom: 4px solid var(--cx-border);
1310
+ max-height: calc(100vh - 32px);
1311
+ overflow: hidden;
1312
+ display: flex;
1313
+ flex-direction: column;
1314
+ }
1315
+ .__crossx-card--password .__crossx-header {
1316
+ flex-shrink: 0;
1317
+ padding: 16px 24px 12px;
1318
+ }
1319
+ .__crossx-card--password > .__crossx-divider { flex-shrink: 0; }
1320
+ .__crossx-card--password .__crossx-pw-body {
1321
+ flex: 1;
1322
+ min-height: 0;
1323
+ overflow: hidden;
1324
+ padding: 16px 24px 20px;
1325
+ gap: 16px;
1326
+ }
1327
+ /* Notice: scrollable content, button fixed at bottom */
1328
+ .__crossx-card--password .__crossx-pw-fields--notice {
1329
+ flex: 1;
1330
+ min-height: 0;
1331
+ overflow-y: auto;
1332
+ -webkit-overflow-scrolling: touch;
1333
+ }
1334
+ /* Setup & Notice: button pinned at bottom of body */
1335
+ .__crossx-card--password .__crossx-pw-body > .__crossx-pw-btn {
1336
+ flex-shrink: 0;
1337
+ margin-top: 4px;
1338
+ }
1339
+ /* Create Password: 2-column grid layout */
1340
+ .__crossx-card--password .__crossx-pw-fields--setup {
1341
+ display: grid;
1342
+ grid-template-columns: 1fr 1fr;
1343
+ grid-template-areas:
1344
+ "new rules"
1345
+ "conf rules";
1346
+ gap: 16px 24px;
1347
+ align-items: start;
1348
+ flex: 1;
1349
+ min-height: 0;
1350
+ overflow-y: auto;
1351
+ -webkit-overflow-scrolling: touch;
1352
+ }
1353
+ .__crossx-card--password .__crossx-pw-fg--new { grid-area: new; }
1354
+ .__crossx-card--password .__crossx-pw-fg--confirm { grid-area: conf; margin-top: 0; }
1355
+ .__crossx-card--password .__crossx-pw-rules { grid-area: rules; padding-top: 24px; align-self: start; }
1356
+ /* Consent / notice modal adjustments */
1357
+ .__crossx-card--password .__crossx-pw-notice-title { font-size: 18px; }
1358
+ .__crossx-card--password .__crossx-pw-notice-item { padding: 12px 14px; }
1359
+ }
1360
+ `;function ce(){let r=document.getElementById(jt);r||(r=document.createElement("style"),r.id=jt,document.head.appendChild(r)),r.textContent=xo}function X(r){return r?r.length<=13?r:`${r.slice(0,6)}…${r.slice(-4)}`:"—"}function wo(r,e="CROSS",s=18){if(!r||r==="0x"||r==="0x0")return null;try{const t=BigInt(r);if(t===0n)return null;const o=lt(t,s);return o==="0"?null:`${o} ${e}`}catch{return null}}const Zt={1:"Ethereum Mainnet",5:"Goerli Testnet",11155111:"Ethereum Sepolia",17e3:"Ethereum Holesky",10:"Optimism",420:"Optimism Goerli",42161:"Arbitrum One",421614:"Arbitrum Sepolia",8453:"Base",84532:"Base Sepolia",137:"Polygon",80002:"Polygon Amoy",56:"BNB Smart Chain",97:"BNB Testnet",43114:"Avalanche C-Chain",43113:"Avalanche Fuji",250:"Fantom Opera",2020:"Ronin",202601:"Ronin Saigon",612044:"CROSS Testnet",612055:"CROSS Mainnet"};function Rs(r){const e=parseInt(r.split(":")[1]??"",10);return!isNaN(e)&&Zt[e]?Zt[e]:r}function lt(r,e){if(r===0n)return"0";const s=10n**BigInt(e),t=r/s,i=(r%s).toString().padStart(e,"0").slice(0,6).replace(/0+$/,"");return i?`${t}.${i}`:`${t}`}function nt(r){try{const e=BigInt(r),s=e/1000000000n,o=(e%1000000000n).toString().padStart(9,"0").slice(0,2).replace(/0+$/,"");return o?`${s}.${o}`:`${s}`}catch{return r}}function mo(r){try{return BigInt(r).toLocaleString()}catch{return r}}function yo(r){const{gasLimit:e,gasPrice:s,maxFeePerGas:t,maxPriorityFeePerGas:o,nativeSymbol:n="ETH",nativeDecimals:i=18}=r;if(!e)return null;try{const a=BigInt(e),c=mo(e);if(t){const l=a*BigInt(t);return{isDynamic:!0,estTxFee:`${lt(l,i)} ${n}`,maxFeeGwei:nt(t),maxPriorityFeeGwei:o?nt(o):void 0,gasLimitFormatted:c}}if(s){const l=a*BigInt(s);return{isDynamic:!1,estTxFee:`${lt(l,i)} ${n}`,gasPriceGwei:nt(s),gasLimitFormatted:c}}return{isDynamic:!1,estTxFee:`${a.toLocaleString()} gas`,gasLimitFormatted:c}}catch{return null}}function Ps(r){const e=yo(r);if(!e)return W("Estimated fee","<span>—</span>");let s=W("Est. Tx Fee",`<span>${e.estTxFee}</span>`);return e.isDynamic?(e.maxPriorityFeeGwei!==void 0&&(s+=W("Max Priority Fee",`<span>${e.maxPriorityFeeGwei} Gwei</span>`)),e.maxFeeGwei!==void 0&&(s+=W("Max Gas Fee",`<span>${e.maxFeeGwei} Gwei</span>`))):e.gasPriceGwei!==void 0&&(s+=W("Gas Price",`<span>${e.gasPriceGwei} Gwei</span>`)),e.gasLimitFormatted&&(s+=W("Gas Limit",`<span>${e.gasLimitFormatted}</span>`)),s}const he=`<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
918
1361
  <rect x="9" y="9" width="13" height="13" rx="2"/>
919
1362
  <path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"/>
920
- </svg>`,ie=`<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round">
1363
+ </svg>`,te=`<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round">
921
1364
  <line x1="18" y1="6" x2="6" y2="18"/>
922
1365
  <line x1="6" y1="6" x2="18" y2="18"/>
923
- </svg>`;function _n(r){return`<svg width="28" height="28" viewBox="0 0 28 28" fill="none">
1366
+ </svg>`;function bo(r){return`<svg width="28" height="28" viewBox="0 0 28 28" fill="none">
924
1367
  <circle cx="14" cy="14" r="14" fill="${r}"/>
925
1368
  <path d="M14 7.5L19.2 10.5V16.5L14 19.5L8.8 16.5V10.5L14 7.5Z" fill="white" opacity="0.9"/>
926
- </svg>`}const _t=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
1369
+ </svg>`}const mt=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
927
1370
  <rect x="2" y="5" width="16" height="12" rx="2" stroke="currentColor" stroke-width="1.5"/>
928
1371
  <path d="M2 9h16" stroke="currentColor" stroke-width="1.5"/>
929
1372
  <rect x="12.5" y="11.5" width="3.5" height="2.5" rx="0.75" fill="currentColor"/>
930
- </svg>`,xn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
931
- <path d="M12 0C18.6274 0 24 5.37258 24 12C23.9999 18.6273 18.6274 24 12 24C5.37264 24 9.89594e-05 18.6273 0 12C0 5.37258 5.37258 0 12 0ZM10.875 15.127V17.377H13.125V15.127H10.875ZM10.875 6.62207V13.627H13.125V6.62207H10.875Z" fill="var(--cx-secondary)"/>
932
- </svg>`,mn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
933
- <circle cx="12" cy="12" r="12" fill="var(--cx-secondary)"/>
1373
+ </svg>`,vo=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
1374
+ <path d="M12 0C18.6274 0 24 5.37258 24 12C23.9999 18.6273 18.6274 24 12 24C5.37264 24 9.89594e-05 18.6273 0 12C0 5.37258 5.37258 0 12 0ZM10.875 15.127V17.377H13.125V15.127H10.875ZM10.875 6.62207V13.627H13.125V6.62207H10.875Z" fill="var(--cx-error)"/>
1375
+ </svg>`,So=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
1376
+ <circle cx="12" cy="12" r="12" fill="var(--cx-error)"/>
934
1377
  <circle cx="12" cy="12" r="5.5" stroke="white" stroke-width="1.5"/>
935
1378
  <path d="M12 9.5v3l2 1.5" stroke="white" stroke-width="1.5" stroke-linecap="round"/>
936
- </svg>`;function ae(r){return[`--cx-bg:${r.bg}`,`--cx-border:${r.border}`,`--cx-title:${r.titleColor}`,`--cx-subtitle:${r.subtitleColor}`,`--cx-label:${r.labelColor}`,`--cx-value:${r.valueColor}`,`--cx-pill-bg:${r.pillBg}`,`--cx-pill-from:${r.pillFromColor}`,`--cx-pill-amt:${r.pillAmtColor}`,`--cx-divider:${r.divider}`,`--cx-close:${r.closeColor}`,`--cx-close-hover:${r.closeHoverBg}`,`--cx-copy:${r.copyColor}`,`--cx-input-bg:${r.inputBg}`,`--cx-input-border:${r.inputBorder}`,`--cx-hint:${r.hintColor}`,`--cx-primary:${r.primary}`,`--cx-primary-glow:${r.primaryGlow}`,`--cx-secondary:${r.secondary}`,`--cx-on-primary:${r.onPrimary}`].join(";")}function q(r,e){return`
1379
+ </svg>`;function re(r){return[`--cx-bg:${r.bg}`,`--cx-border:${r.border}`,`--cx-title:${r.titleColor}`,`--cx-subtitle:${r.subtitleColor}`,`--cx-label:${r.labelColor}`,`--cx-value:${r.valueColor}`,`--cx-pill-bg:${r.pillBg}`,`--cx-pill-from:${r.pillFromColor}`,`--cx-pill-amt:${r.pillAmtColor}`,`--cx-divider:${r.divider}`,`--cx-close:${r.closeColor}`,`--cx-close-hover:${r.closeHoverBg}`,`--cx-copy:${r.copyColor}`,`--cx-input-bg:${r.inputBg}`,`--cx-input-border:${r.inputBorder}`,`--cx-hint:${r.hintColor}`,`--cx-surface-subtle:${r.surfaceSubtle}`,`--cx-primary:${r.primary}`,`--cx-primary-glow:${r.primaryGlow}`,`--cx-secondary:${r.secondary}`,`--cx-error:${r.errorColor}`,`--cx-on-primary:${r.onPrimary}`].join(";")}function W(r,e){return`
937
1380
  <div class="__crossx-row">
938
1381
  <span class="__crossx-row-label">${r}</span>
939
1382
  <div class="__crossx-row-value">${e}</div>
940
- </div>`}function wn(r,e){const s=e,t=ze(),n=r.to?`<span class="__crossx-addr-text">${Y(r.to)}</span>
941
- <button class="__crossx-copy-btn" data-copy="${M(r.to)}" title="Copy address">${de}</button>`:"<span>—</span>",o=Is(r),i=r.data&&r.data!=="0x"?r.data:"0x",a=document.createElement("div");return a.id=te,a.innerHTML=`
942
- <div class="__crossx-card __crossx-card--migration __crossx-card--sign-tx" style="${ae(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1383
+ </div>`}function Eo(r,e){const s=e,t=Xe(),o=r.to?`<span class="__crossx-addr-text">${X(r.to)}</span>
1384
+ <button class="__crossx-copy-btn" data-copy="${T(r.to)}" title="Copy address">${he}</button>`:"<span>—</span>",n=Ps(r),i=r.data&&r.data!=="0x"?r.data:"0x",a=document.createElement("div");return a.id=z,a.innerHTML=`
1385
+ <div class="__crossx-card __crossx-card--migration __crossx-card--sign-tx" style="${re(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
943
1386
  <div class="__crossx-header">
944
1387
  <p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
945
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1388
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
946
1389
  </div>
947
1390
  <hr class="__crossx-divider">
948
1391
  <div class="__crossx-body">
949
1392
  <div class="__crossx-body-cols">
950
1393
  <div class="__crossx-col-left">
951
1394
  <p class="__crossx-sig-subtitle">
952
- <span class="__crossx-sig-origin">${M(t)} </span>is requesting a Signature
1395
+ <span class="__crossx-sig-origin">${T(t)} </span>is requesting a Signature
953
1396
  </p>
954
1397
  <div class="__crossx-addr-pill">
955
- ${_t}
956
- <span class="__crossx-addr-pill-text">${Y(r.from)}</span>
1398
+ ${mt}
1399
+ <span class="__crossx-addr-pill-text">${X(r.from)}</span>
957
1400
  </div>
958
1401
  <p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
959
1402
  <hr class="__crossx-divider">
960
1403
  <div class="__crossx-rows">
961
- ${q("To",n)}
962
- ${q("Network",`<span>${Ts(r.chainId)}</span>`)}
963
- ${o}
1404
+ ${W("To",o)}
1405
+ ${W("Network",`<span>${Rs(r.chainId)}</span>`)}
1406
+ ${n}
964
1407
  </div>
965
1408
  </div>
966
- <pre class="__crossx-raw-tx">${M(i)}</pre>
1409
+ <pre class="__crossx-raw-tx">${T(i)}</pre>
967
1410
  </div>
968
1411
  <div class="__crossx-btn-row">
969
1412
  <button class="__crossx-cancel-btn" id="__crossx-cancel-btn">Cancel</button>
@@ -971,59 +1414,59 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
971
1414
  </div>
972
1415
  </div>
973
1416
  </div>
974
- `,a}function yn(r,e){const s=e,t=r.nativeSymbol??"ETH",n=r.nativeDecimals??18,o=ze(),i=r.to?`<span class="__crossx-addr-text">${Y(r.to)}</span>
975
- <button class="__crossx-copy-btn" data-copy="${M(r.to)}" title="Copy address">${de}</button>`:"<span>—</span>",a=Is(r),l=fn(r.value,t,n)??"—",d=document.createElement("div");return d.id=te,d.innerHTML=`
976
- <div class="__crossx-card __crossx-card--migration __crossx-card--send-tx" style="${ae(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1417
+ `,a}function Io(r,e){const s=e,t=r.nativeSymbol??"ETH",o=r.nativeDecimals??18,n=Xe(),i=r.to?`<span class="__crossx-addr-text">${X(r.to)}</span>
1418
+ <button class="__crossx-copy-btn" data-copy="${T(r.to)}" title="Copy address">${he}</button>`:"<span>—</span>",a=Ps(r),l=wo(r.value,t,o)??"—",d=document.createElement("div");return d.id=z,d.innerHTML=`
1419
+ <div class="__crossx-card __crossx-card--migration __crossx-card--send-tx" style="${re(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
977
1420
  <div class="__crossx-header">
978
1421
  <p class="__crossx-title" id="__crossx-ttl">Approve transaction</p>
979
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1422
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
980
1423
  </div>
981
1424
  <hr class="__crossx-divider">
982
1425
  <div class="__crossx-body">
983
1426
  <p class="__crossx-tx-subtitle">
984
- <span class="__crossx-sig-origin">${M(o)}</span> wants your permission to approve the following transaction.
1427
+ <span class="__crossx-sig-origin">${T(n)}</span> wants your permission to approve the following transaction.
985
1428
  </p>
986
1429
  <div class="__crossx-body-cols">
987
1430
  <div class="__crossx-rows">
988
- ${q("To",i)}
989
- ${q("Network",`<span>${Ts(r.chainId)}</span>`)}
1431
+ ${W("To",i)}
1432
+ ${W("Network",`<span>${Rs(r.chainId)}</span>`)}
990
1433
  ${a}
991
1434
  </div>
992
1435
  <div class="__crossx-pill">
993
- <span class="__crossx-pill-from">${Y(r.from)}</span>
1436
+ <span class="__crossx-pill-from">${X(r.from)}</span>
994
1437
  <span class="__crossx-pill-amount">${l}</span>
995
1438
  </div>
996
1439
  </div>
997
1440
  <button class="__crossx-approve-btn" id="__crossx-confirm-btn">Approve</button>
998
1441
  </div>
999
1442
  </div>
1000
- `,d}function ze(){var r;try{return((r=window.location)==null?void 0:r.hostname)||"This site"}catch{return"This site"}}function M(r){return r.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function bn(r){return typeof r=="string"&&/^0x[0-9a-fA-F]{40}$/i.test(r)}function vn(r){if(typeof r=="string")return M(r);if(typeof r=="number"||typeof r=="bigint"||typeof r=="boolean")return String(r);try{return M(JSON.stringify(r))}catch{return String(r)}}function Sn(r,e){const s=q("From",`<span class="__crossx-addr-text">${Y(r.from)}</span>
1001
- <button class="__crossx-copy-btn" data-copy="${M(r.from)}" title="Copy address">${de}</button>`),t=r.to?q("To",`<span class="__crossx-addr-text">${Y(r.to)}</span>
1002
- <button class="__crossx-copy-btn" data-copy="${M(r.to)}" title="Copy address">${de}</button>`):"",n=r.amount?q("Transfer",`<span>${M(r.amount)}</span>`):"",o=r.fees?q("Tx Fee",`<span>${M(r.fees)}</span>`):"",i=r.txHash?q("Tx Hash",`<span class="__crossx-addr-text">${Y(r.txHash)}</span>
1003
- <button class="__crossx-copy-btn" data-copy="${M(r.txHash)}" title="Copy hash">${de}</button>`):"",a=r.total?`<div class="__crossx-total-pill">
1443
+ `,d}function Xe(){var r;try{return((r=window.location)==null?void 0:r.hostname)||"This site"}catch{return"This site"}}function T(r){return r.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function Ao(r){return typeof r=="string"&&/^0x[0-9a-fA-F]{40}$/i.test(r)}function To(r){if(typeof r=="string")return T(r);if(typeof r=="number"||typeof r=="bigint"||typeof r=="boolean")return String(r);try{return T(JSON.stringify(r))}catch{return String(r)}}function Co(r,e){const s=W("From",`<span class="__crossx-addr-text">${X(r.from)}</span>
1444
+ <button class="__crossx-copy-btn" data-copy="${T(r.from)}" title="Copy address">${he}</button>`),t=r.to?W("To",`<span class="__crossx-addr-text">${X(r.to)}</span>
1445
+ <button class="__crossx-copy-btn" data-copy="${T(r.to)}" title="Copy address">${he}</button>`):"",o=r.amount?W("Transfer",`<span>${T(r.amount)}</span>`):"",n=r.fees?W("Tx Fee",`<span>${T(r.fees)}</span>`):"",i=r.txHash?W("Tx Hash",`<span class="__crossx-addr-text">${X(r.txHash)}</span>
1446
+ <button class="__crossx-copy-btn" data-copy="${T(r.txHash)}" title="Copy hash">${he}</button>`):"",a=r.total?`<div class="__crossx-total-pill">
1004
1447
  <span class="__crossx-total-label">Total<br>(including fees)</span>
1005
- <span class="__crossx-total-amount">${M(r.total)}</span>
1006
- </div>`:"",c=document.createElement("div");return c.id=te,c.innerHTML=`
1007
- <div class="__crossx-card __crossx-card--migration" style="${ae(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1448
+ <span class="__crossx-total-amount">${T(r.total)}</span>
1449
+ </div>`:"",c=document.createElement("div");return c.id=z,c.innerHTML=`
1450
+ <div class="__crossx-card __crossx-card--migration" style="${re(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1008
1451
  <div class="__crossx-header">
1009
1452
  <p class="__crossx-title" id="__crossx-ttl">Transaction complete</p>
1010
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1453
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1011
1454
  </div>
1012
1455
  <hr class="__crossx-divider">
1013
1456
  <div class="__crossx-body">
1014
1457
  <div class="__crossx-rows">
1015
1458
  ${s}
1016
1459
  ${t}
1017
- ${n}
1018
1460
  ${o}
1461
+ ${n}
1019
1462
  ${i}
1020
1463
  </div>
1021
1464
  ${a}
1022
1465
  <button class="__crossx-approve-btn" id="__crossx-done-btn">All Done</button>
1023
1466
  </div>
1024
1467
  </div>
1025
- `,c}function En(r,e){const s=document.createElement("div");return s.id=te,s.innerHTML=`
1026
- <div class="__crossx-card __crossx-card--migration" style="${ae(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1468
+ `,c}function ko(r,e){const s=document.createElement("div");return s.id=z,s.innerHTML=`
1469
+ <div class="__crossx-card __crossx-card--migration" style="${re(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1027
1470
  <div class="__crossx-header">
1028
1471
  <p class="__crossx-title" id="__crossx-ttl">Waiting for confirmation</p>
1029
1472
  </div>
@@ -1035,43 +1478,43 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1035
1478
  </div>
1036
1479
  </div>
1037
1480
  </div>
1038
- `,s}function Tn(r,e,s){const t=e.status!=="reverted"&&e.status!=="timeout",n=e.status==="timeout",o=r.querySelector("#__crossx-ttl"),i=r.querySelector(".__crossx-header");if(o){const m=n?mn:t?"":xn,A=n?"Transaction timeout":t?"Transaction complete":"Transaction failed";m?(o.style.display="flex",o.style.alignItems="center",o.style.gap="8px",o.innerHTML=`${m}<span>${A}</span>`):o.textContent=A}if(i&&!r.querySelector("#__crossx-close-btn")){const m=document.createElement("button");m.className="__crossx-close",m.id="__crossx-close-btn",m.setAttribute("aria-label","Close"),m.innerHTML=ie,i.appendChild(m)}const a=r.querySelector("#__crossx-progress-body");if(!a)return;const c=e.from?q("From",`<span class="__crossx-addr-text">${Y(e.from)}</span>
1039
- <button class="__crossx-copy-btn" data-copy="${M(e.from)}" title="Copy address">${de}</button>`):"",l=e.to?q("To",`<span class="__crossx-addr-text">${Y(e.to)}</span>
1040
- <button class="__crossx-copy-btn" data-copy="${M(e.to)}" title="Copy address">${de}</button>`):"",d=e.amount?q("Transfer",`<span>${M(e.amount)}</span>`):"",f=e.fees?q("Tx Fee",`<span>${M(e.fees)}</span>`):"",w=e.txHash?q("Tx Hash",`<span class="__crossx-addr-text">${Y(e.txHash)}</span>
1041
- <button class="__crossx-copy-btn" data-copy="${M(e.txHash)}" title="Copy hash">${de}</button>`):"",_=e.total?`<div class="__crossx-total-pill">
1481
+ `,s}function Ro(r,e,s){const t=e.status!=="reverted"&&e.status!=="timeout",o=e.status==="timeout",n=r.querySelector("#__crossx-ttl"),i=r.querySelector(".__crossx-header");if(n){const p=o?So:t?"":vo,b=o?"Transaction timeout":t?"Transaction complete":"Transaction failed";p?(n.style.display="flex",n.style.alignItems="center",n.style.gap="8px",n.innerHTML=`${p}<span>${b}</span>`):n.textContent=b}if(i&&!r.querySelector("#__crossx-close-btn")){const p=document.createElement("button");p.className="__crossx-close",p.id="__crossx-close-btn",p.setAttribute("aria-label","Close"),p.innerHTML=te,i.appendChild(p)}const a=r.querySelector("#__crossx-progress-body");if(!a)return;const c=e.from?W("From",`<span class="__crossx-addr-text">${X(e.from)}</span>
1482
+ <button class="__crossx-copy-btn" data-copy="${T(e.from)}" title="Copy address">${he}</button>`):"",l=e.to?W("To",`<span class="__crossx-addr-text">${X(e.to)}</span>
1483
+ <button class="__crossx-copy-btn" data-copy="${T(e.to)}" title="Copy address">${he}</button>`):"",d=e.amount?W("Transfer",`<span>${T(e.amount)}</span>`):"",u=e.fees?W("Tx Fee",`<span>${T(e.fees)}</span>`):"",g=e.txHash?W("Tx Hash",`<span class="__crossx-addr-text">${X(e.txHash)}</span>
1484
+ <button class="__crossx-copy-btn" data-copy="${T(e.txHash)}" title="Copy hash">${he}</button>`):"",f=e.total?`<div class="__crossx-total-pill">
1042
1485
  <span class="__crossx-total-label">Total<br>(including fees)</span>
1043
- <span class="__crossx-total-amount">${M(e.total)}</span>
1486
+ <span class="__crossx-total-amount">${T(e.total)}</span>
1044
1487
  </div>`:"";a.innerHTML=`
1045
1488
  <div class="__crossx-rows">
1046
1489
  ${c}
1047
1490
  ${l}
1048
1491
  ${d}
1049
- ${f}
1050
- ${w}
1492
+ ${u}
1493
+ ${g}
1051
1494
  </div>
1052
- ${_}
1495
+ ${f}
1053
1496
  <button class="__crossx-approve-btn" id="__crossx-done-btn">${t?"All Done":"Done"}</button>
1054
- `,a.querySelectorAll(".__crossx-copy-btn").forEach(m=>{m.addEventListener("click",A=>{var T;A.stopPropagation();const y=m.dataset.copy;y&&((T=navigator.clipboard)==null||T.writeText(y).catch(()=>{}))})})}function In(r,e){const s=e,t=ze(),n=M(r.message),o=document.createElement("div");return o.id=te,o.innerHTML=`
1055
- <div class="__crossx-card __crossx-card--migration __crossx-card--sign-msg" style="${ae(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1497
+ `,a.querySelectorAll(".__crossx-copy-btn").forEach(p=>{p.addEventListener("click",b=>{var E;b.stopPropagation();const y=p.dataset.copy;y&&((E=navigator.clipboard)==null||E.writeText(y).catch(()=>{}))})})}function Po(r,e){const s=e,t=Xe(),o=T(r.message),n=document.createElement("div");return n.id=z,n.innerHTML=`
1498
+ <div class="__crossx-card __crossx-card--migration __crossx-card--sign-msg" style="${re(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1056
1499
  <div class="__crossx-header">
1057
1500
  <p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
1058
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1501
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1059
1502
  </div>
1060
1503
  <hr class="__crossx-divider">
1061
1504
  <div class="__crossx-body">
1062
1505
  <div class="__crossx-body-cols">
1063
1506
  <div class="__crossx-col-left">
1064
1507
  <p class="__crossx-sig-subtitle">
1065
- <span class="__crossx-sig-origin">${M(t)} </span>is requesting a Signature
1508
+ <span class="__crossx-sig-origin">${T(t)} </span>is requesting a Signature
1066
1509
  </p>
1067
1510
  <div class="__crossx-addr-pill">
1068
- ${_t}
1069
- <span class="__crossx-addr-pill-text">${Y(r.from)}</span>
1511
+ ${mt}
1512
+ <span class="__crossx-addr-pill-text">${X(r.from)}</span>
1070
1513
  </div>
1071
1514
  <p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
1072
1515
  </div>
1073
1516
  <hr class="__crossx-divider __crossx-divider--cols">
1074
- <div class="__crossx-msg-raw">${n}</div>
1517
+ <div class="__crossx-msg-raw">${o}</div>
1075
1518
  </div>
1076
1519
  <div class="__crossx-btn-row">
1077
1520
  <button class="__crossx-cancel-btn" id="__crossx-cancel-btn">Cancel</button>
@@ -1079,31 +1522,31 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1079
1522
  </div>
1080
1523
  </div>
1081
1524
  </div>
1082
- `,o}function An(r,e){const s=e,t=ze();let n={};if(typeof r.typedData=="string")try{n=JSON.parse(r.typedData)}catch{}else r.typedData&&typeof r.typedData=="object"&&(n=r.typedData);const o=n.primaryType??"—",i=n.message??{};let a=`
1525
+ `,n}function Oo(r,e){const s=e,t=Xe();let o={};if(typeof r.typedData=="string")try{o=JSON.parse(r.typedData)}catch{}else r.typedData&&typeof r.typedData=="object"&&(o=r.typedData);const n=o.primaryType??"—",i=o.message??{};let a=`
1083
1526
  <div class="__crossx-td-row">
1084
1527
  <span class="__crossx-td-label">Primary Type</span>
1085
- <span class="__crossx-td-value">${M(o)}</span>
1086
- </div>`;for(const[l,d]of Object.entries(i)){const f=vn(d),_=bn(d)?`<span class="__crossx-addr-text">${Y(d)}</span>
1087
- <button class="__crossx-copy-btn" data-copy="${M(String(d))}" title="Copy">${de}</button>`:`<span>${f}</span>`;a+=`
1528
+ <span class="__crossx-td-value">${T(n)}</span>
1529
+ </div>`;for(const[l,d]of Object.entries(i)){const u=To(d),f=Ao(d)?`<span class="__crossx-addr-text">${X(d)}</span>
1530
+ <button class="__crossx-copy-btn" data-copy="${T(String(d))}" title="Copy">${he}</button>`:`<span>${u}</span>`;a+=`
1088
1531
  <div class="__crossx-td-row">
1089
- <span class="__crossx-td-label">${M(l)}</span>
1090
- <div class="__crossx-td-value">${_}</div>
1091
- </div>`}const c=document.createElement("div");return c.id=te,c.innerHTML=`
1092
- <div class="__crossx-card __crossx-card--migration __crossx-card--sign-typed" style="${ae(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1532
+ <span class="__crossx-td-label">${T(l)}</span>
1533
+ <div class="__crossx-td-value">${f}</div>
1534
+ </div>`}const c=document.createElement("div");return c.id=z,c.innerHTML=`
1535
+ <div class="__crossx-card __crossx-card--migration __crossx-card--sign-typed" style="${re(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1093
1536
  <div class="__crossx-header">
1094
1537
  <p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
1095
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1538
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1096
1539
  </div>
1097
1540
  <hr class="__crossx-divider">
1098
1541
  <div class="__crossx-body">
1099
1542
  <div class="__crossx-body-cols">
1100
1543
  <div class="__crossx-col-left">
1101
1544
  <p class="__crossx-sig-subtitle">
1102
- <span class="__crossx-sig-origin">${M(t)} </span>is requesting a Signature
1545
+ <span class="__crossx-sig-origin">${T(t)} </span>is requesting a Signature
1103
1546
  </p>
1104
1547
  <div class="__crossx-addr-pill">
1105
- ${_t}
1106
- <span class="__crossx-addr-pill-text">${Y(r.from)}</span>
1548
+ ${mt}
1549
+ <span class="__crossx-addr-pill-text">${X(r.from)}</span>
1107
1550
  </div>
1108
1551
  <p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
1109
1552
  </div>
@@ -1116,19 +1559,19 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1116
1559
  </div>
1117
1560
  </div>
1118
1561
  </div>
1119
- `,c}const Rn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round">
1562
+ `,c}const No=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round">
1120
1563
  <line x1="12" y1="5" x2="12" y2="19"/>
1121
1564
  <line x1="5" y1="12" x2="19" y2="12"/>
1122
- </svg>`;function On(r,e,s){const t=s==null?void 0:s.toLowerCase(),n=r.map(i=>{const a=t&&i.address.toLowerCase()===t;return`<button class="__crossx-wallet-item" data-wallet-index="${i.index}" data-wallet-address="${M(i.address)}">
1123
- <span class="__crossx-wallet-addr">${Y(i.address)}</span>${a?'<span class="__crossx-wallet-selected">selected</span>':""}
1124
- </button>`}).join(""),o=document.createElement("div");return o.id=te,o.innerHTML=`
1125
- <div class="__crossx-card __crossx-card--migration __crossx-card--wallet-selector" style="${ae(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1565
+ </svg>`;function Lo(r,e,s){const t=s==null?void 0:s.toLowerCase(),o=r.map(i=>{const a=t&&i.address.toLowerCase()===t;return`<button class="__crossx-wallet-item" data-wallet-index="${i.index}" data-wallet-address="${T(i.address)}">
1566
+ <span class="__crossx-wallet-addr">${X(i.address)}</span>${a?'<span class="__crossx-wallet-selected">selected</span>':""}
1567
+ </button>`}).join(""),n=document.createElement("div");return n.id=z,n.innerHTML=`
1568
+ <div class="__crossx-card __crossx-card--migration __crossx-card--wallet-selector" style="${re(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1126
1569
  <div class="__crossx-header">
1127
1570
  <div style="display:flex;flex-direction:column;gap:4px;padding-right:36px;">
1128
1571
  <p class="__crossx-title" id="__crossx-ttl" style="padding-right:0;">Select Connected Wallet</p>
1129
1572
  <p class="__crossx-subtitle--body">Please select the wallet you previously used for this game to continue.</p>
1130
1573
  </div>
1131
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1574
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1132
1575
  </div>
1133
1576
  <hr class="__crossx-divider">
1134
1577
  <div class="__crossx-body">
@@ -1142,42 +1585,42 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1142
1585
  <hr class="__crossx-divider __crossx-divider--cols">
1143
1586
  <div class="__crossx-col-right-ws">
1144
1587
  <div class="__crossx-wallet-list" id="__crossx-wallet-list">
1145
- ${n}
1588
+ ${o}
1146
1589
  </div>
1147
1590
  <button class="__crossx-wallet-add" id="__crossx-add-wallet-btn" type="button">
1148
- <span class="__crossx-wallet-add-icon">${Rn}</span>
1591
+ <span class="__crossx-wallet-add-icon">${No}</span>
1149
1592
  <span class="__crossx-wallet-add-label">add a wallet</span>
1150
1593
  </button>
1151
1594
  </div>
1152
1595
  </div>
1153
1596
  </div>
1154
1597
  </div>
1155
- `,o}const Cn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1598
+ `,n}const Do=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1156
1599
  <path d="M26.693 21.193c-.028-3.168 2.587-4.712 2.706-4.786-1.477-2.16-3.77-2.454-4.58-2.484-1.944-.197-3.804 1.148-4.793 1.148-.992 0-2.52-1.12-4.147-1.09-2.13.032-4.1 1.239-5.198 3.133-2.222 3.855-.569 9.562 1.593 12.69 1.061 1.535 2.318 3.258 3.975 3.196 1.6-.064 2.2-1.03 4.133-1.03 1.928 0 2.48 1.03 4.172.997 1.72-.03 2.806-1.56 3.862-3.1 1.211-1.779 1.713-3.495 1.74-3.583-.037-.017-3.427-1.316-3.463-5.09z" fill="currentColor"/>
1157
1600
  <path d="M23.527 11.876c.877-1.065 1.471-2.545 1.31-4.024-1.266.053-2.807.845-3.718 1.907-.813.946-1.53 2.468-1.34 3.915 1.41.107 2.852-.716 3.748-1.798z" fill="currentColor"/>
1158
- </svg>`,kn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1601
+ </svg>`,Mo=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1159
1602
  <path d="M38.06 20.44c0-1.34-.12-2.63-.34-3.87H20.5v7.32h9.84c-.42 2.28-1.71 4.21-3.65 5.51v4.57h5.91c3.46-3.19 5.46-7.88 5.46-13.53z" fill="#4285F4"/>
1160
1603
  <path d="M20.5 38.5c4.94 0 9.09-1.64 12.12-4.44l-5.91-4.57c-1.64 1.1-3.73 1.75-6.21 1.75-4.77 0-8.82-3.22-10.26-7.55H4.16v4.72A18.49 18.49 0 0 0 20.5 38.5z" fill="#34A853"/>
1161
1604
  <path d="M10.24 23.69A11.16 11.16 0 0 1 9.66 20c0-1.28.22-2.52.58-3.69v-4.72H4.16A18.49 18.49 0 0 0 2 20c0 2.97.71 5.78 1.97 8.28l6.27-4.59z" fill="#FBBC05"/>
1162
1605
  <path d="M20.5 8.76c2.69 0 5.1.92 7 2.73l5.24-5.24C29.58 3.36 25.43 1.5 20.5 1.5A18.49 18.49 0 0 0 4.16 11.59l6.08 4.72C11.68 11.98 15.73 8.76 20.5 8.76z" fill="#EA4335"/>
1163
- </svg>`;function Nn(r){const e=r,s=document.createElement("div");return s.id=te,s.innerHTML=`
1164
- <div class="__crossx-card __crossx-card--migration" style="${ae(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1606
+ </svg>`;function $o(r){const e=r,s=document.createElement("div");return s.id=z,s.innerHTML=`
1607
+ <div class="__crossx-card __crossx-card--migration" style="${re(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1165
1608
  <div class="__crossx-header">
1166
1609
  <div style="display:flex;flex-direction:column;gap:4px;padding-right:36px;">
1167
1610
  <p class="__crossx-title" id="__crossx-ttl" style="padding-right:0;">Welcome onboard</p>
1168
1611
  <p class="__crossx-subtitle">Creating CROSSx Embedded Wallet</p>
1169
1612
  </div>
1170
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1613
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1171
1614
  </div>
1172
1615
  <hr class="__crossx-divider">
1173
1616
  <div class="__crossx-body">
1174
1617
  <div class="__crossx-login-btn-row">
1175
1618
  <button class="__crossx-login-btn" id="__crossx-apple-btn" type="button">
1176
- <span class="__crossx-login-icon" style="color:var(--cx-value);">${Cn}</span>
1619
+ <span class="__crossx-login-icon" style="color:var(--cx-value);">${Do}</span>
1177
1620
  <span class="__crossx-login-btn-label">Sign in with&nbsp;&nbsp;Apple</span>
1178
1621
  </button>
1179
1622
  <button class="__crossx-login-btn" id="__crossx-google-btn" type="button">
1180
- <span class="__crossx-login-icon">${kn}</span>
1623
+ <span class="__crossx-login-icon">${Mo}</span>
1181
1624
  <span class="__crossx-login-btn-label">Sign in with&nbsp;&nbsp;Google</span>
1182
1625
  </button>
1183
1626
  </div>
@@ -1187,12 +1630,12 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1187
1630
  </p>
1188
1631
  </div>
1189
1632
  </div>
1190
- `,s}function Pn(r){const e=r,s=document.createElement("div");return s.id=te,s.innerHTML=`
1191
- <div class="__crossx-card __crossx-card--migration" style="${ae(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1633
+ `,s}function Bo(r){const e=r,s=document.createElement("div");return s.id=z,s.innerHTML=`
1634
+ <div class="__crossx-card __crossx-card--migration" style="${re(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1192
1635
  <div class="__crossx-header">
1193
1636
  <p class="__crossx-title" id="__crossx-ttl">Wallet Found on Social Account 🎉</p>
1194
1637
  <p class="__crossx-subtitle--body">We found a wallet linked to your social account. Enter your 4-digit PIN to restore your assets.</p>
1195
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1638
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1196
1639
  </div>
1197
1640
  <hr class="__crossx-divider">
1198
1641
  <div class="__crossx-body">
@@ -1201,28 +1644,172 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1201
1644
  <p class="__crossx-mig-info-desc">It safely restores and integrates all your previous assets. Simply verify your PIN to get started.</p>
1202
1645
  </div>
1203
1646
  <button class="__crossx-recover-btn" id="__crossx-recover-btn">
1204
- <span>${_n(e.primary)}</span>
1647
+ <span>${bo(e.primary)}</span>
1205
1648
  <span class="__crossx-recover-label">Recover My Wallet</span>
1206
1649
  </button>
1207
1650
  <button class="__crossx-skip-btn" id="__crossx-skip-btn">Skip for Now</button>
1208
1651
  </div>
1209
1652
  </div>
1210
- `,s}function Ln(r,e){const s=r,t=e?`<p class="__crossx-pin-error-text">${e}</p>`:"",n=document.createElement("div");return n.id=te,n.innerHTML=`
1211
- <div class="__crossx-card __crossx-card--migration" style="${ae(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1653
+ `,s}function Uo(r,e){const s=r,{errorMessage:t,attemptCount:o,maxAttempts:n=5}=e??{},i=!!t,a=i?" --error":"",c=o!=null&&o>0?`<p class="__crossx-pin-attempt">${o}/${n}</p>`:"",l=o!=null&&o>=3?'<p class="__crossx-pin-warning">Your account will be locked after further failures.</p>':"",d=i?`<p class="__crossx-pin-error-text">${t}</p>`:"",u=document.createElement("div");return u.id=z,u.innerHTML=`
1654
+ <div class="__crossx-card __crossx-card--migration" style="${re(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1212
1655
  <div class="__crossx-header">
1213
1656
  <p class="__crossx-title" id="__crossx-ttl">Recover My Wallet</p>
1214
- <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
1657
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1215
1658
  </div>
1216
1659
  <hr class="__crossx-divider">
1217
1660
  <div class="__crossx-pin-center">
1661
+ ${c}
1662
+ ${l}
1218
1663
  <div class="__crossx-pin-inputs">
1219
- <input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1220
- <input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1221
- <input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1222
- <input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1664
+ <input class="__crossx-pin-input${a}" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1665
+ <input class="__crossx-pin-input${a}" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1666
+ <input class="__crossx-pin-input${a}" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1667
+ <input class="__crossx-pin-input${a}" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
1223
1668
  </div>
1224
1669
  <p class="__crossx-pin-hint">Enter your 4-digit PIN to recover your wallet.</p>
1225
- ${t}
1670
+ ${d}
1671
+ </div>
1672
+ </div>
1673
+ `,u}function Ho(r){const e=new Date(r),s=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],t=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],o=s[e.getDay()],n=t[e.getMonth()],i=e.getDate(),a=String(e.getHours()).padStart(2,"0"),c=String(e.getMinutes()).padStart(2,"0");return`${o}, ${n} ${i} ${a}:${c}`}function Fo(r,e,s){const t=r,o=e<=0,n=o?null:Date.now()+e*1e3,i=n?Ho(n):null,a=document.createElement("div");return a.id=z,a.innerHTML=`
1674
+ <div class="__crossx-card __crossx-card--migration" style="${re(t)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1675
+ <div class="__crossx-header">
1676
+ <p class="__crossx-title" id="__crossx-ttl">Recover My Wallet</p>
1677
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1678
+ </div>
1679
+ <hr class="__crossx-divider">
1680
+ <div class="__crossx-pin-center">
1681
+ <div class="__crossx-pin-inputs">
1682
+ <div class="__crossx-pin-dot" aria-hidden="true">●</div>
1683
+ <div class="__crossx-pin-dot" aria-hidden="true">●</div>
1684
+ <div class="__crossx-pin-dot" aria-hidden="true">●</div>
1685
+ <div class="__crossx-pin-dot" aria-hidden="true">●</div>
1686
+ </div>
1687
+ <div class="__crossx-pin-lock-messages">
1688
+ <p class="__crossx-pin-lock-message">${o?s:"Please try again after the lock expires."}</p>
1689
+ ${i?`<p class="__crossx-pin-lock-secondary">(Available from ${i})</p>`:""}
1690
+ </div>
1691
+ </div>
1692
+ </div>
1693
+ `,{overlay:a,startCountdown:l=>{if(o||!n)return()=>{};const u=setInterval(()=>{Date.now()>=n&&(clearInterval(u),l())},1e3);return()=>clearInterval(u)}}}const ze=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
1694
+ <path d="M15 12C15 13.6569 13.6569 15 12 15C10.3431 15 9 13.6569 9 12C9 10.3431 10.3431 9 12 9C13.6569 9 15 10.3431 15 12Z" fill="currentColor"/>
1695
+ <path d="M21.8944 11.5528C19.7362 7.23635 15.9031 5 12 5C8.09687 5 4.26379 7.23635 2.10557 11.5528C1.96481 11.8343 1.96481 12.1657 2.10557 12.4472C4.26379 16.7637 8.09687 19 12 19C15.9031 19 19.7362 16.7637 21.8944 12.4472C22.0352 12.1657 22.0352 11.8343 21.8944 11.5528ZM12 17C9.03121 17 5.99806 15.3792 4.12966 12C5.99806 8.62078 9.03121 7 12 7C14.9688 7 18.0019 8.62078 19.8703 12C18.0019 15.3792 14.9688 17 12 17Z" fill="currentColor"/>
1696
+ </svg>`,yt=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
1697
+ <path d="M4.70711 3.29289C4.31658 2.90237 3.68342 2.90237 3.29289 3.29289C2.90237 3.68342 2.90237 4.31658 3.29289 4.70711L5.71706 7.13127C4.28639 8.20737 3.03925 9.68543 2.10557 11.5528C1.96481 11.8343 1.96481 12.1657 2.10557 12.4472C4.26379 16.7637 8.09687 19 12 19C13.5552 19 15.0992 18.645 16.5306 17.9448L19.2929 20.7071C19.6834 21.0976 20.3166 21.0976 20.7071 20.7071C21.0976 20.3166 21.0976 19.6834 20.7071 19.2929L4.70711 3.29289ZM15.0138 16.428C14.0343 16.8112 13.0134 17 12 17C9.03121 17 5.99806 15.3792 4.12966 12C4.94721 10.5214 5.98778 9.3794 7.14838 8.56259L9.29237 10.7066C9.10495 11.0982 9 11.5369 9 12C9 13.6569 10.3431 15 12 15C12.4631 15 12.9018 14.8951 13.2934 14.7076L15.0138 16.428Z" fill="currentColor"/>
1698
+ <path d="M18.5523 13.8955C19.0353 13.3402 19.4784 12.7088 19.8703 12C18.0019 8.62078 14.9687 7 12 7C11.888 7 11.7759 7.00231 11.6637 7.00693L9.87939 5.22258C10.5774 5.07451 11.2875 5 12 5C15.9031 5 19.7362 7.23635 21.8944 11.5528C22.0352 11.8343 22.0352 12.1657 21.8944 12.4472C21.3504 13.5352 20.7 14.491 19.9689 15.3121L18.5523 13.8955Z" fill="currentColor"/>
1699
+ </svg>`,Go=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
1700
+ <path d="M14.5 8.5H14V6.5C14 4.015 11.985 2 9.5 2C7.015 2 5 4.015 5 6.5V8.5H4.5C3.672 8.5 3 9.172 3 10V16.5C3 17.328 3.672 18 4.5 18H14.5C15.328 18 16 17.328 16 16.5V10C16 9.172 15.328 8.5 14.5 8.5ZM10.5 13.415V15C10.5 15.276 10.276 15.5 10 15.5H9C8.724 15.5 8.5 15.276 8.5 15V13.415C8.187 13.196 8 12.847 8 12.5C8 11.672 8.672 11 9.5 11C10.328 11 11 11.672 11 12.5C11 12.847 10.813 13.196 10.5 13.415ZM12.5 8.5H6.5V6.5C6.5 4.843 7.843 3.5 9.5 3.5C11.157 3.5 12.5 4.843 12.5 6.5V8.5Z" fill="currentColor"/>
1701
+ </svg>`,Ue=`<svg width="9" height="7" viewBox="0 0 9 7" fill="none" xmlns="http://www.w3.org/2000/svg">
1702
+ <path d="M1 3.5L3.5 6L8 1" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
1703
+ </svg>`,Wo=`<svg width="11" height="9" viewBox="0 0 11 9" fill="none" xmlns="http://www.w3.org/2000/svg">
1704
+ <path d="M1 4.5L4 7.5L10 1" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
1705
+ </svg>`,qo=`<svg width="28" height="28" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
1706
+ <path d="M12 0C18.6274 0 24 5.37258 24 12C23.9999 18.6273 18.6274 24 12 24C5.37264 24 9.89594e-05 18.6273 0 12C0 5.37258 5.37258 0 12 0ZM10.875 15.127V17.377H13.125V15.127H10.875ZM10.875 6.62207V13.627H13.125V6.62207H10.875Z" fill="currentColor"/>
1707
+ </svg>`;function Vo(r){return{minLength:r.length>=8,uppercase:/[A-Z]/.test(r),number:/[0-9]/.test(r),special:/[^A-Za-z0-9]/.test(r)}}function Ko(r){return r.minLength&&r.uppercase&&r.number&&r.special}function zo(r){const s=[r.check1,r.check2,r.check3].map((t,o)=>`
1708
+ <div class="__crossx-pw-notice-item" data-check-index="${o}" role="checkbox" aria-checked="false" tabindex="0">
1709
+ <div class="__crossx-pw-notice-check" id="__crossx-notice-check-${o}">${Wo}</div>
1710
+ <span class="__crossx-pw-notice-item-text">${T(t)}</span>
1711
+ </div>
1712
+ `).join("");return`
1713
+ <div class="__crossx-header">
1714
+ <p class="__crossx-title" id="__crossx-ttl" style="padding-right:48px;">${T(r.title)}</p>
1715
+ <p class="__crossx-pw-subtitle">${T(r.headerSubtitle)}</p>
1716
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1717
+ </div>
1718
+ <hr class="__crossx-divider">
1719
+ <div class="__crossx-pw-body">
1720
+ <div class="__crossx-pw-fields __crossx-pw-fields--notice">
1721
+ <div class="__crossx-pw-notice-header">
1722
+ <div class="__crossx-pw-notice-title-row">
1723
+ <span class="__crossx-pw-notice-icon">${qo}</span>
1724
+ <p class="__crossx-pw-notice-title">${T(r.noticeTitle)}</p>
1725
+ </div>
1726
+ <p class="__crossx-pw-notice-desc">${T(r.noticeDesc)}</p>
1727
+ </div>
1728
+ <div class="__crossx-pw-notice-checks" id="__crossx-notice-checks">
1729
+ ${s}
1730
+ </div>
1731
+ </div>
1732
+ <button class="__crossx-pw-btn --disabled" id="__crossx-notice-submit" disabled
1733
+ data-next-label="${T(r.nextButton)}"
1734
+ data-submit-label="${T(r.submitButton)}">
1735
+ ${T(r.nextButton)}
1736
+ </button>
1737
+ </div>
1738
+ <div class="__crossx-home-indicator"></div>
1739
+ `}function jo(r,e){return`
1740
+ <div class="__crossx-header">
1741
+ <p class="__crossx-title" id="__crossx-ttl" style="padding-right:48px;">${T(r.title)}</p>
1742
+ <p class="__crossx-pw-subtitle--tertiary">${T(r.subtitle)}</p>
1743
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1744
+ </div>
1745
+ <hr class="__crossx-divider">
1746
+ <div class="__crossx-pw-body">
1747
+ <div class="__crossx-pw-fields __crossx-pw-fields--setup">
1748
+ <div class="__crossx-pw-field-group __crossx-pw-fg--new">
1749
+ <label class="__crossx-pw-label" for="__crossx-pw-new">${T(r.newPasswordLabel)}</label>
1750
+ <div class="__crossx-pw-input-wrap" id="__crossx-pw-new-wrap">
1751
+ <input class="__crossx-pw-input" id="__crossx-pw-new" type="password" autocomplete="new-password" />
1752
+ <button class="__crossx-pw-toggle" id="__crossx-pw-new-toggle" type="button" aria-label="Toggle visibility">${ze}</button>
1753
+ </div>
1754
+ </div>
1755
+ <div class="__crossx-pw-rules" id="__crossx-pw-rules">
1756
+ <div class="__crossx-pw-rule">
1757
+ <div class="__crossx-pw-rule-dot" id="__crossx-rule-minLength">${Ue}</div>
1758
+ <span class="__crossx-pw-rule-text">${T(r.rule_minLength)}</span>
1759
+ </div>
1760
+ <div class="__crossx-pw-rule">
1761
+ <div class="__crossx-pw-rule-dot" id="__crossx-rule-uppercase">${Ue}</div>
1762
+ <span class="__crossx-pw-rule-text">${T(r.rule_uppercase)}</span>
1763
+ </div>
1764
+ <div class="__crossx-pw-rule">
1765
+ <div class="__crossx-pw-rule-dot" id="__crossx-rule-number">${Ue}</div>
1766
+ <span class="__crossx-pw-rule-text">${T(r.rule_number)}</span>
1767
+ </div>
1768
+ <div class="__crossx-pw-rule">
1769
+ <div class="__crossx-pw-rule-dot" id="__crossx-rule-special">${Ue}</div>
1770
+ <span class="__crossx-pw-rule-text">${T(r.rule_special)}</span>
1771
+ </div>
1772
+ </div>
1773
+ <div class="__crossx-pw-field-group __crossx-pw-fg--confirm">
1774
+ <label class="__crossx-pw-label" for="__crossx-pw-confirm">${T(r.confirmPasswordLabel)}</label>
1775
+ <div class="__crossx-pw-input-wrap" id="__crossx-pw-confirm-wrap">
1776
+ <input class="__crossx-pw-input" id="__crossx-pw-confirm" type="password" autocomplete="new-password" />
1777
+ <button class="__crossx-pw-toggle" id="__crossx-pw-confirm-toggle" type="button" aria-label="Toggle visibility">${ze}</button>
1778
+ </div>
1779
+ <p class="__crossx-pw-error-text" id="__crossx-pw-confirm-error" style="display:none;">${T(r.confirmError)}</p>
1780
+ ${e!=null&&e.errorMessage?`<p class="__crossx-pw-error-text">${T(e.errorMessage)}</p>`:""}
1781
+ </div>
1782
+ </div>
1783
+ <button class="__crossx-pw-btn --disabled" id="__crossx-pw-submit" disabled>
1784
+ ${T(r.submitButton)}
1785
+ </button>
1786
+ </div>
1787
+ <div class="__crossx-home-indicator"></div>
1788
+ `}function Yo(r,e,s,t){const o=r,n=document.createElement("div");n.id=z;const i=document.createElement("div");return i.className="__crossx-card __crossx-card--password",i.setAttribute("style",re(o)),i.setAttribute("role","dialog"),i.setAttribute("aria-modal","true"),i.setAttribute("aria-labelledby","__crossx-ttl"),i.innerHTML=zo(e),n.appendChild(i),n}function Zo(r,e,s){var u;const t=r.querySelector("#__crossx-notice-submit"),o=Array.from(r.querySelectorAll(".__crossx-pw-notice-item")),n=new Set;t.removeAttribute("disabled");const i=t.dataset.nextLabel??"Next",a=t.dataset.submitLabel??"I Understand",c=()=>{const g=n.size===o.length;t.classList.toggle("--disabled",!g),t.textContent=g?a:i},l=(g,f)=>{if(n.has(f))return;const p=g.querySelector(`#__crossx-notice-check-${f}`);n.add(f),p.classList.add("--checked"),g.setAttribute("aria-checked","true"),c()},d=(g,f)=>{if(!n.has(f))return;const p=g.querySelector(`#__crossx-notice-check-${f}`);n.delete(f),p.classList.remove("--checked"),g.setAttribute("aria-checked","false"),c()};o.forEach(g=>{const f=parseInt(g.dataset.checkIndex??"0",10);g.addEventListener("click",()=>{n.has(f)?d(g,f):l(g,f)}),g.addEventListener("keydown",p=>{(p.key==="Enter"||p.key===" ")&&(p.preventDefault(),n.has(f)?d(g,f):l(g,f))})}),t.addEventListener("click",()=>{if(n.size===o.length){s();return}const g=o.find(p=>{const b=parseInt(p.dataset.checkIndex??"0",10);return!n.has(b)});if(!g)return;const f=parseInt(g.dataset.checkIndex??"0",10);g.scrollIntoView({behavior:"smooth",block:"nearest"}),g.classList.add("--highlight"),setTimeout(()=>{g.classList.remove("--highlight"),l(g,f)},400)}),(u=r.querySelector("#__crossx-close-btn"))==null||u.addEventListener("click",e)}function Xo(r,e,s,t){var p;const o=r.querySelector("#__crossx-pw-new"),n=r.querySelector("#__crossx-pw-confirm"),i=r.querySelector("#__crossx-pw-new-toggle"),a=r.querySelector("#__crossx-pw-confirm-toggle"),c=r.querySelector("#__crossx-pw-confirm-wrap"),l=r.querySelector("#__crossx-pw-confirm-error"),d=r.querySelector("#__crossx-pw-submit"),u={minLength:r.querySelector("#__crossx-rule-minLength"),uppercase:r.querySelector("#__crossx-rule-uppercase"),number:r.querySelector("#__crossx-rule-number"),special:r.querySelector("#__crossx-rule-special")},g=()=>{const b=o.value,y=n.value,E=Vo(b),D=Ko(E);Object.keys(E).forEach(le=>{u[le].classList.toggle("--met",E[le])});const U=y.length>0,M=b===y,B=U&&!M;c.classList.toggle("--error",B),l.style.display=B?"block":"none";const K=D&&M&&y.length>0;d.disabled=!K,d.classList.toggle("--disabled",!K)},f=(b,y)=>{const E=b.type==="password";b.type=E?"text":"password",y.innerHTML=E?yt:ze};o.addEventListener("input",g),n.addEventListener("input",g),i.addEventListener("click",()=>f(o,i)),a.addEventListener("click",()=>f(n,a)),d.addEventListener("click",()=>{d.disabled||s(o.value)}),(p=r.querySelector("#__crossx-close-btn"))==null||p.addEventListener("click",t),o.addEventListener("keydown",b=>{b.key==="Escape"&&t()}),n.addEventListener("keydown",b=>{b.key==="Enter"&&!d.disabled&&s(o.value),b.key==="Escape"&&t()}),o.focus()}function Jo(r,e,s){const t=r,o=!!(s!=null&&s.errorMessage),n=document.createElement("div");return n.id=z,n.innerHTML=`
1789
+ <div class="__crossx-card __crossx-card--password" style="${re(t)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1790
+ <div class="__crossx-header">
1791
+ <p class="__crossx-title" id="__crossx-ttl" style="padding-right:48px;">${T(e.title)}</p>
1792
+ <p class="__crossx-pw-subtitle">${T(e.subtitle)}</p>
1793
+ <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${te}</button>
1794
+ </div>
1795
+ <hr class="__crossx-divider">
1796
+ <div class="__crossx-pw-body">
1797
+ <div class="__crossx-pw-fields">
1798
+ <div class="__crossx-pw-confirm-group${o?" --has-error":""}" id="__crossx-pw-confirm-group">
1799
+ <div class="__crossx-pw-field-group">
1800
+ <label class="__crossx-pw-label" for="__crossx-pw-enter">${T(e.passwordLabel)}</label>
1801
+ <div class="__crossx-pw-input-wrap${o?" --error":""}" id="__crossx-pw-enter-wrap">
1802
+ <span class="__crossx-pw-lock">${Go}</span>
1803
+ <input class="__crossx-pw-input" id="__crossx-pw-enter" type="password" autocomplete="current-password" />
1804
+ <button class="__crossx-pw-toggle" id="__crossx-pw-enter-toggle" type="button" aria-label="Toggle visibility">${yt}</button>
1805
+ </div>
1806
+ <p class="__crossx-pw-error-text" id="__crossx-pw-enter-error" style="${o?"":"display:none;"}">${o?T(s.errorMessage):""}</p>
1807
+ </div>
1808
+ <button class="__crossx-pw-btn --disabled" id="__crossx-pw-submit" disabled>
1809
+ ${T(e.submitButton)}
1810
+ </button>
1811
+ </div>
1812
+ </div>
1226
1813
  </div>
1227
1814
  </div>
1228
- `,n}function Dn(r,e,s){var n;const t=r.querySelectorAll(".__crossx-pin-input");t.forEach((o,i)=>{o.addEventListener("input",()=>{const a=o.value.replace(/\D/g,"");o.value=a?a[0]:"",a&&i<3&&t[i+1].focus();const c=Array.from(t).map(l=>l.value).join("");c.length===4&&setTimeout(()=>e(c),200)}),o.addEventListener("keydown",a=>{a.key==="Backspace"&&!o.value&&i>0&&(t[i-1].focus(),t[i-1].value=""),a.key==="Escape"&&s()}),o.addEventListener("keypress",a=>{/[0-9]/.test(a.key)||a.preventDefault()}),o.addEventListener("paste",a=>{var d;a.preventDefault();const c=(((d=a.clipboardData)==null?void 0:d.getData("text"))??"").replace(/\D/g,"").slice(0,4);if(!c)return;c.split("").forEach((f,w)=>{t[w]&&(t[w].value=f)});const l=Math.min(c.length,3);t[l].focus(),c.length===4&&setTimeout(()=>e(c),200)})}),(n=t[0])==null||n.focus()}class $n{constructor(e="light",s){this.theme=e,this.overrides=s,this.tokens=jt(e,s)}setTheme(e,s){this.theme=e,s!==void 0&&(this.overrides=s),this.tokens=jt(e,this.overrides)}setMessages(e){this.messages=e}getTheme(){return this.theme}showWalletSelector(e,s,t){return new Promise(n=>{var A;me();const o=[...e],i=On(o,this.tokens,t),a=document.body.style.overflow;document.body.style.overflow="hidden",document.body.appendChild(i);let c=!1;const l=()=>{c||(c=!0,i.remove(),document.body.style.overflow=a)},d=y=>{l(),n(y)},f=()=>{l(),n(null)};(()=>{i.querySelectorAll(".__crossx-wallet-item").forEach(y=>{y.addEventListener("click",()=>{const T=y.dataset.walletAddress??"",L=parseInt(y.dataset.walletIndex??"0",10);d({address:T,index:L})})})})();const _=i.querySelector("#__crossx-add-wallet-btn");_&&_.addEventListener("click",async()=>{_.disabled=!0;try{const y=await s();o.push(y);const T=i.querySelector("#__crossx-wallet-list");if(T){const L=document.createElement("button");L.className="__crossx-wallet-item",L.dataset.walletIndex=String(y.index),L.dataset.walletAddress=y.address,L.innerHTML=`<span class="__crossx-wallet-addr">${Y(y.address)}</span>`,L.addEventListener("click",()=>d(y)),T.appendChild(L),L.scrollIntoView({behavior:"smooth",block:"nearest"})}}catch{}finally{_.disabled=!1}}),(A=i.querySelector("#__crossx-close-btn"))==null||A.addEventListener("click",f),i.addEventListener("click",y=>{y.target===i&&f()});const m=y=>{y.key==="Escape"&&(document.removeEventListener("keydown",m),f())};document.addEventListener("keydown",m)})}showLoginSelector(){return new Promise(e=>{var a,c,l;me();const s=Nn(this.tokens);document.body.appendChild(s);const t=()=>s.remove(),n=d=>{t(),e(d)},o=()=>{t(),e(null)};(a=s.querySelector("#__crossx-apple-btn"))==null||a.addEventListener("click",()=>n("apple")),(c=s.querySelector("#__crossx-google-btn"))==null||c.addEventListener("click",()=>n("google")),(l=s.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",o),s.addEventListener("click",d=>{d.target===s&&o()}),s.querySelectorAll(".__crossx-login-terms-link").forEach(d=>{d.addEventListener("click",f=>f.stopPropagation())});const i=d=>{d.key==="Escape"&&(document.removeEventListener("keydown",i),o())};document.addEventListener("keydown",i)})}showMigrationFoundPrompt(){return new Promise(e=>{var a,c,l;me();const s=Pn(this.tokens);document.body.appendChild(s);const t=()=>s.remove(),n=()=>{t(),e("recover")},o=()=>{t(),e("skip")};(a=s.querySelector("#__crossx-recover-btn"))==null||a.addEventListener("click",n),(c=s.querySelector("#__crossx-skip-btn"))==null||c.addEventListener("click",o),(l=s.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",o),s.addEventListener("click",d=>{d.target===s&&o()});const i=d=>{d.key==="Escape"&&(document.removeEventListener("keydown",i),o())};document.addEventListener("keydown",i)})}showPinInputPrompt(e){return new Promise(s=>{var a;me();const t=Ln(this.tokens,e);document.body.appendChild(t);const n=()=>t.remove(),o=c=>{n(),s(c)},i=()=>{n(),s(null)};Dn(t,o,i),(a=t.querySelector("#__crossx-close-btn"))==null||a.addEventListener("click",i),t.addEventListener("click",c=>{c.target===t&&i()})})}showTransactionComplete(e){return new Promise(s=>{var a,c;me();const t=Sn(e,this.tokens);document.body.appendChild(t);const n=()=>t.remove(),o=()=>{n(),s()};(a=t.querySelector("#__crossx-done-btn"))==null||a.addEventListener("click",o),(c=t.querySelector("#__crossx-close-btn"))==null||c.addEventListener("click",o),t.querySelectorAll(".__crossx-copy-btn").forEach(l=>{l.addEventListener("click",d=>{var w;d.stopPropagation();const f=l.dataset.copy;f&&((w=navigator.clipboard)==null||w.writeText(f).catch(()=>{}))})}),t.addEventListener("click",l=>{l.target===t&&o()});const i=l=>{l.key==="Escape"&&(document.removeEventListener("keydown",i),o())};document.addEventListener("keydown",i)})}showTransactionProgress(e,s){return new Promise(t=>{me();const n=En(e,this.tokens);document.body.appendChild(n);const o=()=>n.remove();let i=!1;const a=()=>{i||(i=!0,o(),t())},c=()=>{var d,f;(d=n.querySelector("#__crossx-done-btn"))==null||d.addEventListener("click",a),(f=n.querySelector("#__crossx-close-btn"))==null||f.addEventListener("click",a),n.addEventListener("click",w=>{w.target===n&&a()});const l=w=>{w.key==="Escape"&&(document.removeEventListener("keydown",l),a())};document.addEventListener("keydown",l)};s.then(l=>{i||(Tn(n,l,this.tokens),c())})})}requestConfirmation(e){return new Promise(s=>{var c,l,d;me();let t;e.type==="sign-message"?t=In(e,this.tokens):e.type==="sign-typed-data"?t=An(e,this.tokens):e.type==="sign"?t=wn(e,this.tokens):t=yn(e,this.tokens),document.body.appendChild(t);const n=()=>t.remove(),o=()=>{n(),s(!0)},i=()=>{n(),s(!1)};(c=t.querySelector("#__crossx-confirm-btn"))==null||c.addEventListener("click",o),(l=t.querySelector("#__crossx-cancel-btn"))==null||l.addEventListener("click",i),(d=t.querySelector("#__crossx-close-btn"))==null||d.addEventListener("click",i),t.querySelectorAll(".__crossx-copy-btn").forEach(f=>{f.addEventListener("click",w=>{var m;w.stopPropagation();const _=f.dataset.copy;_&&((m=navigator.clipboard)==null||m.writeText(_).catch(()=>{}))})}),t.addEventListener("click",f=>{f.target===t&&i()});const a=f=>{f.key==="Escape"&&(document.removeEventListener("keydown",a),i())};document.addEventListener("keydown",a)})}}class Mn{constructor(){this._accessToken=null}set(e){this._accessToken=e}get(){return this._accessToken}clear(){this._accessToken=null}has(){return this._accessToken!==null}}function Bn(r){r.debug;const e=Fe.production,s={...r,oauthServiceUrl:e.oauthServiceUrl,authApiUrl:e.authApiUrl,walletGatewayUrl:e.walletGatewayUrl},t={gatewayUrl:e.walletGatewayUrl,projectId:r.projectId},o=s.authMode!=="cookie"&&At.isAvailable()?new At:new Xs,i=new on,a=new ln,c=new gt,l=new Mn;let d;r.useMockWallet?(p.log("[CROSSx] Mock Wallet Provider 사용"),d=new dn(o)):(p.log("[CROSSx] Remote Wallet Provider 사용"),d=new We(t,o,a,l));const f=new Ce(t,a),w=new $n(r.theme??"light",r.themeTokens);return new Ue(s,t,o,i,a,c,d,l,w,f)}exports.CROSSxError=x;exports.CROSSxEthereumProvider=Kt;exports.CROSSxSDK=Ue;exports.ChainId=Cs;exports.ErrorCode=g;exports.createCROSSxSDK=Bn;
1815
+ `,n}function Qo(r,e,s,t,o){var f;const n=r.querySelector("#__crossx-pw-enter"),i=r.querySelector("#__crossx-pw-enter-toggle"),a=r.querySelector("#__crossx-pw-enter-wrap"),c=r.querySelector("#__crossx-pw-enter-error"),l=r.querySelector("#__crossx-pw-confirm-group"),d=r.querySelector("#__crossx-pw-submit");n.addEventListener("input",()=>{const p=n.value.length>0;d.disabled=!p,d.classList.toggle("--disabled",!p),p&&(a.classList.remove("--error"),c.style.display="none",l.classList.remove("--has-error"))}),i.addEventListener("click",()=>{const p=n.type==="password";n.type=p?"text":"password",i.innerHTML=p?ze:yt});const u=p=>{c.textContent=p,c.style.display="",a.classList.add("--error"),l.classList.add("--has-error"),d.disabled=!1,d.classList.remove("--disabled")},g=()=>{if(d.disabled)return;const p=n.value;t?(d.disabled=!0,d.classList.add("--disabled"),t(p).then(b=>{b.ok?e(p):(u(b.error??"Incorrect password. Please try again."),n.focus())}).catch(b=>{o?o(b):s()})):e(p)};d.addEventListener("click",g),n.addEventListener("keydown",p=>{p.key==="Enter"&&g(),p.key==="Escape"&&s()}),(f=r.querySelector("#__crossx-close-btn"))==null||f.addEventListener("click",s),n.focus()}function en(r,e,s){var o;const t=r.querySelectorAll(".__crossx-pin-input");t.forEach((n,i)=>{n.addEventListener("input",()=>{const a=n.value.replace(/\D/g,"");n.value=a?a[0]:"",a&&i<3&&t[i+1].focus();const c=Array.from(t).map(l=>l.value).join("");c.length===4&&setTimeout(()=>e(c),200)}),n.addEventListener("keydown",a=>{a.key==="Backspace"&&!n.value&&i>0&&(t[i-1].focus(),t[i-1].value=""),a.key==="Escape"&&s()}),n.addEventListener("keypress",a=>{/[0-9]/.test(a.key)||a.preventDefault()}),n.addEventListener("paste",a=>{var d;a.preventDefault();const c=(((d=a.clipboardData)==null?void 0:d.getData("text"))??"").replace(/\D/g,"").slice(0,4);if(!c)return;c.split("").forEach((u,g)=>{t[g]&&(t[g].value=u)});const l=Math.min(c.length,3);t[l].focus(),c.length===4&&setTimeout(()=>e(c),200)})}),(o=t[0])==null||o.focus()}class tn{constructor(e="light",s){this.theme=e,this.overrides=s,this.tokens=Yt(e,s)}setTheme(e,s){this.theme=e,s!==void 0&&(this.overrides=s),this.tokens=Yt(e,this.overrides)}setMessages(e){this.messages=e}getTheme(){return this.theme}showWalletSelector(e,s,t){return new Promise(o=>{var b;ce();const n=[...e],i=Lo(n,this.tokens,t),a=document.body.style.overflow;document.body.style.overflow="hidden",document.body.appendChild(i);let c=!1;const l=()=>{c||(c=!0,i.remove(),document.body.style.overflow=a)},d=y=>{l(),o(y)},u=()=>{l(),o(null)};(()=>{i.querySelectorAll(".__crossx-wallet-item").forEach(y=>{y.addEventListener("click",()=>{const E=y.dataset.walletAddress??"",D=parseInt(y.dataset.walletIndex??"0",10);d({address:E,index:D})})})})();const f=i.querySelector("#__crossx-add-wallet-btn");f&&f.addEventListener("click",async()=>{f.disabled=!0;try{const y=await s();n.push(y);const E=i.querySelector("#__crossx-wallet-list");if(E){const D=document.createElement("button");D.className="__crossx-wallet-item",D.dataset.walletIndex=String(y.index),D.dataset.walletAddress=y.address,D.innerHTML=`<span class="__crossx-wallet-addr">${X(y.address)}</span>`,D.addEventListener("click",()=>d(y)),E.appendChild(D),D.scrollIntoView({behavior:"smooth",block:"nearest"})}}catch{}finally{f.disabled=!1}}),(b=i.querySelector("#__crossx-close-btn"))==null||b.addEventListener("click",u),i.addEventListener("click",y=>{y.target===i&&u()});const p=y=>{y.key==="Escape"&&(document.removeEventListener("keydown",p),u())};document.addEventListener("keydown",p)})}showLoginSelector(){return new Promise(e=>{var a,c,l;ce();const s=$o(this.tokens);document.body.appendChild(s);const t=()=>s.remove(),o=d=>{t(),e(d)},n=()=>{t(),e(null)};(a=s.querySelector("#__crossx-apple-btn"))==null||a.addEventListener("click",()=>o("apple")),(c=s.querySelector("#__crossx-google-btn"))==null||c.addEventListener("click",()=>o("google")),(l=s.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",n),s.addEventListener("click",d=>{d.target===s&&n()}),s.querySelectorAll(".__crossx-login-terms-link").forEach(d=>{d.addEventListener("click",u=>u.stopPropagation())});const i=d=>{d.key==="Escape"&&(document.removeEventListener("keydown",i),n())};document.addEventListener("keydown",i)})}showMigrationFoundPrompt(){return new Promise(e=>{var a,c,l;ce();const s=Bo(this.tokens);document.body.appendChild(s);const t=()=>s.remove(),o=()=>{t(),e("recover")},n=()=>{t(),e("skip")};(a=s.querySelector("#__crossx-recover-btn"))==null||a.addEventListener("click",o),(c=s.querySelector("#__crossx-skip-btn"))==null||c.addEventListener("click",n),(l=s.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",n),s.addEventListener("click",d=>{d.target===s&&n()});const i=d=>{d.key==="Escape"&&(document.removeEventListener("keydown",i),n())};document.addEventListener("keydown",i)})}showPasswordSetupPrompt(e){return new Promise(s=>{ce();const t=this.messages,o={title:(t==null?void 0:t.passwordSetup_title)??"Create Password",headerSubtitle:(t==null?void 0:t.passwordNotice_headerSubtitle)??"Required for Transactions, PK/Mnemonic & Account Deletion.",noticeTitle:(t==null?void 0:t.passwordNotice_title)??"Password Setup Notice",noticeDesc:(t==null?void 0:t.passwordNotice_description)??"For your security, this password cannot be reset or recovered. Please ensure you have it backed up or memorized.",check1:(t==null?void 0:t.passwordNotice_check1)??"This password cannot be recovered if lost, and I have securely backed it up.",check2:(t==null?void 0:t.passwordNotice_check2)??"Losing this password may result in permanent loss of access to my account and all associated data.",check3:(t==null?void 0:t.passwordNotice_check3)??"No third party, including the support team, can recover or reset this password on my behalf.",nextButton:(t==null?void 0:t.passwordNotice_nextButton)??"Next",submitButton:(t==null?void 0:t.passwordNotice_submitButton)??"I Understand"},n={title:(t==null?void 0:t.passwordSetup_title)??"Create Password",subtitle:(t==null?void 0:t.passwordSetup_subtitle)??"Password is only used to transfer your asset.",newPasswordLabel:(t==null?void 0:t.passwordSetup_newPasswordLabel)??"New Password",confirmPasswordLabel:(t==null?void 0:t.passwordSetup_confirmPasswordLabel)??"Confirm New Password",rule_minLength:(t==null?void 0:t.passwordSetup_rule_minLength)??"Over 8 letters",rule_uppercase:(t==null?void 0:t.passwordSetup_rule_uppercase)??"Include at least 1 uppercase letter",rule_number:(t==null?void 0:t.passwordSetup_rule_number)??"Include at least 1 number",rule_special:(t==null?void 0:t.passwordSetup_rule_special)??"Include at least 1 special character",confirmError:(t==null?void 0:t.passwordSetup_confirmError)??"Password is incorrect",submitButton:(t==null?void 0:t.passwordSetup_submitButton)??"Next"},i=Yo(this.tokens,o),a=document.body.style.overflow;document.body.style.overflow="hidden",document.body.appendChild(i);let c=!1;const l=()=>{c||(c=!0,i.remove(),document.body.style.overflow=a)},d=p=>{l(),s(p)},u=()=>{l(),s(null)},g=p=>{p.key==="Escape"&&(document.removeEventListener("keydown",g),u())};document.addEventListener("keydown",g);const f=i.querySelector(".__crossx-card");Zo(f,u,()=>{var p;f.innerHTML=jo(n,e),Xo(i,{},d,u),(p=i.querySelector("#__crossx-close-btn"))==null||p.addEventListener("click",u)}),i.addEventListener("click",p=>{p.target===i&&u()})})}showPasswordInputPrompt(e){return new Promise((s,t)=>{ce();const o=this.messages,n=(e==null?void 0:e.verifyMode)===!0,i={title:n?(o==null?void 0:o.verifyPassword_title)??"Verify Your Password":(o==null?void 0:o.passwordInput_title)??"Enter Password",subtitle:n?(o==null?void 0:o.verifyPassword_subtitle)??"To continue, please confirm your current password":(o==null?void 0:o.passwordInput_subtitle)??"Enter your password to continue.",passwordLabel:n?(o==null?void 0:o.verifyPassword_passwordLabel)??"Confirm Password":(o==null?void 0:o.passwordInput_passwordLabel)??"Password",submitButton:(o==null?void 0:o.passwordInput_submitButton)??"Confirm",error:(o==null?void 0:o.passwordInput_error)??"Incorrect password. Please try again."},a=Jo(this.tokens,i,e),c=document.body.style.overflow;document.body.style.overflow="hidden",document.body.appendChild(a);let l=!1;const d=()=>{l||(l=!0,a.remove(),document.body.style.overflow=c)},u=b=>{d(),s(b)},g=()=>{d(),s(null)},f=b=>{d(),t(b)};Qo(a,u,g,e==null?void 0:e.onSubmit,f),a.addEventListener("click",b=>{b.target===a&&g()});const p=b=>{b.key==="Escape"&&(document.removeEventListener("keydown",p),g())};document.addEventListener("keydown",p)})}showPinInputPrompt(e){return new Promise(s=>{var a;ce();const t=Uo(this.tokens,e);document.body.appendChild(t);const o=()=>t.remove(),n=c=>{o(),s(c)},i=()=>{o(),s(null)};en(t,n,i),(a=t.querySelector("#__crossx-close-btn"))==null||a.addEventListener("click",i),t.addEventListener("click",c=>{c.target===t&&i()})})}showPinLockedPrompt(e,s){return new Promise(t=>{var l;ce();const{overlay:o,startCountdown:n}=Fo(this.tokens,e,s);document.body.appendChild(o);const i=()=>{c(),o.remove()},a=()=>{i(),t()},c=n(a);(l=o.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",a),o.addEventListener("click",d=>{d.target===o&&a()})})}showTransactionComplete(e){return new Promise(s=>{var a,c;ce();const t=Co(e,this.tokens);document.body.appendChild(t);const o=()=>t.remove(),n=()=>{o(),s()};(a=t.querySelector("#__crossx-done-btn"))==null||a.addEventListener("click",n),(c=t.querySelector("#__crossx-close-btn"))==null||c.addEventListener("click",n),t.querySelectorAll(".__crossx-copy-btn").forEach(l=>{l.addEventListener("click",d=>{var g;d.stopPropagation();const u=l.dataset.copy;u&&((g=navigator.clipboard)==null||g.writeText(u).catch(()=>{}))})}),t.addEventListener("click",l=>{l.target===t&&n()});const i=l=>{l.key==="Escape"&&(document.removeEventListener("keydown",i),n())};document.addEventListener("keydown",i)})}showTransactionProgress(e,s){return new Promise(t=>{ce();const o=ko(e,this.tokens);document.body.appendChild(o);const n=()=>o.remove();let i=!1;const a=()=>{i||(i=!0,n(),t())},c=()=>{var d,u;(d=o.querySelector("#__crossx-done-btn"))==null||d.addEventListener("click",a),(u=o.querySelector("#__crossx-close-btn"))==null||u.addEventListener("click",a),o.addEventListener("click",g=>{g.target===o&&a()});const l=g=>{g.key==="Escape"&&(document.removeEventListener("keydown",l),a())};document.addEventListener("keydown",l)};s.then(l=>{i||(Ro(o,l,this.tokens),c())})})}requestConfirmation(e){return new Promise(s=>{var c,l,d;ce();let t;e.type==="sign-message"?t=Po(e,this.tokens):e.type==="sign-typed-data"?t=Oo(e,this.tokens):e.type==="sign"?t=Eo(e,this.tokens):t=Io(e,this.tokens),document.body.appendChild(t);const o=()=>t.remove(),n=()=>{o(),s(!0)},i=()=>{o(),s(!1)};(c=t.querySelector("#__crossx-confirm-btn"))==null||c.addEventListener("click",n),(l=t.querySelector("#__crossx-cancel-btn"))==null||l.addEventListener("click",i),(d=t.querySelector("#__crossx-close-btn"))==null||d.addEventListener("click",i),t.querySelectorAll(".__crossx-copy-btn").forEach(u=>{u.addEventListener("click",g=>{var p;g.stopPropagation();const f=u.dataset.copy;f&&((p=navigator.clipboard)==null||p.writeText(f).catch(()=>{}))})}),t.addEventListener("click",u=>{u.target===t&&i()});const a=u=>{u.key==="Escape"&&(document.removeEventListener("keydown",a),i())};document.addEventListener("keydown",a)})}}class sn{constructor(){this._accessToken=null}set(e){this._accessToken=e}get(){return this._accessToken}clear(){this._accessToken=null}has(){return this._accessToken!==null}}function rn(r){r.debug;const e=Fe.production,s={...r,oauthServiceUrl:e.oauthServiceUrl,authApiUrl:e.authApiUrl,walletGatewayUrl:e.walletGatewayUrl},t={gatewayUrl:e.walletGatewayUrl,projectId:r.projectId},n=s.authMode!=="cookie"&&Pt.isAvailable()?new Pt:new sr,i=new uo,a=new fo,c=new wt,l=new sn,d=new Qt;let u;r.useMockWallet?(h.log("[CROSSx] Mock Wallet Provider 사용"),u=new _o(n,d)):(h.log("[CROSSx] Remote Wallet Provider 사용"),u=new Ke(t,n,a,l,d));const g=new Pe(t,a),f=new tn(r.theme??"light",r.themeTokens);return new Ge(s,t,n,i,a,c,u,l,f,g,d)}exports.CROSSxError=m;exports.CROSSxEthereumProvider=Xt;exports.CROSSxSDK=Ge;exports.ChainId=Ds;exports.ErrorCode=_;exports.createCROSSxSDK=rn;