@nexus-cross/crossx-sdk-core 1.3.8 → 1.3.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -1,8 +1,18 @@
1
- "use strict";var $s=Object.defineProperty;var Bs=(r,e,s)=>e in r?$s(r,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[e]=s;var E=(r,e,s)=>Bs(r,typeof e!="symbol"?e+"":e,s);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Xe=require("jose");var p=(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.WALLET_ALREADY_EXISTS="WALLET_ALREADY_EXISTS",r.SIGN_FAILED="SIGN_FAILED",r.SIGN_REJECTED="SIGN_REJECTED",r.TX_FAILED="TX_FAILED",r.TX_REJECTED="TX_REJECTED",r.BROADCAST_FAILED="BROADCAST_FAILED",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.PIN_NOT_SET="PIN_NOT_SET",r.PIN_WRONG="PIN_WRONG",r.PIN_INVALID="PIN_INVALID",r.PIN_REPEATED_PATTERN="PIN_REPEATED_PATTERN",r.PIN_CANCELLED="PIN_CANCELLED",r.EXTERNAL_WALLET_REQUESTED="EXTERNAL_WALLET_REQUESTED",r.PIN_LOCKED="PIN_LOCKED",r.HMAC_REQUIRED="HMAC_REQUIRED",r.HMAC_VERIFICATION_FAILED="HMAC_VERIFICATION_FAILED",r.WITHDRAW_FAILED="WITHDRAW_FAILED",r.INVALID_CONFIG="INVALID_CONFIG",r.UNKNOWN_ERROR="UNKNOWN_ERROR",r))(p||{});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 ze={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}},Us=Object.fromEntries(Object.entries(ze).map(([r,e])=>[r,e.caipId])),Hs=new Map(Object.values(ze).map(r=>[r.caipId,r]));new Map(Object.values(ze).map(r=>[r.chainId,r]));const Fs={symbol:"",decimals:18};function Ze(r){var e;return((e=Hs.get(r))==null?void 0:e.nativeCurrency)??Fs}class ts{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(p.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signMessage()를 직접 사용하세요.`);case"eth_signTypedData":case"eth_signTypedData_v1":case"eth_signTypedData_v3":case"eth_signTypedData_v4":throw new m(p.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 _e=null;function Et(r){_e=r}const d={info(...r){if(_e){_e.log(...r);return}console.log(...r)},log(...r){if(_e){_e.log(...r);return}},warn(...r){if(_e){_e.warn(...r);return}},error(...r){if(_e){_e.error(...r);return}}},Gs={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로 계속하기",loginSelector_connectOtherWallets:"다른 지갑으로 연결",loginSelector_connectOtherWalletsDesc:"기존 Web3 지갑을 연결하여 자산을 관리하세요.",migration_foundTitle:"기존 지갑 발견",migration_foundDescription:"기존 CROSSx 지갑이 발견되었습니다. 복구하시겠습니까?",migration_recoverButton:"복구하기",migration_skipButton:"건너뛰기",recoveryPinInput_title:"PIN 입력",recoveryPinInput_placeholder:"4자리 PIN을 입력하세요",recoveryPinInput_error:"PIN이 올바르지 않습니다. 다시 시도해 주세요.",walletSelector_title:"지갑 선택",walletSelector_addButton:"지갑 추가",walletSelector_selected:"선택됨",pinNotice_headerSubtitle:"트랜잭션, PK/니모닉 내보내기 및 계정 삭제 시 필요합니다.",pinNotice_title:"PIN 설정 주의사항",pinNotice_description:"보안을 위해 이 PIN은 재설정하거나 복구할 수 없습니다. 반드시 기억해 두거나 안전한 곳에 보관하세요.",pinNotice_check1:"이 PIN을 분실하면 지갑과 자산에 영구적으로 접근이 불가능해진다는 것을 이해합니다.",pinNotice_check2:"지원팀을 포함한 어느 누구도 이 PIN을 복구하거나 재설정해 줄 수 없다는 것을 이해합니다.",pinNotice_nextButton:"다음",pinNotice_submitButton:"동의합니다",pinSetup_title:"PIN 만들기",pinSetup_headerSubtitle:"이 PIN은 거래 승인에 사용됩니다.",pinSetup_subtitle:"거래 승인을 위한 6자리 PIN을 설정하세요.",pinSetup_confirmTitle:"PIN 확인",pinSetup_confirmSubtitle:"확인을 위해 PIN을 다시 입력하세요.",pinSetup_mismatchError:"PIN이 일치하지 않습니다. 다시 시도해 주세요.",pinValidation_tooShort:"6자리 PIN을 입력해 주세요.",pinValidation_numbersOnly:"숫자(0-9)만 입력할 수 있습니다.",pinValidation_repeatingDigit:"같은 숫자를 연속으로 3번 이상 사용할 수 없습니다.",pinValidation_sequential:"연속된 숫자(예: 123456)는 사용할 수 없습니다.",pinValidation_alternatingPattern:"반복 패턴(예: 121212)은 사용할 수 없습니다.",pinInput_title:"PIN 입력",pinInput_subtitle:"계속하려면 6자리 PIN을 입력하세요.",pinInput_error:"PIN이 올바르지 않습니다. 다시 시도해 주세요.",verifyPin_title:"PIN 확인",verifyPin_subtitle:"계속하려면 PIN을 확인해 주세요.",pinLocked_message:"잠금이 해제된 후 다시 시도해 주세요.",pinLocked_availableFrom:"이용 가능 시간"},ss={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",loginSelector_connectOtherWallets:"Connect with Other Wallets",loginSelector_connectOtherWalletsDesc:"Connect your existing Web3 wallet to manage your assets.",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",recoveryPinInput_title:"Enter PIN",recoveryPinInput_placeholder:"Enter your 4-digit PIN",recoveryPinInput_error:"Incorrect PIN. Please try again.",walletSelector_title:"Select Wallet",walletSelector_addButton:"Add Wallet",walletSelector_selected:"Selected",pinNotice_headerSubtitle:"Required for transactions, PK/mnemonic export & account deletion.",pinNotice_title:"PIN Setup Notice",pinNotice_description:"For your security, this PIN cannot be reset or recovered. Please make sure you remember it or store it in a safe place.",pinNotice_check1:"I understand that losing this PIN will result in permanent loss of access to my wallet and assets.",pinNotice_check2:"I understand that no one, including the support team, can recover or reset this PIN on my behalf.",pinNotice_nextButton:"Next",pinNotice_submitButton:"I Understand",pinSetup_title:"Create PIN",pinSetup_headerSubtitle:"This PIN is used to authorize your transactions.",pinSetup_subtitle:"Set a 6-digit PIN to authorize transactions.",pinSetup_confirmTitle:"Confirm PIN",pinSetup_confirmSubtitle:"Enter your PIN again to confirm.",pinSetup_mismatchError:"PINs do not match. Please try again.",pinValidation_tooShort:"Please enter a 6-digit PIN.",pinValidation_numbersOnly:"Only numbers (0-9) are allowed.",pinValidation_repeatingDigit:"Cannot use the same number 3+ times in a row.",pinValidation_sequential:"Sequential numbers (e.g., 123456) are not allowed.",pinValidation_alternatingPattern:"Repeating patterns (e.g., 121212) are not allowed.",pinInput_title:"Enter PIN",pinInput_subtitle:"Enter your 6-digit PIN to continue.",pinInput_error:"Incorrect PIN. Please try again.",verifyPin_title:"Verify Your PIN",verifyPin_subtitle:"To continue, please confirm your PIN.",pinLocked_message:"Please try again after the lock expires.",pinLocked_availableFrom:"Available from"},Ws={ko:Gs,en:ss};function It(r="en",e){return Ws[r]??ss}const Tt="crossx_access_token",At="crossx_refresh_token",Rt="crossx_user_info";class qs{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,this._migrated=!1;const c=e.projectId;this.STORAGE_KEY_ACCESS_TOKEN=`crossx_${c}_access_token`,this.STORAGE_KEY_REFRESH_TOKEN=`crossx_${c}_refresh_token`,this.STORAGE_KEY_USER=`crossx_${c}_user_info`}get useCookieAuth(){return this.config.authMode==="cookie"}checkResponseError(e,s){if(e!=null&&e.code&&e.code!==200&&e.code>0)throw new m(p.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 m(p.AUTH_FAILED,`${s} 실패 (코드 ${n.code}): ${n.message}`)}}async execute(e){let s;try{const t=e==null?void 0:e.provider;let n="/login";t==="google"?n="/google":t==="apple"&&(n="/apple");const{oauthServiceUrl:o}=this.config,i=`${o}${n}`;d.log(`[CROSSx] OAuth 팝업 열기 (${t||"일반"} 로그인)`),s=await this.oauth.openAuth({authUrl:i,expectedOrigin:new URL(o).origin}),d.log("[CROSSx] OAuth Firebase 토큰 받음 (length:",s.length,")")}catch(t){return d.error("[CROSSx] SignIn 에러 (OAuth 단계):",t),{success:!1,error:t instanceof Error?t.message:"Sign in failed"}}return this.processFirebaseToken(s)}async executeWithOAuthToken(e){return d.log("[CROSSx] signInWithOAuthToken — Firebase 토큰 주입 (length:",e.length,")"),this.processFirebaseToken(e)}async processFirebaseToken(e){var n,o,i,a;let s,t=!1;try{const{authApiUrl:c}=this.config,{accessToken:l,refreshToken:u}=await this.exchangeFirebaseToken(e,c);let h,_;try{const w=this.crypto.decodeJWT(e);_=(n=w.firebase)==null?void 0:n.sign_in_provider;const b=((o=w.firebase)==null?void 0:o.identities)??{};_==="google.com"?h=(i=b["google.com"])==null?void 0:i[0]:_==="apple.com"&&(h=(a=b["apple.com"])==null?void 0:a[0]),d.log("[CROSSx] OAuth provider sub 추출 — provider:",_,"hasProviderSub:",!!h)}catch{d.warn("[CROSSx] firebaseToken에서 providerSub 추출 실패")}if(l){const w=this.crypto.decodeJWT(l);d.log("[CROSSx] access_token 디코딩 — sub:",w.sub,"exp:",w.exp);const b=await this.crypto.verifyJWT(l);if(t=b.signatureVerified??!1,!b.valid)throw d.error("[CROSSx] access_token 검증 실패"),new Error("유효하지 않은 access token");const y=b.payload;s={id:y.sub,email:y.email,signInProvider:_,providerSub:h},this.tokenStore.set(l),this.useCookieAuth||(await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,l),u&&this.config.secureStorageAvailable!==!1?await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,u):u&&d.warn("[CROSSx] 안전한 스토리지 미사용 — refresh_token 영속 저장을 건너뜁니다"))}else{const w=this.crypto.decodeJWT(e);s={id:w.sub,email:w.email,signInProvider:_,providerSub:h},d.log("[CROSSx] Cookie 모드 — Firebase 토큰에서 사용자 정보 추출 — id:",s.id)}d.log("[CROSSx] 사용자 정보 — id:",s.id);const f=this.useCookieAuth?{id:s.id,signInProvider:s.signInProvider,providerSub:s.providerSub}:s;await this.storage.set(this.STORAGE_KEY_USER,f),d.log("[CROSSx] 사용자 정보 저장 완료 (authMode:",this.useCookieAuth?"cookie":"token",")")}catch(c){return d.error("[CROSSx] SignIn 에러 (토큰 교환 단계):",c),{success:!1,error:c instanceof Error?c.message:"Sign in failed"}}return d.log("[CROSSx][Migration Phase 1] 로그인 완료, 지갑 로드 시작 — 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`;d.log("[CROSSx] Firebase 토큰 교환 요청");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"}:{}});d.log("[CROSSx] 토큰 교환 응답 — status:",o.status);const i=o.data;this.checkResponseError(i,"Token exchange");const a=this.extractAccessToken(i);if(t&&!a)return d.log("[CROSSx] Cookie 모드 — 로그인 성공 (JWT는 HttpOnly 쿠키)"),{};if(!a)throw new m(p.AUTH_FAILED,"토큰 교환 응답에서 access_token을 찾을 수 없습니다");d.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{await this.migrateStorageKeys();const e=this.tokenStore.get();if(e){const t=await this.crypto.verifyJWT(e);if(t.valid){const n=await this.storage.get(this.STORAGE_KEY_USER);if(n)return d.log("[CROSSx] restoreSession — 메모리 토큰 유효, 세션 복원"),this.loadWallet(n,t.signatureVerified)}this.tokenStore.clear()}if(this.useCookieAuth){d.log("[CROSSx] restoreSession — 쿠키 기반 silentRefresh 시도");const t=await this.silentRefresh();t&&this.tokenStore.set(t)}else{const t=await this.storage.get(this.STORAGE_KEY_ACCESS_TOKEN),n=await this.storage.get(this.STORAGE_KEY_REFRESH_TOKEN);if(d.log("[CROSSx] restoreSession — access_token:",t?"있음":"없음","refresh_token:",n?"있음":"없음"),!n)return d.log("[CROSSx] restoreSession — refresh_token 없음, 세션 복원 생략"),null;t&&this.tokenStore.set(t);const o=await this.silentRefresh(n);d.log("[CROSSx] restoreSession — silentRefresh 결과:",o?"토큰 발급 성공":"토큰 없음"),o&&this.tokenStore.set(o)}const s=await this.storage.get(this.STORAGE_KEY_USER);if(d.log("[CROSSx] restoreSession — userInfo 조회:",s?`있음 (id: ${s.id})`:"없음"),!s)return null;d.log("[CROSSx] restoreSession — silentRefresh 성공, 세션 복원 — userId:",s.id);try{return await this.loadWallet(s,!1)}catch(t){return d.warn("[CROSSx] restoreSession — 지갑 로드 실패 (세션은 유지):",t),{success:!0,user:s,tokenSignatureVerified:!1}}}catch(e){return d.log("[CROSSx] restoreSession — 세션 복원 실패, 스토리지 정리:",e),this.tokenStore.clear(),this.useCookieAuth||await this.storage.remove(this.STORAGE_KEY_REFRESH_TOKEN),await this.storage.remove(this.STORAGE_KEY_USER),null}}silentRefresh(e){return this._refreshPromise&&this._lastRefreshToken===e?this._refreshPromise:(this._lastRefreshToken=e,this._refreshPromise=this._doSilentRefresh(e).finally(()=>{this._refreshPromise=null,this._lastRefreshToken=void 0}),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"}:{}});d.log("[CROSSx] silentRefresh 응답 — status:",i.status);const a=i.data;this.checkResponseError(a,"Silent refresh");const c=this.extractAccessToken(a);if(t&&!c){d.log("[CROSSx] silentRefresh 성공 (cookie 갱신)");return}if(!c)throw new m(p.AUTH_FAILED,"토큰 자동 갱신 실패: 응답에 토큰이 없습니다");if(this.tokenStore.set(c),!t){await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,c);const l=this.extractRefreshToken(a);l&&this.config.secureStorageAvailable!==!1&&await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,l)}return d.log("[CROSSx] silentRefresh 성공"),c}async refreshAccessToken(){try{if(this.useCookieAuth)return!!await this.silentRefresh()||this.tokenStore.has();const e=await this.storage.get(this.STORAGE_KEY_REFRESH_TOKEN);return e?!!await this.silentRefresh(e):(d.warn("[CROSSx] refreshAccessToken: refresh_token 없음 — 갱신 불가"),!1)}catch(e){return d.warn("[CROSSx] refreshAccessToken 실패:",e),!1}}async executeWithJWT(e,s){let t,n=!1;try{let o=await this.crypto.verifyJWT(e);if(n=o.signatureVerified??!1,!o.valid){if(!s)return d.error("[CROSSx] signInWithJWT: access_token 검증 실패, refreshToken 없음"),{success:!1,error:"유효하지 않은 access token"};d.log("[CROSSx] signInWithJWT: access_token 만료, refreshToken으로 갱신 시도");const a=await this.silentRefresh(s);if(!a)return d.error("[CROSSx] signInWithJWT: silentRefresh 실패"),{success:!1,error:"access token이 만료되었고 갱신에 실패했습니다"};if(e=a,o=await this.crypto.verifyJWT(e),n=o.signatureVerified??!1,!o.valid)return d.error("[CROSSx] signInWithJWT: 갱신된 access_token도 유효하지 않음"),{success:!1,error:"갱신된 access token이 유효하지 않습니다"};d.log("[CROSSx] signInWithJWT: silentRefresh 성공, 새 access_token 사용")}const i=o.payload;d.log("[CROSSx] signInWithJWT — sub:",i.sub,"signatureVerified:",n),t={id:i.sub,email:i.email},this.tokenStore.set(e),this.useCookieAuth||(await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,e),s&&this.config.secureStorageAvailable!==!1&&await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,s)),await this.storage.set(this.STORAGE_KEY_USER,t),d.log("[CROSSx] signInWithJWT — 토큰 및 사용자 정보 저장 완료")}catch(o){return d.error("[CROSSx] signInWithJWT 에러:",o),{success:!1,error:o instanceof Error?o.message:"JWT sign in failed"}}return this.loadWallet(t,n)}async migrateStorageKeys(){if(!this._migrated){this._migrated=!0;try{const e=await this.storage.get(Rt);if(!e||await this.storage.get(this.STORAGE_KEY_USER))return;await this.storage.set(this.STORAGE_KEY_USER,e);const t=await this.storage.get(Tt);t&&await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,t);const n=await this.storage.get(At);n&&await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,n),await this.storage.remove(Rt),await this.storage.remove(Tt),await this.storage.remove(At),d.log("[CROSSx] 스토리지 키 마이그레이션 완료 (projectId 스코프)")}catch(e){d.warn("[CROSSx] 스토리지 키 마이그레이션 실패:",e)}}}async loadWallet(e,s){let t,n=!1;try{if(typeof this.walletProvider.checkWallet=="function"){d.log("[CROSSx] GET /mnemonic/check — 지갑 상태 확인 (비밀번호 불필요)");const o=await this.walletProvider.checkWallet();if(d.log("[CROSSx] 지갑 상태:",o),o==="migration_required")d.log("[CROSSx] migration_required → needsMigration = true"),n=!0;else if(o==="exists")try{const i=await this.walletProvider.getAddresses(e.id);i.length>0?(t=i[0].address,d.log("[CROSSx] 캐시된 주소 로드 완료 (비밀번호 불필요):",t)):d.log("[CROSSx] 주소 캐시 없음 — createWallet 단계에서 비밀번호 입력 후 로드")}catch(i){d.warn("[CROSSx] getAddresses 실패, createWallet 단계에서 재시도:",i)}}else d.log("[CROSSx] getOrCreateWallet 직접 호출 (폴백)"),t=(await this.walletProvider.getOrCreateWallet(e.id)).address,d.log("[CROSSx] 지갑 로드 완료 — address:",t)}catch(o){if(o instanceof m&&o.code===p.MIGRATION_BACKUP_EXISTS)d.log("[CROSSx] MIGRATION_BACKUP_EXISTS 감지 → needsMigration = true"),n=!0;else{if(o instanceof m&&(o.code===p.PROJECT_NOT_REGISTERED||o.code===p.PROJECT_ID_MISSING||o.code===p.ORIGIN_NOT_ALLOWED))throw d.error("[CROSSx] 프로젝트 설정 에러:",o.message),o;d.warn("[CROSSx] 지갑 상태 확인 실패 (로그인은 유지):",o)}}return d.log("[CROSSx] loadWallet 결과 — address:",t,"needsMigration:",n),{success:!0,address:t,user:e,needsMigration:n,tokenSignatureVerified:s}}}class Ks{constructor(e,s,t){this.config=e,this.storage=s,this.tokenStore=t;const n=e.projectId;this.STORAGE_KEY_ACCESS_TOKEN=`crossx_${n}_access_token`,this.STORAGE_KEY_REFRESH_TOKEN=`crossx_${n}_refresh_token`,this.STORAGE_KEY_USER=`crossx_${n}_user_info`}async execute(){this.tokenStore.clear(),this.config.authMode!=="cookie"&&(await this.storage.remove(this.STORAGE_KEY_ACCESS_TOKEN),await this.storage.remove(this.STORAGE_KEY_REFRESH_TOKEN)),await this.storage.remove(this.STORAGE_KEY_USER),await this.storage.clear()}}class Vs{constructor(e,s){this.storage=e,this.walletProvider=s}async execute(e,s){if(!this.walletProvider.migrateWallet)throw new m(p.NOT_IMPLEMENTED,"현재 환경에서는 마이그레이션이 지원되지 않습니다");d.log("[CROSSx][Migration Phase 4] MigrateWalletUseCase.execute() — pin 길이:",e.length,"sub:",s);const t=await this.walletProvider.migrateWallet(e,s);return d.log("[CROSSx][Migration Phase 5] MigrateWalletUseCase 완료 — address:",t.address),{address:t.address}}}class ht{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 n=new Uint8Array(s.length);for(let o=0;o<s.length;o++)n[o]=s[o]^t[o];s.fill(0),this.xorKey=t,this.encryptedBytes=n}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 zs{constructor(e,s){this.chainRegistry=e,this.transport=s,this._nextId=1}async call(e,s,t){const n=await this.chainRegistry.getChain(t),o={jsonrpc:"2.0",method:e,params:s,id:this._nextId++},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 m(p.UNKNOWN_ERROR,`RPC 오류 [${e}] (${t}): ${a.error.message} (코드: ${a.error.code})`);return a==null?void 0:a.result}}class js{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 Ge={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 Ys(r){const e=r.environment;return e&&e in Ge?Ge[e]:null}function Js(){try{if(typeof __CROSSX_CONFIG__<"u"){const r=typeof __CROSSX_CONFIG__=="string"?JSON.parse(__CROSSX_CONFIG__):__CROSSX_CONFIG__,e=Ys(r);if(e)return e}}catch{}return Ge.production}const Xs=2e3,kt=6e4,Zs=1e3,Qs=1e4,er="0x77359400",Pt="0x3B9ACA00",Ot=130,Ct=6,Nt=18,tr=3e4,sr=5*60*1e3,rr=30*1e3,re=class re extends js{constructor(e,s,t,n,o,i,a,c,l,u,h){var _,f;super(),this.storage=t,this.crypto=n,this.transport=o,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._verifyPinMutex=null,this._themeMediaCleanup=null,this._config=Object.freeze({...e}),this.internalConfig=e,this.adapterConfig=s,e.logger&&Et(e.logger),this.confirmation=l,this.pinStore=h??new ht,this.chainRegistry=u,this.jsonRpc=new zs(u,o),this.signInUseCase=new qs(this.internalConfig,t,n,i,o,a,c),this.signOutUseCase=new Ks(this.internalConfig,t,c),this.migrateWalletUseCase=new Vs(t,a),(_=a.setOnUnauthorized)==null||_.call(a,()=>this.forceLogout()),(f=a.setTokenRefresher)==null||f.call(a,()=>this.signInUseCase.refreshAccessToken()),e.autoDetectTheme&&this._setupAutoDetectTheme()}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){var s,t;d.log("[CROSSx SDK] v1.3.8 초기화 중..."),this.confirmation.setMessages(It(this._config.locale));try{const n=Js();this.internalConfig.oauthServiceUrl=n.oauthServiceUrl,this.internalConfig.authApiUrl=n.authApiUrl,this.internalConfig.walletGatewayUrl=n.walletGatewayUrl,this.adapterConfig.gatewayUrl=n.walletGatewayUrl,(t=(s=this.crypto).setJWKSEndpoint)==null||t.call(s,`${n.authApiUrl}/.well-known/jwks.json`);const o=await this.signInUseCase.restoreSession();if(o!=null&&o.success){this.applyAuthResult(o);try{await this.loadWalletAfterAuth(e==null?void 0:e.preferredWalletIndex)}catch(i){if(!(i instanceof m&&i.code===p.PIN_CANCELLED))throw i;d.log("[CROSSx] initialize: 비밀번호 입력 취소 — 지갑 미로드 상태로 계속")}}return this.initialized=!0,d.info("[CROSSx SDK] v1.3.8 초기화 완료"),this.emit("initialized",{restored:!!(o!=null&&o.success)}),o??null}catch(n){throw new m(p.AUTH_NOT_INITIALIZED,"SDK 초기화에 실패했습니다",n)}}async signIn(e){if(this.ensureInitialized(),this.authenticated)throw new m(p.ALREADY_AUTHENTICATED,"이미 로그인된 상태입니다. signOut()을 먼저 호출하세요.");let s=e;if(!(e!=null&&e.provider)){const t=await this.confirmation.showLoginSelector({showConnectOtherWallets:this._config.showConnectOtherWallets});if(t==="external")throw this.emit("connectExternalWallet",{}),new m(p.EXTERNAL_WALLET_REQUESTED,"User requested external wallet connection");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(p.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: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}}catch(t){throw t instanceof m&&t.code===p.PIN_CANCELLED&&(d.log("[CROSSx] signInWithCreate: 비밀번호 설정 취소 — 자동 로그아웃 진행"),await this.signOut().catch(n=>d.warn("[CROSSx] signInWithCreate: 자동 로그아웃 실패",n))),t}}async signInWithOAuthToken(e){if(this.ensureInitialized(),this.authenticated)throw new m(p.ALREADY_AUTHENTICATED,"이미 로그인된 상태입니다. signOut()을 먼저 호출하세요.");try{const s=await this.signInUseCase.executeWithOAuthToken(e);return s.success&&this.applyAuthResult(s),s}catch(s){throw new m(p.AUTH_FAILED,"OAuth 토큰 로그인에 실패했습니다",s)}}async signInWithJWT(e,s){if(this.ensureInitialized(),this.authenticated)throw new m(p.ALREADY_AUTHENTICATED,"이미 로그인된 상태입니다. signOut()을 먼저 호출하세요.");try{const t=await this.signInUseCase.executeWithJWT(e,s);return t.success&&this.applyAuthResult(t),t}catch(t){throw new m(p.AUTH_FAILED,"JWT 로그인에 실패했습니다",t)}}async signOut(){this.ensureInitialized();try{await this.signOutUseCase.execute(),this.clearAuthState()}catch(e){throw new m(p.UNKNOWN_ERROR,"로그아웃에 실패했습니다",e)}}isAuthenticated(){return this.authenticated}async whenReady(){if(this.initialized)return!0;if(this._initPromise)try{return await this._initPromise,this.initialized}catch{return!1}return!1}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===p.PIN_CANCELLED||d.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(p.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}),d.log("[CROSSx] migrateWallet 완료 — address:",s.address),s}catch(s){throw s instanceof m?s:new m(p.MIGRATION_FAILED,"지갑 마이그레이션에 실패했습니다",s)}}async getAddress(e){if(e!==void 0){if(this.ensureAuthenticated(),!this.userId)throw new m(p.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(p.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.ensurePinForSigning();const n=s.length,i={address:(await this.withPinRetry(()=>this.walletProvider.getAddress(this.userId,n))).address,index:n};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(p.UNKNOWN_ERROR,"체인 목록 조회에 실패했습니다",e)}}async getChain(e){this.ensureInitialized();try{return await this.chainRegistry.getChain(e)}catch(s){throw s instanceof m?s:new m(p.CHAIN_NOT_SUPPORTED,`체인 조회에 실패했습니다: ${e}`,s)}}_setupAutoDetectTheme(){if(typeof window>"u"||!window.matchMedia)return;const e=window.matchMedia("(prefers-color-scheme: dark)"),s=n=>{const o=n?"dark":"light";this.applyTheme(o,this._config.themeTokens??{})};s(e.matches);const t=n=>s(n.matches);e.addEventListener("change",t),this._themeMediaCleanup=()=>e.removeEventListener("change",t)}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(It(e))}async createWallet(){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");d.log("[CROSSx] createWallet 시작");const e=await this.fetchWalletStatus();if(d.log("[CROSSx] 지갑 상태:",e),e==="migration_required"){const s=this.providerSub??this.userId;d.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(p.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}if(e==="exists"){await this.ensureVerifiedPin();try{const s=await this.withPinRetry(()=>this.walletProvider.getOrCreateWallet(this.userId));return this.address=s.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:s.address,index:0}),d.log("[CROSSx] 지갑 준비 완료:",s.address),{address:s.address}}catch(s){if(s instanceof m&&s.code===p.MIGRATION_BACKUP_EXISTS){const t=this.providerSub??this.userId;d.log("[CROSSx] MIGRATION_BACKUP_EXISTS (폴백) → 마이그레이션 UI 시작");const n=await this.handleMigrationFlow(t);if(n)return this.address=n.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:n.address,index:0}),{address:n.address};throw new m(p.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}throw s}}await this.ensurePinSetup();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}),d.log("[CROSSx] 지갑 준비 완료:",s.address),{address:s.address}}catch(s){if(s instanceof m&&s.code===p.MIGRATION_BACKUP_EXISTS){const t=this.providerSub??this.userId;d.log("[CROSSx] MIGRATION_BACKUP_EXISTS (폴백) → 마이그레이션 UI 시작");const n=await this.handleMigrationFlow(t);if(n)return this.address=n.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:n.address,index:0}),{address:n.address};throw new m(p.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}throw s}}async fetchWalletStatus(){if(typeof this.walletProvider.checkWallet=="function")try{return await this.walletProvider.checkWallet()}catch(e){return d.warn("[CROSSx] checkWallet 실패 (폴백: not_found 처리):",e),"not_found"}return null}async signMessage(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.resolveAddress(t==null?void 0:t.index);if(!await this.confirmation.requestConfirmation({type:"sign-message",chainId:e,from:n.address,message:s,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the message signing request");try{const i=await this.withPinRetry(async()=>{let a;return this.walletProvider.prepare&&(a=(await this.walletProvider.prepare("sign-message",{message:s,from:n.address})).uuid),await this.ensureVerifiedPin(),this.walletProvider.signMessage(this.userId,e,s,t==null?void 0:t.index,a,n.address)});return this.verifySignatureSigner(s,i.signature,n.address),{chainId:e,signature:i.signature,message:s,address:n.address}}catch(i){throw i instanceof m?i:new m(p.SIGNATURE_FAILED,`메시지 서명에 실패했습니다 (${e})`,i)}}async signTypedData(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");if(!this.walletProvider.signTypedData)throw new m(p.NOT_IMPLEMENTED,"signTypedData가 구현되어 있지 않습니다");re.validateTypedDataChainId(e,s);const n=await this.resolveAddress(t==null?void 0:t.index);if(!await this.confirmation.requestConfirmation({type:"sign-typed-data",chainId:e,from:n.address,typedData:s,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the typed data signing request");try{const i=await this.withPinRetry(async()=>{let a;return this.walletProvider.prepare&&(a=(await this.walletProvider.prepare("sign-typed-data",{typedData:s,from:n.address})).uuid),await this.ensureVerifiedPin(),this.walletProvider.signTypedData(this.userId,e,s,t==null?void 0:t.index,a,n.address)});return re.validateSignatureFormat(i.signature),{chainId:e,signature:i.signature,address:n.address}}catch(i){throw i instanceof m?i:new m(p.SIGNATURE_FAILED,`타입 데이터 서명에 실패했습니다 (${e})`,i)}}async signTypedDataOffchain(e,s){return this.signTypedData(re.OFFCHAIN_CHAIN_ID,e,s)}async signTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);n.from||(n.from=(await this.resolveAddress(t==null?void 0:t.index)).address);const o=Ze(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:o.symbol,nativeDecimals:o.decimals,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the transaction signing request");try{const a=await this.withPinRetry(async()=>{let c;return this.walletProvider.prepare&&(c=(await this.walletProvider.prepare("sign",{tx:n})).uuid),await this.ensureVerifiedPin(),this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,c)});return re.validateSignedTxFormat(a.signature),{chainId:e,signedTx:a.signature,txHash:a.txHash??""}}catch(a){if(a instanceof m)throw a;const c=a instanceof Error?a.message:String(a);throw new m(p.SIGNATURE_FAILED,`트랜잭션 서명에 실패했습니다 (${e}): ${c}`,a)}}async sendTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);n.from||(n.from=(await this.resolveAddress(t==null?void 0:t.index)).address);const o=Ze(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:o.symbol,nativeDecimals:o.decimals,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the transaction request");try{const a=await this.withPinRetry(async()=>{let c;if(this.walletProvider.prepare&&(c=(await this.walletProvider.prepare("send",{tx:n})).uuid),await this.ensureVerifiedPin(),this.walletProvider.sendTransaction)return(await this.walletProvider.sendTransaction(this.userId,e,n,c)).txHash;const l=await this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,c);return l.txHash??l.signature});return{chainId:e,txHash:a,status:"pending"}}catch(a){if(a instanceof m)throw a;const c=a instanceof Error?a.message:String(a);throw new m(p.TRANSACTION_FAILED,`트랜잭션 전송에 실패했습니다 (${e}): ${c}`,a)}}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??Zs,o=Qs,i=t.timeoutMs??kt,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(u=>setTimeout(u,c)),c=Math.min(c*2,o)}throw new m(p.UNKNOWN_ERROR,`트랜잭션 영수증 조회 시간이 초과되었습니다 (${e})`)}async sendTransactionWithWaitForReceipt(e,s,t={}){var b,y;const{intervalMs:n,timeoutMs:o,...i}=t,{txHash:a}=await this.sendTransaction(e,s,i),c=n??((b=this._config.receiptPolling)==null?void 0:b.intervalMs)??Xs,l=o??((y=this._config.receiptPolling)==null?void 0:y.timeoutMs)??kt,u=Ze(e),h=s.from??"";let _,f;const w=this.waitForTxAndGetReceipt(a,e,{intervalMs:c,timeoutMs:l}).then(T=>{_=T;const N=BigInt(T.gasUsed)*BigInt(T.effectiveGasPrice),W=s.value?BigInt(s.value):0n,B=re.formatTxAmount(s.value,u.symbol,u.decimals),j=re.formatTxAmount("0x"+N.toString(16),u.symbol,u.decimals),q=re.formatTxAmount("0x"+(W+N).toString(16),u.symbol,u.decimals);return{chainId:e,txHash:a,from:T.from,to:T.to??s.to,amount:B,fees:j,total:q,nativeSymbol:u.symbol,status:T.status==="0x1"?"success":"reverted"}}).catch(T=>(f=T instanceof Error?T:new Error(String(T)),{chainId:e,txHash:a,from:h,to:s.to,amount:re.formatTxAmount(s.value,u.symbol,u.decimals),nativeSymbol:u.symbol,status:"timeout"}));if(await this.confirmation.showTransactionProgress({chainId:e,txHash:a,from:h,to:s.to},w),f)throw f;return{chainId:e,txHash:a,receipt:_}}setPin(e){this.pinStore.set(e)}clearPin(){this.pinStore.clear()}hasPin(){return this.pinStore.has()}async changePin(e,s){this.ensureAuthenticated();const t=this.walletProvider;if(typeof t.changePin!="function")throw new m(p.NOT_IMPLEMENTED,"changePin이 구현되어 있지 않습니다");this.pinStore.set(e);try{await t.changePin(e,s),this.pinStore.set(s),d.log("[CROSSx] PIN 변경 완료")}catch(n){throw n instanceof m?n:new m(p.UNKNOWN_ERROR,"PIN 변경에 실패했습니다",n)}}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(p.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 m(p.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 m(p.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(p.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 n=t instanceof Error?t.message:String(t);throw new m(p.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:re.formatWei(n),chainId:e}}catch(t){if(t instanceof m)throw t;const n=t instanceof Error?t.message:String(t);throw new m(p.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(Nt),n=s/t,i=(s%t).toString().padStart(Nt,"0").replace(/0+$/,"").slice(0,Ct);return i?`${n}.${i}`:`${n}`}catch{return"?"}}getProvider(e){return this.ensureAuthenticated(),new ts(this,e)}async walletRpc(e,s,t){this.ensureAuthenticated();try{return await this.jsonRpc.call(e,s,t)}catch(n){if(n instanceof m)throw n;const o=n instanceof Error?n.message:String(n);throw new m(p.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,Ct).replace(/0+$/,"");return`${c?`${i}.${c}`:`${i}`} ${s}`}catch{return}}async handleMigrationFlow(e){var c,l,u;d.log('[CROSSx][Migration Phase 3] "Wallet Found" 팝업 표시');const s=((c=this._config.migration)==null?void 0:c.allowSkip)??!0,t=await this.confirmation.showMigrationFoundPrompt({allowSkip:s});if(d.log("[CROSSx][Migration Phase 3] 사용자 선택:",t),t==="skip")return d.log("[CROSSx][Migration Phase 3] 사용자가 마이그레이션을 건너뜀 → 종료"),null;let n,o=0,i=5,a=null;for(;;){o++,d.log(`[CROSSx][Migration Phase 4] PIN 입력 팝업 표시 (시도 #${o}/${i})`,n?`— 이전 메시지: ${n}`:"");const h=await this.confirmation.showRecoveryPinInputPrompt({errorMessage:n,attemptCount:o>1?o-1:void 0,maxAttempts:i});if(h===null)return d.log("[CROSSx][Migration Phase 4] 사용자가 PIN 입력을 취소함 → 종료"),null;d.log("[CROSSx][Migration Phase 4] PIN 입력 완료 — verify-recovery-pin API 호출"),n=void 0;try{const _=await((u=(l=this.walletProvider).verifyRecoveryPin)==null?void 0:u.call(l,h,e));if(!_){d.log("[CROSSx][Migration Phase 4] verifyRecoveryPin 미지원 — PIN 검증 생략"),a=h;break}if(_.valid){d.log("[CROSSx][Migration Phase 4] PIN 검증 성공"),a=h;break}const f=_.pinStatus;if(i=f.maxAttempts,o=i-f.remainingAttempts,f.remainingAttempts===0&&f.lockExpiresAt){const w=f.lockExpiresAt*1e3,b=Math.max(1,Math.round((w-Date.now())/1e3)),y=b<=1800?"Too many failed attempts. Please try again in 30 minutes.":"Too many failed attempts. Please try again in 24 hours.";d.warn(`[CROSSx][Migration Phase 4] verify-recovery-pin 잠금 — ${b}초, 메시지: ${y}`),await this.confirmation.showRecoveryPinLockedPrompt(b,y),o=0,n="Your account lock has been lifted. You may try again."}else d.warn(`[CROSSx][Migration Phase 4] PIN 불일치 (시도 ${o}/${i})`),n="Incorrect PIN."}catch(_){if(!(_ instanceof m))throw _;if(_.code===p.MIGRATION_PIN_LOCKED){const f=_.details;if(i=(f==null?void 0:f.maxAttempts)??5,(f==null?void 0:f.permanent)===!0)return d.warn("[CROSSx][Migration Phase 4] PIN 영구 잠금 (verify-recovery-pin)"),await this.confirmation.showRecoveryPinLockedPrompt(0,"Your account has been permanently locked due to too many failed attempts."),null;const w=((f==null?void 0:f.lockExpiresAt)??0)*1e3,b=Math.max(1,Math.round((w-Date.now())/1e3)),y=b<=1800?"Too many failed attempts. Please try again in 30 minutes.":"Too many failed attempts. Please try again in 24 hours.";d.warn(`[CROSSx][Migration Phase 4] verify-recovery-pin 이미 잠금 — ${b}초`),await this.confirmation.showRecoveryPinLockedPrompt(b,y),o=0,n="Your account lock has been lifted. You may try again."}else throw d.error("[CROSSx][Migration Phase 4] verify-recovery-pin 실패 (복구 불가):",_),_}}d.log("[CROSSx][Migration Phase 5] PIN 검증 완료 — 비밀번호 설정 및 마이그레이션 진행");try{await this.ensurePinSetup();const h=await this.migrateWalletUseCase.execute(a,e);return d.log("[CROSSx][Migration Phase 5] 마이그레이션 성공 — address:",h.address),h}catch(h){if(h instanceof m&&h.code===p.MIGRATION_FAILED)return d.warn("[CROSSx][Migration Phase 5] migrate PIN 불일치 (경합) — 처음부터 재시도"),this.handleMigrationFlow(e);throw d.error("[CROSSx][Migration Phase 5] 마이그레이션 실패 (복구 불가):",h),h}}async withResolvedGasAndFee(e,s){const t=f=>!(f!=null&&f.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},l=n?c.from??this.address:void 0;l&&d.log("[CROSSx] nonce 비어있음 → eth_getTransactionCount 호출 (from:",l,")"),o&&d.log("[CROSSx] gasLimit 비어있음 → eth_estimateGas 호출"),i&&d.log("[CROSSx] gasPrice & maxFeePerGas 비어있음 → baseFee 조회로 Dynamic/Legacy 판별");const[u,h,_]=await Promise.all([l?this.jsonRpc.call("eth_getTransactionCount",[l,"pending"],s):null,o?this.estimateGas(e,s):null,i?this.getBaseFeePerGas(s):null]);if(l&&(c.nonce=parseInt(u??"0x0",16),d.log("[CROSSx] nonce 결과:",c.nonce)),o&&(c.gasLimit=h,d.log("[CROSSx] estimateGas 결과:",c.gasLimit)),i){const f=_;if(f){const w=Pt;c.maxFeePerGas="0x"+(BigInt(f)+BigInt(w)).toString(16),c.maxPriorityFeePerGas=w,d.log("[CROSSx] Dynamic 체인 감지 — baseFee:",f,"maxFeePerGas:",c.maxFeePerGas,"maxPriorityFeePerGas: 1 Gwei")}else c.gasPrice=er,d.log("[CROSSx] Legacy 체인 감지 — gasPrice: 2 Gwei")}return!i&&a&&(c.maxPriorityFeePerGas=Pt,d.log("[CROSSx] maxPriorityFeePerGas 비어있음 → 1 Gwei 기본값 적용")),c}static validateTypedDataChainId(e,s){const t=re.extractDomainChainId(s);if(e==="0"){if(t!==void 0&&t!==0)throw new m(p.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 m(p.TYPED_DATA_CHAIN_ID_MISMATCH,`온체인 서명(${e})에서는 typedData.domain.chainId가 반드시 있어야 합니다`);if(t!==o)throw new m(p.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 m(p.SIGNATURE_FAILED,"유효하지 않은 서명: 올바른 hex 문자열이 아닙니다");if(s.length!==Ot)throw new m(p.SIGNATURE_FAILED,`서명 길이가 유효하지 않습니다: ${Ot} 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(p.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 올바른 hex 문자열이 아닙니다");if(s.length<2)throw new m(p.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 너무 짧습니다")}verifySignatureSigner(e,s,t){if(this.crypto.recoverPersonalSignSigner)try{const n=this.crypto.recoverPersonalSignSigner(e,s);if(n.toLowerCase()!==t.toLowerCase())throw d.error("[CROSSx] 서명 검증 실패: 서명자 주소 불일치",{expected:t,recovered:n}),new m(p.SIGNATURE_SIGNER_MISMATCH,`서명자 주소가 일치하지 않습니다: 예상 ${t}, 복원된 주소 ${n}`);d.log("[CROSSx] 서명 ecrecover 검증 성공")}catch(n){if(n instanceof m)throw n;d.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.activeWalletIndex=0,this.userEmail=((t=e.user)==null?void 0:t.email)??null,this.providerSub=((n=e.user)==null?void 0:n.providerSub)??null,this.loginType=re.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.activeWalletIndex=0,this.userEmail=null,this.providerSub=null,this.loginType=null,this.tokenSignatureVerified=!1,this.pinStore.clear(),this.emit("authChanged",{isAuthenticated:!1,address:null,userId:null})}forceLogout(){this.authenticated&&(d.warn("[CROSSx] 인증 만료(Gateway -10002) — 강제 로그아웃"),this.clearAuthState())}static normalizeLoginType(e){return e?e.includes("google")?"google":e.includes("apple")?"apple":e:null}async ensurePinSetup(){if(this.pinStore.has())return;const e=await this.confirmation.showPinSetupPrompt();if(!e)throw new m(p.PIN_CANCELLED,"사용자가 PIN 설정을 취소했습니다");this.pinStore.set(e),d.log("[CROSSx] PIN 설정 완료 (메모리 캐시)")}async ensurePinForSigning(e){if(this.pinStore.has()&&!e)return;e&&this.pinStore.clear();const s=await this.confirmation.showPinInputPrompt({errorMessage:e});if(!s)throw new m(p.PIN_CANCELLED,"사용자가 PIN 입력을 취소했습니다");this.pinStore.set(s),d.log("[CROSSx] PIN 입력 완료 (메모리 캐시)")}async ensureVerifiedPin(e,s){if(e)this.pinStore.clear();else if(this.pinStore.has())return;if(this._verifyPinMutex&&!e){d.log("[CROSSx] ensureVerifiedPin: 진행 중인 검증 대기"),await this._verifyPinMutex;return}let t,n;this._verifyPinMutex=new Promise((o,i)=>{t=o,n=i});try{if(typeof this.walletProvider.verifyPin!="function"){const i=await this.confirmation.showPinInputPrompt({verifyMode:!0,errorMessage:e,lockExpiresAt:s});if(!i)throw new m(p.PIN_CANCELLED,"사용자가 PIN 입력을 취소했습니다");this.pinStore.set(i),d.log("[CROSSx] PIN 캐시 완료 (verifyPin 미지원, 로컬 전용)"),t();return}const o=await this.confirmation.showPinInputPrompt({verifyMode:!0,errorMessage:e,lockExpiresAt:s,onSubmit:async i=>{var a;this.pinStore.set(i);try{return await this.walletProvider.verifyPin(i)?(d.log("[CROSSx] PIN 서버 검증 완료 (verify-password)"),{ok:!0}):(this.pinStore.clear(),{ok:!1,error:"Incorrect PIN. Please try again."})}catch(c){if(this.pinStore.clear(),c instanceof m){if(c.code===p.PIN_WRONG)return{ok:!1,error:"Incorrect PIN. Please try again."};if(c.code===p.PIN_INVALID)return{ok:!1,error:c.message};if(c.code===p.PIN_LOCKED)return{ok:!1,error:"Too many failed attempts. Your account is temporarily locked.",lockExpiresAt:(a=c.details)==null?void 0:a.lockExpiresAt}}throw c}}});if(!o)throw new m(p.PIN_CANCELLED,"사용자가 PIN 입력을 취소했습니다");this.pinStore.set(o),d.log("[CROSSx] PIN 갱신 완료 (verify 모달 닫힘)"),t()}catch(o){throw n(o),o}finally{this._verifyPinMutex=null}}async loadWalletAfterAuth(e){if(!this.userId)return;const s=await this.fetchWalletStatus();if(d.log("[CROSSx] loadWalletAfterAuth 지갑 상태:",s),s!=="exists")return;const t=await this.walletProvider.getAddresses(this.userId);if(t.length>0){const o=e!==void 0?t.find(i=>i.index===e)??t[0]:t[0];this.address=o.address,this.activeWalletIndex=o.index,d.log("[CROSSx] 캐시된 주소 로드 완료 (비밀번호 불필요):",this.address),this.emit("addressChanged",{address:o.address,index:o.index});return}d.log("[CROSSx] 주소 캐시 없음 — 비밀번호 확인 후 address(0) 조회"),await this.ensureVerifiedPin();const n=await this.walletProvider.getAddress(this.userId,0);this.address=n.address,this.activeWalletIndex=0,d.log("[CROSSx] 세션 복원 후 지갑 주소 로드 완료:",this.address),this.emit("addressChanged",{address:n.address,index:0})}async withPinRetry(e){let s,t;try{return await e()}catch(n){if(n instanceof m)if(n.code===p.PIN_WRONG)s="Incorrect PIN. Please enter your current PIN.";else if(n.code===p.PIN_INVALID)s=n.message;else if(n.code===p.PIN_LOCKED){const o=n.details;t=o==null?void 0:o.lockExpiresAt,s="Too many failed attempts. Your account is temporarily locked."}else throw n;else throw n}for(;;){d.warn("[CROSSx] PIN 불일치/잠금 — 재입력 요청:",s),this.pinStore.clear(),await this.ensureVerifiedPin(s,t),t=void 0;try{return await e()}catch(n){if(n instanceof m){if(n.code===p.PIN_WRONG){s="Incorrect PIN. Please try again.";continue}if(n.code===p.PIN_INVALID){s=n.message;continue}if(n.code===p.PIN_LOCKED){const o=n.details;t=o==null?void 0:o.lockExpiresAt,s="Too many failed attempts. Your account is temporarily locked.";continue}}throw n}}}async resolveAddress(e){if(e===void 0||e===this.activeWalletIndex){if(!this.address)throw new m(p.AUTH_NOT_AUTHENTICATED,"활성 지갑 주소를 찾을 수 없습니다");return{address:this.address,index:this.activeWalletIndex}}return{address:(await this.withPinRetry(()=>this.walletProvider.getAddress(this.userId,e))).address,index:e}}ensureInitialized(){if(!this.initialized)throw new m(p.AUTH_NOT_INITIALIZED,"SDK가 초기화되지 않았습니다. initialize()를 먼저 호출하세요.")}ensureAuthenticated(){if(this.ensureInitialized(),!this.authenticated)throw new m(p.AUTH_NOT_AUTHENTICATED,"인증되지 않은 상태입니다. signIn()을 먼저 호출하세요.")}dispose(){var e;(e=this._themeMediaCleanup)==null||e.call(this),this._themeMediaCleanup=null,this.clearAuthState(),this.tokenStore.clear(),this.pinStore.clear(),this.initialized=!1,this.removeAllListeners(),Et(null)}_getInternalContext(){return{transport:this.transport,storage:this.storage,walletProvider:this.walletProvider,confirmation:this.confirmation,tokenStore:this.tokenStore,pinStore:this.pinStore,adapterConfig:this.adapterConfig}}};re.OFFCHAIN_CHAIN_ID="0";let We=re;class nr{constructor(){this.prefix="crossx_"}async set(e,s){try{const t=JSON.stringify(s);localStorage.setItem(this.prefix+e,t)}catch(t){throw d.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 d.error("Storage get error:",s),null}}async remove(e){try{localStorage.removeItem(this.prefix+e)}catch(s){throw d.error("Storage remove error:",s),s}}async clear(){try{Object.keys(localStorage).forEach(s=>{s.startsWith(this.prefix)&&localStorage.removeItem(s)})}catch(e){throw d.error("Storage clear error:",e),e}}}const Qe="crossx-sdk",or=1,de="data",ve="keys",$e="aes-primary",ir=12;class Lt{constructor(e){this.db=null,this.cryptoKey=null,this.initPromise=null,this.dbName=`crossx-sdk-${e}`}async ensureReady(){this.db&&this.cryptoKey||(this.initPromise||(this.initPromise=this.init()),await this.initPromise)}openDB(e=this.dbName){return new Promise((s,t)=>{const n=indexedDB.open(e,or);n.onupgradeneeded=()=>{const o=n.result;o.objectStoreNames.contains(de)||o.createObjectStore(de),o.objectStoreNames.contains(ve)||o.createObjectStore(ve)},n.onsuccess=()=>s(n.result),n.onerror=()=>t(n.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(ve,$e);if(e){this.cryptoKey=e;return}const s=await this.migrateFromLegacyDB();if(s){this.cryptoKey=s;return}this.cryptoKey=await crypto.subtle.generateKey({name:"AES-GCM",length:256},!1,["encrypt","decrypt"]),await this.idbPut(ve,$e,this.cryptoKey)}async migrateFromLegacyDB(){if(this.dbName===Qe)return null;try{const e=await this.openDB(Qe),s=e.transaction([ve,de],"readonly"),t=s.objectStore(ve).get($e),n=await new Promise((l,u)=>{t.onsuccess=()=>l(t.result),t.onerror=()=>u(t.error)});if(!n)return e.close(),null;const o=s.objectStore(de).getAll(),i=s.objectStore(de).getAllKeys(),[a,c]=await Promise.all([new Promise((l,u)=>{o.onsuccess=()=>l(o.result),o.onerror=()=>u(o.error)}),new Promise((l,u)=>{i.onsuccess=()=>l(i.result),i.onerror=()=>u(i.error)})]);e.close(),await this.idbPut(ve,$e,n);for(let l=0;l<c.length;l++)await this.idbPut(de,String(c[l]),a[l]);return indexedDB.deleteDatabase(Qe),d.log("[CROSSx] IndexedDB 레거시 DB 마이그레이션 완료"),n}catch(e){return d.warn("[CROSSx] IndexedDB 레거시 DB 마이그레이션 실패:",e),null}}async encrypt(e){const s=new Uint8Array(ir);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(de,e,n)}catch(t){throw d.error("[CROSSx] IndexedDB set error:",t),t}}async get(e){try{await this.ensureReady();const s=await this.idbGet(de,e);if(!s)return null;const t=await this.decrypt(s);return JSON.parse(t)}catch(s){return d.error("[CROSSx] IndexedDB get error:",s),null}}async remove(e){try{await this.ensureReady(),await this.idbDelete(de,e)}catch(s){throw d.error("[CROSSx] IndexedDB remove error:",s),s}}async clear(){try{await this.ensureReady(),await this.idbClear(de)}catch(e){throw d.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 pt(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function me(r,e=""){if(!Number.isSafeInteger(r)||r<0){const s=e&&`"${e}" `;throw new Error(`${s}expected integer >= 0, got ${r}`)}}function V(r,e,s=""){const t=pt(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 rs(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");me(r.outputLen),me(r.blockLen)}function ke(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 ns(r,e){V(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 ar(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function Pe(...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 ue(r,e){return r<<32-e|r>>>e}const cr=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function lr(r){return r<<24&4278190080|r<<8&16711680|r>>>8&65280|r>>>24&255}function dr(r){for(let e=0;e<r.length;e++)r[e]=lr(r[e]);return r}const Dt=cr?r=>r:dr,os=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",ur=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Me(r){if(V(r),os)return r.toHex();let e="";for(let s=0;s<r.length;s++)e+=ur[r[s]];return e}const fe={_0:48,_9:57,A:65,F:70,a:97,f:102};function Mt(r){if(r>=fe._0&&r<=fe._9)return r-fe._0;if(r>=fe.A&&r<=fe.F)return r-(fe.A-10);if(r>=fe.a&&r<=fe.f)return r-(fe.a-10)}function qe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(os)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=Mt(r.charCodeAt(o)),a=Mt(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 Se(...r){let e=0;for(let t=0;t<r.length;t++){const n=r[t];V(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 is(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 as(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 hr=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function pr(r,e,s){return r&e^~r&s}function fr(r,e,s){return r&e^r&s^e&s}class _r{constructor(e,s,t,n){E(this,"blockLen");E(this,"outputLen");E(this,"padOffset");E(this,"isLE");E(this,"buffer");E(this,"view");E(this,"finished",!1);E(this,"length",0);E(this,"pos",0);E(this,"destroyed",!1);this.blockLen=e,this.outputLen=s,this.padOffset=t,this.isLE=n,this.buffer=new Uint8Array(e),this.view=et(this.buffer)}update(e){ke(this),V(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=et(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){ke(this),ns(e,this),this.finished=!0;const{buffer:s,view:t,blockLen:n,isLE:o}=this;let{pos:i}=this;s[i++]=128,Pe(this.buffer.subarray(i)),this.padOffset>n-i&&(this.process(t,0),i=0);for(let h=i;h<n;h++)s[h]=0;t.setBigUint64(n-8,BigInt(this.length*8),o),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,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let h=0;h<l;h++)a.setUint32(4*h,u[h],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 we=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Be=BigInt(2**32-1),$t=BigInt(32);function xr(r,e=!1){return e?{h:Number(r&Be),l:Number(r>>$t&Be)}:{h:Number(r>>$t&Be)|0,l:Number(r&Be)|0}}function gr(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}=xr(r[o],e);[t[o],n[o]]=[i,a]}return[t,n]}const mr=(r,e,s)=>r<<s|e>>>32-s,wr=(r,e,s)=>e<<s|r>>>32-s,yr=(r,e,s)=>e<<s-32|r>>>64-s,br=(r,e,s)=>r<<s-32|e>>>64-s,Sr=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]),ye=new Uint32Array(64);class vr extends _r{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 h=0;h<16;h++,s+=4)ye[h]=e.getUint32(s,!1);for(let h=16;h<64;h++){const _=ye[h-15],f=ye[h-2],w=ue(_,7)^ue(_,18)^_>>>3,b=ue(f,17)^ue(f,19)^f>>>10;ye[h]=b+ye[h-7]+w+ye[h-16]|0}let{A:t,B:n,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let h=0;h<64;h++){const _=ue(a,6)^ue(a,11)^ue(a,25),f=u+_+pr(a,c,l)+Sr[h]+ye[h]|0,b=(ue(t,2)^ue(t,13)^ue(t,22))+fr(t,n,o)|0;u=l,l=c,c=a,a=i+f|0,i=o,o=n,n=t,t=f+b|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,u=u+this.H|0,this.set(t,n,o,i,a,c,l,u)}roundClean(){Pe(ye)}destroy(){this.set(0,0,0,0,0,0,0,0),Pe(this.buffer)}}class Er extends vr{constructor(){super(32);E(this,"A",we[0]|0);E(this,"B",we[1]|0);E(this,"C",we[2]|0);E(this,"D",we[3]|0);E(this,"E",we[4]|0);E(this,"F",we[5]|0);E(this,"G",we[6]|0);E(this,"H",we[7]|0)}}const Ir=is(()=>new Er,hr(1));/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const ft=BigInt(0),ct=BigInt(1);function Ke(r,e=""){if(typeof r!="boolean"){const s=e&&`"${e}" `;throw new Error(s+"expected boolean, got type="+typeof r)}return r}function cs(r){if(typeof r=="bigint"){if(!Fe(r))throw new Error("positive bigint expected, got "+r)}else me(r);return r}function Ue(r){const e=cs(r).toString(16);return e.length&1?"0"+e:e}function ls(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ft:BigInt("0x"+r)}function je(r){return ls(Me(r))}function ds(r){return ls(Me(Tr(V(r)).reverse()))}function _t(r,e){me(e),r=cs(r);const s=qe(r.toString(16).padStart(e*2,"0"));if(s.length!==e)throw new Error("number too large");return s}function us(r,e){return _t(r,e).reverse()}function Tr(r){return Uint8Array.from(r)}const Fe=r=>typeof r=="bigint"&&ft<=r;function Ar(r,e,s){return Fe(r)&&Fe(e)&&Fe(s)&&e<=r&&r<s}function Rr(r,e,s,t){if(!Ar(e,s,t))throw new Error("expected valid "+r+": "+s+" <= n < "+t+", got "+e)}function kr(r){let e;for(e=0;r>ft;r>>=ct,e+=1);return e}const xt=r=>(ct<<BigInt(r))-ct;function Pr(r,e,s){if(me(r,"hashLen"),me(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),u=0;const h=()=>{c.fill(1),l.fill(0),u=0},_=(...y)=>s(l,Se(c,...y)),f=(y=n)=>{l=_(o,y),c=_(),y.length!==0&&(l=_(i,y),c=_())},w=()=>{if(u++>=a)throw new Error("drbg: tried max amount of iterations");let y=0;const T=[];for(;y<e;){c=_();const N=c.slice();T.push(N),y+=c.length}return Se(...T)};return(y,T)=>{h(),f(y);let N;for(;!(N=T(w()));)f();return h(),N}}function gt(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 Bt(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 ne=BigInt(0),ee=BigInt(1),Ie=BigInt(2),hs=BigInt(3),ps=BigInt(4),fs=BigInt(5),Or=BigInt(7),_s=BigInt(8),Cr=BigInt(9),xs=BigInt(16);function le(r,e){const s=r%e;return s>=ne?s:e+s}function ae(r,e,s){let t=r;for(;e-- >ne;)t*=t,t%=s;return t}function Ut(r,e){if(r===ne)throw new Error("invert: expected non-zero number");if(e<=ne)throw new Error("invert: expected positive modulus, got "+e);let s=le(r,e),t=e,n=ne,o=ee;for(;s!==ne;){const a=t/s,c=t%s,l=n-o*a;t=s,s=c,n=o,o=l}if(t!==ee)throw new Error("invert: does not exist");return le(n,e)}function mt(r,e,s){if(!r.eql(r.sqr(e),s))throw new Error("Cannot find square root")}function gs(r,e){const s=(r.ORDER+ee)/ps,t=r.pow(e,s);return mt(r,t,e),t}function Nr(r,e){const s=(r.ORDER-fs)/_s,t=r.mul(e,Ie),n=r.pow(t,s),o=r.mul(e,n),i=r.mul(r.mul(o,Ie),n),a=r.mul(o,r.sub(i,r.ONE));return mt(r,a,e),a}function Lr(r){const e=Ye(r),s=ms(r),t=s(e,e.neg(e.ONE)),n=s(e,t),o=s(e,e.neg(t)),i=(r+Or)/xs;return(a,c)=>{let l=a.pow(c,i),u=a.mul(l,t);const h=a.mul(l,n),_=a.mul(l,o),f=a.eql(a.sqr(u),c),w=a.eql(a.sqr(h),c);l=a.cmov(l,u,f),u=a.cmov(_,h,w);const b=a.eql(a.sqr(u),c),y=a.cmov(l,u,b);return mt(a,y,c),y}}function ms(r){if(r<hs)throw new Error("sqrt is not defined for small field");let e=r-ee,s=0;for(;e%Ie===ne;)e/=Ie,s++;let t=Ie;const n=Ye(r);for(;Ht(n,t)===1;)if(t++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(s===1)return gs;let o=n.pow(t,e);const i=(e+ee)/Ie;return function(c,l){if(c.is0(l))return l;if(Ht(c,l)!==1)throw new Error("Cannot find square root");let u=s,h=c.mul(c.ONE,o),_=c.pow(l,e),f=c.pow(l,i);for(;!c.eql(_,c.ONE);){if(c.is0(_))return c.ZERO;let w=1,b=c.sqr(_);for(;!c.eql(b,c.ONE);)if(w++,b=c.sqr(b),w===u)throw new Error("Cannot find square root");const y=ee<<BigInt(u-w-1),T=c.pow(h,y);u=w,h=c.sqr(T),_=c.mul(_,h),f=c.mul(f,T)}return f}}function Dr(r){return r%ps===hs?gs:r%_s===fs?Nr:r%xs===Cr?Lr(r):ms(r)}const Mr=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function $r(r){const e={ORDER:"bigint",BYTES:"number",BITS:"number"},s=Mr.reduce((t,n)=>(t[n]="function",t),e);return gt(r,s),r}function Br(r,e,s){if(s<ne)throw new Error("invalid exponent, negatives unsupported");if(s===ne)return r.ONE;if(s===ee)return e;let t=r.ONE,n=e;for(;s>ne;)s&ee&&(t=r.mul(t,n)),n=r.sqr(n),s>>=ee;return t}function ws(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 Ht(r,e){const s=(r.ORDER-ee)/Ie,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 Ur(r,e){e!==void 0&&me(e);const s=e!==void 0?e:r.toString(2).length,t=Math.ceil(s/8);return{nBitLength:s,nByteLength:t}}class Hr{constructor(e,s={}){E(this,"ORDER");E(this,"BITS");E(this,"BYTES");E(this,"isLE");E(this,"ZERO",ne);E(this,"ONE",ee);E(this,"_lengths");E(this,"_sqrt");E(this,"_mod");var i;if(e<=ne)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}=Ur(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 le(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return ne<=e&&e<this.ORDER}is0(e){return e===ne}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&ee)===ee}neg(e){return le(-e,this.ORDER)}eql(e,s){return e===s}sqr(e){return le(e*e,this.ORDER)}add(e,s){return le(e+s,this.ORDER)}sub(e,s){return le(e-s,this.ORDER)}mul(e,s){return le(e*s,this.ORDER)}pow(e,s){return Br(this,e,s)}div(e,s){return le(e*Ut(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 Ut(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=Dr(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?us(e,this.BYTES):_t(e,this.BYTES)}fromBytes(e,s=!1){V(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?ds(e):je(e);if(a&&(c=le(c,i)),!s&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return ws(this,e)}cmov(e,s,t){return t?s:e}}function Ye(r,e={}){return new Hr(r,e)}function ys(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 bs(r){const e=ys(r);return e+Math.ceil(e/2)}function Fr(r,e,s=!1){V(r);const t=r.length,n=ys(e),o=bs(e);if(t<16||t<o||t>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+t);const i=s?ds(r):je(r),a=le(i,e-ee)+ee;return s?us(a,n):_t(a,n)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Oe=BigInt(0),Te=BigInt(1);function Ve(r,e){const s=e.negate();return r?s:e}function Ft(r,e){const s=ws(r.Fp,e.map(t=>t.Z));return e.map((t,n)=>r.fromAffine(t.toAffine(s[n])))}function Ss(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){Ss(r,e);const s=Math.ceil(e/r)+1,t=2**(r-1),n=2**r,o=xt(r),i=BigInt(r);return{windows:s,windowSize:t,mask:o,maxNumber:n,shiftBy:i}}function Gt(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+=Te);const l=e*t,u=l+Math.abs(a)-1,h=a===0,_=a<0,f=e%2!==0;return{nextN:c,offset:u,isZero:h,isNeg:_,isNegF:f,offsetF:l}}const st=new WeakMap,vs=new WeakMap;function rt(r){return vs.get(r)||1}function Wt(r){if(r!==Oe)throw new Error("invalid wNAF")}class Gr{constructor(e,s){E(this,"BASE");E(this,"ZERO");E(this,"Fn");E(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>Oe;)s&Te&&(t=t.add(n)),n=n.double(),s>>=Te;return t}precomputeWindow(e,s){const{windows:t,windowSize:n}=tt(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=tt(e,this.bits);for(let a=0;a<i.windows;a++){const{nextN:c,offset:l,isZero:u,isNeg:h,isNegF:_,offsetF:f}=Gt(t,a,i);t=c,u?o=o.add(Ve(_,s[f])):n=n.add(Ve(h,s[l]))}return Wt(t),{p:n,f:o}}wNAFUnsafe(e,s,t,n=this.ZERO){const o=tt(e,this.bits);for(let i=0;i<o.windows&&t!==Oe;i++){const{nextN:a,offset:c,isZero:l,isNeg:u}=Gt(t,i,o);if(t=a,!l){const h=s[c];n=n.add(u?h.negate():h)}}return Wt(t),n}getPrecomputes(e,s,t){let n=st.get(s);return n||(n=this.precomputeWindow(s,e),e!==1&&(typeof t=="function"&&(n=t(n)),st.set(s,n))),n}cached(e,s,t){const n=rt(e);return this.wNAF(n,this.getPrecomputes(n,e,t),s)}unsafe(e,s,t,n){const o=rt(e);return o===1?this._unsafeLadder(e,s,n):this.wNAFUnsafe(o,this.getPrecomputes(o,e,t),s,n)}createCache(e,s){Ss(s,this.bits),vs.set(e,s),st.delete(e)}hasCache(e){return rt(e)!==1}}function Wr(r,e,s,t){let n=e,o=r.ZERO,i=r.ZERO;for(;s>Oe||t>Oe;)s&Te&&(o=o.add(n)),t&Te&&(i=i.add(n)),n=n.double(),s>>=Te,t>>=Te;return{p1:o,p2:i}}function qt(r,e,s){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return $r(e),e}else return Ye(r,{isLE:s})}function qr(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>Oe))throw new Error(`CURVE.${c} must be positive bigint`)}const n=qt(e.p,s.Fp,t),o=qt(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 Kr(r,e){return function(t){const n=r(t);return{secretKey:n,publicKey:e(n)}}}class Es{constructor(e,s){E(this,"oHash");E(this,"iHash");E(this,"blockLen");E(this,"outputLen");E(this,"finished",!1);E(this,"destroyed",!1);if(rs(e),V(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),Pe(n)}update(e){return ke(this),this.iHash.update(e),this}digestInto(e){ke(this),V(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 Is=(r,e,s)=>new Es(r,e).update(s).digest();Is.create=(r,e)=>new Es(r,e);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Kt=(r,e)=>(r+(r>=0?e:-e)/Ts)/e;function Vr(r,e,s){const[[t,n],[o,i]]=e,a=Kt(i*r,s),c=Kt(-n*r,s);let l=r-a*t-c*o,u=-a*n-c*i;const h=l<xe,_=u<xe;h&&(l=-l),_&&(u=-u);const f=xt(Math.ceil(kr(s)/2))+Re;if(l<xe||l>=f||u<xe||u>=f)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:h,k1:l,k2neg:_,k2:u}}function lt(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function nt(r,e){const s={};for(let t of Object.keys(e))s[t]=r[t]===void 0?e[t]:r[t];return Ke(s.lowS,"lowS"),Ke(s.prehash,"prehash"),s.format!==void 0&&lt(s.format),s}class zr extends Error{constructor(e=""){super(e)}}const be={Err:zr,_tlv:{encode:(r,e)=>{const{Err:s}=be;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=Ue(t);if(n.length/2&128)throw new s("tlv.encode: long form length too big");const o=t>127?Ue(n.length/2|128):"";return Ue(r)+o+n+e},decode(r,e){const{Err:s}=be;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 u of l)i=i<<8|u;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}=be;if(r<xe)throw new e("integer: negative integers are not allowed");let s=Ue(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}=be;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 je(r)}},toSig(r){const{Err:e,_int:s,_tlv:t}=be,n=V(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:u}=t.decode(2,c);if(u.length)throw new e("invalid signature: left bytes after parsing");return{r:s.decode(a),s:s.decode(l)}},hexFromSig(r){const{_tlv:e,_int:s}=be,t=e.encode(2,s.encode(r.r)),n=e.encode(2,s.encode(r.s)),o=t+n;return e.encode(48,o)}},xe=BigInt(0),Re=BigInt(1),Ts=BigInt(2),He=BigInt(3),jr=BigInt(4);function Yr(r,e={}){const s=qr("weierstrass",r,e),{Fp:t,Fn:n}=s;let o=s.CURVE;const{h:i,n:a}=o;gt(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=Rs(t,n);function u(){if(!t.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function h(I,x,g){const{x:S,y:k}=x.toAffine(),D=t.toBytes(S);if(Ke(g,"isCompressed"),g){u();const C=!t.isOdd(k);return Se(As(C),D)}else return Se(Uint8Array.of(4),D,t.toBytes(k))}function _(I){V(I,void 0,"Point");const{publicKey:x,publicKeyUncompressed:g}=l,S=I.length,k=I[0],D=I.subarray(1);if(S===x&&(k===2||k===3)){const C=t.fromBytes(D);if(!t.isValid(C))throw new Error("bad point: is not on curve, wrong x");const M=b(C);let R;try{R=t.sqrt(M)}catch(J){const K=J instanceof Error?": "+J.message:"";throw new Error("bad point: is not on curve, sqrt error"+K)}u();const $=t.isOdd(R);return(k&1)===1!==$&&(R=t.neg(R)),{x:C,y:R}}else if(S===g&&k===4){const C=t.BYTES,M=t.fromBytes(D.subarray(0,C)),R=t.fromBytes(D.subarray(C,C*2));if(!y(M,R))throw new Error("bad point: is not on curve");return{x:M,y:R}}else throw new Error(`bad point: got length ${S}, expected compressed=${x} or uncompressed=${g}`)}const f=e.toBytes||h,w=e.fromBytes||_;function b(I){const x=t.sqr(I),g=t.mul(x,I);return t.add(t.add(g,t.mul(I,o.a)),o.b)}function y(I,x){const g=t.sqr(x),S=b(I);return t.eql(g,S)}if(!y(o.Gx,o.Gy))throw new Error("bad curve params: generator point");const T=t.mul(t.pow(o.a,He),jr),N=t.mul(t.sqr(o.b),BigInt(27));if(t.is0(t.add(T,N)))throw new Error("bad curve params: a or b");function W(I,x,g=!1){if(!t.isValid(x)||g&&t.is0(x))throw new Error(`bad point coordinate ${I}`);return x}function B(I){if(!(I instanceof L))throw new Error("Weierstrass Point expected")}function j(I){if(!c||!c.basises)throw new Error("no endo");return Vr(I,c.basises,n.ORDER)}const q=Bt((I,x)=>{const{X:g,Y:S,Z:k}=I;if(t.eql(k,t.ONE))return{x:g,y:S};const D=I.is0();x==null&&(x=D?t.ONE:t.inv(k));const C=t.mul(g,x),M=t.mul(S,x),R=t.mul(k,x);if(D)return{x:t.ZERO,y:t.ZERO};if(!t.eql(R,t.ONE))throw new Error("invZ was invalid");return{x:C,y:M}}),P=Bt(I=>{if(I.is0()){if(e.allowInfinityPoint&&!t.is0(I.Y))return;throw new Error("bad point: ZERO")}const{x,y:g}=I.toAffine();if(!t.isValid(x)||!t.isValid(g))throw new Error("bad point: x or y not field elements");if(!y(x,g))throw new Error("bad point: equation left != right");if(!I.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function v(I,x,g,S,k){return g=new L(t.mul(g.X,I),g.Y,g.Z),x=Ve(S,x),g=Ve(k,g),x.add(g)}const A=class A{constructor(x,g,S){E(this,"X");E(this,"Y");E(this,"Z");this.X=W("x",x),this.Y=W("y",g,!0),this.Z=W("z",S),Object.freeze(this)}static CURVE(){return o}static fromAffine(x){const{x:g,y:S}=x||{};if(!x||!t.isValid(g)||!t.isValid(S))throw new Error("invalid affine point");if(x instanceof A)throw new Error("projective point not allowed");return t.is0(g)&&t.is0(S)?A.ZERO:new A(g,S,t.ONE)}static fromBytes(x){const g=A.fromAffine(w(V(x,void 0,"point")));return g.assertValidity(),g}static fromHex(x){return A.fromBytes(qe(x))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(x=8,g=!0){return O.createCache(this,x),g||this.multiply(He),this}assertValidity(){P(this)}hasEvenY(){const{y:x}=this.toAffine();if(!t.isOdd)throw new Error("Field doesn't support isOdd");return!t.isOdd(x)}equals(x){B(x);const{X:g,Y:S,Z:k}=this,{X:D,Y:C,Z:M}=x,R=t.eql(t.mul(g,M),t.mul(D,k)),$=t.eql(t.mul(S,M),t.mul(C,k));return R&&$}negate(){return new A(this.X,t.neg(this.Y),this.Z)}double(){const{a:x,b:g}=o,S=t.mul(g,He),{X:k,Y:D,Z:C}=this;let M=t.ZERO,R=t.ZERO,$=t.ZERO,F=t.mul(k,k),J=t.mul(D,D),K=t.mul(C,C),H=t.mul(k,D);return H=t.add(H,H),$=t.mul(k,C),$=t.add($,$),M=t.mul(x,$),R=t.mul(S,K),R=t.add(M,R),M=t.sub(J,R),R=t.add(J,R),R=t.mul(M,R),M=t.mul(H,M),$=t.mul(S,$),K=t.mul(x,K),H=t.sub(F,K),H=t.mul(x,H),H=t.add(H,$),$=t.add(F,F),F=t.add($,F),F=t.add(F,K),F=t.mul(F,H),R=t.add(R,F),K=t.mul(D,C),K=t.add(K,K),F=t.mul(K,H),M=t.sub(M,F),$=t.mul(K,J),$=t.add($,$),$=t.add($,$),new A(M,R,$)}add(x){B(x);const{X:g,Y:S,Z:k}=this,{X:D,Y:C,Z:M}=x;let R=t.ZERO,$=t.ZERO,F=t.ZERO;const J=o.a,K=t.mul(o.b,He);let H=t.mul(g,D),X=t.mul(S,C),Z=t.mul(k,M),oe=t.add(g,S),z=t.add(D,C);oe=t.mul(oe,z),z=t.add(H,X),oe=t.sub(oe,z),z=t.add(g,k);let Q=t.add(D,M);return z=t.mul(z,Q),Q=t.add(H,Z),z=t.sub(z,Q),Q=t.add(S,k),R=t.add(C,M),Q=t.mul(Q,R),R=t.add(X,Z),Q=t.sub(Q,R),F=t.mul(J,z),R=t.mul(K,Z),F=t.add(R,F),R=t.sub(X,F),F=t.add(X,F),$=t.mul(R,F),X=t.add(H,H),X=t.add(X,H),Z=t.mul(J,Z),z=t.mul(K,z),X=t.add(X,Z),Z=t.sub(H,Z),Z=t.mul(J,Z),z=t.add(z,Z),H=t.mul(X,z),$=t.add($,H),H=t.mul(Q,z),R=t.mul(oe,R),R=t.sub(R,H),H=t.mul(oe,X),F=t.mul(Q,F),F=t.add(F,H),new A(R,$,F)}subtract(x){return this.add(x.negate())}is0(){return this.equals(A.ZERO)}multiply(x){const{endo:g}=e;if(!n.isValidNot0(x))throw new Error("invalid scalar: out of range");let S,k;const D=C=>O.cached(this,C,M=>Ft(A,M));if(g){const{k1neg:C,k1:M,k2neg:R,k2:$}=j(x),{p:F,f:J}=D(M),{p:K,f:H}=D($);k=J.add(H),S=v(g.beta,F,K,C,R)}else{const{p:C,f:M}=D(x);S=C,k=M}return Ft(A,[S,k])[0]}multiplyUnsafe(x){const{endo:g}=e,S=this;if(!n.isValid(x))throw new Error("invalid scalar: out of range");if(x===xe||S.is0())return A.ZERO;if(x===Re)return S;if(O.hasCache(this))return this.multiply(x);if(g){const{k1neg:k,k1:D,k2neg:C,k2:M}=j(x),{p1:R,p2:$}=Wr(A,S,D,M);return v(g.beta,R,$,k,C)}else return O.unsafe(S,x)}toAffine(x){return q(this,x)}isTorsionFree(){const{isTorsionFree:x}=e;return i===Re?!0:x?x(A,this):O.unsafe(this,a).is0()}clearCofactor(){const{clearCofactor:x}=e;return i===Re?this:x?x(A,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(x=!0){return Ke(x,"isCompressed"),this.assertValidity(),f(A,this,x)}toHex(x=!0){return Me(this.toBytes(x))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}};E(A,"BASE",new A(o.Gx,o.Gy,t.ONE)),E(A,"ZERO",new A(t.ZERO,t.ONE,t.ZERO)),E(A,"Fp",t),E(A,"Fn",n);let L=A;const G=n.BITS,O=new Gr(L,e.endo?Math.ceil(G/2):G);return L.BASE.precompute(8),L}function As(r){return Uint8Array.of(r?2:3)}function Rs(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function Jr(r,e={}){const{Fn:s}=r,t=e.randomBytes||as,n=Object.assign(Rs(r.Fp,s),{seed:bs(s.ORDER)});function o(f){try{const w=s.fromBytes(f);return s.isValidNot0(w)}catch{return!1}}function i(f,w){const{publicKey:b,publicKeyUncompressed:y}=n;try{const T=f.length;return w===!0&&T!==b||w===!1&&T!==y?!1:!!r.fromBytes(f)}catch{return!1}}function a(f=t(n.seed)){return Fr(V(f,n.seed,"seed"),s.ORDER)}function c(f,w=!0){return r.BASE.multiply(s.fromBytes(f)).toBytes(w)}function l(f){const{secretKey:w,publicKey:b,publicKeyUncompressed:y}=n;if(!pt(f)||"_lengths"in s&&s._lengths||w===b)return;const T=V(f,void 0,"key").length;return T===b||T===y}function u(f,w,b=!0){if(l(f)===!0)throw new Error("first arg must be private key");if(l(w)===!1)throw new Error("second arg must be public key");const y=s.fromBytes(f);return r.fromBytes(w).multiply(y).toBytes(b)}const h={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},_=Kr(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:u,keygen:_,Point:r,utils:h,lengths:n})}function Xr(r,e,s={}){rs(e),gt(s,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),s=Object.assign({},s);const t=s.randomBytes||as,n=s.hmac||((x,g)=>Is(e,x,g)),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:u,getSharedSecret:h,utils:_,lengths:f}=Jr(r,s),w={prehash:!0,lowS:typeof s.lowS=="boolean"?s.lowS:!0,format:"compact",extraEntropy:!1},b=a*Ts<o.ORDER;function y(x){const g=a>>Re;return x>g}function T(x,g){if(!i.isValidNot0(g))throw new Error(`invalid signature ${x}: out of range 1..Point.Fn.ORDER`);return g}function N(){if(b)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function W(x,g){lt(g);const S=f.signature,k=g==="compact"?S:g==="recovered"?S+1:void 0;return V(x,k)}class B{constructor(g,S,k){E(this,"r");E(this,"s");E(this,"recovery");if(this.r=T("r",g),this.s=T("s",S),k!=null){if(N(),![0,1,2,3].includes(k))throw new Error("invalid recovery id");this.recovery=k}Object.freeze(this)}static fromBytes(g,S=w.format){W(g,S);let k;if(S==="der"){const{r:R,s:$}=be.toSig(V(g));return new B(R,$)}S==="recovered"&&(k=g[0],S="compact",g=g.subarray(1));const D=f.signature/2,C=g.subarray(0,D),M=g.subarray(D,D*2);return new B(i.fromBytes(C),i.fromBytes(M),k)}static fromHex(g,S){return this.fromBytes(qe(g),S)}assertRecovery(){const{recovery:g}=this;if(g==null)throw new Error("invalid recovery id: must be present");return g}addRecoveryBit(g){return new B(this.r,this.s,g)}recoverPublicKey(g){const{r:S,s:k}=this,D=this.assertRecovery(),C=D===2||D===3?S+a:S;if(!o.isValid(C))throw new Error("invalid recovery id: sig.r+curve.n != R.x");const M=o.toBytes(C),R=r.fromBytes(Se(As((D&1)===0),M)),$=i.inv(C),F=q(V(g,void 0,"msgHash")),J=i.create(-F*$),K=i.create(k*$),H=r.BASE.multiplyUnsafe(J).add(R.multiplyUnsafe(K));if(H.is0())throw new Error("invalid recovery: point at infinify");return H.assertValidity(),H}hasHighS(){return y(this.s)}toBytes(g=w.format){if(lt(g),g==="der")return qe(be.hexFromSig(this));const{r:S,s:k}=this,D=i.toBytes(S),C=i.toBytes(k);return g==="recovered"?(N(),Se(Uint8Array.of(this.assertRecovery()),D,C)):Se(D,C)}toHex(g){return Me(this.toBytes(g))}}const j=s.bits2int||function(g){if(g.length>8192)throw new Error("input is too large");const S=je(g),k=g.length*8-c;return k>0?S>>BigInt(k):S},q=s.bits2int_modN||function(g){return i.create(j(g))},P=xt(c);function v(x){return Rr("num < 2^"+c,x,xe,P),i.toBytes(x)}function L(x,g){return V(x,void 0,"message"),g?V(e(x),void 0,"prehashed message"):x}function G(x,g,S){const{lowS:k,prehash:D,extraEntropy:C}=nt(S,w);x=L(x,D);const M=q(x),R=i.fromBytes(g);if(!i.isValidNot0(R))throw new Error("invalid private key");const $=[v(R),v(M)];if(C!=null&&C!==!1){const H=C===!0?t(f.secretKey):C;$.push(V(H,void 0,"extraEntropy"))}const F=Se(...$),J=M;function K(H){const X=j(H);if(!i.isValidNot0(X))return;const Z=i.inv(X),oe=r.BASE.multiply(X).toAffine(),z=i.create(oe.x);if(z===xe)return;const Q=i.create(Z*i.create(J+z*R));if(Q===xe)return;let St=(oe.x===z?0:2)|Number(oe.y&Re),vt=Q;return k&&y(Q)&&(vt=i.neg(Q),St^=1),new B(z,vt,b?void 0:St)}return{seed:F,k2sig:K}}function O(x,g,S={}){const{seed:k,k2sig:D}=G(x,g,S);return Pr(e.outputLen,i.BYTES,n)(k,D).toBytes(S.format)}function A(x,g,S,k={}){const{lowS:D,prehash:C,format:M}=nt(k,w);if(S=V(S,void 0,"publicKey"),g=L(g,C),!pt(x)){const R=x instanceof B?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+R)}W(x,M);try{const R=B.fromBytes(x,M),$=r.fromBytes(S);if(D&&R.hasHighS())return!1;const{r:F,s:J}=R,K=q(g),H=i.inv(J),X=i.create(K*H),Z=i.create(F*H),oe=r.BASE.multiplyUnsafe(X).add($.multiplyUnsafe(Z));return oe.is0()?!1:i.create(oe.x)===F}catch{return!1}}function I(x,g,S={}){const{prehash:k}=nt(S,w);return g=L(g,k),B.fromBytes(x,"recovered").recoverPublicKey(g).toBytes()}return Object.freeze({keygen:l,getPublicKey:u,getSharedSecret:h,utils:_,lengths:f,Point:r,sign:O,verify:A,recoverPublicKey:I,Signature:B,hash:e})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const wt={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Zr={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},Vt=BigInt(2);function Qr(r){const e=wt.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,u=l*l*r%e,h=ae(u,s,e)*u%e,_=ae(h,s,e)*u%e,f=ae(_,Vt,e)*l%e,w=ae(f,n,e)*f%e,b=ae(w,o,e)*w%e,y=ae(b,a,e)*b%e,T=ae(y,c,e)*y%e,N=ae(T,a,e)*b%e,W=ae(N,s,e)*u%e,B=ae(W,i,e)*w%e,j=ae(B,t,e)*l%e,q=ae(j,Vt,e);if(!dt.eql(dt.sqr(q),r))throw new Error("Cannot find square root");return q}const dt=Ye(wt.p,{sqrt:Qr}),en=Yr(wt,{Fp:dt,endo:Zr}),tn=Xr(en,Ir),sn=BigInt(0),Ce=BigInt(1),rn=BigInt(2),nn=BigInt(7),on=BigInt(256),an=BigInt(113),ks=[],Ps=[],Os=[];for(let r=0,e=Ce,s=1,t=0;r<24;r++){[s,t]=[t,(2*s+3*t)%5],ks.push(2*(5*t+s)),Ps.push((r+1)*(r+2)/2%64);let n=sn;for(let o=0;o<7;o++)e=(e<<Ce^(e>>nn)*an)%on,e&rn&&(n^=Ce<<(Ce<<BigInt(o))-Ce);Os.push(n)}const Cs=gr(Os,!0),cn=Cs[0],ln=Cs[1],zt=(r,e,s)=>s>32?yr(r,e,s):mr(r,e,s),jt=(r,e,s)=>s>32?br(r,e,s):wr(r,e,s);function dn(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],u=s[c+1],h=zt(l,u,1)^s[a],_=jt(l,u,1)^s[a+1];for(let f=0;f<50;f+=10)r[i+f]^=h,r[i+f+1]^=_}let n=r[2],o=r[3];for(let i=0;i<24;i++){const a=Ps[i],c=zt(n,o,a),l=jt(n,o,a),u=ks[i];n=r[u],o=r[u+1],r[u]=c,r[u+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]^=cn[t],r[1]^=ln[t]}Pe(s)}class yt{constructor(e,s,t,n=!1,o=24){E(this,"state");E(this,"pos",0);E(this,"posOut",0);E(this,"finished",!1);E(this,"state32");E(this,"destroyed",!1);E(this,"blockLen");E(this,"suffix");E(this,"outputLen");E(this,"enableXOF",!1);E(this,"rounds");if(this.blockLen=e,this.suffix=s,this.outputLen=t,this.enableXOF=n,this.rounds=o,me(t,"outputLen"),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=ar(this.state)}clone(){return this._cloneInto()}keccak(){Dt(this.state32),dn(this.state32,this.rounds),Dt(this.state32),this.posOut=0,this.pos=0}update(e){ke(this),V(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){ke(this,!1),V(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 me(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(ns(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,Pe(this.state)}_cloneInto(e){const{blockLen:s,suffix:t,outputLen:n,rounds:o,enableXOF:i}=this;return e||(e=new yt(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 un=(r,e,s,t={})=>is(()=>new yt(e,r,s),t),Yt=un(1,136,32),hn=60;class pn{constructor(){this.jwks=null}setJWKSEndpoint(e){try{this.jwks=Xe.createRemoteJWKSet(new URL(e)),d.log("[CROSSx] JWKS 엔드포인트 설정:",e)}catch(s){d.warn("[CROSSx] JWKS 엔드포인트 URL 파싱 실패:",s)}}async verifyJWT(e,s){try{const t=this.decodeJWT(e);d.log("[CROSSx] JWT 디코딩 성공:",{sub:t.sub,exp:t.exp,iat:t.iat});const n=Math.floor(Date.now()/1e3);if(t.exp&&t.exp+hn<n)return d.warn("[CROSSx] 토큰 만료:",{exp:t.exp,now:n,만료시간:new Date(t.exp*1e3).toISOString()}),{payload:t,valid:!1,signatureVerified:!1};if(!t.sub)return d.warn("[CROSSx] JWT에 sub(사용자ID) 없음"),{payload:t,valid:!1,signatureVerified:!1};if(this.jwks)try{const{payload:o}=await Xe.jwtVerify(e,this.jwks,{algorithms:["RS256","ES256"]});return d.log("[CROSSx] JWT 서명 검증 성공"),{payload:o,valid:!0,signatureVerified:!0}}catch(o){if(o instanceof Error&&(o.name==="JWSSignatureVerificationFailed"||o.name==="JWTClaimValidationFailed"))return d.error("[CROSSx] JWT 서명 검증 실패:",o),{payload:t,valid:!1,signatureVerified:!1};d.warn("[CROSSx] JWKS 엔드포인트 접근 불가 — 서명 미검증 모드로 전환")}return d.log("[CROSSx] JWT 검증 성공 (서명 미검증 — JWKS 미설정 또는 접근 불가)"),{payload:t,valid:!0,signatureVerified:!1}}catch(t){throw d.error("[CROSSx] JWT 검증 중 에러:",t),t}}decodeJWT(e){return Xe.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=Yt(o),a=s.startsWith("0x")?s.slice(2):s;if(a.length!==130)throw new Error(`서명 길이가 유효하지 않습니다: 130 hex 문자 예상, 현재 ${a.length}`);const c=fn(a),l=c.slice(0,32),u=c.slice(32,64),h=c[64],_=h>=27?h-27:h,b=new tn.Signature(Jt(l),Jt(u)).addRecoveryBit(_).recoverPublicKey(i).toBytes(!1).slice(1),y=Yt(b);return"0x"+Me(y.slice(12))}}function fn(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 Jt(r){let e="0x";for(const s of r)e+=s.toString(16).padStart(2,"0");return BigInt(e)}const _n=3e4,xn=1e3;class gn{async request(e){const s=e.retries??0;for(let t=0;t<=s;t++){try{const n=await this._doRequest(e);if(n.status<500||t===s)return n}catch(n){if(t===s)throw n}await new Promise(n=>setTimeout(n,xn*2**t))}throw new Error("Unexpected: retry loop exited without result")}async _doRequest(e){const s=new AbortController,t=setTimeout(()=>s.abort(),e.timeoutMs??_n);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)}}}const mn=new Set(["https://cross-wallet-oauth.crosstoken.io","https://stg-cross-wallet-oauth.crosstoken.io","https://dev-cross-wallet-oauth.crosstoken.io"]);class Ee{static generateRandom16Hex(){const e=new Uint8Array(16);return crypto.getRandomValues(e),Array.from(e,s=>s.toString(16).padStart(2,"0")).join("")}static parseJwtPayload(e){const s=e.split(".");if(s.length<2)throw new Error("Invalid JWT format");const t=(s[1]??"").replace(/-/g,"+").replace(/_/g,"/"),n=atob(t);return JSON.parse(n)}static async sha256Hex(e){const s=new TextEncoder().encode(e),t=await crypto.subtle.digest("SHA-256",s);return Array.from(new Uint8Array(t),n=>n.toString(16).padStart(2,"0")).join("")}static async verifyIdTokenNonce(e,s){const t=Ee.parseJwtPayload(e),n=t.nonce,o=typeof t.iss=="string"?t.iss:"(unknown)";if(d.log("[CROSSx] nonce 검증 시작 —",{iss:o,nonceClaimType:typeof n,nonceClaimPresent:typeof n=="string"&&n!=="",appleNonceSupported:t.nonce_supported??"(field absent)"}),o.includes("securetoken.google.com")){d.log("[CROSSx] Firebase ID Token 감지 — nonce 검증 skip.","서버 측에서 Google/Apple nonce 검증이 완료된 것으로 간주합니다.");return}if(typeof n!="string"||n===""){d.warn("[CROSSx] nonce claim 누락 — nonce 검증 skip.",{iss:o,keys:Object.keys(t)});return}if(o.includes("appleid.apple.com")){const i=await Ee.sha256Hex(s);if(d.log("[CROSSx] Apple nonce 검증 —",{expectedHashLength:i.length,receivedHashLength:n.length,match:n===i}),n!==i)throw new Error("ID Token nonce 불일치 — replay attack 가능성이 있습니다")}else if(d.log("[CROSSx] Google nonce 검증 —",{expectedLength:s.length,receivedLength:n.length,match:n===s}),n!==s)throw new Error("ID Token nonce 불일치 — replay attack 가능성이 있습니다");d.log("[CROSSx] nonce 검증 성공 —",{iss:o})}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=Ee.generateRandom16Hex(),l=Ee.generateRandom16Hex(),u=e.authUrl.includes("?")?"&":"?",h=`${e.authUrl}${u}state=${c}&nonce=${l}`;d.log("[CROSSx] OAuth 팝업 열기 — state, nonce 생성 완료:",{stateLength:c.length,nonceLength:l.length,authUrlBase:e.authUrl});const _=window.open(h,"CROSSx OAuth",`width=${n},height=${o},left=${i},top=${a}`);if(!_){t(new Error("팝업 창을 열 수 없습니다. 팝업 차단을 해제해 주세요."));return}const f=setTimeout(()=>{d.warn("[CROSSx] OAuth 타임아웃 (5분) — postMessage를 수신하지 못했습니다"),B(),t(new Error("Authentication timeout"))},5*60*1e3),w=10,b=30;let y=0,T=null;const N=()=>{clearInterval(W),d.warn("[CROSSx] COOP 감지 — OAuth 서버 응답을 "+b+"초간 대기합니다"),T=setTimeout(()=>{B(),t(new Error("OAuth 서버로부터 응답을 받지 못했습니다. 브라우저 보안 정책(COOP)으로 인해 팝업 통신이 차단되었을 수 있습니다. 다시 시도해 주세요."))},b*1e3)},W=setInterval(()=>{y++;try{_.closed&&(y<=w?N():(B(),t(new Error("로그인이 취소되었습니다"))))}catch{N()}},1e3),B=()=>{clearTimeout(f),clearInterval(W),T&&clearTimeout(T),window.removeEventListener("message",j)},j=q=>{if(q.origin!==e.expectedOrigin)return;if(!mn.has(q.origin)){d.error("[CROSSx] postMessage origin이 허용 목록에 없음:",q.origin),B(),t(new Error("Unauthorized OAuth origin"));return}B();const P=typeof q.data.status=="string",v=P?q.data.data??{}:q.data;d.log("[CROSSx] OAuth postMessage 수신 —",{format:P?"wrapped":"flat",status:P?q.data.status:"(flat)"});const L=(v==null?void 0:v.state)??q.data.state;if(!L||L!==c){t(new Error("OAuth state mismatch — possible CSRF attack"));return}if(P&&q.data.status!=="success"){d.error("[CROSSx] OAuth 실패:",v==null?void 0:v.error),t(new Error((v==null?void 0:v.error)||"Authentication failed"));return}if(!P&&(v!=null&&v.error)){d.error("[CROSSx] OAuth 실패:",v.error),t(new Error(v.error||"Authentication failed"));return}const G=v==null?void 0:v.idToken,O=v==null?void 0:v.accessToken,A=O??G;if(d.log("[CROSSx] OAuth 토큰 수신:",{hasAccessToken:!!O,hasIdToken:!!G}),!A){d.error("[CROSSx] 토큰을 찾을 수 없음:",q.data),t(new Error("Token not found in response"));return}const I=x=>{Ee.verifyIdTokenNonce(x,l).then(()=>s(A)).catch(g=>{d.error("[CROSSx] nonce 검증 실패:",g),t(g instanceof Error?g:new Error("nonce verification failed"))})};O?O.split(".").length===3?I(O):G?I(G):(d.warn("[CROSSx] opaque accessToken만 수신 (idToken 없음) — nonce 검증 불가.","서버 측 nonce 검증이 필요합니다."),s(A)):G?I(G):t(new Error("Token not found in response"))};window.addEventListener("message",j)})}}const Ne="crossx_wallet_data",Ae="crossx_mock_pin_hash";class wn{constructor(e,s){this.storage=e,this.pinStore=s??null}async checkWallet(){if(this.migrateScenario!==void 0)return d.log("[Mock] checkWallet → migration_required"),"migration_required";const s=await this.storage.get(Ne)?"exists":"not_found";return d.log(`[Mock] checkWallet → ${s}`),s}async getOrCreateWallet(e){var s;try{const t=await this.storage.get(Ne);if(t)return t;const n={id:e,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};await this.storage.set(Ne,n);const o=(s=this.pinStore)==null?void 0:s.get();return o&&(await this.storage.set(Ae,o),d.log("[Mock] 지갑 생성 — PIN 저장됨")),n}catch(t){throw new m(p.WALLET_CREATION_FAILED,"지갑 생성에 실패했습니다",t)}}async getAddresses(e){const s=await this.storage.get(Ne);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 d.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 d.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 d.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){d.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 d.log(`[Mock] sendTransaction chainId=${s} uuid=${n}:`,t),{txHash:"0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}async verifyPin(e){var t;if(d.log("[Mock] verifyPin"),this.pinScenario==="wrong")return!1;const s=await this.storage.get(Ae);return s&&s!==e?!1:(s||await this.storage.set(Ae,e),(t=this.pinStore)==null||t.set(e),d.log("[Mock] verifyPin → 성공"),!0)}async changePin(e,s){var o;if(d.log("[Mock] changePin"),this.pinScenario==="wrong")throw new m(p.PIN_WRONG,"Incorrect PIN.");const t=(o=this.pinStore)==null?void 0:o.get(),n=await this.storage.get(Ae);if(n&&t&&n!==t)throw new m(p.PIN_WRONG,"Incorrect PIN.");await this.storage.set(Ae,s),d.log("[Mock] changePin 완료")}async migrateWallet(e,s){var o;if(d.log(`[Mock] migrateWallet pin=${e} sub=${s}`),this.migrateScenario==="wrong_pin")throw new m(p.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(p.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(Ne,t);const n=(o=this.pinStore)==null?void 0:o.get();return n&&(await this.storage.set(Ae,n),d.log("[Mock] 마이그레이션 — PIN 저장됨")),t}async getShareC(){return d.log("[Mock] getShareC"),"mock-share-c-"+crypto.randomUUID()}async verifyRecoveryPin(e,s){return d.log("[Mock] verifyRecoveryPin"),{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 Le{constructor(e,s,t,n,o){this._refreshPromise=null,this._walletStatusCache=null,this.adapterConfig=e,this.projectId=e.projectId,this.storage=s,this.transport=t,this.tokenStore=n,this.pinStore=o??null}setOnUnauthorized(e){this._onUnauthorized=e}setTokenRefresher(e){this._onTokenRefresh=e}getPin(){var e;return((e=this.pinStore)==null?void 0:e.get())??void 0}get baseUrl(){return this.adapterConfig.gatewayUrl}async ensureValidToken(){const e=this.tokenStore.get();if(e&&!this.tokenStore.isExpiringSoon(tr))return e;if(this._onTokenRefresh&&await this.deduplicatedRefresh()){const t=this.tokenStore.get();if(t)return t}if(e)return d.warn("[CROSSx] 토큰 갱신 실패 — 기존 토큰으로 요청 시도"),e;throw new m(p.AUTH_NOT_AUTHENTICATED,"인증 토큰을 찾을 수 없습니다. 먼저 로그인해 주세요.")}deduplicatedRefresh(){return this._refreshPromise?this._refreshPromise:(d.log("[CROSSx] 토큰 만료 임박/만료 — 자동 갱신 시도"),this._refreshPromise=this._onTokenRefresh().finally(()=>{this._refreshPromise=null}),this._refreshPromise)}async request(e,s,t,n=!1){var c,l,u;const o=await this.ensureValidToken(),i=`${this.baseUrl}${s}`,a={Authorization:`Bearer ${o}`,"Content-Type":"application/json","X-Project-Id":this.projectId};try{const _=(await this.transport.request({url:i,method:e,headers:a,body:t??void 0})).data;if(_&&typeof _.code=="number"){if(_.code<0||_.code>=400){const f=_.message||_.data||"API 요청에 실패했습니다";d.error("[CROSSx] Wallet Gateway API 에러 (HTTP 200):",{code:_.code,message:f,url:i,method:e});const w=Le.mapGatewayError(_.code,_.data);if(w===p.AUTH_NOT_AUTHENTICATED&&!n&&this._onTokenRefresh&&(d.warn("[CROSSx] Gateway -10002 감지 — 토큰 갱신 후 재시도"),await this.deduplicatedRefresh()))return this.request(e,s,t,!0);const b=Le.getGatewayErrorMessage(_.code,f),y=_.data,T=w===p.PIN_LOCKED?Le.extractLockDetails(y):y??void 0,N=new m(w,b,T);throw w===p.AUTH_NOT_AUTHENTICATED&&this._onUnauthorized&&(d.warn("[CROSSx] Gateway -10002 갱신 재시도 실패 — 강제 로그아웃 실행"),this._onUnauthorized()),N}return d.log("[CROSSx] Wallet Gateway API 성공:",{code:_.code,url:i,method:e}),_.data??_}return _}catch(h){if(h instanceof m)throw h;const _=((c=h.response)==null?void 0:c.status)??h.status;if((_===401||_===403)&&!n&&this._onTokenRefresh&&(d.warn(`[CROSSx] HTTP ${_} 감지 — 토큰 갱신 후 재시도`),await this.deduplicatedRefresh()))return this.request(e,s,t,!0);if((l=h.response)!=null&&l.data){const f=h.response.data,w=f.message||f.data||"API 요청에 실패했습니다",b=f.code||"UNKNOWN";throw d.error("[CROSSx] Wallet Gateway API 에러 (HTTP 에러):",{code:b,message:w,url:i,method:e,status:(u=h.response)==null?void 0:u.status}),new m(p.UNKNOWN_ERROR,`Wallet Gateway 오류 (${b}): ${w}`)}throw h}}async checkWallet(){d.log("[CROSSx] GET /mnemonic/check");const e=await this.request("GET","/mnemonic/check");return d.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,d.log("[CROSSx] getOrCreateWallet — 캐시된 상태 사용:",s)):(d.log("[CROSSx] GET /mnemonic/check — 지갑 상태 확인"),s=await this.checkWallet(),this._walletStatusCache=null),s==="migration_required")throw d.log("[CROSSx] migration_required → MIGRATION_BACKUP_EXISTS throw"),new m(p.MIGRATION_BACKUP_EXISTS,"CROSSx 백업이 존재합니다. 마이그레이션을 진행해 주세요.");if(s==="exists"){d.log("[CROSSx] 기존 지갑 발견 — POST /mnemonic/address(0)로 주소 조회");const o=await this.getAddress(e,0);return d.log("[CROSSx] 주소 조회 완료 — address:",o.address),{id:e,address:o.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}d.log("[CROSSx] POST /mnemonic/create — 신규 지갑 생성");const t={ignoreBackup:!1,password:this.requirePin()},n=await this.request("POST","/mnemonic/create",t);return d.log("[CROSSx] /mnemonic/create 완료 — address:",n.address),{id:e,address:n.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.requirePin(),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(p.TX_INVALID_PARAMS,"prepare: tx가 필요합니다");t={unsignedTx:this.buildUnsignedTx(s.tx)};break;case"sign-message":if(!s.message)throw new m(p.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(p.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,password:this.requirePin()};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,password:this.requirePin()};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),password:this.requirePin()};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),password:this.requirePin()};return n&&(o.uuid=n),{txHash:(await this.request("POST",`/mnemonic/send/${encodeURIComponent(s)}`,o)).txHash}}async migrateWallet(e,s){d.log("[CROSSx][Migration Phase 4] POST /mnemonic/migrate 호출");const t={recoveryPin:e,sub:s,password:this.requirePin()},n=await this.request("POST","/mnemonic/migrate",t);return d.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()}}async withdrawWallet(e){const s={confirmation:e,password:this.requirePin()};await this.request("POST","/mnemonic/withdraw",s)}async verifyPin(e){const s={password:e};return(await this.request("POST","/mnemonic/verify-password",s)).valid}async changePin(e,s){const t={password:this.requirePin(),newPassword:s};await this.request("POST","/mnemonic/change-password",t)}async getShareC(){const e={password:this.requirePin()};return(await this.request("POST","/mnemonic/share-c",e)).shareC}async verifyRecoveryPin(e,s){const t={recoveryPin:e,sub:s};return this.request("POST","/mnemonic/verify-recovery-pin",t)}requirePin(){const e=this.getPin();if(!e)throw new m(p.PIN_NOT_SET,"PIN이 설정되지 않았습니다. PIN을 입력해 주세요.");return e}static extractLockDetails(e){const s=(e==null?void 0:e.lockStatus)??e,t=(s==null?void 0:s.lockExpiresAt)??(s==null?void 0:s.lock_expires_at);return t?{lockExpiresAt:t>1e10?t:t*1e3}:{}}static mapGatewayError(e,s){switch(e){case-10002:return p.AUTH_NOT_AUTHENTICATED;case-10001:return p.UNKNOWN_ERROR;case-10006:return p.GATEWAY_INTERNAL_ERROR;case-10007:return p.BROADCAST_FAILED;case-10008:return p.GATEWAY_LOCK_CONFLICT;case-10004:return p.WALLET_ALREADY_EXISTS;case-10005:return p.WALLET_NOT_FOUND;case-10011:return p.WALLET_NOT_FOUND;case-10030:return p.WALLET_INCONSISTENT_STATE;case-10010:return p.MIGRATION_FAILED;case-10012:return p.MIGRATION_BACKUP_EXISTS;case-10013:return p.WITHDRAW_FAILED;case-10027:return p.MIGRATION_PIN_LOCKED;case-10022:return p.PROJECT_NOT_REGISTERED;case-10023:return p.PROJECT_ID_MISSING;case-10024:return p.ORIGIN_NOT_ALLOWED;case-10025:return p.INVALID_APP_TYPE;case-10028:return p.PIN_WRONG;case-10029:return p.PIN_INVALID;case-10031:return p.PIN_LOCKED;case-10032:return p.PIN_REPEATED_PATTERN;case-10026:return p.TYPED_DATA_CHAIN_ID_MISMATCH;case-10014:case-10015:case-10019:return p.PREPARE_FAILED;case-10016:return p.PREPARE_EXPIRED;case-10017:case-10018:return p.PREPARE_MISMATCH;case-10020:return p.CHAIN_NOT_SUPPORTED;case-10021:return p.INVALID_CHAIN;case-10040:return p.HMAC_REQUIRED;case-10041:return p.HMAC_VERIFICATION_FAILED;default:return p.UNKNOWN_ERROR}}static getGatewayErrorMessage(e,s){switch(e){case-10002:return"Session expired. Please sign in again.";case-10004:return"Wallet already exists for this user.";case-10005:return"User wallet not found.";case-10006:return"Internal server error. Please try again later.";case-10007:return"Transaction broadcast failed. Please try again.";case-10008:return"Another operation is in progress. Please try again later.";case-10013:return"Withdraw failed. Please try again.";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 or App ID is required. Register the current domain or set X-App-Id header.";case-10025:return"Invalid app type. X-App-Type must be android, ios, or windows.";case-10026:return"Domain chainId mismatch: the chainId in typedData.domain does not match the request chainId.";case-10027:return"Too many incorrect PIN attempts. Your account has been temporarily locked.";case-10028:return"Incorrect PIN. Please try again.";case-10029:return"Sequential PIN is not allowed. Please choose a different PIN.";case-10030:return"Wallet is in an inconsistent state. Please contact support.";case-10031:return"Too many failed PIN attempts. Your account is temporarily locked.";case-10032:return"Repeated digit pattern is not allowed. Please choose a different PIN.";case-10040:return"HMAC signature header is required.";case-10041:return"HMAC signature verification failed.";default:return`Request failed (${e}): ${s}`}}}class De{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=De.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?rr:sr;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(De.mapErrorCode(e.code),s)}}fallbackOrThrow(e){const s=De.fallbackChains().find(t=>t.chainId===e);if(s)return s;throw new m(p.CHAIN_NOT_SUPPORTED,`지원하지 않는 체인: ${e}`)}static fallbackChains(){return Object.values(ze).map(e=>({chainId:e.caipId,rpcUrl:e.rpcUrl}))}static mapErrorCode(e){switch(e){case-10020:return p.CHAIN_NOT_SUPPORTED;case-10021:return p.INVALID_CHAIN;case-10022:return p.PROJECT_NOT_REGISTERED;case-10023:return p.PROJECT_ID_MISSING;case-10024:return p.APP_IDENTIFIER_MISSING;case-10025:return p.INVALID_APP_TYPE;default:return p.UNKNOWN_ERROR}}}const Xt="__crossx-confirm-style",te="__crossx-confirm-overlay",yn={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 Zt(r,e){const s=yn[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 bn=`
1
+ "use strict";var Us=Object.defineProperty;var Hs=(r,e,s)=>e in r?Us(r,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[e]=s;var T=(r,e,s)=>Hs(r,typeof e!="symbol"?e+"":e,s);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Ze=require("jose");var p=(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.SESSION_EXPIRED="SESSION_EXPIRED",r.OAUTH_POPUP_BLOCKED="OAUTH_POPUP_BLOCKED",r.WALLET_NOT_FOUND="WALLET_NOT_FOUND",r.WALLET_CREATION_FAILED="WALLET_CREATION_FAILED",r.WALLET_ALREADY_EXISTS="WALLET_ALREADY_EXISTS",r.SIGN_FAILED="SIGN_FAILED",r.SIGN_REJECTED="SIGN_REJECTED",r.TX_FAILED="TX_FAILED",r.TX_REJECTED="TX_REJECTED",r.BROADCAST_FAILED="BROADCAST_FAILED",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.PIN_NOT_SET="PIN_NOT_SET",r.PIN_WRONG="PIN_WRONG",r.PIN_INVALID="PIN_INVALID",r.PIN_REPEATED_PATTERN="PIN_REPEATED_PATTERN",r.PIN_CANCELLED="PIN_CANCELLED",r.EXTERNAL_WALLET_REQUESTED="EXTERNAL_WALLET_REQUESTED",r.PIN_LOCKED="PIN_LOCKED",r.HMAC_REQUIRED="HMAC_REQUIRED",r.HMAC_VERIFICATION_FAILED="HMAC_VERIFICATION_FAILED",r.WITHDRAW_FAILED="WITHDRAW_FAILED",r.INVALID_CONFIG="INVALID_CONFIG",r.UNKNOWN_ERROR="UNKNOWN_ERROR",r))(p||{});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}},Fs=Object.fromEntries(Object.entries(je).map(([r,e])=>[r,e.caipId])),Gs=new Map(Object.values(je).map(r=>[r.caipId,r]));new Map(Object.values(je).map(r=>[r.chainId,r]));const Ws={symbol:"",decimals:18};function Qe(r){var e;return((e=Gs.get(r))==null?void 0:e.nativeCurrency)??Ws}class rs{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(p.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signMessage()를 직접 사용하세요.`);case"eth_signTypedData":case"eth_signTypedData_v1":case"eth_signTypedData_v3":case"eth_signTypedData_v4":throw new m(p.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 _e=null;function At(r){_e=r}const d={info(...r){if(_e){_e.log(...r);return}console.log(...r)},log(...r){if(_e){_e.log(...r);return}},warn(...r){if(_e){_e.warn(...r);return}},error(...r){if(_e){_e.error(...r);return}}},qs={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로 계속하기",loginSelector_connectOtherWallets:"다른 지갑으로 연결",loginSelector_connectOtherWalletsDesc:"기존 Web3 지갑을 연결하여 자산을 관리하세요.",migration_foundTitle:"기존 지갑 발견",migration_foundDescription:"기존 CROSSx 지갑이 발견되었습니다. 복구하시겠습니까?",migration_recoverButton:"복구하기",migration_skipButton:"건너뛰기",recoveryPinInput_title:"PIN 입력",recoveryPinInput_placeholder:"4자리 PIN을 입력하세요",recoveryPinInput_error:"PIN이 올바르지 않습니다. 다시 시도해 주세요.",walletSelector_title:"지갑 선택",walletSelector_addButton:"지갑 추가",walletSelector_selected:"선택됨",pinNotice_headerSubtitle:"트랜잭션, PK/니모닉 내보내기 및 계정 삭제 시 필요합니다.",pinNotice_title:"PIN 설정 주의사항",pinNotice_description:"보안을 위해 이 PIN은 재설정하거나 복구할 수 없습니다. 반드시 기억해 두거나 안전한 곳에 보관하세요.",pinNotice_check1:"이 PIN을 분실하면 지갑과 자산에 영구적으로 접근이 불가능해진다는 것을 이해합니다.",pinNotice_check2:"지원팀을 포함한 어느 누구도 이 PIN을 복구하거나 재설정해 줄 수 없다는 것을 이해합니다.",pinNotice_nextButton:"다음",pinNotice_submitButton:"동의합니다",pinSetup_title:"PIN 만들기",pinSetup_headerSubtitle:"이 PIN은 거래 승인에 사용됩니다.",pinSetup_subtitle:"거래 승인을 위한 6자리 PIN을 설정하세요.",pinSetup_confirmTitle:"PIN 확인",pinSetup_confirmSubtitle:"확인을 위해 PIN을 다시 입력하세요.",pinSetup_mismatchError:"PIN이 일치하지 않습니다. 다시 시도해 주세요.",pinValidation_tooShort:"6자리 PIN을 입력해 주세요.",pinValidation_numbersOnly:"숫자(0-9)만 입력할 수 있습니다.",pinValidation_repeatingDigit:"같은 숫자를 연속으로 3번 이상 사용할 수 없습니다.",pinValidation_sequential:"연속된 숫자(예: 123456)는 사용할 수 없습니다.",pinValidation_alternatingPattern:"반복 패턴(예: 121212)은 사용할 수 없습니다.",pinInput_title:"PIN 입력",pinInput_subtitle:"계속하려면 6자리 PIN을 입력하세요.",pinInput_error:"PIN이 올바르지 않습니다. 다시 시도해 주세요.",verifyPin_title:"PIN 확인",verifyPin_subtitle:"계속하려면 PIN을 확인해 주세요.",pinLocked_message:"잠금이 해제된 후 다시 시도해 주세요.",pinLocked_availableFrom:"이용 가능 시간",pinLocked_failureWarning:"PIN이 올바르지 않습니다. 추가 실패 시 계정이 잠금됩니다.",pinLocked_permanent:"너무 많은 시도 실패로 계정이 영구 잠금되었습니다.",alert_sessionExpired:"인증이 만료되었습니다. 확인을 누른 뒤 다시 로그인해 주세요.",alert_accountWithdrawn:"계정이 탈퇴 처리되었거나 더 이상 사용할 수 없습니다. 확인 후 다시 로그인해 주세요.",alert_walletNotFound:"지갑 정보를 찾을 수 없습니다. 확인 후 다시 로그인해 주세요.",alert_differentAccount:`이전에 사용하던 계정이 아닌 다른 계정으로 로그인되었습니다.
2
+
3
+ 보안을 위해 동일한 Google/Apple 계정으로만 이어서 사용할 수 있습니다.
4
+
5
+ [확인] 이전과 같은 계정으로 다시 로그인 시도
6
+ [취소] 로그아웃하고 닫기`},ns={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",loginSelector_connectOtherWallets:"Connect with Other Wallets",loginSelector_connectOtherWalletsDesc:"Connect your existing Web3 wallet to manage your assets.",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",recoveryPinInput_title:"Enter PIN",recoveryPinInput_placeholder:"Enter your 4-digit PIN",recoveryPinInput_error:"Incorrect PIN. Please try again.",walletSelector_title:"Select Wallet",walletSelector_addButton:"Add Wallet",walletSelector_selected:"Selected",pinNotice_headerSubtitle:"Required for transactions, PK/mnemonic export & account deletion.",pinNotice_title:"PIN Setup Notice",pinNotice_description:"For your security, this PIN cannot be reset or recovered. Please make sure you remember it or store it in a safe place.",pinNotice_check1:"I understand that losing this PIN will result in permanent loss of access to my wallet and assets.",pinNotice_check2:"I understand that no one, including the support team, can recover or reset this PIN on my behalf.",pinNotice_nextButton:"Next",pinNotice_submitButton:"I Understand",pinSetup_title:"Create PIN",pinSetup_headerSubtitle:"This PIN is used to authorize your transactions.",pinSetup_subtitle:"Set a 6-digit PIN to authorize transactions.",pinSetup_confirmTitle:"Confirm PIN",pinSetup_confirmSubtitle:"Enter your PIN again to confirm.",pinSetup_mismatchError:"PINs do not match. Please try again.",pinValidation_tooShort:"Please enter a 6-digit PIN.",pinValidation_numbersOnly:"Only numbers (0-9) are allowed.",pinValidation_repeatingDigit:"Cannot use the same number 3+ times in a row.",pinValidation_sequential:"Sequential numbers (e.g., 123456) are not allowed.",pinValidation_alternatingPattern:"Repeating patterns (e.g., 121212) are not allowed.",pinInput_title:"Enter PIN",pinInput_subtitle:"Enter your 6-digit PIN to continue.",pinInput_error:"Incorrect PIN. Please try again.",verifyPin_title:"Verify Your PIN",verifyPin_subtitle:"To continue, please confirm your PIN.",pinLocked_message:"Please try again after the lock expires.",pinLocked_availableFrom:"Available from",pinLocked_failureWarning:"Incorrect PIN. Your account will be locked after further failures.",pinLocked_permanent:"Your account has been permanently locked due to too many failed attempts.",alert_sessionExpired:"Your session has expired. Tap OK and sign in again.",alert_accountWithdrawn:"This account is no longer available or has been withdrawn. Tap OK and sign in again.",alert_walletNotFound:"Wallet data could not be found. Tap OK and sign in again.",alert_differentAccount:`You signed in with a different Google/Apple account than before.
7
+
8
+ For security, you must continue with the same account.
9
+
10
+ OK → Try signing in again with the correct account
11
+ Cancel → Sign out and close`},Ks={ko:qs,en:ns};function ve(r="en",e){return Ks[r]??ns}const Tt="crossx_access_token",Rt="crossx_refresh_token",kt="crossx_user_info";class Vs{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,this._migrated=!1;const c=e.projectId;this.STORAGE_KEY_ACCESS_TOKEN=`crossx_${c}_access_token`,this.STORAGE_KEY_REFRESH_TOKEN=`crossx_${c}_refresh_token`,this.STORAGE_KEY_USER=`crossx_${c}_user_info`}get useCookieAuth(){return this.config.authMode==="cookie"}checkResponseError(e,s){if(e!=null&&e.code&&e.code!==200&&e.code>0)throw new m(p.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 m(p.AUTH_FAILED,`${s} 실패 (코드 ${n.code}): ${n.message}`)}}async execute(e){let s;try{const t=e==null?void 0:e.provider;let n="/login";t==="google"?n="/google":t==="apple"&&(n="/apple");const{oauthServiceUrl:o}=this.config,i=`${o}${n}`;d.log(`[CROSSx] OAuth 팝업 열기 (${t||"일반"} 로그인)`),s=await this.oauth.openAuth({authUrl:i,expectedOrigin:new URL(o).origin}),d.log("[CROSSx] OAuth Firebase 토큰 받음 (length:",s.length,")")}catch(t){d.error("[CROSSx] SignIn 에러 (OAuth 단계):",t);const n=t instanceof Error?t.message:"Sign in failed";throw/팝업|popup/i.test(n)?new m(p.OAUTH_POPUP_BLOCKED,n):new m(p.AUTH_FAILED,n)}return this.processFirebaseToken(s)}async executeWithOAuthToken(e){return d.log("[CROSSx] signInWithOAuthToken — Firebase 토큰 주입 (length:",e.length,")"),this.processFirebaseToken(e)}async processFirebaseToken(e){var n,o,i,a;let s,t=!1;try{const{authApiUrl:c}=this.config,{accessToken:l,refreshToken:u}=await this.exchangeFirebaseToken(e,c);let h,_;try{const w=this.crypto.decodeJWT(e);_=(n=w.firebase)==null?void 0:n.sign_in_provider;const E=((o=w.firebase)==null?void 0:o.identities)??{};_==="google.com"?h=(i=E["google.com"])==null?void 0:i[0]:_==="apple.com"&&(h=(a=E["apple.com"])==null?void 0:a[0]),d.log("[CROSSx] OAuth provider sub 추출 — provider:",_,"hasProviderSub:",!!h)}catch{d.warn("[CROSSx] firebaseToken에서 providerSub 추출 실패")}if(l){const w=this.crypto.decodeJWT(l);d.log("[CROSSx] access_token 디코딩 — sub:",w.sub,"exp:",w.exp);const E=await this.crypto.verifyJWT(l);if(t=E.signatureVerified??!1,!E.valid)throw d.error("[CROSSx] access_token 검증 실패"),new Error("유효하지 않은 access token");const y=E.payload;s={id:y.sub,email:y.email,signInProvider:_,providerSub:h},this.tokenStore.set(l),this.useCookieAuth||(await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,l),u&&this.config.secureStorageAvailable!==!1?await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,u):u&&d.warn("[CROSSx] 안전한 스토리지 미사용 — refresh_token 영속 저장을 건너뜁니다"))}else{const w=this.crypto.decodeJWT(e);s={id:w.sub,email:w.email,signInProvider:_,providerSub:h},d.log("[CROSSx] Cookie 모드 — Firebase 토큰에서 사용자 정보 추출 — id:",s.id)}d.log("[CROSSx] 사용자 정보 — id:",s.id);const f=this.useCookieAuth?{id:s.id,signInProvider:s.signInProvider,providerSub:s.providerSub}:s;await this.storage.set(this.STORAGE_KEY_USER,f),d.log("[CROSSx] 사용자 정보 저장 완료 (authMode:",this.useCookieAuth?"cookie":"token",")")}catch(c){return d.error("[CROSSx] SignIn 에러 (토큰 교환 단계):",c),{success:!1,error:c instanceof Error?c.message:"Sign in failed"}}return d.log("[CROSSx][Migration Phase 1] 로그인 완료, 지갑 로드 시작 — 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`;d.log("[CROSSx] Firebase 토큰 교환 요청");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"}:{}});d.log("[CROSSx] 토큰 교환 응답 — status:",o.status);const i=o.data;this.checkResponseError(i,"Token exchange");const a=this.extractAccessToken(i);if(t&&!a)return d.log("[CROSSx] Cookie 모드 — 로그인 성공 (JWT는 HttpOnly 쿠키)"),{};if(!a)throw new m(p.AUTH_FAILED,"토큰 교환 응답에서 access_token을 찾을 수 없습니다");d.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{await this.migrateStorageKeys();const e=this.tokenStore.get();if(e){const t=await this.crypto.verifyJWT(e);if(t.valid){const n=await this.storage.get(this.STORAGE_KEY_USER);if(n)return d.log("[CROSSx] restoreSession — 메모리 토큰 유효, 세션 복원"),this.loadWallet(n,t.signatureVerified)}this.tokenStore.clear()}if(this.useCookieAuth){d.log("[CROSSx] restoreSession — 쿠키 기반 silentRefresh 시도");const t=await this.silentRefresh();t&&this.tokenStore.set(t)}else{const t=await this.storage.get(this.STORAGE_KEY_ACCESS_TOKEN),n=await this.storage.get(this.STORAGE_KEY_REFRESH_TOKEN);if(d.log("[CROSSx] restoreSession — access_token:",t?"있음":"없음","refresh_token:",n?"있음":"없음"),!n)return d.log("[CROSSx] restoreSession — refresh_token 없음, 세션 복원 생략"),null;t&&this.tokenStore.set(t);const o=await this.silentRefresh(n);d.log("[CROSSx] restoreSession — silentRefresh 결과:",o?"토큰 발급 성공":"토큰 없음"),o&&this.tokenStore.set(o)}const s=await this.storage.get(this.STORAGE_KEY_USER);if(d.log("[CROSSx] restoreSession — userInfo 조회:",s?`있음 (id: ${s.id})`:"없음"),!s)return null;d.log("[CROSSx] restoreSession — silentRefresh 성공, 세션 복원 — userId:",s.id);try{return await this.loadWallet(s,!1)}catch(t){return d.warn("[CROSSx] restoreSession — 지갑 로드 실패 (세션은 유지):",t),{success:!0,user:s,tokenSignatureVerified:!1}}}catch(e){return d.log("[CROSSx] restoreSession — 세션 복원 실패, 스토리지 정리:",e),this.tokenStore.clear(),this.useCookieAuth||await this.storage.remove(this.STORAGE_KEY_REFRESH_TOKEN),await this.storage.remove(this.STORAGE_KEY_USER),null}}silentRefresh(e){return this._refreshPromise&&this._lastRefreshToken===e?this._refreshPromise:(this._lastRefreshToken=e,this._refreshPromise=this._doSilentRefresh(e).finally(()=>{this._refreshPromise=null,this._lastRefreshToken=void 0}),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"}:{}});d.log("[CROSSx] silentRefresh 응답 — status:",i.status);const a=i.data;this.checkResponseError(a,"Silent refresh");const c=this.extractAccessToken(a);if(t&&!c){d.log("[CROSSx] silentRefresh 성공 (cookie 갱신)");return}if(!c)throw new m(p.AUTH_FAILED,"토큰 자동 갱신 실패: 응답에 토큰이 없습니다");if(this.tokenStore.set(c),!t){await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,c);const l=this.extractRefreshToken(a);l&&this.config.secureStorageAvailable!==!1&&await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,l)}return d.log("[CROSSx] silentRefresh 성공"),c}async refreshAccessToken(){try{if(this.useCookieAuth)return!!await this.silentRefresh()||this.tokenStore.has();const e=await this.storage.get(this.STORAGE_KEY_REFRESH_TOKEN);return e?!!await this.silentRefresh(e):(d.warn("[CROSSx] refreshAccessToken: refresh_token 없음 — 갱신 불가"),!1)}catch(e){return d.warn("[CROSSx] refreshAccessToken 실패:",e),!1}}async executeWithJWT(e,s){let t,n=!1;try{let o=await this.crypto.verifyJWT(e);if(n=o.signatureVerified??!1,!o.valid){if(!s)return d.error("[CROSSx] signInWithJWT: access_token 검증 실패, refreshToken 없음"),{success:!1,error:"유효하지 않은 access token"};d.log("[CROSSx] signInWithJWT: access_token 만료, refreshToken으로 갱신 시도");const a=await this.silentRefresh(s);if(!a)return d.error("[CROSSx] signInWithJWT: silentRefresh 실패"),{success:!1,error:"access token이 만료되었고 갱신에 실패했습니다"};if(e=a,o=await this.crypto.verifyJWT(e),n=o.signatureVerified??!1,!o.valid)return d.error("[CROSSx] signInWithJWT: 갱신된 access_token도 유효하지 않음"),{success:!1,error:"갱신된 access token이 유효하지 않습니다"};d.log("[CROSSx] signInWithJWT: silentRefresh 성공, 새 access_token 사용")}const i=o.payload;d.log("[CROSSx] signInWithJWT — sub:",i.sub,"signatureVerified:",n),t={id:i.sub,email:i.email},this.tokenStore.set(e),this.useCookieAuth||(await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,e),s&&this.config.secureStorageAvailable!==!1&&await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,s)),await this.storage.set(this.STORAGE_KEY_USER,t),d.log("[CROSSx] signInWithJWT — 토큰 및 사용자 정보 저장 완료")}catch(o){return d.error("[CROSSx] signInWithJWT 에러:",o),{success:!1,error:o instanceof Error?o.message:"JWT sign in failed"}}return this.loadWallet(t,n)}async migrateStorageKeys(){if(!this._migrated){this._migrated=!0;try{const e=await this.storage.get(kt);if(!e||await this.storage.get(this.STORAGE_KEY_USER))return;await this.storage.set(this.STORAGE_KEY_USER,e);const t=await this.storage.get(Tt);t&&await this.storage.set(this.STORAGE_KEY_ACCESS_TOKEN,t);const n=await this.storage.get(Rt);n&&await this.storage.set(this.STORAGE_KEY_REFRESH_TOKEN,n),await this.storage.remove(kt),await this.storage.remove(Tt),await this.storage.remove(Rt),d.log("[CROSSx] 스토리지 키 마이그레이션 완료 (projectId 스코프)")}catch(e){d.warn("[CROSSx] 스토리지 키 마이그레이션 실패:",e)}}}async loadWallet(e,s){let t,n=!1;try{if(typeof this.walletProvider.checkWallet=="function"){d.log("[CROSSx] GET /mnemonic/check — 지갑 상태 확인 (비밀번호 불필요)");const o=await this.walletProvider.checkWallet();if(d.log("[CROSSx] 지갑 상태:",o),o==="migration_required")d.log("[CROSSx] migration_required → needsMigration = true"),n=!0;else if(o==="exists")try{const i=await this.walletProvider.getAddresses(e.id);i.length>0?(t=i[0].address,d.log("[CROSSx] 캐시된 주소 로드 완료 (비밀번호 불필요):",t)):d.log("[CROSSx] 주소 캐시 없음 — createWallet 단계에서 비밀번호 입력 후 로드")}catch(i){d.warn("[CROSSx] getAddresses 실패, createWallet 단계에서 재시도:",i)}}else d.log("[CROSSx] getOrCreateWallet 직접 호출 (폴백)"),t=(await this.walletProvider.getOrCreateWallet(e.id)).address,d.log("[CROSSx] 지갑 로드 완료 — address:",t)}catch(o){if(o instanceof m&&o.code===p.MIGRATION_BACKUP_EXISTS)d.log("[CROSSx] MIGRATION_BACKUP_EXISTS 감지 → needsMigration = true"),n=!0;else{if(o instanceof m&&(o.code===p.PROJECT_NOT_REGISTERED||o.code===p.PROJECT_ID_MISSING||o.code===p.ORIGIN_NOT_ALLOWED))throw d.error("[CROSSx] 프로젝트 설정 에러:",o.message),o;d.warn("[CROSSx] 지갑 상태 확인 실패 (로그인은 유지):",o)}}return d.log("[CROSSx] loadWallet 결과 — address:",t,"needsMigration:",n),{success:!0,address:t,user:e,needsMigration:n,tokenSignatureVerified:s}}}class zs{constructor(e,s,t){this.config=e,this.storage=s,this.tokenStore=t;const n=e.projectId;this.STORAGE_KEY_ACCESS_TOKEN=`crossx_${n}_access_token`,this.STORAGE_KEY_REFRESH_TOKEN=`crossx_${n}_refresh_token`,this.STORAGE_KEY_USER=`crossx_${n}_user_info`}async execute(){this.tokenStore.clear(),this.config.authMode!=="cookie"&&(await this.storage.remove(this.STORAGE_KEY_ACCESS_TOKEN),await this.storage.remove(this.STORAGE_KEY_REFRESH_TOKEN)),await this.storage.remove(this.STORAGE_KEY_USER),await this.storage.clear()}}class js{constructor(e,s){this.storage=e,this.walletProvider=s}async execute(e,s){if(!this.walletProvider.migrateWallet)throw new m(p.NOT_IMPLEMENTED,"현재 환경에서는 마이그레이션이 지원되지 않습니다");d.log("[CROSSx][Migration Phase 4] MigrateWalletUseCase.execute() — pin 길이:",e.length,"sub:",s);const t=await this.walletProvider.migrateWallet(e,s);return d.log("[CROSSx][Migration Phase 5] MigrateWalletUseCase 완료 — address:",t.address),{address:t.address}}}class ft{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 n=new Uint8Array(s.length);for(let o=0;o<s.length;o++)n[o]=s[o]^t[o];s.fill(0),this.xorKey=t,this.encryptedBytes=n}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 Ys{constructor(e,s){this.chainRegistry=e,this.transport=s,this._nextId=1}async call(e,s,t){const n=await this.chainRegistry.getChain(t),o={jsonrpc:"2.0",method:e,params:s,id:this._nextId++},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 m(p.UNKNOWN_ERROR,`RPC 오류 [${e}] (${t}): ${a.error.message} (코드: ${a.error.code})`);return a==null?void 0:a.result}}class Xs{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 We={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 We?We[e]:null}function Zs(){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 We.production}const Qs=2e3,Pt=6e4,er=1e3,tr=1e4,sr="0x77359400",Ot="0x3B9ACA00",Ct=130,Nt=6,Lt=18,Dt=3e4,rr=5*60*1e3,nr=30*1e3,ee=class ee extends Xs{constructor(e,s,t,n,o,i,a,c,l,u,h){var _,f;super(),this.storage=t,this.crypto=n,this.transport=o,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._verifyPinMutex=null,this._themeMediaCleanup=null,this._isRecoveringSession=!1,this._config=Object.freeze({...e}),this.internalConfig=e,this.adapterConfig=s,e.logger&&At(e.logger),this.confirmation=l,this.pinStore=h??new ft,this.chainRegistry=u,this.jsonRpc=new Ys(u,o),this.signInUseCase=new Vs(this.internalConfig,t,n,i,o,a,c),this.signOutUseCase=new zs(this.internalConfig,t,c),this.migrateWalletUseCase=new js(t,a),(_=a.setOnUnauthorized)==null||_.call(a,()=>this.forceLogout()),(f=a.setTokenRefresher)==null||f.call(a,()=>this.signInUseCase.refreshAccessToken()),e.autoDetectTheme&&this._setupAutoDetectTheme()}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){var s,t;d.log("[CROSSx SDK] v1.3.10 초기화 중..."),this.confirmation.setMessages(ve(this._config.locale));try{const n=Zs();this.internalConfig.oauthServiceUrl=n.oauthServiceUrl,this.internalConfig.authApiUrl=n.authApiUrl,this.internalConfig.walletGatewayUrl=n.walletGatewayUrl,this.adapterConfig.gatewayUrl=n.walletGatewayUrl,(t=(s=this.crypto).setJWKSEndpoint)==null||t.call(s,`${n.authApiUrl}/.well-known/jwks.json`);const o=await this.signInUseCase.restoreSession();if(o!=null&&o.success){this.applyAuthResult(o);try{await this.loadWalletAfterAuth(e==null?void 0:e.preferredWalletIndex)}catch(i){if(!(i instanceof m&&i.code===p.PIN_CANCELLED))throw i;d.log("[CROSSx] initialize: 비밀번호 입력 취소 — 지갑 미로드 상태로 계속")}}return this.initialized=!0,d.info("[CROSSx SDK] v1.3.10 초기화 완료"),this.emit("initialized",{restored:!!(o!=null&&o.success)}),o??null}catch(n){throw new m(p.AUTH_NOT_INITIALIZED,"SDK 초기화에 실패했습니다",n)}}async signIn(e){if(this.ensureInitialized(),this.authenticated)throw new m(p.ALREADY_AUTHENTICATED,"이미 로그인된 상태입니다. signOut()을 먼저 호출하세요.");let s=e;if(!(e!=null&&e.provider)){const t=await this.confirmation.showLoginSelector({showConnectOtherWallets:this._config.showConnectOtherWallets});if(t==="external")throw this.emit("connectExternalWallet",{}),new m(p.EXTERNAL_WALLET_REQUESTED,"User requested external wallet connection");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 t instanceof m?t:new m(p.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: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}}catch(t){throw t instanceof m&&t.code===p.PIN_CANCELLED&&(d.log("[CROSSx] signInWithCreate: 비밀번호 설정 취소 — 자동 로그아웃 진행"),await this.signOut().catch(n=>d.warn("[CROSSx] signInWithCreate: 자동 로그아웃 실패",n))),t}}async signInWithOAuthToken(e){if(this.ensureInitialized(),this.authenticated)throw new m(p.ALREADY_AUTHENTICATED,"이미 로그인된 상태입니다. signOut()을 먼저 호출하세요.");try{const s=await this.signInUseCase.executeWithOAuthToken(e);return s.success&&this.applyAuthResult(s),s}catch(s){throw new m(p.AUTH_FAILED,"OAuth 토큰 로그인에 실패했습니다",s)}}async signInWithJWT(e,s){if(this.ensureInitialized(),this.authenticated)throw new m(p.ALREADY_AUTHENTICATED,"이미 로그인된 상태입니다. signOut()을 먼저 호출하세요.");try{const t=await this.signInUseCase.executeWithJWT(e,s);return t.success&&this.applyAuthResult(t),t}catch(t){throw new m(p.AUTH_FAILED,"JWT 로그인에 실패했습니다",t)}}async signOut(){this.ensureInitialized();try{await this.signOutUseCase.execute(),this.clearAuthState()}catch(e){throw new m(p.UNKNOWN_ERROR,"로그아웃에 실패했습니다",e)}}isAuthenticated(){return this.authenticated}async whenReady(){if(this.initialized)return!0;if(this._initPromise)try{return await this._initPromise,this.initialized}catch{return!1}return!1}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===p.PIN_CANCELLED||d.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(p.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}),d.log("[CROSSx] migrateWallet 완료 — address:",s.address),s}catch(s){throw s instanceof m?s:new m(p.MIGRATION_FAILED,"지갑 마이그레이션에 실패했습니다",s)}}async getAddress(e){if(e!==void 0){if(this.ensureAuthenticated(),!this.userId)throw new m(p.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.withSessionRecovery(()=>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(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");let s=await this.withSessionRecovery(()=>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.ensurePinForSigning();const n=s.length,i={address:(await this.withPinRetry(()=>this.withSessionRecovery(()=>this.walletProvider.getAddress(this.userId,n)))).address,index:n};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(p.UNKNOWN_ERROR,"체인 목록 조회에 실패했습니다",e)}}async getChain(e){this.ensureInitialized();try{return await this.chainRegistry.getChain(e)}catch(s){throw s instanceof m?s:new m(p.CHAIN_NOT_SUPPORTED,`체인 조회에 실패했습니다: ${e}`,s)}}_setupAutoDetectTheme(){if(typeof window>"u"||!window.matchMedia)return;const e=window.matchMedia("(prefers-color-scheme: dark)"),s=n=>{const o=n?"dark":"light";this.applyTheme(o,this._config.themeTokens??{})};s(e.matches);const t=n=>s(n.matches);e.addEventListener("change",t),this._themeMediaCleanup=()=>e.removeEventListener("change",t)}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(ve(e))}async createWallet(){return this.withSessionRecovery(()=>this._createWallet())}async _createWallet(){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");d.log("[CROSSx] createWallet 시작");const e=await this.fetchWalletStatus();if(d.log("[CROSSx] 지갑 상태:",e),e==="migration_required"){const s=this.providerSub??this.userId;d.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(p.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}if(e==="exists"){await this.ensureVerifiedPin();try{const s=await this.withPinRetry(()=>this.walletProvider.getOrCreateWallet(this.userId));return this.address=s.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:s.address,index:0}),d.log("[CROSSx] 지갑 준비 완료:",s.address),{address:s.address}}catch(s){if(s instanceof m&&s.code===p.MIGRATION_BACKUP_EXISTS){const t=this.providerSub??this.userId;d.log("[CROSSx] MIGRATION_BACKUP_EXISTS (폴백) → 마이그레이션 UI 시작");const n=await this.handleMigrationFlow(t);if(n)return this.address=n.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:n.address,index:0}),{address:n.address};throw new m(p.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}throw s}}await this.ensurePinSetup();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}),d.log("[CROSSx] 지갑 준비 완료:",s.address),{address:s.address}}catch(s){if(s instanceof m&&s.code===p.MIGRATION_BACKUP_EXISTS){const t=this.providerSub??this.userId;d.log("[CROSSx] MIGRATION_BACKUP_EXISTS (폴백) → 마이그레이션 UI 시작");const n=await this.handleMigrationFlow(t);if(n)return this.address=n.address,this.activeWalletIndex=0,this.emit("addressChanged",{address:n.address,index:0}),{address:n.address};throw new m(p.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}throw s}}async fetchWalletStatus(){if(typeof this.walletProvider.checkWallet=="function")try{return await this.walletProvider.checkWallet()}catch(e){return d.warn("[CROSSx] checkWallet 실패 (폴백: not_found 처리):",e),"not_found"}return null}async signMessage(e,s,t){return this.withSessionRecovery(()=>this._signMessage(e,s,t))}async _signMessage(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.resolveAddress(t==null?void 0:t.index);if(!await this.confirmation.requestConfirmation({type:"sign-message",chainId:e,from:n.address,message:s,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the message signing request");try{const i=await this.withPinRetry(async()=>{let a;return this.walletProvider.prepare&&(a=(await this.walletProvider.prepare("sign-message",{message:s,from:n.address})).uuid),await this.ensureVerifiedPin(),this.walletProvider.signMessage(this.userId,e,s,t==null?void 0:t.index,a,n.address)});return this.verifySignatureSigner(s,i.signature,n.address),{chainId:e,signature:i.signature,message:s,address:n.address}}catch(i){throw i instanceof m?i:new m(p.SIGNATURE_FAILED,`메시지 서명에 실패했습니다 (${e})`,i)}}async signTypedData(e,s,t){return this.withSessionRecovery(()=>this._signTypedData(e,s,t))}async _signTypedData(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");if(!this.walletProvider.signTypedData)throw new m(p.NOT_IMPLEMENTED,"signTypedData가 구현되어 있지 않습니다");ee.validateTypedDataChainId(e,s);const n=await this.resolveAddress(t==null?void 0:t.index);if(!await this.confirmation.requestConfirmation({type:"sign-typed-data",chainId:e,from:n.address,typedData:s,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the typed data signing request");try{const i=await this.withPinRetry(async()=>{let a;return this.walletProvider.prepare&&(a=(await this.walletProvider.prepare("sign-typed-data",{typedData:s,from:n.address})).uuid),await this.ensureVerifiedPin(),this.walletProvider.signTypedData(this.userId,e,s,t==null?void 0:t.index,a,n.address)});return ee.validateSignatureFormat(i.signature),{chainId:e,signature:i.signature,address:n.address}}catch(i){throw i instanceof m?i:new m(p.SIGNATURE_FAILED,`타입 데이터 서명에 실패했습니다 (${e})`,i)}}async signTypedDataOffchain(e,s){return this.signTypedData(ee.OFFCHAIN_CHAIN_ID,e,s)}async signTransaction(e,s,t){return this.withSessionRecovery(()=>this._signTransaction(e,s,t))}async _signTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);n.from||(n.from=(await this.resolveAddress(t==null?void 0:t.index)).address);const o=Qe(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:o.symbol,nativeDecimals:o.decimals,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the transaction signing request");try{const a=await this.withPinRetry(async()=>{let c;return this.walletProvider.prepare&&(c=(await this.walletProvider.prepare("sign",{tx:n})).uuid),await this.ensureVerifiedPin(),this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,c)});return ee.validateSignedTxFormat(a.signature),{chainId:e,signedTx:a.signature,txHash:a.txHash??""}}catch(a){if(a instanceof m)throw a;const c=a instanceof Error?a.message:String(a);throw new m(p.SIGNATURE_FAILED,`트랜잭션 서명에 실패했습니다 (${e}): ${c}`,a)}}async sendTransaction(e,s,t){return this.withSessionRecovery(()=>this._sendTransaction(e,s,t))}async _sendTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new m(p.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);n.from||(n.from=(await this.resolveAddress(t==null?void 0:t.index)).address);const o=Qe(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:o.symbol,nativeDecimals:o.decimals,dappName:(t==null?void 0:t.dappName)??this._config.appName,accountName:t==null?void 0:t.accountName}))throw new m(p.USER_REJECTED,"User rejected the transaction request");try{const a=await this.withPinRetry(async()=>{let c;if(this.walletProvider.prepare&&(c=(await this.walletProvider.prepare("send",{tx:n})).uuid),await this.ensureVerifiedPin(),this.walletProvider.sendTransaction)return(await this.walletProvider.sendTransaction(this.userId,e,n,c)).txHash;const l=await this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,c);return l.txHash??l.signature});return{chainId:e,txHash:a,status:"pending"}}catch(a){if(a instanceof m)throw a;const c=a instanceof Error?a.message:String(a);throw new m(p.TRANSACTION_FAILED,`트랜잭션 전송에 실패했습니다 (${e}): ${c}`,a)}}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??er,o=tr,i=t.timeoutMs??Pt,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(u=>setTimeout(u,c)),c=Math.min(c*2,o)}throw new m(p.UNKNOWN_ERROR,`트랜잭션 영수증 조회 시간이 초과되었습니다 (${e})`)}async sendTransactionWithWaitForReceipt(e,s,t={}){var E,y;const{intervalMs:n,timeoutMs:o,...i}=t,{txHash:a}=await this.sendTransaction(e,s,i),c=n??((E=this._config.receiptPolling)==null?void 0:E.intervalMs)??Qs,l=o??((y=this._config.receiptPolling)==null?void 0:y.timeoutMs)??Pt,u=Qe(e),h=s.from??"";let _,f;const w=this.waitForTxAndGetReceipt(a,e,{intervalMs:c,timeoutMs:l}).then(R=>{_=R;const N=BigInt(R.gasUsed)*BigInt(R.effectiveGasPrice),F=s.value?BigInt(s.value):0n,M=ee.formatTxAmount(s.value,u.symbol,u.decimals),V=ee.formatTxAmount("0x"+N.toString(16),u.symbol,u.decimals),G=ee.formatTxAmount("0x"+(F+N).toString(16),u.symbol,u.decimals);return{chainId:e,txHash:a,from:R.from,to:R.to??s.to,amount:M,fees:V,total:G,nativeSymbol:u.symbol,status:R.status==="0x1"?"success":"reverted"}}).catch(R=>(f=R instanceof Error?R:new Error(String(R)),{chainId:e,txHash:a,from:h,to:s.to,amount:ee.formatTxAmount(s.value,u.symbol,u.decimals),nativeSymbol:u.symbol,status:"timeout"}));if(await this.confirmation.showTransactionProgress({chainId:e,txHash:a,from:h,to:s.to},w),f)throw f;return{chainId:e,txHash:a,receipt:_}}setPin(e){this.pinStore.set(e)}clearPin(){this.pinStore.clear()}hasPin(){return this.pinStore.has()}async changePin(e,s){this.ensureAuthenticated();const t=this.walletProvider;if(typeof t.changePin!="function")throw new m(p.NOT_IMPLEMENTED,"changePin이 구현되어 있지 않습니다");this.pinStore.set(e);try{await t.changePin(e,s),this.pinStore.set(s),d.log("[CROSSx] PIN 변경 완료")}catch(n){throw n instanceof m?n:new m(p.UNKNOWN_ERROR,"PIN 변경에 실패했습니다",n)}}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(p.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 m(p.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 m(p.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(p.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 n=t instanceof Error?t.message:String(t);throw new m(p.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:ee.formatWei(n),chainId:e}}catch(t){if(t instanceof m)throw t;const n=t instanceof Error?t.message:String(t);throw new m(p.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(Lt),n=s/t,i=(s%t).toString().padStart(Lt,"0").replace(/0+$/,"").slice(0,Nt);return i?`${n}.${i}`:`${n}`}catch{return"?"}}getProvider(e){return this.ensureAuthenticated(),new rs(this,e)}async walletRpc(e,s,t){this.ensureAuthenticated();try{return await this.jsonRpc.call(e,s,t)}catch(n){if(n instanceof m)throw n;const o=n instanceof Error?n.message:String(n);throw new m(p.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,Nt).replace(/0+$/,"");return`${c?`${i}.${c}`:`${i}`} ${s}`}catch{return}}async handleMigrationFlow(e){var c,l,u;d.log('[CROSSx][Migration Phase 3] "Wallet Found" 팝업 표시');const s=((c=this._config.migration)==null?void 0:c.allowSkip)??!0,t=await this.confirmation.showMigrationFoundPrompt({allowSkip:s});if(d.log("[CROSSx][Migration Phase 3] 사용자 선택:",t),t==="skip")return d.log("[CROSSx][Migration Phase 3] 사용자가 마이그레이션을 건너뜀 → 종료"),null;let n,o=0,i=5,a=null;for(;;){o++,d.log(`[CROSSx][Migration Phase 4] PIN 입력 팝업 표시 (시도 #${o}/${i})`,n?`— 이전 메시지: ${n}`:"");const h=await this.confirmation.showRecoveryPinInputPrompt({errorMessage:n,attemptCount:o>1?o-1:void 0,maxAttempts:i});if(h===null)return d.log("[CROSSx][Migration Phase 4] 사용자가 PIN 입력을 취소함 → 종료"),null;d.log("[CROSSx][Migration Phase 4] PIN 입력 완료 — verify-recovery-pin API 호출"),n=void 0;try{const _=await((u=(l=this.walletProvider).verifyRecoveryPin)==null?void 0:u.call(l,h,e));if(!_){d.log("[CROSSx][Migration Phase 4] verifyRecoveryPin 미지원 — PIN 검증 생략"),a=h;break}if(_.valid){d.log("[CROSSx][Migration Phase 4] PIN 검증 성공"),a=h;break}const f=_.pinStatus;if(i=f.maxAttempts,o=i-f.remainingAttempts,f.remainingAttempts===0&&f.lockExpiresAt){const w=f.lockExpiresAt*1e3,E=Math.max(1,Math.round((w-Date.now())/1e3)),y=E<=1800?"Too many failed attempts. Please try again in 30 minutes.":"Too many failed attempts. Please try again in 24 hours.";d.warn(`[CROSSx][Migration Phase 4] verify-recovery-pin 잠금 — ${E}초, 메시지: ${y}`),await this.confirmation.showRecoveryPinLockedPrompt(E,y),o=0,n="Your account lock has been lifted. You may try again."}else d.warn(`[CROSSx][Migration Phase 4] PIN 불일치 (시도 ${o}/${i})`),n="Incorrect PIN."}catch(_){if(!(_ instanceof m))throw _;if(_.code===p.MIGRATION_PIN_LOCKED){const f=_.details;if(i=(f==null?void 0:f.maxAttempts)??5,(f==null?void 0:f.permanent)===!0)return d.warn("[CROSSx][Migration Phase 4] PIN 영구 잠금 (verify-recovery-pin)"),await this.confirmation.showRecoveryPinLockedPrompt(0,"Your account has been permanently locked due to too many failed attempts."),null;const w=((f==null?void 0:f.lockExpiresAt)??0)*1e3,E=Math.max(1,Math.round((w-Date.now())/1e3)),y=E<=1800?"Too many failed attempts. Please try again in 30 minutes.":"Too many failed attempts. Please try again in 24 hours.";d.warn(`[CROSSx][Migration Phase 4] verify-recovery-pin 이미 잠금 — ${E}초`),await this.confirmation.showRecoveryPinLockedPrompt(E,y),o=0,n="Your account lock has been lifted. You may try again."}else throw d.error("[CROSSx][Migration Phase 4] verify-recovery-pin 실패 (복구 불가):",_),_}}d.log("[CROSSx][Migration Phase 5] PIN 검증 완료 — 비밀번호 설정 및 마이그레이션 진행");try{await this.ensurePinSetup();const h=await this.migrateWalletUseCase.execute(a,e);return d.log("[CROSSx][Migration Phase 5] 마이그레이션 성공 — address:",h.address),h}catch(h){if(h instanceof m&&h.code===p.MIGRATION_FAILED)return d.warn("[CROSSx][Migration Phase 5] migrate PIN 불일치 (경합) — 처음부터 재시도"),this.handleMigrationFlow(e);throw d.error("[CROSSx][Migration Phase 5] 마이그레이션 실패 (복구 불가):",h),h}}async withResolvedGasAndFee(e,s){const t=f=>!(f!=null&&f.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},l=n?c.from??this.address:void 0;l&&d.log("[CROSSx] nonce 비어있음 → eth_getTransactionCount 호출 (from:",l,")"),o&&d.log("[CROSSx] gasLimit 비어있음 → eth_estimateGas 호출"),i&&d.log("[CROSSx] gasPrice & maxFeePerGas 비어있음 → baseFee 조회로 Dynamic/Legacy 판별");const[u,h,_]=await Promise.all([l?this.jsonRpc.call("eth_getTransactionCount",[l,"pending"],s):null,o?this.estimateGas(e,s):null,i?this.getBaseFeePerGas(s):null]);if(l&&(c.nonce=parseInt(u??"0x0",16),d.log("[CROSSx] nonce 결과:",c.nonce)),o&&(c.gasLimit=h,d.log("[CROSSx] estimateGas 결과:",c.gasLimit)),i){const f=_;if(f){const w=Ot;c.maxFeePerGas="0x"+(BigInt(f)+BigInt(w)).toString(16),c.maxPriorityFeePerGas=w,d.log("[CROSSx] Dynamic 체인 감지 — baseFee:",f,"maxFeePerGas:",c.maxFeePerGas,"maxPriorityFeePerGas: 1 Gwei")}else c.gasPrice=sr,d.log("[CROSSx] Legacy 체인 감지 — gasPrice: 2 Gwei")}return!i&&a&&(c.maxPriorityFeePerGas=Ot,d.log("[CROSSx] maxPriorityFeePerGas 비어있음 → 1 Gwei 기본값 적용")),c}static validateTypedDataChainId(e,s){const t=ee.extractDomainChainId(s);if(e==="0"){if(t!==void 0&&t!==0)throw new m(p.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 m(p.TYPED_DATA_CHAIN_ID_MISMATCH,`온체인 서명(${e})에서는 typedData.domain.chainId가 반드시 있어야 합니다`);if(t!==o)throw new m(p.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 m(p.SIGNATURE_FAILED,"유효하지 않은 서명: 올바른 hex 문자열이 아닙니다");if(s.length!==Ct)throw new m(p.SIGNATURE_FAILED,`서명 길이가 유효하지 않습니다: ${Ct} 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(p.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 올바른 hex 문자열이 아닙니다");if(s.length<2)throw new m(p.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 너무 짧습니다")}verifySignatureSigner(e,s,t){if(this.crypto.recoverPersonalSignSigner)try{const n=this.crypto.recoverPersonalSignSigner(e,s);if(n.toLowerCase()!==t.toLowerCase())throw d.error("[CROSSx] 서명 검증 실패: 서명자 주소 불일치",{expected:t,recovered:n}),new m(p.SIGNATURE_SIGNER_MISMATCH,`서명자 주소가 일치하지 않습니다: 예상 ${t}, 복원된 주소 ${n}`);d.log("[CROSSx] 서명 ecrecover 검증 성공")}catch(n){if(n instanceof m)throw n;d.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.activeWalletIndex=0,this.userEmail=((t=e.user)==null?void 0:t.email)??null,this.providerSub=((n=e.user)==null?void 0:n.providerSub)??null,this.loginType=ee.normalizeLoginType((o=e.user)==null?void 0:o.signInProvider),this.tokenSignatureVerified=e.tokenSignatureVerified??!1,this._isRecoveringSession||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.pinStore.clear(),this._isRecoveringSession||this.emit("authChanged",{isAuthenticated:!1,address:null,userId:null})}forceLogout(){this.authenticated&&(d.warn("[CROSSx] 인증 만료(Gateway -10002) — 강제 로그아웃"),this.clearAuthState())}async signInAgain(){var n,o;this.ensureInitialized();const e=this.providerSub,s=this.userId,t=this.loginType;this._isRecoveringSession=!0;try{this.authenticated=!1,this.tokenStore.clear();const i=t?{provider:t}:void 0;let a;try{a=await this.signInUseCase.execute(i)}catch(h){throw this.clearAuthState(),h}if(!a.success)return this.clearAuthState(),a;const c=((n=a.user)==null?void 0:n.providerSub)??null,l=((o=a.user)==null?void 0:o.id)??null;if(!(e?!!c&&c===e:s?!!l&&s===l:!0)){d.warn("[CROSSx] signInAgain: providerSub/userId 불일치 — 잘못된 계정으로 로그인됨"),await this.signOutUseCase.execute().catch(()=>{});const h=ve(this._config.locale??"en");return(typeof globalThis.confirm=="function"?globalThis.confirm(h.alert_differentAccount):!1)?(this._isRecoveringSession=!1,this.signInAgain()):(this.clearAuthState(),{success:!1,error:"Different account signed in"})}this.applyAuthResult(a);try{await this.loadWalletAfterAuth()}catch{d.warn("[CROSSx] signInAgain: loadWalletAfterAuth 실패 (로그인은 유지)")}return d.log("[CROSSx] signInAgain: 세션 복구 성공"),a}finally{this._isRecoveringSession=!1}}async withSessionRecovery(e){try{return await e()}catch(s){const t=ve(this._config.locale??"en");if(s instanceof m&&s.code===p.WITHDRAW_FAILED)throw d.warn("[CROSSx] WITHDRAW_FAILED — 로컬 인증 초기화"),typeof globalThis.alert=="function"&&globalThis.alert(t.alert_accountWithdrawn),this.clearAuthState(),s;if(s instanceof m&&s.code===p.WALLET_NOT_FOUND)throw d.warn("[CROSSx] WALLET_NOT_FOUND — 로컬 인증 초기화"),typeof globalThis.alert=="function"&&globalThis.alert(t.alert_walletNotFound),this.clearAuthState(),s;if(!(s instanceof m)||s.code!==p.SESSION_EXPIRED)throw s;d.warn("[CROSSx] SESSION_EXPIRED 감지 — 자동 재인증 시도"),typeof globalThis.alert=="function"&&globalThis.alert(t.alert_sessionExpired);const n=await this.signInAgain();if(!n.success)throw new m(p.SESSION_EXPIRED,n.error??"세션이 만료되었습니다. 다시 로그인해 주세요.");return e()}}static normalizeLoginType(e){return e?e.includes("google")?"google":e.includes("apple")?"apple":e:null}async ensurePinSetup(){if(this.pinStore.has())return;const e=await this.confirmation.showPinSetupPrompt();if(!e)throw new m(p.PIN_CANCELLED,"사용자가 PIN 설정을 취소했습니다");this.pinStore.set(e),d.log("[CROSSx] PIN 설정 완료 (메모리 캐시)")}async ensurePinForSigning(e){if(this.pinStore.has()&&!e)return;e&&this.pinStore.clear();const s=await this.confirmation.showPinInputPrompt({errorMessage:e});if(!s)throw new m(p.PIN_CANCELLED,"사용자가 PIN 입력을 취소했습니다");this.pinStore.set(s),d.log("[CROSSx] PIN 입력 완료 (메모리 캐시)")}async ensureVerifiedPin(e,s,t,n){if(e)this.pinStore.clear();else if(this.pinStore.has())return;if(this._verifyPinMutex&&!e){d.log("[CROSSx] ensureVerifiedPin: 진행 중인 검증 대기"),await this._verifyPinMutex;return}let o,i;this._verifyPinMutex=new Promise((c,l)=>{o=c,i=l});const a=ve(this._config.locale??"en");try{if(typeof this.walletProvider.verifyPin!="function"){const l=await this.confirmation.showPinInputPrompt({verifyMode:!0,errorMessage:e,lockExpiresAt:s,attemptCount:t,maxAttempts:n});if(!l)throw new m(p.PIN_CANCELLED,"사용자가 PIN 입력을 취소했습니다");this.pinStore.set(l),d.log("[CROSSx] PIN 캐시 완료 (verifyPin 미지원, 로컬 전용)"),o();return}const c=await this.confirmation.showPinInputPrompt({verifyMode:!0,errorMessage:e,lockExpiresAt:s,attemptCount:t,maxAttempts:n,onSubmit:async l=>{this.pinStore.set(l);try{return await this.walletProvider.verifyPin(l)?(d.log("[CROSSx] PIN 서버 검증 완료 (verify-password)"),{ok:!0}):(this.pinStore.clear(),{ok:!1,error:a.pinInput_error})}catch(u){if(this.pinStore.clear(),u instanceof m){if(u.code===p.PIN_WRONG)return{ok:!1,error:a.pinInput_error};if(u.code===p.PIN_INVALID)return{ok:!1,error:u.message};if(u.code===p.PIN_LOCKED)return ee.buildPinLockedResult(u,a)}throw u}}});if(!c)throw new m(p.PIN_CANCELLED,"사용자가 PIN 입력을 취소했습니다");this.pinStore.set(c),d.log("[CROSSx] PIN 갱신 완료 (verify 모달 닫힘)"),o()}catch(c){if(c instanceof m&&(c.code===p.AUTH_NOT_AUTHENTICATED||c.code===p.AUTH_TOKEN_EXPIRED||c.code===p.SESSION_EXPIRED)&&c.code!==p.SESSION_EXPIRED){const{alert_sessionExpired:l}=ve(this._config.locale??"en");typeof globalThis.alert=="function"&&globalThis.alert(l)}throw i(c),c}finally{this._verifyPinMutex=null}}static buildPinLockedResult(e,s){const t=e.details;if(t!=null&&t.permanent)return{ok:!1,error:s.pinLocked_permanent};if((t==null?void 0:t.remainingAttempts)!=null&&t.remainingAttempts>0&&t.maxAttempts){const n=t.maxAttempts-t.remainingAttempts;return{ok:!1,error:s.pinLocked_failureWarning,attemptCount:n,maxAttempts:t.maxAttempts}}return{ok:!1,error:"Too many failed attempts. Your account is temporarily locked.",lockExpiresAt:t==null?void 0:t.lockExpiresAt}}async loadWalletAfterAuth(e){if(!this.userId)return;const s=await this.fetchWalletStatus();if(d.log("[CROSSx] loadWalletAfterAuth 지갑 상태:",s),s!=="exists")return;const t=await this.walletProvider.getAddresses(this.userId);if(t.length>0){const o=e!==void 0?t.find(i=>i.index===e)??t[0]:t[0];this.address=o.address,this.activeWalletIndex=o.index,d.log("[CROSSx] 캐시된 주소 로드 완료 (비밀번호 불필요):",this.address),this.emit("addressChanged",{address:o.address,index:o.index});return}d.log("[CROSSx] 주소 캐시 없음 — 비밀번호 확인 후 address(0) 조회"),await this.ensureVerifiedPin();const n=await this.walletProvider.getAddress(this.userId,0);this.address=n.address,this.activeWalletIndex=0,d.log("[CROSSx] 세션 복원 후 지갑 주소 로드 완료:",this.address),this.emit("addressChanged",{address:n.address,index:0})}async withPinRetry(e){const s=ve(this._config.locale??"en");let t,n,o,i;const a=c=>{if(c.code===p.PIN_WRONG)return t=s.pinInput_error,n=void 0,o=void 0,i=void 0,!0;if(c.code===p.PIN_INVALID)return t=c.message,n=void 0,o=void 0,i=void 0,!0;if(c.code===p.PIN_LOCKED){const l=c.details;return l!=null&&l.permanent?(t=s.pinLocked_permanent,n=void 0,o=void 0,i=void 0):(l==null?void 0:l.remainingAttempts)!=null&&l.remainingAttempts>0&&l.maxAttempts?(t=s.pinLocked_failureWarning,n=void 0,o=l.maxAttempts-l.remainingAttempts,i=l.maxAttempts):(t="Too many failed attempts. Your account is temporarily locked.",n=l==null?void 0:l.lockExpiresAt,o=void 0,i=void 0),!0}return!1};try{return await e()}catch(c){if(!(c instanceof m&&a(c)))throw c}for(;;){d.warn("[CROSSx] PIN 불일치/잠금 — 재입력 요청:",t),this.pinStore.clear(),await this.ensureVerifiedPin(t,n,o,i),n=void 0,o=void 0,i=void 0;try{return await e()}catch(c){if(c instanceof m&&a(c))continue;throw c}}}async resolveAddress(e){if(e===void 0||e===this.activeWalletIndex){if(!this.address)throw new m(p.AUTH_NOT_AUTHENTICATED,"활성 지갑 주소를 찾을 수 없습니다");return{address:this.address,index:this.activeWalletIndex}}return{address:(await this.withPinRetry(()=>this.walletProvider.getAddress(this.userId,e))).address,index:e}}ensureInitialized(){if(!this.initialized)throw new m(p.AUTH_NOT_INITIALIZED,"SDK가 초기화되지 않았습니다. initialize()를 먼저 호출하세요.")}ensureAuthenticated(){if(this.ensureInitialized(),!this.authenticated)throw new m(p.AUTH_NOT_AUTHENTICATED,"인증되지 않은 상태입니다. signIn()을 먼저 호출하세요.")}dispose(){var e;(e=this._themeMediaCleanup)==null||e.call(this),this._themeMediaCleanup=null,this.clearAuthState(),this.tokenStore.clear(),this.pinStore.clear(),this.initialized=!1,this.removeAllListeners(),At(null)}_getInternalContext(){return{transport:this.transport,storage:this.storage,walletProvider:this.walletProvider,confirmation:this.confirmation,tokenStore:this.tokenStore,pinStore:this.pinStore,adapterConfig:this.adapterConfig}}};ee.OFFCHAIN_CHAIN_ID="0";let qe=ee;class or{constructor(){this.prefix="crossx_"}async set(e,s){try{const t=JSON.stringify(s);localStorage.setItem(this.prefix+e,t)}catch(t){throw d.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 d.error("Storage get error:",s),null}}async remove(e){try{localStorage.removeItem(this.prefix+e)}catch(s){throw d.error("Storage remove error:",s),s}}async clear(){try{Object.keys(localStorage).forEach(s=>{s.startsWith(this.prefix)&&localStorage.removeItem(s)})}catch(e){throw d.error("Storage clear error:",e),e}}}const et="crossx-sdk",ir=1,de="data",Ee="keys",Be="aes-primary",ar=12;class Mt{constructor(e){this.db=null,this.cryptoKey=null,this.initPromise=null,this.dbName=`crossx-sdk-${e}`}async ensureReady(){this.db&&this.cryptoKey||(this.initPromise||(this.initPromise=this.init()),await this.initPromise)}openDB(e=this.dbName){return new Promise((s,t)=>{const n=indexedDB.open(e,ir);n.onupgradeneeded=()=>{const o=n.result;o.objectStoreNames.contains(de)||o.createObjectStore(de),o.objectStoreNames.contains(Ee)||o.createObjectStore(Ee)},n.onsuccess=()=>s(n.result),n.onerror=()=>t(n.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(Ee,Be);if(e){this.cryptoKey=e;return}const s=await this.migrateFromLegacyDB();if(s){this.cryptoKey=s;return}this.cryptoKey=await crypto.subtle.generateKey({name:"AES-GCM",length:256},!1,["encrypt","decrypt"]),await this.idbPut(Ee,Be,this.cryptoKey)}async migrateFromLegacyDB(){if(this.dbName===et)return null;try{const e=await this.openDB(et),s=e.transaction([Ee,de],"readonly"),t=s.objectStore(Ee).get(Be),n=await new Promise((l,u)=>{t.onsuccess=()=>l(t.result),t.onerror=()=>u(t.error)});if(!n)return e.close(),null;const o=s.objectStore(de).getAll(),i=s.objectStore(de).getAllKeys(),[a,c]=await Promise.all([new Promise((l,u)=>{o.onsuccess=()=>l(o.result),o.onerror=()=>u(o.error)}),new Promise((l,u)=>{i.onsuccess=()=>l(i.result),i.onerror=()=>u(i.error)})]);e.close(),await this.idbPut(Ee,Be,n);for(let l=0;l<c.length;l++)await this.idbPut(de,String(c[l]),a[l]);return indexedDB.deleteDatabase(et),d.log("[CROSSx] IndexedDB 레거시 DB 마이그레이션 완료"),n}catch(e){return d.warn("[CROSSx] IndexedDB 레거시 DB 마이그레이션 실패:",e),null}}async encrypt(e){const s=new Uint8Array(ar);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(de,e,n)}catch(t){throw d.error("[CROSSx] IndexedDB set error:",t),t}}async get(e){try{await this.ensureReady();const s=await this.idbGet(de,e);if(!s)return null;const t=await this.decrypt(s);return JSON.parse(t)}catch(s){return d.error("[CROSSx] IndexedDB get error:",s),null}}async remove(e){try{await this.ensureReady(),await this.idbDelete(de,e)}catch(s){throw d.error("[CROSSx] IndexedDB remove error:",s),s}}async clear(){try{await this.ensureReady(),await this.idbClear(de)}catch(e){throw d.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 _t(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function me(r,e=""){if(!Number.isSafeInteger(r)||r<0){const s=e&&`"${e}" `;throw new Error(`${s}expected integer >= 0, got ${r}`)}}function q(r,e,s=""){const t=_t(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 os(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");me(r.outputLen),me(r.blockLen)}function Oe(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 is(r,e){q(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 cr(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function Ce(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function tt(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function ue(r,e){return r<<32-e|r>>>e}const lr=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function dr(r){return r<<24&4278190080|r<<8&16711680|r>>>8&65280|r>>>24&255}function ur(r){for(let e=0;e<r.length;e++)r[e]=dr(r[e]);return r}const $t=lr?r=>r:ur,as=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",hr=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function $e(r){if(q(r),as)return r.toHex();let e="";for(let s=0;s<r.length;s++)e+=hr[r[s]];return e}const fe={_0:48,_9:57,A:65,F:70,a:97,f:102};function Bt(r){if(r>=fe._0&&r<=fe._9)return r-fe._0;if(r>=fe.A&&r<=fe.F)return r-(fe.A-10);if(r>=fe.a&&r<=fe.f)return r-(fe.a-10)}function Ke(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(as)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=Bt(r.charCodeAt(o)),a=Bt(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 Se(...r){let e=0;for(let t=0;t<r.length;t++){const n=r[t];q(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 cs(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 ls(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 pr=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function fr(r,e,s){return r&e^~r&s}function _r(r,e,s){return r&e^r&s^e&s}class xr{constructor(e,s,t,n){T(this,"blockLen");T(this,"outputLen");T(this,"padOffset");T(this,"isLE");T(this,"buffer");T(this,"view");T(this,"finished",!1);T(this,"length",0);T(this,"pos",0);T(this,"destroyed",!1);this.blockLen=e,this.outputLen=s,this.padOffset=t,this.isLE=n,this.buffer=new Uint8Array(e),this.view=tt(this.buffer)}update(e){Oe(this),q(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=tt(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){Oe(this),is(e,this),this.finished=!0;const{buffer:s,view:t,blockLen:n,isLE:o}=this;let{pos:i}=this;s[i++]=128,Ce(this.buffer.subarray(i)),this.padOffset>n-i&&(this.process(t,0),i=0);for(let h=i;h<n;h++)s[h]=0;t.setBigUint64(n-8,BigInt(this.length*8),o),this.process(t,0);const a=tt(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");const l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let h=0;h<l;h++)a.setUint32(4*h,u[h],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 we=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ue=BigInt(2**32-1),Ut=BigInt(32);function gr(r,e=!1){return e?{h:Number(r&Ue),l:Number(r>>Ut&Ue)}:{h:Number(r>>Ut&Ue)|0,l:Number(r&Ue)|0}}function mr(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}=gr(r[o],e);[t[o],n[o]]=[i,a]}return[t,n]}const wr=(r,e,s)=>r<<s|e>>>32-s,yr=(r,e,s)=>e<<s|r>>>32-s,br=(r,e,s)=>e<<s-32|r>>>64-s,Sr=(r,e,s)=>r<<s-32|e>>>64-s,vr=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]),ye=new Uint32Array(64);class Er extends xr{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 h=0;h<16;h++,s+=4)ye[h]=e.getUint32(s,!1);for(let h=16;h<64;h++){const _=ye[h-15],f=ye[h-2],w=ue(_,7)^ue(_,18)^_>>>3,E=ue(f,17)^ue(f,19)^f>>>10;ye[h]=E+ye[h-7]+w+ye[h-16]|0}let{A:t,B:n,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let h=0;h<64;h++){const _=ue(a,6)^ue(a,11)^ue(a,25),f=u+_+fr(a,c,l)+vr[h]+ye[h]|0,E=(ue(t,2)^ue(t,13)^ue(t,22))+_r(t,n,o)|0;u=l,l=c,c=a,a=i+f|0,i=o,o=n,n=t,t=f+E|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,u=u+this.H|0,this.set(t,n,o,i,a,c,l,u)}roundClean(){Ce(ye)}destroy(){this.set(0,0,0,0,0,0,0,0),Ce(this.buffer)}}class Ir extends Er{constructor(){super(32);T(this,"A",we[0]|0);T(this,"B",we[1]|0);T(this,"C",we[2]|0);T(this,"D",we[3]|0);T(this,"E",we[4]|0);T(this,"F",we[5]|0);T(this,"G",we[6]|0);T(this,"H",we[7]|0)}}const Ar=cs(()=>new Ir,pr(1));/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const xt=BigInt(0),dt=BigInt(1);function Ve(r,e=""){if(typeof r!="boolean"){const s=e&&`"${e}" `;throw new Error(s+"expected boolean, got type="+typeof r)}return r}function ds(r){if(typeof r=="bigint"){if(!Ge(r))throw new Error("positive bigint expected, got "+r)}else me(r);return r}function He(r){const e=ds(r).toString(16);return e.length&1?"0"+e:e}function us(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?xt:BigInt("0x"+r)}function Ye(r){return us($e(r))}function hs(r){return us($e(Tr(q(r)).reverse()))}function gt(r,e){me(e),r=ds(r);const s=Ke(r.toString(16).padStart(e*2,"0"));if(s.length!==e)throw new Error("number too large");return s}function ps(r,e){return gt(r,e).reverse()}function Tr(r){return Uint8Array.from(r)}const Ge=r=>typeof r=="bigint"&&xt<=r;function Rr(r,e,s){return Ge(r)&&Ge(e)&&Ge(s)&&e<=r&&r<s}function kr(r,e,s,t){if(!Rr(e,s,t))throw new Error("expected valid "+r+": "+s+" <= n < "+t+", got "+e)}function Pr(r){let e;for(e=0;r>xt;r>>=dt,e+=1);return e}const mt=r=>(dt<<BigInt(r))-dt;function Or(r,e,s){if(me(r,"hashLen"),me(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),u=0;const h=()=>{c.fill(1),l.fill(0),u=0},_=(...y)=>s(l,Se(c,...y)),f=(y=n)=>{l=_(o,y),c=_(),y.length!==0&&(l=_(i,y),c=_())},w=()=>{if(u++>=a)throw new Error("drbg: tried max amount of iterations");let y=0;const R=[];for(;y<e;){c=_();const N=c.slice();R.push(N),y+=c.length}return Se(...R)};return(y,R)=>{h(),f(y);let N;for(;!(N=R(w()));)f();return h(),N}}function wt(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 Ht(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 ne=BigInt(0),te=BigInt(1),Ae=BigInt(2),fs=BigInt(3),_s=BigInt(4),xs=BigInt(5),Cr=BigInt(7),gs=BigInt(8),Nr=BigInt(9),ms=BigInt(16);function le(r,e){const s=r%e;return s>=ne?s:e+s}function ae(r,e,s){let t=r;for(;e-- >ne;)t*=t,t%=s;return t}function Ft(r,e){if(r===ne)throw new Error("invert: expected non-zero number");if(e<=ne)throw new Error("invert: expected positive modulus, got "+e);let s=le(r,e),t=e,n=ne,o=te;for(;s!==ne;){const a=t/s,c=t%s,l=n-o*a;t=s,s=c,n=o,o=l}if(t!==te)throw new Error("invert: does not exist");return le(n,e)}function yt(r,e,s){if(!r.eql(r.sqr(e),s))throw new Error("Cannot find square root")}function ws(r,e){const s=(r.ORDER+te)/_s,t=r.pow(e,s);return yt(r,t,e),t}function Lr(r,e){const s=(r.ORDER-xs)/gs,t=r.mul(e,Ae),n=r.pow(t,s),o=r.mul(e,n),i=r.mul(r.mul(o,Ae),n),a=r.mul(o,r.sub(i,r.ONE));return yt(r,a,e),a}function Dr(r){const e=Xe(r),s=ys(r),t=s(e,e.neg(e.ONE)),n=s(e,t),o=s(e,e.neg(t)),i=(r+Cr)/ms;return(a,c)=>{let l=a.pow(c,i),u=a.mul(l,t);const h=a.mul(l,n),_=a.mul(l,o),f=a.eql(a.sqr(u),c),w=a.eql(a.sqr(h),c);l=a.cmov(l,u,f),u=a.cmov(_,h,w);const E=a.eql(a.sqr(u),c),y=a.cmov(l,u,E);return yt(a,y,c),y}}function ys(r){if(r<fs)throw new Error("sqrt is not defined for small field");let e=r-te,s=0;for(;e%Ae===ne;)e/=Ae,s++;let t=Ae;const n=Xe(r);for(;Gt(n,t)===1;)if(t++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(s===1)return ws;let o=n.pow(t,e);const i=(e+te)/Ae;return function(c,l){if(c.is0(l))return l;if(Gt(c,l)!==1)throw new Error("Cannot find square root");let u=s,h=c.mul(c.ONE,o),_=c.pow(l,e),f=c.pow(l,i);for(;!c.eql(_,c.ONE);){if(c.is0(_))return c.ZERO;let w=1,E=c.sqr(_);for(;!c.eql(E,c.ONE);)if(w++,E=c.sqr(E),w===u)throw new Error("Cannot find square root");const y=te<<BigInt(u-w-1),R=c.pow(h,y);u=w,h=c.sqr(R),_=c.mul(_,h),f=c.mul(f,R)}return f}}function Mr(r){return r%_s===fs?ws:r%gs===xs?Lr:r%ms===Nr?Dr(r):ys(r)}const $r=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Br(r){const e={ORDER:"bigint",BYTES:"number",BITS:"number"},s=$r.reduce((t,n)=>(t[n]="function",t),e);return wt(r,s),r}function Ur(r,e,s){if(s<ne)throw new Error("invalid exponent, negatives unsupported");if(s===ne)return r.ONE;if(s===te)return e;let t=r.ONE,n=e;for(;s>ne;)s&te&&(t=r.mul(t,n)),n=r.sqr(n),s>>=te;return t}function bs(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 Gt(r,e){const s=(r.ORDER-te)/Ae,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 Hr(r,e){e!==void 0&&me(e);const s=e!==void 0?e:r.toString(2).length,t=Math.ceil(s/8);return{nBitLength:s,nByteLength:t}}class Fr{constructor(e,s={}){T(this,"ORDER");T(this,"BITS");T(this,"BYTES");T(this,"isLE");T(this,"ZERO",ne);T(this,"ONE",te);T(this,"_lengths");T(this,"_sqrt");T(this,"_mod");var i;if(e<=ne)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}=Hr(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 le(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return ne<=e&&e<this.ORDER}is0(e){return e===ne}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&te)===te}neg(e){return le(-e,this.ORDER)}eql(e,s){return e===s}sqr(e){return le(e*e,this.ORDER)}add(e,s){return le(e+s,this.ORDER)}sub(e,s){return le(e-s,this.ORDER)}mul(e,s){return le(e*s,this.ORDER)}pow(e,s){return Ur(this,e,s)}div(e,s){return le(e*Ft(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 Ft(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=Mr(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?ps(e,this.BYTES):gt(e,this.BYTES)}fromBytes(e,s=!1){q(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?hs(e):Ye(e);if(a&&(c=le(c,i)),!s&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return bs(this,e)}cmov(e,s,t){return t?s:e}}function Xe(r,e={}){return new Fr(r,e)}function Ss(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 vs(r){const e=Ss(r);return e+Math.ceil(e/2)}function Gr(r,e,s=!1){q(r);const t=r.length,n=Ss(e),o=vs(e);if(t<16||t<o||t>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+t);const i=s?hs(r):Ye(r),a=le(i,e-te)+te;return s?ps(a,n):gt(a,n)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Ne=BigInt(0),Te=BigInt(1);function ze(r,e){const s=e.negate();return r?s:e}function Wt(r,e){const s=bs(r.Fp,e.map(t=>t.Z));return e.map((t,n)=>r.fromAffine(t.toAffine(s[n])))}function Es(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function st(r,e){Es(r,e);const s=Math.ceil(e/r)+1,t=2**(r-1),n=2**r,o=mt(r),i=BigInt(r);return{windows:s,windowSize:t,mask:o,maxNumber:n,shiftBy:i}}function qt(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+=Te);const l=e*t,u=l+Math.abs(a)-1,h=a===0,_=a<0,f=e%2!==0;return{nextN:c,offset:u,isZero:h,isNeg:_,isNegF:f,offsetF:l}}const rt=new WeakMap,Is=new WeakMap;function nt(r){return Is.get(r)||1}function Kt(r){if(r!==Ne)throw new Error("invalid wNAF")}class Wr{constructor(e,s){T(this,"BASE");T(this,"ZERO");T(this,"Fn");T(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>Ne;)s&Te&&(t=t.add(n)),n=n.double(),s>>=Te;return t}precomputeWindow(e,s){const{windows:t,windowSize:n}=st(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=st(e,this.bits);for(let a=0;a<i.windows;a++){const{nextN:c,offset:l,isZero:u,isNeg:h,isNegF:_,offsetF:f}=qt(t,a,i);t=c,u?o=o.add(ze(_,s[f])):n=n.add(ze(h,s[l]))}return Kt(t),{p:n,f:o}}wNAFUnsafe(e,s,t,n=this.ZERO){const o=st(e,this.bits);for(let i=0;i<o.windows&&t!==Ne;i++){const{nextN:a,offset:c,isZero:l,isNeg:u}=qt(t,i,o);if(t=a,!l){const h=s[c];n=n.add(u?h.negate():h)}}return Kt(t),n}getPrecomputes(e,s,t){let n=rt.get(s);return n||(n=this.precomputeWindow(s,e),e!==1&&(typeof t=="function"&&(n=t(n)),rt.set(s,n))),n}cached(e,s,t){const n=nt(e);return this.wNAF(n,this.getPrecomputes(n,e,t),s)}unsafe(e,s,t,n){const o=nt(e);return o===1?this._unsafeLadder(e,s,n):this.wNAFUnsafe(o,this.getPrecomputes(o,e,t),s,n)}createCache(e,s){Es(s,this.bits),Is.set(e,s),rt.delete(e)}hasCache(e){return nt(e)!==1}}function qr(r,e,s,t){let n=e,o=r.ZERO,i=r.ZERO;for(;s>Ne||t>Ne;)s&Te&&(o=o.add(n)),t&Te&&(i=i.add(n)),n=n.double(),s>>=Te,t>>=Te;return{p1:o,p2:i}}function Vt(r,e,s){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Br(e),e}else return Xe(r,{isLE:s})}function Kr(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>Ne))throw new Error(`CURVE.${c} must be positive bigint`)}const n=Vt(e.p,s.Fp,t),o=Vt(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 Vr(r,e){return function(t){const n=r(t);return{secretKey:n,publicKey:e(n)}}}class As{constructor(e,s){T(this,"oHash");T(this,"iHash");T(this,"blockLen");T(this,"outputLen");T(this,"finished",!1);T(this,"destroyed",!1);if(os(e),q(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),Ce(n)}update(e){return Oe(this),this.iHash.update(e),this}digestInto(e){Oe(this),q(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 Ts=(r,e,s)=>new As(r,e).update(s).digest();Ts.create=(r,e)=>new As(r,e);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const zt=(r,e)=>(r+(r>=0?e:-e)/Rs)/e;function zr(r,e,s){const[[t,n],[o,i]]=e,a=zt(i*r,s),c=zt(-n*r,s);let l=r-a*t-c*o,u=-a*n-c*i;const h=l<xe,_=u<xe;h&&(l=-l),_&&(u=-u);const f=mt(Math.ceil(Pr(s)/2))+Pe;if(l<xe||l>=f||u<xe||u>=f)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:h,k1:l,k2neg:_,k2:u}}function ut(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 Ve(s.lowS,"lowS"),Ve(s.prehash,"prehash"),s.format!==void 0&&ut(s.format),s}class jr extends Error{constructor(e=""){super(e)}}const be={Err:jr,_tlv:{encode:(r,e)=>{const{Err:s}=be;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=He(t);if(n.length/2&128)throw new s("tlv.encode: long form length too big");const o=t>127?He(n.length/2|128):"";return He(r)+o+n+e},decode(r,e){const{Err:s}=be;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 u of l)i=i<<8|u;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}=be;if(r<xe)throw new e("integer: negative integers are not allowed");let s=He(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}=be;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}=be,n=q(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:u}=t.decode(2,c);if(u.length)throw new e("invalid signature: left bytes after parsing");return{r:s.decode(a),s:s.decode(l)}},hexFromSig(r){const{_tlv:e,_int:s}=be,t=e.encode(2,s.encode(r.r)),n=e.encode(2,s.encode(r.s)),o=t+n;return e.encode(48,o)}},xe=BigInt(0),Pe=BigInt(1),Rs=BigInt(2),Fe=BigInt(3),Yr=BigInt(4);function Xr(r,e={}){const s=Kr("weierstrass",r,e),{Fp:t,Fn:n}=s;let o=s.CURVE;const{h:i,n:a}=o;wt(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=Ps(t,n);function u(){if(!t.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function h(I,x,g){const{x:v,y:A}=x.toAffine(),C=t.toBytes(v);if(Ve(g,"isCompressed"),g){u();const O=!t.isOdd(A);return Se(ks(O),C)}else return Se(Uint8Array.of(4),C,t.toBytes(A))}function _(I){q(I,void 0,"Point");const{publicKey:x,publicKeyUncompressed:g}=l,v=I.length,A=I[0],C=I.subarray(1);if(v===x&&(A===2||A===3)){const O=t.fromBytes(C);if(!t.isValid(O))throw new Error("bad point: is not on curve, wrong x");const L=E(O);let P;try{P=t.sqrt(L)}catch(Y){const W=Y instanceof Error?": "+Y.message:"";throw new Error("bad point: is not on curve, sqrt error"+W)}u();const D=t.isOdd(P);return(A&1)===1!==D&&(P=t.neg(P)),{x:O,y:P}}else if(v===g&&A===4){const O=t.BYTES,L=t.fromBytes(C.subarray(0,O)),P=t.fromBytes(C.subarray(O,O*2));if(!y(L,P))throw new Error("bad point: is not on curve");return{x:L,y:P}}else throw new Error(`bad point: got length ${v}, expected compressed=${x} or uncompressed=${g}`)}const f=e.toBytes||h,w=e.fromBytes||_;function E(I){const x=t.sqr(I),g=t.mul(x,I);return t.add(t.add(g,t.mul(I,o.a)),o.b)}function y(I,x){const g=t.sqr(x),v=E(I);return t.eql(g,v)}if(!y(o.Gx,o.Gy))throw new Error("bad curve params: generator point");const R=t.mul(t.pow(o.a,Fe),Yr),N=t.mul(t.sqr(o.b),BigInt(27));if(t.is0(t.add(R,N)))throw new Error("bad curve params: a or b");function F(I,x,g=!1){if(!t.isValid(x)||g&&t.is0(x))throw new Error(`bad point coordinate ${I}`);return x}function M(I){if(!(I instanceof z))throw new Error("Weierstrass Point expected")}function V(I){if(!c||!c.basises)throw new Error("no endo");return zr(I,c.basises,n.ORDER)}const G=Ht((I,x)=>{const{X:g,Y:v,Z:A}=I;if(t.eql(A,t.ONE))return{x:g,y:v};const C=I.is0();x==null&&(x=C?t.ONE:t.inv(A));const O=t.mul(g,x),L=t.mul(v,x),P=t.mul(A,x);if(C)return{x:t.ZERO,y:t.ZERO};if(!t.eql(P,t.ONE))throw new Error("invZ was invalid");return{x:O,y:L}}),J=Ht(I=>{if(I.is0()){if(e.allowInfinityPoint&&!t.is0(I.Y))return;throw new Error("bad point: ZERO")}const{x,y:g}=I.toAffine();if(!t.isValid(x)||!t.isValid(g))throw new Error("bad point: x or y not field elements");if(!y(x,g))throw new Error("bad point: equation left != right");if(!I.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function H(I,x,g,v,A){return g=new z(t.mul(g.X,I),g.Y,g.Z),x=ze(v,x),g=ze(A,g),x.add(g)}const S=class S{constructor(x,g,v){T(this,"X");T(this,"Y");T(this,"Z");this.X=F("x",x),this.Y=F("y",g,!0),this.Z=F("z",v),Object.freeze(this)}static CURVE(){return o}static fromAffine(x){const{x:g,y:v}=x||{};if(!x||!t.isValid(g)||!t.isValid(v))throw new Error("invalid affine point");if(x instanceof S)throw new Error("projective point not allowed");return t.is0(g)&&t.is0(v)?S.ZERO:new S(g,v,t.ONE)}static fromBytes(x){const g=S.fromAffine(w(q(x,void 0,"point")));return g.assertValidity(),g}static fromHex(x){return S.fromBytes(Ke(x))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(x=8,g=!0){return b.createCache(this,x),g||this.multiply(Fe),this}assertValidity(){J(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:g,Y:v,Z:A}=this,{X:C,Y:O,Z:L}=x,P=t.eql(t.mul(g,L),t.mul(C,A)),D=t.eql(t.mul(v,L),t.mul(O,A));return P&&D}negate(){return new S(this.X,t.neg(this.Y),this.Z)}double(){const{a:x,b:g}=o,v=t.mul(g,Fe),{X:A,Y:C,Z:O}=this;let L=t.ZERO,P=t.ZERO,D=t.ZERO,U=t.mul(A,A),Y=t.mul(C,C),W=t.mul(O,O),B=t.mul(A,C);return B=t.add(B,B),D=t.mul(A,O),D=t.add(D,D),L=t.mul(x,D),P=t.mul(v,W),P=t.add(L,P),L=t.sub(Y,P),P=t.add(Y,P),P=t.mul(L,P),L=t.mul(B,L),D=t.mul(v,D),W=t.mul(x,W),B=t.sub(U,W),B=t.mul(x,B),B=t.add(B,D),D=t.add(U,U),U=t.add(D,U),U=t.add(U,W),U=t.mul(U,B),P=t.add(P,U),W=t.mul(C,O),W=t.add(W,W),U=t.mul(W,B),L=t.sub(L,U),D=t.mul(W,Y),D=t.add(D,D),D=t.add(D,D),new S(L,P,D)}add(x){M(x);const{X:g,Y:v,Z:A}=this,{X:C,Y:O,Z:L}=x;let P=t.ZERO,D=t.ZERO,U=t.ZERO;const Y=o.a,W=t.mul(o.b,Fe);let B=t.mul(g,C),X=t.mul(v,O),Z=t.mul(A,L),oe=t.add(g,v),K=t.add(C,O);oe=t.mul(oe,K),K=t.add(B,X),oe=t.sub(oe,K),K=t.add(g,A);let Q=t.add(C,L);return K=t.mul(K,Q),Q=t.add(B,Z),K=t.sub(K,Q),Q=t.add(v,A),P=t.add(O,L),Q=t.mul(Q,P),P=t.add(X,Z),Q=t.sub(Q,P),U=t.mul(Y,K),P=t.mul(W,Z),U=t.add(P,U),P=t.sub(X,U),U=t.add(X,U),D=t.mul(P,U),X=t.add(B,B),X=t.add(X,B),Z=t.mul(Y,Z),K=t.mul(W,K),X=t.add(X,Z),Z=t.sub(B,Z),Z=t.mul(Y,Z),K=t.add(K,Z),B=t.mul(X,K),D=t.add(D,B),B=t.mul(Q,K),P=t.mul(oe,P),P=t.sub(P,B),B=t.mul(oe,X),U=t.mul(Q,U),U=t.add(U,B),new S(P,D,U)}subtract(x){return this.add(x.negate())}is0(){return this.equals(S.ZERO)}multiply(x){const{endo:g}=e;if(!n.isValidNot0(x))throw new Error("invalid scalar: out of range");let v,A;const C=O=>b.cached(this,O,L=>Wt(S,L));if(g){const{k1neg:O,k1:L,k2neg:P,k2:D}=V(x),{p:U,f:Y}=C(L),{p:W,f:B}=C(D);A=Y.add(B),v=H(g.beta,U,W,O,P)}else{const{p:O,f:L}=C(x);v=O,A=L}return Wt(S,[v,A])[0]}multiplyUnsafe(x){const{endo:g}=e,v=this;if(!n.isValid(x))throw new Error("invalid scalar: out of range");if(x===xe||v.is0())return S.ZERO;if(x===Pe)return v;if(b.hasCache(this))return this.multiply(x);if(g){const{k1neg:A,k1:C,k2neg:O,k2:L}=V(x),{p1:P,p2:D}=qr(S,v,C,L);return H(g.beta,P,D,A,O)}else return b.unsafe(v,x)}toAffine(x){return G(this,x)}isTorsionFree(){const{isTorsionFree:x}=e;return i===Pe?!0:x?x(S,this):b.unsafe(this,a).is0()}clearCofactor(){const{clearCofactor:x}=e;return i===Pe?this:x?x(S,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(x=!0){return Ve(x,"isCompressed"),this.assertValidity(),f(S,this,x)}toHex(x=!0){return $e(this.toBytes(x))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}};T(S,"BASE",new S(o.Gx,o.Gy,t.ONE)),T(S,"ZERO",new S(t.ZERO,t.ONE,t.ZERO)),T(S,"Fp",t),T(S,"Fn",n);let z=S;const k=n.BITS,b=new Wr(z,e.endo?Math.ceil(k/2):k);return z.BASE.precompute(8),z}function ks(r){return Uint8Array.of(r?2:3)}function Ps(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function Jr(r,e={}){const{Fn:s}=r,t=e.randomBytes||ls,n=Object.assign(Ps(r.Fp,s),{seed:vs(s.ORDER)});function o(f){try{const w=s.fromBytes(f);return s.isValidNot0(w)}catch{return!1}}function i(f,w){const{publicKey:E,publicKeyUncompressed:y}=n;try{const R=f.length;return w===!0&&R!==E||w===!1&&R!==y?!1:!!r.fromBytes(f)}catch{return!1}}function a(f=t(n.seed)){return Gr(q(f,n.seed,"seed"),s.ORDER)}function c(f,w=!0){return r.BASE.multiply(s.fromBytes(f)).toBytes(w)}function l(f){const{secretKey:w,publicKey:E,publicKeyUncompressed:y}=n;if(!_t(f)||"_lengths"in s&&s._lengths||w===E)return;const R=q(f,void 0,"key").length;return R===E||R===y}function u(f,w,E=!0){if(l(f)===!0)throw new Error("first arg must be private key");if(l(w)===!1)throw new Error("second arg must be public key");const y=s.fromBytes(f);return r.fromBytes(w).multiply(y).toBytes(E)}const h={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},_=Vr(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:u,keygen:_,Point:r,utils:h,lengths:n})}function Zr(r,e,s={}){os(e),wt(s,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),s=Object.assign({},s);const t=s.randomBytes||ls,n=s.hmac||((x,g)=>Ts(e,x,g)),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:u,getSharedSecret:h,utils:_,lengths:f}=Jr(r,s),w={prehash:!0,lowS:typeof s.lowS=="boolean"?s.lowS:!0,format:"compact",extraEntropy:!1},E=a*Rs<o.ORDER;function y(x){const g=a>>Pe;return x>g}function R(x,g){if(!i.isValidNot0(g))throw new Error(`invalid signature ${x}: out of range 1..Point.Fn.ORDER`);return g}function N(){if(E)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function F(x,g){ut(g);const v=f.signature,A=g==="compact"?v:g==="recovered"?v+1:void 0;return q(x,A)}class M{constructor(g,v,A){T(this,"r");T(this,"s");T(this,"recovery");if(this.r=R("r",g),this.s=R("s",v),A!=null){if(N(),![0,1,2,3].includes(A))throw new Error("invalid recovery id");this.recovery=A}Object.freeze(this)}static fromBytes(g,v=w.format){F(g,v);let A;if(v==="der"){const{r:P,s:D}=be.toSig(q(g));return new M(P,D)}v==="recovered"&&(A=g[0],v="compact",g=g.subarray(1));const C=f.signature/2,O=g.subarray(0,C),L=g.subarray(C,C*2);return new M(i.fromBytes(O),i.fromBytes(L),A)}static fromHex(g,v){return this.fromBytes(Ke(g),v)}assertRecovery(){const{recovery:g}=this;if(g==null)throw new Error("invalid recovery id: must be present");return g}addRecoveryBit(g){return new M(this.r,this.s,g)}recoverPublicKey(g){const{r:v,s:A}=this,C=this.assertRecovery(),O=C===2||C===3?v+a:v;if(!o.isValid(O))throw new Error("invalid recovery id: sig.r+curve.n != R.x");const L=o.toBytes(O),P=r.fromBytes(Se(ks((C&1)===0),L)),D=i.inv(O),U=G(q(g,void 0,"msgHash")),Y=i.create(-U*D),W=i.create(A*D),B=r.BASE.multiplyUnsafe(Y).add(P.multiplyUnsafe(W));if(B.is0())throw new Error("invalid recovery: point at infinify");return B.assertValidity(),B}hasHighS(){return y(this.s)}toBytes(g=w.format){if(ut(g),g==="der")return Ke(be.hexFromSig(this));const{r:v,s:A}=this,C=i.toBytes(v),O=i.toBytes(A);return g==="recovered"?(N(),Se(Uint8Array.of(this.assertRecovery()),C,O)):Se(C,O)}toHex(g){return $e(this.toBytes(g))}}const V=s.bits2int||function(g){if(g.length>8192)throw new Error("input is too large");const v=Ye(g),A=g.length*8-c;return A>0?v>>BigInt(A):v},G=s.bits2int_modN||function(g){return i.create(V(g))},J=mt(c);function H(x){return kr("num < 2^"+c,x,xe,J),i.toBytes(x)}function z(x,g){return q(x,void 0,"message"),g?q(e(x),void 0,"prehashed message"):x}function k(x,g,v){const{lowS:A,prehash:C,extraEntropy:O}=ot(v,w);x=z(x,C);const L=G(x),P=i.fromBytes(g);if(!i.isValidNot0(P))throw new Error("invalid private key");const D=[H(P),H(L)];if(O!=null&&O!==!1){const B=O===!0?t(f.secretKey):O;D.push(q(B,void 0,"extraEntropy"))}const U=Se(...D),Y=L;function W(B){const X=V(B);if(!i.isValidNot0(X))return;const Z=i.inv(X),oe=r.BASE.multiply(X).toAffine(),K=i.create(oe.x);if(K===xe)return;const Q=i.create(Z*i.create(Y+K*P));if(Q===xe)return;let Et=(oe.x===K?0:2)|Number(oe.y&Pe),It=Q;return A&&y(Q)&&(It=i.neg(Q),Et^=1),new M(K,It,E?void 0:Et)}return{seed:U,k2sig:W}}function b(x,g,v={}){const{seed:A,k2sig:C}=k(x,g,v);return Or(e.outputLen,i.BYTES,n)(A,C).toBytes(v.format)}function S(x,g,v,A={}){const{lowS:C,prehash:O,format:L}=ot(A,w);if(v=q(v,void 0,"publicKey"),g=z(g,O),!_t(x)){const P=x instanceof M?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+P)}F(x,L);try{const P=M.fromBytes(x,L),D=r.fromBytes(v);if(C&&P.hasHighS())return!1;const{r:U,s:Y}=P,W=G(g),B=i.inv(Y),X=i.create(W*B),Z=i.create(U*B),oe=r.BASE.multiplyUnsafe(X).add(D.multiplyUnsafe(Z));return oe.is0()?!1:i.create(oe.x)===U}catch{return!1}}function I(x,g,v={}){const{prehash:A}=ot(v,w);return g=z(g,A),M.fromBytes(x,"recovered").recoverPublicKey(g).toBytes()}return Object.freeze({keygen:l,getPublicKey:u,getSharedSecret:h,utils:_,lengths:f,Point:r,sign:b,verify:S,recoverPublicKey:I,Signature:M,hash:e})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const bt={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Qr={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},jt=BigInt(2);function en(r){const e=bt.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,u=l*l*r%e,h=ae(u,s,e)*u%e,_=ae(h,s,e)*u%e,f=ae(_,jt,e)*l%e,w=ae(f,n,e)*f%e,E=ae(w,o,e)*w%e,y=ae(E,a,e)*E%e,R=ae(y,c,e)*y%e,N=ae(R,a,e)*E%e,F=ae(N,s,e)*u%e,M=ae(F,i,e)*w%e,V=ae(M,t,e)*l%e,G=ae(V,jt,e);if(!ht.eql(ht.sqr(G),r))throw new Error("Cannot find square root");return G}const ht=Xe(bt.p,{sqrt:en}),tn=Xr(bt,{Fp:ht,endo:Qr}),sn=Zr(tn,Ar),rn=BigInt(0),Le=BigInt(1),nn=BigInt(2),on=BigInt(7),an=BigInt(256),cn=BigInt(113),Os=[],Cs=[],Ns=[];for(let r=0,e=Le,s=1,t=0;r<24;r++){[s,t]=[t,(2*s+3*t)%5],Os.push(2*(5*t+s)),Cs.push((r+1)*(r+2)/2%64);let n=rn;for(let o=0;o<7;o++)e=(e<<Le^(e>>on)*cn)%an,e&nn&&(n^=Le<<(Le<<BigInt(o))-Le);Ns.push(n)}const Ls=mr(Ns,!0),ln=Ls[0],dn=Ls[1],Yt=(r,e,s)=>s>32?br(r,e,s):wr(r,e,s),Xt=(r,e,s)=>s>32?Sr(r,e,s):yr(r,e,s);function un(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],u=s[c+1],h=Yt(l,u,1)^s[a],_=Xt(l,u,1)^s[a+1];for(let f=0;f<50;f+=10)r[i+f]^=h,r[i+f+1]^=_}let n=r[2],o=r[3];for(let i=0;i<24;i++){const a=Cs[i],c=Yt(n,o,a),l=Xt(n,o,a),u=Os[i];n=r[u],o=r[u+1],r[u]=c,r[u+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]^=ln[t],r[1]^=dn[t]}Ce(s)}class St{constructor(e,s,t,n=!1,o=24){T(this,"state");T(this,"pos",0);T(this,"posOut",0);T(this,"finished",!1);T(this,"state32");T(this,"destroyed",!1);T(this,"blockLen");T(this,"suffix");T(this,"outputLen");T(this,"enableXOF",!1);T(this,"rounds");if(this.blockLen=e,this.suffix=s,this.outputLen=t,this.enableXOF=n,this.rounds=o,me(t,"outputLen"),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=cr(this.state)}clone(){return this._cloneInto()}keccak(){$t(this.state32),un(this.state32,this.rounds),$t(this.state32),this.posOut=0,this.pos=0}update(e){Oe(this),q(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){Oe(this,!1),q(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 me(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(is(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,Ce(this.state)}_cloneInto(e){const{blockLen:s,suffix:t,outputLen:n,rounds:o,enableXOF:i}=this;return e||(e=new St(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 hn=(r,e,s,t={})=>cs(()=>new St(e,r,s),t),Jt=hn(1,136,32),pn=60;class fn{constructor(){this.jwks=null}setJWKSEndpoint(e){try{this.jwks=Ze.createRemoteJWKSet(new URL(e)),d.log("[CROSSx] JWKS 엔드포인트 설정:",e)}catch(s){d.warn("[CROSSx] JWKS 엔드포인트 URL 파싱 실패:",s)}}async verifyJWT(e,s){try{const t=this.decodeJWT(e);d.log("[CROSSx] JWT 디코딩 성공:",{sub:t.sub,exp:t.exp,iat:t.iat});const n=Math.floor(Date.now()/1e3);if(t.exp&&t.exp+pn<n)return d.warn("[CROSSx] 토큰 만료:",{exp:t.exp,now:n,만료시간:new Date(t.exp*1e3).toISOString()}),{payload:t,valid:!1,signatureVerified:!1};if(!t.sub)return d.warn("[CROSSx] JWT에 sub(사용자ID) 없음"),{payload:t,valid:!1,signatureVerified:!1};if(this.jwks)try{const{payload:o}=await Ze.jwtVerify(e,this.jwks,{algorithms:["RS256","ES256"]});return d.log("[CROSSx] JWT 서명 검증 성공"),{payload:o,valid:!0,signatureVerified:!0}}catch(o){if(o instanceof Error&&(o.name==="JWSSignatureVerificationFailed"||o.name==="JWTClaimValidationFailed"))return d.error("[CROSSx] JWT 서명 검증 실패:",o),{payload:t,valid:!1,signatureVerified:!1};d.warn("[CROSSx] JWKS 엔드포인트 접근 불가 — 서명 미검증 모드로 전환")}return d.log("[CROSSx] JWT 검증 성공 (서명 미검증 — JWKS 미설정 또는 접근 불가)"),{payload:t,valid:!0,signatureVerified:!1}}catch(t){throw d.error("[CROSSx] JWT 검증 중 에러:",t),t}}decodeJWT(e){return Ze.decodeJwt(e)}recoverPersonalSignSigner(e,s){const t=new TextEncoder().encode(e),n=new TextEncoder().encode(`Ethereum Signed Message:
12
+ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);const i=Jt(o),a=s.startsWith("0x")?s.slice(2):s;if(a.length!==130)throw new Error(`서명 길이가 유효하지 않습니다: 130 hex 문자 예상, 현재 ${a.length}`);const c=_n(a),l=c.slice(0,32),u=c.slice(32,64),h=c[64],_=h>=27?h-27:h,E=new sn.Signature(Zt(l),Zt(u)).addRecoveryBit(_).recoverPublicKey(i).toBytes(!1).slice(1),y=Jt(E);return"0x"+$e(y.slice(12))}}function _n(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 xn=3e4,gn=1e3;class mn{async request(e){const s=e.retries??0;for(let t=0;t<=s;t++){try{const n=await this._doRequest(e);if(n.status<500||t===s)return n}catch(n){if(t===s)throw n}await new Promise(n=>setTimeout(n,gn*2**t))}throw new Error("Unexpected: retry loop exited without result")}async _doRequest(e){const s=new AbortController,t=setTimeout(()=>s.abort(),e.timeoutMs??xn);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)}}}const wn=new Set(["https://cross-wallet-oauth.crosstoken.io","https://stg-cross-wallet-oauth.crosstoken.io","https://dev-cross-wallet-oauth.crosstoken.io"]);class Ie{static generateRandom16Hex(){const e=new Uint8Array(16);return crypto.getRandomValues(e),Array.from(e,s=>s.toString(16).padStart(2,"0")).join("")}static parseJwtPayload(e){const s=e.split(".");if(s.length<2)throw new Error("Invalid JWT format");const t=(s[1]??"").replace(/-/g,"+").replace(/_/g,"/"),n=atob(t);return JSON.parse(n)}static async sha256Hex(e){const s=new TextEncoder().encode(e),t=await crypto.subtle.digest("SHA-256",s);return Array.from(new Uint8Array(t),n=>n.toString(16).padStart(2,"0")).join("")}static async verifyIdTokenNonce(e,s){const t=Ie.parseJwtPayload(e),n=t.nonce,o=typeof t.iss=="string"?t.iss:"(unknown)";if(d.log("[CROSSx] nonce 검증 시작 —",{iss:o,nonceClaimType:typeof n,nonceClaimPresent:typeof n=="string"&&n!=="",appleNonceSupported:t.nonce_supported??"(field absent)"}),o.includes("securetoken.google.com")){d.log("[CROSSx] Firebase ID Token 감지 — nonce 검증 skip.","서버 측에서 Google/Apple nonce 검증이 완료된 것으로 간주합니다.");return}if(typeof n!="string"||n===""){d.warn("[CROSSx] nonce claim 누락 — nonce 검증 skip.",{iss:o,keys:Object.keys(t)});return}if(o.includes("appleid.apple.com")){const i=await Ie.sha256Hex(s);if(d.log("[CROSSx] Apple nonce 검증 —",{expectedHashLength:i.length,receivedHashLength:n.length,match:n===i}),n!==i)throw new Error("ID Token nonce 불일치 — replay attack 가능성이 있습니다")}else if(d.log("[CROSSx] Google nonce 검증 —",{expectedLength:s.length,receivedLength:n.length,match:n===s}),n!==s)throw new Error("ID Token nonce 불일치 — replay attack 가능성이 있습니다");d.log("[CROSSx] nonce 검증 성공 —",{iss:o})}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=Ie.generateRandom16Hex(),l=Ie.generateRandom16Hex(),u=e.authUrl.includes("?")?"&":"?",h=`${e.authUrl}${u}state=${c}&nonce=${l}`;d.log("[CROSSx] OAuth 팝업 열기 — state, nonce 생성 완료:",{stateLength:c.length,nonceLength:l.length,authUrlBase:e.authUrl});const _=window.open(h,"CROSSx OAuth",`width=${n},height=${o},left=${i},top=${a}`);if(!_){t(new Error("팝업 창을 열 수 없습니다. 팝업 차단을 해제해 주세요."));return}const f=setTimeout(()=>{d.warn("[CROSSx] OAuth 타임아웃 (5분) — postMessage를 수신하지 못했습니다"),M(),t(new Error("Authentication timeout"))},5*60*1e3),w=10,E=30;let y=0,R=null;const N=()=>{clearInterval(F),d.warn("[CROSSx] COOP 감지 — OAuth 서버 응답을 "+E+"초간 대기합니다"),R=setTimeout(()=>{M(),t(new Error("OAuth 서버로부터 응답을 받지 못했습니다. 브라우저 보안 정책(COOP)으로 인해 팝업 통신이 차단되었을 수 있습니다. 다시 시도해 주세요."))},E*1e3)},F=setInterval(()=>{y++;try{_.closed&&(y<=w?N():(M(),t(new Error("로그인이 취소되었습니다"))))}catch{N()}},1e3),M=()=>{clearTimeout(f),clearInterval(F),R&&clearTimeout(R),window.removeEventListener("message",V)},V=G=>{if(G.origin!==e.expectedOrigin)return;if(!wn.has(G.origin)){d.error("[CROSSx] postMessage origin이 허용 목록에 없음:",G.origin),M(),t(new Error("Unauthorized OAuth origin"));return}M();const J=typeof G.data.status=="string",H=J?G.data.data??{}:G.data;d.log("[CROSSx] OAuth postMessage 수신 —",{format:J?"wrapped":"flat",status:J?G.data.status:"(flat)"});const z=(H==null?void 0:H.state)??G.data.state;if(!z||z!==c){t(new Error("OAuth state mismatch — possible CSRF attack"));return}if(J&&G.data.status!=="success"){d.error("[CROSSx] OAuth 실패:",H==null?void 0:H.error),t(new Error((H==null?void 0:H.error)||"Authentication failed"));return}if(!J&&(H!=null&&H.error)){d.error("[CROSSx] OAuth 실패:",H.error),t(new Error(H.error||"Authentication failed"));return}const k=H==null?void 0:H.idToken,b=H==null?void 0:H.accessToken,S=b??k;if(d.log("[CROSSx] OAuth 토큰 수신:",{hasAccessToken:!!b,hasIdToken:!!k}),!S){d.error("[CROSSx] 토큰을 찾을 수 없음:",G.data),t(new Error("Token not found in response"));return}const I=x=>{Ie.verifyIdTokenNonce(x,l).then(()=>s(S)).catch(g=>{d.error("[CROSSx] nonce 검증 실패:",g),t(g instanceof Error?g:new Error("nonce verification failed"))})};b?b.split(".").length===3?I(b):k?I(k):(d.warn("[CROSSx] opaque accessToken만 수신 (idToken 없음) — nonce 검증 불가.","서버 측 nonce 검증이 필요합니다."),s(S)):k?I(k):t(new Error("Token not found in response"))};window.addEventListener("message",V)})}}const De="crossx_wallet_data",Re="crossx_mock_pin_hash";class yn{constructor(e,s){this.storage=e,this.pinStore=s??null}async checkWallet(){if(this.migrateScenario!==void 0)return d.log("[Mock] checkWallet → migration_required"),"migration_required";const s=await this.storage.get(De)?"exists":"not_found";return d.log(`[Mock] checkWallet → ${s}`),s}async getOrCreateWallet(e){var s;try{const t=await this.storage.get(De);if(t)return t;const n={id:e,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};await this.storage.set(De,n);const o=(s=this.pinStore)==null?void 0:s.get();return o&&(await this.storage.set(Re,o),d.log("[Mock] 지갑 생성 — PIN 저장됨")),n}catch(t){throw new m(p.WALLET_CREATION_FAILED,"지갑 생성에 실패했습니다",t)}}async getAddresses(e){const s=await this.storage.get(De);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 d.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 d.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 d.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){d.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 d.log(`[Mock] sendTransaction chainId=${s} uuid=${n}:`,t),{txHash:"0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}async verifyPin(e){var t;if(d.log("[Mock] verifyPin"),this.pinScenario==="wrong")return!1;const s=await this.storage.get(Re);return s&&s!==e?!1:(s||await this.storage.set(Re,e),(t=this.pinStore)==null||t.set(e),d.log("[Mock] verifyPin → 성공"),!0)}async changePin(e,s){var o;if(d.log("[Mock] changePin"),this.pinScenario==="wrong")throw new m(p.PIN_WRONG,"Incorrect PIN.");const t=(o=this.pinStore)==null?void 0:o.get(),n=await this.storage.get(Re);if(n&&t&&n!==t)throw new m(p.PIN_WRONG,"Incorrect PIN.");await this.storage.set(Re,s),d.log("[Mock] changePin 완료")}async migrateWallet(e,s){var o;if(d.log(`[Mock] migrateWallet pin=${e} sub=${s}`),this.migrateScenario==="wrong_pin")throw new m(p.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(p.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(De,t);const n=(o=this.pinStore)==null?void 0:o.get();return n&&(await this.storage.set(Re,n),d.log("[Mock] 마이그레이션 — PIN 저장됨")),t}async getShareC(){return d.log("[Mock] getShareC"),"mock-share-c-"+crypto.randomUUID()}async verifyRecoveryPin(e,s){return d.log("[Mock] verifyRecoveryPin"),{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,n,o){this._refreshPromise=null,this._walletStatusCache=null,this.adapterConfig=e,this.projectId=e.projectId,this.storage=s,this.transport=t,this.tokenStore=n,this.pinStore=o??null}setOnUnauthorized(e){this._onUnauthorized=e}setTokenRefresher(e){this._onTokenRefresh=e}getPin(){var e;return((e=this.pinStore)==null?void 0:e.get())??void 0}get baseUrl(){return this.adapterConfig.gatewayUrl}async ensureValidToken(){const e=this.tokenStore.get();if(e&&!this.tokenStore.isExpiringSoon(Dt))return e;const s=!e||this.tokenStore.isExpiringSoon(Dt);if(this._onTokenRefresh){if(await this.deduplicatedRefresh()){const n=this.tokenStore.get();if(n)return n}if(s)throw new m(p.SESSION_EXPIRED,"인증 세션이 만료되었습니다. 다시 로그인해 주세요.")}if(e)return d.warn("[CROSSx] 토큰 갱신 실패 — 기존 토큰으로 요청 시도"),e;throw new m(p.SESSION_EXPIRED,"인증 세션이 만료되었습니다. 다시 로그인해 주세요.")}deduplicatedRefresh(){return this._refreshPromise?this._refreshPromise:(d.log("[CROSSx] 토큰 만료 임박/만료 — 자동 갱신 시도"),this._refreshPromise=this._onTokenRefresh().finally(()=>{this._refreshPromise=null}),this._refreshPromise)}async request(e,s,t,n=!1){var c,l,u;const o=await this.ensureValidToken(),i=`${this.baseUrl}${s}`,a={Authorization:`Bearer ${o}`,"Content-Type":"application/json","X-Project-Id":this.projectId};try{const _=(await this.transport.request({url:i,method:e,headers:a,body:t??void 0})).data;if(_&&typeof _.code=="number"){if(_.code<0||_.code>=400){const f=_.message||_.data||"API 요청에 실패했습니다";d.error("[CROSSx] Wallet Gateway API 에러 (HTTP 200):",{code:_.code,message:f,url:i,method:e});const w=ke.mapGatewayError(_.code,_.data);if(w===p.AUTH_NOT_AUTHENTICATED&&!n&&this._onTokenRefresh){if(d.warn("[CROSSx] Gateway -10002 감지 — 토큰 갱신 후 재시도"),await this.deduplicatedRefresh())return this.request(e,s,t,!0);throw new m(p.SESSION_EXPIRED,"인증 세션이 만료되었습니다. 다시 로그인해 주세요.")}const E=w===p.AUTH_NOT_AUTHENTICATED?p.SESSION_EXPIRED:w,y=E===p.SESSION_EXPIRED?"인증 세션이 만료되었습니다. 다시 로그인해 주세요.":ke.getGatewayErrorMessage(_.code,f),R=_.data,N=w===p.PIN_LOCKED?ke.extractLockDetails(R):R??void 0;throw new m(E,y,N)}return d.log("[CROSSx] Wallet Gateway API 성공:",{code:_.code,url:i,method:e}),_.data??_}return _}catch(h){if(h instanceof m)throw h;const _=((c=h.response)==null?void 0:c.status)??h.status;if((_===401||_===403)&&!n&&this._onTokenRefresh){if(d.warn(`[CROSSx] HTTP ${_} 감지 — 토큰 갱신 후 재시도`),await this.deduplicatedRefresh())return this.request(e,s,t,!0);throw new m(p.SESSION_EXPIRED,"인증 세션이 만료되었습니다. 다시 로그인해 주세요.")}if((l=h.response)!=null&&l.data){const f=h.response.data,w=f.message||f.data||"API 요청에 실패했습니다",E=f.code||"UNKNOWN";throw d.error("[CROSSx] Wallet Gateway API 에러 (HTTP 에러):",{code:E,message:w,url:i,method:e,status:(u=h.response)==null?void 0:u.status}),new m(p.UNKNOWN_ERROR,`Wallet Gateway 오류 (${E}): ${w}`)}throw h}}async checkWallet(){d.log("[CROSSx] GET /mnemonic/check");const e=await this.request("GET","/mnemonic/check");return d.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,d.log("[CROSSx] getOrCreateWallet — 캐시된 상태 사용:",s)):(d.log("[CROSSx] GET /mnemonic/check — 지갑 상태 확인"),s=await this.checkWallet(),this._walletStatusCache=null),s==="migration_required")throw d.log("[CROSSx] migration_required → MIGRATION_BACKUP_EXISTS throw"),new m(p.MIGRATION_BACKUP_EXISTS,"CROSSx 백업이 존재합니다. 마이그레이션을 진행해 주세요.");if(s==="exists"){d.log("[CROSSx] 기존 지갑 발견 — POST /mnemonic/address(0)로 주소 조회");const o=await this.getAddress(e,0);return d.log("[CROSSx] 주소 조회 완료 — address:",o.address),{id:e,address:o.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}d.log("[CROSSx] POST /mnemonic/create — 신규 지갑 생성");const t={ignoreBackup:!1,password:this.requirePin()},n=await this.request("POST","/mnemonic/create",t);return d.log("[CROSSx] /mnemonic/create 완료 — address:",n.address),{id:e,address:n.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.requirePin(),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(p.TX_INVALID_PARAMS,"prepare: tx가 필요합니다");t={unsignedTx:this.buildUnsignedTx(s.tx)};break;case"sign-message":if(!s.message)throw new m(p.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(p.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,password:this.requirePin()};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,password:this.requirePin()};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),password:this.requirePin()};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),password:this.requirePin()};return n&&(o.uuid=n),{txHash:(await this.request("POST",`/mnemonic/send/${encodeURIComponent(s)}`,o)).txHash}}async migrateWallet(e,s){d.log("[CROSSx][Migration Phase 4] POST /mnemonic/migrate 호출");const t={recoveryPin:e,sub:s,password:this.requirePin()},n=await this.request("POST","/mnemonic/migrate",t);return d.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()}}async withdrawWallet(e){const s={confirmation:e,password:this.requirePin()};await this.request("POST","/mnemonic/withdraw",s)}async verifyPin(e){const s={password:e};return(await this.request("POST","/mnemonic/verify-password",s)).valid}async changePin(e,s){const t={password:this.requirePin(),newPassword:s};await this.request("POST","/mnemonic/change-password",t)}async getShareC(){const e={password:this.requirePin()};return(await this.request("POST","/mnemonic/share-c",e)).shareC}async verifyRecoveryPin(e,s){const t={recoveryPin:e,sub:s};return this.request("POST","/mnemonic/verify-recovery-pin",t)}requirePin(){const e=this.getPin();if(!e)throw new m(p.PIN_NOT_SET,"PIN이 설정되지 않았습니다. PIN을 입력해 주세요.");return e}static extractLockDetails(e){const s=(e==null?void 0:e.lockStatus)??(e==null?void 0:e.lock_status)??e,t={},n=(s==null?void 0:s.lockExpiresAt)??(s==null?void 0:s.lock_expires_at);n&&(t.lockExpiresAt=n>1e10?n:n*1e3);const o=(s==null?void 0:s.remainingAttempts)??(s==null?void 0:s.remaining_attempts);typeof o=="number"&&(t.remainingAttempts=o);const i=(s==null?void 0:s.maxAttempts)??(s==null?void 0:s.max_attempts);return typeof i=="number"&&(t.maxAttempts=i),typeof(s==null?void 0:s.permanent)=="boolean"&&(t.permanent=s.permanent),t}static hasLockInfo(e){const s=(e==null?void 0:e.lockStatus)??(e==null?void 0:e.lock_status)??e;return!s||typeof s!="object"?!1:typeof s.remainingAttempts=="number"||typeof s.remaining_attempts=="number"||typeof s.maxAttempts=="number"||typeof s.max_attempts=="number"}static mapGatewayError(e,s){switch(e){case-10002:return p.AUTH_NOT_AUTHENTICATED;case-10001:return p.UNKNOWN_ERROR;case-10006:return p.GATEWAY_INTERNAL_ERROR;case-10007:return p.BROADCAST_FAILED;case-10008:return p.GATEWAY_LOCK_CONFLICT;case-10004:return p.WALLET_ALREADY_EXISTS;case-10005:return p.WALLET_NOT_FOUND;case-10011:return p.WALLET_NOT_FOUND;case-10030:return p.WALLET_INCONSISTENT_STATE;case-10010:return p.MIGRATION_FAILED;case-10012:return p.MIGRATION_BACKUP_EXISTS;case-10013:return p.WITHDRAW_FAILED;case-10027:return p.MIGRATION_PIN_LOCKED;case-10022:return p.PROJECT_NOT_REGISTERED;case-10023:return p.PROJECT_ID_MISSING;case-10024:return p.ORIGIN_NOT_ALLOWED;case-10025:return p.INVALID_APP_TYPE;case-10028:return ke.hasLockInfo(s)?p.PIN_LOCKED:p.PIN_WRONG;case-10029:return p.PIN_INVALID;case-10031:return p.PIN_LOCKED;case-10032:return p.PIN_REPEATED_PATTERN;case-10026:return p.TYPED_DATA_CHAIN_ID_MISMATCH;case-10014:case-10015:case-10019:return p.PREPARE_FAILED;case-10016:return p.PREPARE_EXPIRED;case-10017:case-10018:return p.PREPARE_MISMATCH;case-10020:return p.CHAIN_NOT_SUPPORTED;case-10021:return p.INVALID_CHAIN;case-10040:return p.HMAC_REQUIRED;case-10041:return p.HMAC_VERIFICATION_FAILED;default:return p.UNKNOWN_ERROR}}static getGatewayErrorMessage(e,s){switch(e){case-10002:return"Session expired. Please sign in again.";case-10004:return"Wallet already exists for this user.";case-10005:return"User wallet not found.";case-10006:return"Internal server error. Please try again later.";case-10007:return"Transaction broadcast failed. Please try again.";case-10008:return"Another operation is in progress. Please try again later.";case-10013:return"Withdraw failed. Please try again.";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 or App ID is required. Register the current domain or set X-App-Id header.";case-10025:return"Invalid app type. X-App-Type must be android, ios, or windows.";case-10026:return"Domain chainId mismatch: the chainId in typedData.domain does not match the request chainId.";case-10027:return"Too many incorrect PIN attempts. Your account has been temporarily locked.";case-10028:return"Incorrect PIN. Please try again.";case-10029:return"Sequential PIN is not allowed. Please choose a different PIN.";case-10030:return"Wallet is in an inconsistent state. Please contact support.";case-10031:return"Too many failed PIN attempts. Your account is temporarily locked.";case-10032:return"Repeated digit pattern is not allowed. Please choose a different PIN.";case-10040:return"HMAC signature header is required.";case-10041:return"HMAC signature verification failed.";default:return`Request failed (${e}): ${s}`}}}class Me{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=Me.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?nr:rr;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(Me.mapErrorCode(e.code),s)}}fallbackOrThrow(e){const s=Me.fallbackChains().find(t=>t.chainId===e);if(s)return s;throw new m(p.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 p.CHAIN_NOT_SUPPORTED;case-10021:return p.INVALID_CHAIN;case-10022:return p.PROJECT_NOT_REGISTERED;case-10023:return p.PROJECT_ID_MISSING;case-10024:return p.APP_IDENTIFIER_MISSING;case-10025:return p.INVALID_APP_TYPE;default:return p.UNKNOWN_ERROR}}}const Qt="__crossx-confirm-style",se="__crossx-confirm-overlay",bn={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 es(r,e){const s=bn[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 Sn=`
3
13
  @import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600&display=swap');
4
14
 
5
- #${te} {
15
+ #${se} {
6
16
  position: fixed;
7
17
  inset: 0;
8
18
  z-index: 2147483647;
@@ -1166,6 +1176,8 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1166
1176
  max-height: 320px;
1167
1177
  overflow-y: auto;
1168
1178
  -webkit-overflow-scrolling: touch;
1179
+ overscroll-behavior: contain;
1180
+ touch-action: pan-y;
1169
1181
  scrollbar-width: thin;
1170
1182
  }
1171
1183
  .__crossx-wallet-list::-webkit-scrollbar {
@@ -1268,7 +1280,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1268
1280
 
1269
1281
  /* ── Mobile bottom sheet ───────────────────────────────────── */
1270
1282
  @media (max-width: 480px) {
1271
- #${te} { align-items: flex-end; }
1283
+ #${se} { align-items: flex-end; }
1272
1284
  .__crossx-card {
1273
1285
  width: 100%;
1274
1286
  max-width: 100%;
@@ -1280,6 +1292,18 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1280
1292
  }
1281
1293
  .__crossx-card--wallet-selector {
1282
1294
  overflow: hidden !important;
1295
+ display: flex !important;
1296
+ flex-direction: column !important;
1297
+ }
1298
+ .__crossx-card--wallet-selector .__crossx-body {
1299
+ flex: 1;
1300
+ min-height: 0;
1301
+ overflow: hidden;
1302
+ display: flex;
1303
+ flex-direction: column;
1304
+ }
1305
+ .__crossx-card--wallet-selector .__crossx-col-right-ws {
1306
+ min-height: 0;
1283
1307
  }
1284
1308
  .__crossx-card--wallet-selector .__crossx-wallet-list { max-height: 203px; }
1285
1309
  .__crossx-card--send-tx,
@@ -1407,7 +1431,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1407
1431
 
1408
1432
  /* ── Landscape for signing/transaction modals ──────────── */
1409
1433
  @media (orientation: landscape) and (max-height: 500px) {
1410
- #${te} { align-items: center !important; overflow: hidden; }
1434
+ #${se} { align-items: center !important; overflow: hidden; }
1411
1435
  .__crossx-card--send-tx,
1412
1436
  .__crossx-card--sign-tx,
1413
1437
  .__crossx-card--sign-msg,
@@ -1704,6 +1728,24 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1704
1728
  flex-shrink: 0;
1705
1729
  color: var(--cx-error);
1706
1730
  }
1731
+ /* 시도 횟수 카운트 (X/Y) */
1732
+ .__crossx-pin6-attempt {
1733
+ font-size: 16px;
1734
+ font-weight: 500;
1735
+ line-height: 1.5;
1736
+ color: var(--cx-error);
1737
+ text-align: center;
1738
+ letter-spacing: -0.16px;
1739
+ margin: 0;
1740
+ }
1741
+ .__crossx-pin6-warning {
1742
+ font-size: 14px;
1743
+ font-weight: 500;
1744
+ line-height: 1.5;
1745
+ color: var(--cx-error);
1746
+ text-align: center;
1747
+ margin: 0;
1748
+ }
1707
1749
  /* Next 버튼 */
1708
1750
  .__crossx-pin6-next {
1709
1751
  width: 100%;
@@ -1724,31 +1766,31 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1724
1766
  opacity: 0.5;
1725
1767
  cursor: default;
1726
1768
  }
1727
- `;function he(){let r=document.getElementById(Xt);r||(r=document.createElement("style"),r.id=Xt,document.head.appendChild(r)),r.textContent=bn}function pe(r){const e=s=>s.stopPropagation();for(const s of["pointerdown","pointerup","mousedown","mouseup","click","touchstart","touchend"])r.addEventListener(s,e);document.body.appendChild(r)}function se(r){return r?r.length<=13?r:`${r.slice(0,6)}…${r.slice(-4)}`:"—"}function Sn(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=ut(t,s);return n==="0"?null:`${n} ${e}`}catch{return null}}const Qt={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 Ns(r){const e=parseInt(r.split(":")[1]??"",10);return!isNaN(e)&&Qt[e]?Qt[e]:r}function ut(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 ot(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 vn(r){try{return BigInt(r).toLocaleString()}catch{return r}}function En(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=vn(e);if(t){const l=a*BigInt(t);return{isDynamic:!0,estTxFee:`${ut(l,i)} ${o}`,maxFeeGwei:ot(t),maxPriorityFeeGwei:n?ot(n):void 0,gasLimitFormatted:c}}if(s){const l=a*BigInt(s);return{isDynamic:!1,estTxFee:`${ut(l,i)} ${o}`,gasPriceGwei:ot(s),gasLimitFormatted:c}}return{isDynamic:!1,estTxFee:`${a.toLocaleString()} gas`,gasLimitFormatted:c}}catch{return null}}function Ls(r){const e=En(r);if(!e)return Y("Estimated fee","<span>—</span>");let s=Y("Est. Tx Fee",`<span>${e.estTxFee}</span>`);return e.isDynamic?(e.maxPriorityFeeGwei!==void 0&&(s+=Y("Max Priority Fee",`<span>${e.maxPriorityFeeGwei} Gwei</span>`)),e.maxFeeGwei!==void 0&&(s+=Y("Max Gas Fee",`<span>${e.maxFeeGwei} Gwei</span>`))):e.gasPriceGwei!==void 0&&(s+=Y("Gas Price",`<span>${e.gasPriceGwei} Gwei</span>`)),e.gasLimitFormatted&&(s+=Y("Gas Limit",`<span>${e.gasLimitFormatted}</span>`)),s}const ge=`<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
1769
+ `;function he(){let r=document.getElementById(Qt);r||(r=document.createElement("style"),r.id=Qt,document.head.appendChild(r)),r.textContent=Sn}function pe(r){const e=s=>s.stopPropagation();for(const s of["pointerdown","pointerup","mousedown","mouseup","click"])r.addEventListener(s,e);for(const s of["touchstart","touchend"])r.addEventListener(s,e,{passive:!0});document.body.appendChild(r)}const vn=()=>/iPad|iPhone|iPod/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1;function it(){if(vn()){const e=window.scrollY;return document.body.style.position="fixed",document.body.style.top=`-${e}px`,document.body.style.left="0",document.body.style.right="0",()=>{document.body.style.position="",document.body.style.top="",document.body.style.left="",document.body.style.right="",window.scrollTo(0,e)}}const r=document.body.style.overflow;return document.body.style.overflow="hidden",()=>{document.body.style.overflow=r}}function re(r){return r?r.length<=13?r:`${r.slice(0,6)}…${r.slice(-4)}`:"—"}function En(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=pt(t,s);return n==="0"?null:`${n} ${e}`}catch{return null}}const ts={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 Ds(r){const e=parseInt(r.split(":")[1]??"",10);return!isNaN(e)&&ts[e]?ts[e]:r}function pt(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 at(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 In(r){try{return BigInt(r).toLocaleString()}catch{return r}}function An(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=In(e);if(t){const l=a*BigInt(t);return{isDynamic:!0,estTxFee:`${pt(l,i)} ${o}`,maxFeeGwei:at(t),maxPriorityFeeGwei:n?at(n):void 0,gasLimitFormatted:c}}if(s){const l=a*BigInt(s);return{isDynamic:!1,estTxFee:`${pt(l,i)} ${o}`,gasPriceGwei:at(s),gasLimitFormatted:c}}return{isDynamic:!1,estTxFee:`${a.toLocaleString()} gas`,gasLimitFormatted:c}}catch{return null}}function Ms(r){const e=An(r);if(!e)return j("Estimated fee","<span>—</span>");let s=j("Est. Tx Fee",`<span>${e.estTxFee}</span>`);return e.isDynamic?(e.maxPriorityFeeGwei!==void 0&&(s+=j("Max Priority Fee",`<span>${e.maxPriorityFeeGwei} Gwei</span>`)),e.maxFeeGwei!==void 0&&(s+=j("Max Gas Fee",`<span>${e.maxFeeGwei} Gwei</span>`))):e.gasPriceGwei!==void 0&&(s+=j("Gas Price",`<span>${e.gasPriceGwei} Gwei</span>`)),e.gasLimitFormatted&&(s+=j("Gas Limit",`<span>${e.gasLimitFormatted}</span>`)),s}const ge=`<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
1728
1770
  <rect x="9" y="9" width="13" height="13" rx="2"/>
1729
1771
  <path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"/>
1730
1772
  </svg>`,ie=`<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round">
1731
1773
  <line x1="18" y1="6" x2="6" y2="18"/>
1732
1774
  <line x1="6" y1="6" x2="18" y2="18"/>
1733
- </svg>`,In=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1775
+ </svg>`,Tn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1734
1776
  <circle cx="20" cy="20" r="20" fill="#00D5AA"/>
1735
1777
  <path fill-rule="evenodd" clip-rule="evenodd" d="M20.3225 2.85742L23.7249 6.25982V11.8301L28.1175 7.43757L32.9292 12.2493L28.5806 16.5979H20.3225C18.4435 16.5979 16.9201 18.1212 16.9201 20.0003C16.9201 21.8794 18.4434 23.4027 20.3225 23.4027H28.5372L32.9293 27.7948L28.1176 32.6066L23.7249 28.2139V33.7407L20.3225 37.1431L16.9201 33.7407V28.2584L12.5719 32.6066L7.76022 27.7948L12.1524 23.4027H6.58209L3.17969 20.0003L6.58209 16.5979H12.1089L7.76035 12.2493L12.5721 7.43757L16.9201 11.7857V6.25982L20.3225 2.85742Z" fill="#121212"/>
1736
- </svg>`,bt=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
1778
+ </svg>`,vt=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
1737
1779
  <rect x="2" y="5" width="16" height="12" rx="2" stroke="currentColor" stroke-width="1.5"/>
1738
1780
  <path d="M2 9h16" stroke="currentColor" stroke-width="1.5"/>
1739
1781
  <rect x="12.5" y="11.5" width="3.5" height="2.5" rx="0.75" fill="currentColor"/>
1740
- </svg>`,Tn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
1782
+ </svg>`,Rn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
1741
1783
  <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)"/>
1742
- </svg>`,An=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
1784
+ </svg>`,kn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
1743
1785
  <circle cx="12" cy="12" r="12" fill="var(--cx-error)"/>
1744
1786
  <circle cx="12" cy="12" r="5.5" stroke="white" stroke-width="1.5"/>
1745
1787
  <path d="M12 9.5v3l2 1.5" stroke="white" stroke-width="1.5" stroke-linecap="round"/>
1746
- </svg>`;function ce(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 Y(r,e){return`
1788
+ </svg>`;function ce(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 j(r,e){return`
1747
1789
  <div class="__crossx-row">
1748
1790
  <span class="__crossx-row-label">${r}</span>
1749
1791
  <div class="__crossx-row-value">${e}</div>
1750
- </div>`}function Rn(r,e){const s=e,t=Je(r.dappName),n=r.to?`<span class="__crossx-addr-text">${se(r.to)}</span>
1751
- <button class="__crossx-copy-btn" data-copy="${U(r.to)}" title="Copy address">${ge}</button>`:"<span>—</span>",o=Ls(r),i=r.data??"0x",a=document.createElement("div");return a.id=te,a.innerHTML=`
1792
+ </div>`}function Pn(r,e){const s=e,t=Je(r.dappName),n=r.to?`<span class="__crossx-addr-text">${re(r.to)}</span>
1793
+ <button class="__crossx-copy-btn" data-copy="${$(r.to)}" title="Copy address">${ge}</button>`:"<span>—</span>",o=Ms(r),i=r.data??"0x",a=document.createElement("div");return a.id=se,a.innerHTML=`
1752
1794
  <div class="__crossx-card __crossx-card--migration __crossx-card--sign-tx" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1753
1795
  <div class="__crossx-header">
1754
1796
  <p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
@@ -1759,22 +1801,22 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1759
1801
  <div class="__crossx-body-cols">
1760
1802
  <div class="__crossx-col-left">
1761
1803
  <p class="__crossx-sig-subtitle">
1762
- <span class="__crossx-sig-origin">${U(t)} </span>is requesting a Signature
1804
+ <span class="__crossx-sig-origin">${$(t)} </span>is requesting a Signature
1763
1805
  </p>
1764
1806
  <div class="__crossx-addr-pill">
1765
- ${bt}
1766
- <span class="__crossx-addr-pill-text">${se(r.from)}</span>
1807
+ ${vt}
1808
+ <span class="__crossx-addr-pill-text">${re(r.from)}</span>
1767
1809
  </div>
1768
1810
  <p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
1769
1811
  </div>
1770
1812
  <hr class="__crossx-divider __crossx-divider--cols">
1771
1813
  <div class="__crossx-col-right-sign">
1772
1814
  <div class="__crossx-rows">
1773
- ${Y("To",n)}
1774
- ${Y("Network",`<span>${Ns(r.chainId)}</span>`)}
1815
+ ${j("To",n)}
1816
+ ${j("Network",`<span>${Ds(r.chainId)}</span>`)}
1775
1817
  ${o}
1776
1818
  </div>
1777
- <pre class="__crossx-raw-tx">${U(i)}</pre>
1819
+ <pre class="__crossx-raw-tx">${$(i)}</pre>
1778
1820
  </div>
1779
1821
  </div>
1780
1822
  <div class="__crossx-btn-row">
@@ -1783,8 +1825,8 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1783
1825
  </div>
1784
1826
  </div>
1785
1827
  </div>
1786
- `,a}function kn(r,e){const s=e,t=r.nativeSymbol??"ETH",n=r.nativeDecimals??18,o=Je(r.dappName),i=r.to?`<span class="__crossx-addr-text">${se(r.to)}</span>
1787
- <button class="__crossx-copy-btn" data-copy="${U(r.to)}" title="Copy address">${ge}</button>`:"<span>—</span>",a=Ls(r),l=Sn(r.value,t,n)??"—",u=document.createElement("div");return u.id=te,u.innerHTML=`
1828
+ `,a}function On(r,e){const s=e,t=r.nativeSymbol??"ETH",n=r.nativeDecimals??18,o=Je(r.dappName),i=r.to?`<span class="__crossx-addr-text">${re(r.to)}</span>
1829
+ <button class="__crossx-copy-btn" data-copy="${$(r.to)}" title="Copy address">${ge}</button>`:"<span>—</span>",a=Ms(r),l=En(r.value,t,n)??"—",u=document.createElement("div");return u.id=se,u.innerHTML=`
1788
1830
  <div class="__crossx-card __crossx-card--migration __crossx-card--send-tx" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1789
1831
  <div class="__crossx-header">
1790
1832
  <p class="__crossx-title" id="__crossx-ttl">Approve transaction</p>
@@ -1793,29 +1835,29 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1793
1835
  <hr class="__crossx-divider">
1794
1836
  <div class="__crossx-body">
1795
1837
  <p class="__crossx-tx-subtitle">
1796
- <span class="__crossx-sig-origin">${U(o)}</span> wants your permission to approve the following transaction.
1838
+ <span class="__crossx-sig-origin">${$(o)}</span> wants your permission to approve the following transaction.
1797
1839
  </p>
1798
1840
  <div class="__crossx-body-cols">
1799
1841
  <div class="__crossx-rows">
1800
- ${Y("To",i)}
1801
- ${Y("Network",`<span>${Ns(r.chainId)}</span>`)}
1842
+ ${j("To",i)}
1843
+ ${j("Network",`<span>${Ds(r.chainId)}</span>`)}
1802
1844
  ${a}
1803
1845
  </div>
1804
1846
  <div class="__crossx-pill">
1805
- <span class="__crossx-pill-from">${se(r.from)}</span>
1847
+ <span class="__crossx-pill-from">${re(r.from)}</span>
1806
1848
  <span class="__crossx-pill-amount">${l}</span>
1807
1849
  </div>
1808
1850
  </div>
1809
1851
  <button class="__crossx-approve-btn" id="__crossx-confirm-btn">Approve</button>
1810
1852
  </div>
1811
1853
  </div>
1812
- `,u}function Je(r){var e;if(r)return r;try{return((e=window.location)==null?void 0:e.hostname)||"This site"}catch{return"This site"}}function U(r){return r.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function Pn(r){return typeof r=="string"&&/^0x[0-9a-fA-F]{40}$/i.test(r)}function On(r){if(typeof r=="string")return U(r);if(typeof r=="number"||typeof r=="bigint"||typeof r=="boolean")return String(r);try{return U(JSON.stringify(r))}catch{return String(r)}}function Cn(r,e){const s=Y("From",`<span class="__crossx-addr-text">${se(r.from)}</span>
1813
- <button class="__crossx-copy-btn" data-copy="${U(r.from)}" title="Copy address">${ge}</button>`),t=r.to?Y("To",`<span class="__crossx-addr-text">${se(r.to)}</span>
1814
- <button class="__crossx-copy-btn" data-copy="${U(r.to)}" title="Copy address">${ge}</button>`):"",n=r.amount?Y("Transfer",`<span>${U(r.amount)}</span>`):"",o=r.fees?Y("Tx Fee",`<span>${U(r.fees)}</span>`):"",i=r.txHash?Y("Tx Hash",`<span class="__crossx-addr-text">${se(r.txHash)}</span>
1815
- <button class="__crossx-copy-btn" data-copy="${U(r.txHash)}" title="Copy hash">${ge}</button>`):"",a=r.total?`<div class="__crossx-total-pill">
1854
+ `,u}function Je(r){var e;if(r)return r;try{return((e=window.location)==null?void 0:e.hostname)||"This site"}catch{return"This site"}}function $(r){return r.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function Cn(r){return typeof r=="string"&&/^0x[0-9a-fA-F]{40}$/i.test(r)}function Nn(r){if(typeof r=="string")return $(r);if(typeof r=="number"||typeof r=="bigint"||typeof r=="boolean")return String(r);try{return $(JSON.stringify(r))}catch{return String(r)}}function Ln(r,e){const s=j("From",`<span class="__crossx-addr-text">${re(r.from)}</span>
1855
+ <button class="__crossx-copy-btn" data-copy="${$(r.from)}" title="Copy address">${ge}</button>`),t=r.to?j("To",`<span class="__crossx-addr-text">${re(r.to)}</span>
1856
+ <button class="__crossx-copy-btn" data-copy="${$(r.to)}" title="Copy address">${ge}</button>`):"",n=r.amount?j("Transfer",`<span>${$(r.amount)}</span>`):"",o=r.fees?j("Tx Fee",`<span>${$(r.fees)}</span>`):"",i=r.txHash?j("Tx Hash",`<span class="__crossx-addr-text">${re(r.txHash)}</span>
1857
+ <button class="__crossx-copy-btn" data-copy="${$(r.txHash)}" title="Copy hash">${ge}</button>`):"",a=r.total?`<div class="__crossx-total-pill">
1816
1858
  <span class="__crossx-total-label">Total<br>(including fees)</span>
1817
- <span class="__crossx-total-amount">${U(r.total)}</span>
1818
- </div>`:"",c=document.createElement("div");return c.id=te,c.innerHTML=`
1859
+ <span class="__crossx-total-amount">${$(r.total)}</span>
1860
+ </div>`:"",c=document.createElement("div");return c.id=se,c.innerHTML=`
1819
1861
  <div class="__crossx-card __crossx-card--migration" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1820
1862
  <div class="__crossx-header">
1821
1863
  <p class="__crossx-title" id="__crossx-ttl">Transaction complete</p>
@@ -1834,7 +1876,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1834
1876
  <button class="__crossx-approve-btn" id="__crossx-done-btn">All Done</button>
1835
1877
  </div>
1836
1878
  </div>
1837
- `,c}function Nn(r,e){const s=document.createElement("div");return s.id=te,s.innerHTML=`
1879
+ `,c}function Dn(r,e){const s=document.createElement("div");return s.id=se,s.innerHTML=`
1838
1880
  <div class="__crossx-card __crossx-card--migration" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1839
1881
  <div class="__crossx-header">
1840
1882
  <p class="__crossx-title" id="__crossx-ttl">Waiting for confirmation</p>
@@ -1847,12 +1889,12 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1847
1889
  </div>
1848
1890
  </div>
1849
1891
  </div>
1850
- `,s}function Ln(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 w=n?An:t?"":Tn,b=n?"Transaction timeout":t?"Transaction complete":"Transaction failed";w?(o.style.display="flex",o.style.alignItems="center",o.style.gap="8px",o.innerHTML=`${w}<span>${b}</span>`):o.textContent=b}if(i&&!r.querySelector("#__crossx-close-btn")){const w=document.createElement("button");w.className="__crossx-close",w.id="__crossx-close-btn",w.setAttribute("aria-label","Close"),w.innerHTML=ie,i.appendChild(w)}const a=r.querySelector("#__crossx-progress-body");if(!a)return;const c=e.from?Y("From",`<span class="__crossx-addr-text">${se(e.from)}</span>
1851
- <button class="__crossx-copy-btn" data-copy="${U(e.from)}" title="Copy address">${ge}</button>`):"",l=e.to?Y("To",`<span class="__crossx-addr-text">${se(e.to)}</span>
1852
- <button class="__crossx-copy-btn" data-copy="${U(e.to)}" title="Copy address">${ge}</button>`):"",u=e.amount?Y("Transfer",`<span>${U(e.amount)}</span>`):"",h=e.fees?Y("Tx Fee",`<span>${U(e.fees)}</span>`):"",_=e.txHash?Y("Tx Hash",`<span class="__crossx-addr-text">${se(e.txHash)}</span>
1853
- <button class="__crossx-copy-btn" data-copy="${U(e.txHash)}" title="Copy hash">${ge}</button>`):"",f=e.total?`<div class="__crossx-total-pill">
1892
+ `,s}function Mn(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 w=n?kn:t?"":Rn,E=n?"Transaction timeout":t?"Transaction complete":"Transaction failed";w?(o.style.display="flex",o.style.alignItems="center",o.style.gap="8px",o.innerHTML=`${w}<span>${E}</span>`):o.textContent=E}if(i&&!r.querySelector("#__crossx-close-btn")){const w=document.createElement("button");w.className="__crossx-close",w.id="__crossx-close-btn",w.setAttribute("aria-label","Close"),w.innerHTML=ie,i.appendChild(w)}const a=r.querySelector("#__crossx-progress-body");if(!a)return;const c=e.from?j("From",`<span class="__crossx-addr-text">${re(e.from)}</span>
1893
+ <button class="__crossx-copy-btn" data-copy="${$(e.from)}" title="Copy address">${ge}</button>`):"",l=e.to?j("To",`<span class="__crossx-addr-text">${re(e.to)}</span>
1894
+ <button class="__crossx-copy-btn" data-copy="${$(e.to)}" title="Copy address">${ge}</button>`):"",u=e.amount?j("Transfer",`<span>${$(e.amount)}</span>`):"",h=e.fees?j("Tx Fee",`<span>${$(e.fees)}</span>`):"",_=e.txHash?j("Tx Hash",`<span class="__crossx-addr-text">${re(e.txHash)}</span>
1895
+ <button class="__crossx-copy-btn" data-copy="${$(e.txHash)}" title="Copy hash">${ge}</button>`):"",f=e.total?`<div class="__crossx-total-pill">
1854
1896
  <span class="__crossx-total-label">Total<br>(including fees)</span>
1855
- <span class="__crossx-total-amount">${U(e.total)}</span>
1897
+ <span class="__crossx-total-amount">${$(e.total)}</span>
1856
1898
  </div>`:"";a.innerHTML=`
1857
1899
  <div class="__crossx-rows">
1858
1900
  ${c}
@@ -1863,7 +1905,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1863
1905
  </div>
1864
1906
  ${f}
1865
1907
  <button class="__crossx-approve-btn" id="__crossx-done-btn">${t?"All Done":"Done"}</button>
1866
- `,a.querySelectorAll(".__crossx-copy-btn").forEach(w=>{w.addEventListener("click",b=>{var T;b.stopPropagation();const y=w.dataset.copy;y&&((T=navigator.clipboard)==null||T.writeText(y).catch(()=>{}))})})}function Dn(r,e){const s=e,t=Je(r.dappName),n=U(r.message),o=document.createElement("div");return o.id=te,o.innerHTML=`
1908
+ `,a.querySelectorAll(".__crossx-copy-btn").forEach(w=>{w.addEventListener("click",E=>{var R;E.stopPropagation();const y=w.dataset.copy;y&&((R=navigator.clipboard)==null||R.writeText(y).catch(()=>{}))})})}function $n(r,e){const s=e,t=Je(r.dappName),n=$(r.message),o=document.createElement("div");return o.id=se,o.innerHTML=`
1867
1909
  <div class="__crossx-card __crossx-card--migration __crossx-card--sign-msg" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1868
1910
  <div class="__crossx-header">
1869
1911
  <p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
@@ -1874,11 +1916,11 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1874
1916
  <div class="__crossx-body-cols">
1875
1917
  <div class="__crossx-col-left">
1876
1918
  <p class="__crossx-sig-subtitle">
1877
- <span class="__crossx-sig-origin">${U(t)} </span>is requesting a Signature
1919
+ <span class="__crossx-sig-origin">${$(t)} </span>is requesting a Signature
1878
1920
  </p>
1879
1921
  <div class="__crossx-addr-pill">
1880
- ${bt}
1881
- <span class="__crossx-addr-pill-text">${se(r.from)}</span>
1922
+ ${vt}
1923
+ <span class="__crossx-addr-pill-text">${re(r.from)}</span>
1882
1924
  </div>
1883
1925
  <p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
1884
1926
  </div>
@@ -1891,16 +1933,16 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1891
1933
  </div>
1892
1934
  </div>
1893
1935
  </div>
1894
- `,o}function Mn(r,e){const s=e,t=Je(r.dappName);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=`
1936
+ `,o}function Bn(r,e){const s=e,t=Je(r.dappName);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=`
1895
1937
  <div class="__crossx-td-row">
1896
1938
  <span class="__crossx-td-label">Primary Type</span>
1897
- <span class="__crossx-td-value">${U(o)}</span>
1898
- </div>`;for(const[l,u]of Object.entries(i)){const h=On(u),f=Pn(u)?`<span class="__crossx-addr-text">${se(u)}</span>
1899
- <button class="__crossx-copy-btn" data-copy="${U(String(u))}" title="Copy">${ge}</button>`:`<span>${h}</span>`;a+=`
1939
+ <span class="__crossx-td-value">${$(o)}</span>
1940
+ </div>`;for(const[l,u]of Object.entries(i)){const h=Nn(u),f=Cn(u)?`<span class="__crossx-addr-text">${re(u)}</span>
1941
+ <button class="__crossx-copy-btn" data-copy="${$(String(u))}" title="Copy">${ge}</button>`:`<span>${h}</span>`;a+=`
1900
1942
  <div class="__crossx-td-row">
1901
- <span class="__crossx-td-label">${U(l)}</span>
1943
+ <span class="__crossx-td-label">${$(l)}</span>
1902
1944
  <div class="__crossx-td-value">${f}</div>
1903
- </div>`}const c=document.createElement("div");return c.id=te,c.innerHTML=`
1945
+ </div>`}const c=document.createElement("div");return c.id=se,c.innerHTML=`
1904
1946
  <div class="__crossx-card __crossx-card--migration __crossx-card--sign-typed" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1905
1947
  <div class="__crossx-header">
1906
1948
  <p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
@@ -1911,11 +1953,11 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1911
1953
  <div class="__crossx-body-cols">
1912
1954
  <div class="__crossx-col-left">
1913
1955
  <p class="__crossx-sig-subtitle">
1914
- <span class="__crossx-sig-origin">${U(t)} </span>is requesting a Signature
1956
+ <span class="__crossx-sig-origin">${$(t)} </span>is requesting a Signature
1915
1957
  </p>
1916
1958
  <div class="__crossx-addr-pill">
1917
- ${bt}
1918
- <span class="__crossx-addr-pill-text">${se(r.from)}</span>
1959
+ ${vt}
1960
+ <span class="__crossx-addr-pill-text">${re(r.from)}</span>
1919
1961
  </div>
1920
1962
  <p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
1921
1963
  </div>
@@ -1928,12 +1970,12 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1928
1970
  </div>
1929
1971
  </div>
1930
1972
  </div>
1931
- `,c}const $n=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round">
1973
+ `,c}const Un=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round">
1932
1974
  <line x1="12" y1="5" x2="12" y2="19"/>
1933
1975
  <line x1="5" y1="12" x2="19" y2="12"/>
1934
- </svg>`;function Bn(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="${U(i.address)}">
1935
- <span class="__crossx-wallet-addr">${se(i.address)}</span>${a?'<span class="__crossx-wallet-selected">selected</span>':""}
1936
- </button>`}).join(""),o=document.createElement("div");return o.id=te,o.innerHTML=`
1976
+ </svg>`;function Hn(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="${$(i.address)}">
1977
+ <span class="__crossx-wallet-addr">${re(i.address)}</span>${a?'<span class="__crossx-wallet-selected">selected</span>':""}
1978
+ </button>`}).join(""),o=document.createElement("div");return o.id=se,o.innerHTML=`
1937
1979
  <div class="__crossx-card __crossx-card--migration __crossx-card--wallet-selector" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1938
1980
  <div class="__crossx-header">
1939
1981
  <div style="display:flex;flex-direction:column;gap:4px;padding-right:36px;">
@@ -1957,22 +1999,22 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1957
1999
  ${n}
1958
2000
  </div>
1959
2001
  <button class="__crossx-wallet-add" id="__crossx-add-wallet-btn" type="button">
1960
- <span class="__crossx-wallet-add-icon">${$n}</span>
2002
+ <span class="__crossx-wallet-add-icon">${Un}</span>
1961
2003
  <span class="__crossx-wallet-add-label">add a wallet</span>
1962
2004
  </button>
1963
2005
  </div>
1964
2006
  </div>
1965
2007
  </div>
1966
2008
  </div>
1967
- `,o}const Un=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
2009
+ `,o}const Fn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1968
2010
  <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"/>
1969
2011
  <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"/>
1970
- </svg>`,Hn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
2012
+ </svg>`,Gn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
1971
2013
  <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"/>
1972
2014
  <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"/>
1973
2015
  <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"/>
1974
2016
  <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"/>
1975
- </svg>`;function Fn(r,e=!1){const s=r,t=e?`
2017
+ </svg>`;function Wn(r,e=!1){const s=r,t=e?`
1976
2018
  <div class="__crossx-login-or-divider">
1977
2019
  <hr><span>or</span><hr>
1978
2020
  </div>
@@ -1981,7 +2023,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1981
2023
  <span class="__crossx-connect-other-title">Connect with Other Wallets</span>
1982
2024
  <span class="__crossx-connect-other-desc">Connect your existing Web3 wallet to manage your assets.</span>
1983
2025
  </div>
1984
- </button>`:"",n=document.createElement("div");return n.id=te,n.innerHTML=`
2026
+ </button>`:"",n=document.createElement("div");return n.id=se,n.innerHTML=`
1985
2027
  <div class="__crossx-card __crossx-card--migration" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
1986
2028
  <div class="__crossx-header">
1987
2029
  <div style="display:flex;flex-direction:column;gap:4px;padding-right:36px;">
@@ -1994,11 +2036,11 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
1994
2036
  <div class="__crossx-body">
1995
2037
  <div class="__crossx-login-btn-row">
1996
2038
  <button class="__crossx-login-btn" id="__crossx-apple-btn" type="button">
1997
- <span class="__crossx-login-icon" style="color:var(--cx-value);">${Un}</span>
2039
+ <span class="__crossx-login-icon" style="color:var(--cx-value);">${Fn}</span>
1998
2040
  <span class="__crossx-login-btn-label">Sign in with&nbsp;&nbsp;Apple</span>
1999
2041
  </button>
2000
2042
  <button class="__crossx-login-btn" id="__crossx-google-btn" type="button">
2001
- <span class="__crossx-login-icon">${Hn}</span>
2043
+ <span class="__crossx-login-icon">${Gn}</span>
2002
2044
  <span class="__crossx-login-btn-label">Sign in with&nbsp;&nbsp;Google</span>
2003
2045
  </button>
2004
2046
  </div>${t}
@@ -2007,7 +2049,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
2007
2049
  </p>
2008
2050
  </div>
2009
2051
  </div>
2010
- `,n}function Gn(r,e=!0){const s=r,t=e?`<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>`:"",n=e?'<button class="__crossx-skip-btn" id="__crossx-skip-btn">Skip for Now</button>':"",o=document.createElement("div");return o.id=te,o.innerHTML=`
2052
+ `,n}function qn(r,e=!0){const s=r,t=e?`<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>`:"",n=e?'<button class="__crossx-skip-btn" id="__crossx-skip-btn">Skip for Now</button>':"",o=document.createElement("div");return o.id=se,o.innerHTML=`
2011
2053
  <div class="__crossx-card __crossx-card--migration" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
2012
2054
  <div class="__crossx-header">
2013
2055
  <p class="__crossx-title" id="__crossx-ttl">Wallet Found on Social Account 🎉</p>
@@ -2021,13 +2063,13 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
2021
2063
  <p class="__crossx-mig-info-desc">It safely restores and integrates all your previous assets. Simply verify your PIN to get started.</p>
2022
2064
  </div>
2023
2065
  <button class="__crossx-recover-btn" id="__crossx-recover-btn">
2024
- <span class="__crossx-recover-icon">${In}</span>
2066
+ <span class="__crossx-recover-icon">${Tn}</span>
2025
2067
  <span class="__crossx-recover-label">Import from Social Backup</span>
2026
2068
  </button>
2027
2069
  ${n}
2028
2070
  </div>
2029
2071
  </div>
2030
- `,o}function Wn(r,e){const s=r,{errorMessage:t,attemptCount:n,maxAttempts:o=5}=e??{},i=!!t,a=i?" --error":"",c=n!=null&&n>0?`<p class="__crossx-pin-attempt">${n}/${o}</p>`:"",l=n!=null&&n>=3?'<p class="__crossx-pin-warning">Your account will be locked after further failures.</p>':"",u=i?`<p class="__crossx-pin-error-text">${t}</p>`:"",h=document.createElement("div");return h.id=te,h.innerHTML=`
2072
+ `,o}function Kn(r,e){const s=r,{errorMessage:t,attemptCount:n,maxAttempts:o=5}=e??{},i=!!t,a=i?" --error":"",c=n!=null&&n>0?`<p class="__crossx-pin-attempt">${n}/${o}</p>`:"",l=n!=null&&n>=3?'<p class="__crossx-pin-warning">Your account will be locked after further failures.</p>':"",u=i?`<p class="__crossx-pin-error-text">${t}</p>`:"",h=document.createElement("div");return h.id=se,h.innerHTML=`
2031
2073
  <div class="__crossx-card __crossx-card--migration" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
2032
2074
  <div class="__crossx-header">
2033
2075
  <p class="__crossx-title" id="__crossx-ttl">Import from Social Backup</p>
@@ -2047,7 +2089,7 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
2047
2089
  ${u}
2048
2090
  </div>
2049
2091
  </div>
2050
- `,h}function qn(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"],n=s[e.getDay()],o=t[e.getMonth()],i=e.getDate(),a=String(e.getHours()).padStart(2,"0"),c=String(e.getMinutes()).padStart(2,"0");return`${n}, ${o} ${i} ${a}:${c}`}function Kn(r,e,s){const t=r,n=e<=0,o=n?null:Date.now()+e*1e3,i=o?qn(o):null,a=document.createElement("div");return a.id=te,a.innerHTML=`
2092
+ `,h}function Vn(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"],n=s[e.getDay()],o=t[e.getMonth()],i=e.getDate(),a=String(e.getHours()).padStart(2,"0"),c=String(e.getMinutes()).padStart(2,"0");return`${n}, ${o} ${i} ${a}:${c}`}function zn(r,e,s){const t=r,n=e<=0,o=n?null:Date.now()+e*1e3,i=o?Vn(o):null,a=document.createElement("div");return a.id=se,a.innerHTML=`
2051
2093
  <div class="__crossx-card __crossx-card--migration" style="${ce(t)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
2052
2094
  <div class="__crossx-header">
2053
2095
  <p class="__crossx-title" id="__crossx-ttl">Import from Social Backup</p>
@@ -2067,15 +2109,15 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
2067
2109
  </div>
2068
2110
  </div>
2069
2111
  </div>
2070
- `,{overlay:a,startCountdown:l=>{if(n||!o)return()=>{};const h=setInterval(()=>{Date.now()>=o&&(clearInterval(h),l())},1e3);return()=>clearInterval(h)}}}function Vn(r){const s=[r.check1,r.check2].map((t,n)=>`
2112
+ `,{overlay:a,startCountdown:l=>{if(n||!o)return()=>{};const h=setInterval(()=>{Date.now()>=o&&(clearInterval(h),l())},1e3);return()=>clearInterval(h)}}}function jn(r){const s=[r.check1,r.check2].map((t,n)=>`
2071
2113
  <div class="__crossx-pw-notice-item" data-check-index="${n}" role="checkbox" aria-checked="false" tabindex="0">
2072
- <div class="__crossx-pw-notice-check" id="__crossx-notice-check-${n}">${Yn}</div>
2073
- <span class="__crossx-pw-notice-item-text">${U(t)}</span>
2114
+ <div class="__crossx-pw-notice-check" id="__crossx-notice-check-${n}">${Jn}</div>
2115
+ <span class="__crossx-pw-notice-item-text">${$(t)}</span>
2074
2116
  </div>
2075
2117
  `).join("");return`
2076
2118
  <div class="__crossx-header">
2077
- <p class="__crossx-title" id="__crossx-ttl" style="padding-right:48px;">${U(r.title)}</p>
2078
- <p class="__crossx-pw-subtitle">${U(r.headerSubtitle)}</p>
2119
+ <p class="__crossx-title" id="__crossx-ttl" style="padding-right:48px;">${$(r.title)}</p>
2120
+ <p class="__crossx-pw-subtitle">${$(r.headerSubtitle)}</p>
2079
2121
  <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
2080
2122
  </div>
2081
2123
  <hr class="__crossx-divider">
@@ -2083,28 +2125,28 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
2083
2125
  <div class="__crossx-pw-fields __crossx-pw-fields--notice">
2084
2126
  <div class="__crossx-pw-notice-header">
2085
2127
  <div class="__crossx-pw-notice-title-row">
2086
- <span class="__crossx-pw-notice-icon">${Jn}</span>
2087
- <p class="__crossx-pw-notice-title">${U(r.noticeTitle)}</p>
2128
+ <span class="__crossx-pw-notice-icon">${Zn}</span>
2129
+ <p class="__crossx-pw-notice-title">${$(r.noticeTitle)}</p>
2088
2130
  </div>
2089
- <p class="__crossx-pw-notice-desc">${U(r.noticeDesc)}</p>
2131
+ <p class="__crossx-pw-notice-desc">${$(r.noticeDesc)}</p>
2090
2132
  </div>
2091
2133
  <div class="__crossx-pw-notice-checks" id="__crossx-notice-checks">
2092
2134
  ${s}
2093
2135
  </div>
2094
2136
  </div>
2095
2137
  <button class="__crossx-pw-btn --disabled" id="__crossx-pin-notice-next"
2096
- data-next-label="${U(r.nextButton)}"
2097
- data-submit-label="${U(r.submitButton)}">
2098
- ${U(r.nextButton)}
2138
+ data-next-label="${$(r.nextButton)}"
2139
+ data-submit-label="${$(r.submitButton)}">
2140
+ ${$(r.nextButton)}
2099
2141
  </button>
2100
2142
  </div>
2101
2143
  <div class="__crossx-home-indicator"></div>
2102
- `}function it(r){const e=!!r.lockExpiresAt&&r.lockExpiresAt>Date.now(),s=r.lockExpiresAt?` data-lock-expires="${r.lockExpiresAt}"`:"",t=r.headerSubtitle?`<p class="__crossx-pin6-header-sub">${U(r.headerSubtitle)}</p>`:"",n=r.subtitle?`<p class="__crossx-pin6-subtitle">${U(r.subtitle)}</p>`:"",o=r.errorMessage?`<p class="__crossx-pin6-error" id="__crossx-pin6-error">${U(r.errorMessage)}</p>`:'<p class="__crossx-pin6-error" id="__crossx-pin6-error"></p>',i=e?`<p class="__crossx-pin6-lock-msg" id="__crossx-pin6-lock-msg">
2103
- ${Ds}
2144
+ `}function ct(r){const e=!!r.lockExpiresAt&&r.lockExpiresAt>Date.now(),s=r.lockExpiresAt?` data-lock-expires="${r.lockExpiresAt}"`:"",t=r.headerSubtitle?`<p class="__crossx-pin6-header-sub">${$(r.headerSubtitle)}</p>`:"",n=r.subtitle?`<p class="__crossx-pin6-subtitle">${$(r.subtitle)}</p>`:"",o=r.errorMessage?`<p class="__crossx-pin6-error" id="__crossx-pin6-error">${$(r.errorMessage)}</p>`:'<p class="__crossx-pin6-error" id="__crossx-pin6-error"></p>',i=e?`<p class="__crossx-pin6-lock-msg" id="__crossx-pin6-lock-msg">
2145
+ ${$s}
2104
2146
  <span id="__crossx-pin6-lock-countdown"></span>
2105
- </p>`:"",a=e?" --locked":"",c=Array.from({length:6},(l,u)=>`<input class="__crossx-pin6-box${a}" type="password" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off" aria-label="PIN digit ${u+1}"${e?" disabled":""}>`).join("");return`
2147
+ </p>`:"",a=r.attemptCount!=null&&r.attemptCount>0?`<p class="__crossx-pin6-attempt" id="__crossx-pin6-attempt">${r.attemptCount}/${r.maxAttempts??"?"}</p>`:'<p class="__crossx-pin6-attempt" id="__crossx-pin6-attempt"></p>',c=e?" --locked":"",l=Array.from({length:6},(u,h)=>`<input class="__crossx-pin6-box${c}" type="password" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off" aria-label="PIN digit ${h+1}"${e?" disabled":""}>`).join("");return`
2106
2148
  <div class="__crossx-header">
2107
- <p class="__crossx-title" id="__crossx-ttl" style="padding-right:48px;">${U(r.title)}</p>
2149
+ <p class="__crossx-title" id="__crossx-ttl" style="padding-right:48px;">${$(r.title)}</p>
2108
2150
  ${t}
2109
2151
  <button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ie}</button>
2110
2152
  </div>
@@ -2112,20 +2154,21 @@ ${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);c
2112
2154
  <div class="__crossx-pin6-body"${s}>
2113
2155
  ${n}
2114
2156
  <div class="__crossx-pin6-boxes" id="__crossx-pin6-boxes">
2115
- ${c}
2157
+ ${l}
2116
2158
  </div>
2117
2159
  ${o}
2160
+ ${a}
2118
2161
  ${i}
2119
2162
  </div>
2120
2163
  <div class="__crossx-home-indicator"></div>
2121
- `}function es(r,e){const s=document.createElement("div");return s.id=te,s.innerHTML=`
2164
+ `}function ss(r,e){const s=document.createElement("div");return s.id=se,s.innerHTML=`
2122
2165
  <div class="__crossx-card __crossx-card--pin6" style="${ce(r)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
2123
2166
  ${e}
2124
2167
  </div>
2125
- `,s}function zn(r,e){if(r.length!==6)return e.tooShort;if(!/^\d+$/.test(r))return e.numbersOnly;if(/(.)\1{2}/.test(r))return e.repeatingDigit;const s=r.split("").map(Number),t=s.every((o,i)=>i===0||o===(s[i-1]+1)%10),n=s.every((o,i)=>i===0||o===(s[i-1]+9)%10);return t||n?e.sequential:r[0]!==r[1]&&r===r.slice(0,2).repeat(3)?e.alternatingPattern:null}function jn(r){const e=Math.max(0,Math.ceil(r/1e3)),s=Math.floor(e/3600),t=Math.floor(e%3600/60),n=e%60;return s>0?`${s}h ${String(t).padStart(2,"0")}m`:`${String(t).padStart(2,"0")}:${String(n).padStart(2,"0")}`}function at(r,e,s,t,n,o){var j,q;let i=!!(o&&o>Date.now()),a=!1;const c=()=>Array.from(r.querySelectorAll(".__crossx-pin6-box")),l=()=>r.querySelector("#__crossx-pin6-boxes"),u=()=>r.querySelector("#__crossx-pin6-error"),h=()=>r.querySelector("#__crossx-pin6-lock-msg"),_=()=>r.querySelector("#__crossx-pin6-lock-countdown"),f=()=>r.querySelector(".__crossx-pin6-body"),w=()=>c().map(P=>P.value).join(""),b=P=>{i=P,c().forEach(v=>{v.disabled=P,v.classList.toggle("--locked",P)})},y=()=>{const P=u();P&&(P.textContent="")},T=P=>{const v=u();v&&(v.textContent=P);const L=l();L==null||L.classList.add("--shake"),setTimeout(()=>L==null?void 0:L.classList.remove("--shake"),500),c().forEach(G=>{G.value=""}),setTimeout(()=>{var G;return(G=c()[0])==null?void 0:G.focus()},50)},N=P=>{var A;b(!0),c().forEach(I=>{I.value=""});const v=u();if(v&&(v.textContent="Too many failed attempts. Please wait."),!h()){const I=document.createElement("p");I.className="__crossx-pin6-lock-msg",I.id="__crossx-pin6-lock-msg",I.innerHTML=`${Ds}<span id="__crossx-pin6-lock-countdown"></span>`;const x=u();x?x.insertAdjacentElement("afterend",I):(A=f())==null||A.appendChild(I)}const L=()=>{var g;const I=P-Date.now(),x=_();I<=0?(clearInterval(G),b(!1),(g=h())==null||g.remove(),v&&(v.textContent=""),setTimeout(()=>{var S;return(S=c()[0])==null?void 0:S.focus()},50)):x&&(x.textContent=` ${jn(I)}`)},G=setInterval(L,1e3);L();const O=new MutationObserver(()=>{document.contains(r)||(clearInterval(G),O.disconnect())});O.observe(document.body,{childList:!0,subtree:!1})},W=async()=>{if(i||a)return;const P=w();if(P.length===6){a=!0,c().forEach(v=>{v.disabled=!0});try{if(n){const v=await n(P);v.ok?e(P):v.lockExpiresAt?N(v.lockExpiresAt):T(v.error??"Incorrect PIN. Please try again.")}else e(P)}catch(v){t&&t(v)}finally{a=!1,i||c().forEach(v=>{v.disabled=!1})}}};o&&o>Date.now()?N(o):setTimeout(()=>{var P;return(P=c()[0])==null?void 0:P.focus()},100);const B=()=>{if(i||a)return;const P=c(),v=P.find(L=>!L.value)??P[P.length-1];v==null||v.focus()};(j=l())==null||j.addEventListener("click",P=>{P.target.classList.contains("__crossx-pin6-box")||B()}),(q=f())==null||q.addEventListener("click",P=>{const v=P.target;v.classList.contains("__crossx-pin6-box")||v.closest("button")||B()}),c().forEach((P,v)=>{P.addEventListener("input",()=>{var G;const L=P.value.replace(/\D/g,"").slice(-1);P.value=L,y(),L&&v<5&&((G=c()[v+1])==null||G.focus()),w().length===6&&setTimeout(W,80)}),P.addEventListener("keydown",L=>{var G,O;if(L.key==="Backspace"){if(L.preventDefault(),P.value)P.value="";else if(v>0){const A=c()[v-1];A.value="",A.focus()}}else L.key==="ArrowLeft"&&v>0?(L.preventDefault(),(G=c()[v-1])==null||G.focus()):L.key==="ArrowRight"&&v<5?(L.preventDefault(),(O=c()[v+1])==null||O.focus()):L.key==="Escape"&&s()}),P.addEventListener("paste",L=>{var A,I;L.preventDefault();const G=(((A=L.clipboardData)==null?void 0:A.getData("text"))??"").replace(/\D/g,"").slice(0,6);if(!G)return;const O=c();G.split("").forEach((x,g)=>{O[g]&&(O[g].value=x)}),(I=O[Math.min(G.length-1,5)])==null||I.focus(),y(),w().length===6&&setTimeout(W,80)}),P.addEventListener("focus",()=>P.select())})}const Ds=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
2168
+ `,s}function Yn(r,e){if(r.length!==6)return e.tooShort;if(!/^\d+$/.test(r))return e.numbersOnly;if(/(.)\1{2}/.test(r))return e.repeatingDigit;const s=r.split("").map(Number),t=s.every((o,i)=>i===0||o===(s[i-1]+1)%10),n=s.every((o,i)=>i===0||o===(s[i-1]+9)%10);return t||n?e.sequential:r[0]!==r[1]&&r===r.slice(0,2).repeat(3)?e.alternatingPattern:null}function Xn(r){const e=Math.max(0,Math.ceil(r/1e3)),s=Math.floor(e/3600),t=Math.floor(e%3600/60),n=e%60;return s>0?`${s}h ${String(t).padStart(2,"0")}m`:`${String(t).padStart(2,"0")}:${String(n).padStart(2,"0")}`}function lt(r,e,s,t,n,o){var H,z;let i=!!(o&&o>Date.now()),a=!1;const c=()=>Array.from(r.querySelectorAll(".__crossx-pin6-box")),l=()=>r.querySelector("#__crossx-pin6-boxes"),u=()=>r.querySelector("#__crossx-pin6-error"),h=()=>r.querySelector("#__crossx-pin6-lock-msg"),_=()=>r.querySelector("#__crossx-pin6-lock-countdown"),f=()=>r.querySelector(".__crossx-pin6-body"),w=()=>c().map(k=>k.value).join(""),E=k=>{i=k,c().forEach(b=>{b.disabled=k,b.classList.toggle("--locked",k)})},y=()=>r.querySelector("#__crossx-pin6-attempt"),R=()=>{const k=u();k&&(k.textContent="")},N=(k,b)=>{var I;let S=y();if(!S){S=document.createElement("p"),S.className="__crossx-pin6-attempt",S.id="__crossx-pin6-attempt";const x=u();x?x.insertAdjacentElement("afterend",S):(I=f())==null||I.appendChild(S)}S.textContent=`${k}/${b}`},F=()=>{const k=y();k&&(k.textContent="")},M=k=>{const b=u();b&&(b.textContent=k);const S=l();S==null||S.classList.add("--shake"),setTimeout(()=>S==null?void 0:S.classList.remove("--shake"),500),c().forEach(I=>{I.value=""}),setTimeout(()=>{var I;return(I=c()[0])==null?void 0:I.focus()},50)},V=k=>{var g;E(!0),c().forEach(v=>{v.value=""});const b=u();if(b&&(b.textContent="Too many failed attempts. Please wait."),!h()){const v=document.createElement("p");v.className="__crossx-pin6-lock-msg",v.id="__crossx-pin6-lock-msg",v.innerHTML=`${$s}<span id="__crossx-pin6-lock-countdown"></span>`;const A=u();A?A.insertAdjacentElement("afterend",v):(g=f())==null||g.appendChild(v)}const S=()=>{var C;const v=k-Date.now(),A=_();v<=0?(clearInterval(I),E(!1),(C=h())==null||C.remove(),b&&(b.textContent=""),setTimeout(()=>{var O;return(O=c()[0])==null?void 0:O.focus()},50)):A&&(A.textContent=` ${Xn(v)}`)},I=setInterval(S,1e3);S();const x=new MutationObserver(()=>{document.contains(r)||(clearInterval(I),x.disconnect())});x.observe(document.body,{childList:!0,subtree:!1})},G=async()=>{if(i||a)return;const k=w();if(k.length===6){a=!0,c().forEach(b=>{b.disabled=!0});try{if(n){const b=await n(k);b.ok?e(k):b.lockExpiresAt?(F(),V(b.lockExpiresAt)):(M(b.error??"Incorrect PIN. Please try again."),b.attemptCount!=null&&b.maxAttempts!=null?N(b.attemptCount,b.maxAttempts):F())}else e(k)}catch(b){t&&t(b)}finally{a=!1,i||c().forEach(b=>{b.disabled=!1})}}};o&&o>Date.now()?V(o):setTimeout(()=>{var k;return(k=c()[0])==null?void 0:k.focus()},100);const J=()=>{if(i||a)return;const k=c(),b=k.find(S=>!S.value)??k[k.length-1];b==null||b.focus()};(H=l())==null||H.addEventListener("click",k=>{k.target.classList.contains("__crossx-pin6-box")||J()}),(z=f())==null||z.addEventListener("click",k=>{const b=k.target;b.classList.contains("__crossx-pin6-box")||b.closest("button")||J()}),c().forEach((k,b)=>{k.addEventListener("input",()=>{var I;const S=k.value.replace(/\D/g,"").slice(-1);k.value=S,R(),S&&b<5&&((I=c()[b+1])==null||I.focus()),w().length===6&&setTimeout(G,80)}),k.addEventListener("keydown",S=>{var I,x;if(S.key==="Backspace"){if(S.preventDefault(),k.value)k.value="";else if(b>0){const g=c()[b-1];g.value="",g.focus()}}else S.key==="ArrowLeft"&&b>0?(S.preventDefault(),(I=c()[b-1])==null||I.focus()):S.key==="ArrowRight"&&b<5?(S.preventDefault(),(x=c()[b+1])==null||x.focus()):S.key==="Escape"&&s()}),k.addEventListener("paste",S=>{var g,v;S.preventDefault();const I=(((g=S.clipboardData)==null?void 0:g.getData("text"))??"").replace(/\D/g,"").slice(0,6);if(!I)return;const x=c();I.split("").forEach((A,C)=>{x[C]&&(x[C].value=A)}),(v=x[Math.min(I.length-1,5)])==null||v.focus(),R(),w().length===6&&setTimeout(G,80)}),k.addEventListener("focus",()=>k.select())})}const $s=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
2126
2169
  <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"/>
2127
- </svg>`,Yn=`<svg width="11" height="9" viewBox="0 0 11 9" fill="none" xmlns="http://www.w3.org/2000/svg">
2170
+ </svg>`,Jn=`<svg width="11" height="9" viewBox="0 0 11 9" fill="none" xmlns="http://www.w3.org/2000/svg">
2128
2171
  <path d="M1 4.5L4 7.5L10 1" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
2129
- </svg>`,Jn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
2172
+ </svg>`,Zn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
2130
2173
  <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"/>
2131
- </svg>`;function Xn(r,e,s){var o;const t=r.querySelectorAll(".__crossx-pin-input");t.forEach((i,a)=>{i.addEventListener("input",()=>{const c=i.value.replace(/\D/g,"");i.value=c?c[0]:"",c&&a<3&&t[a+1].focus();const l=Array.from(t).map(u=>u.value).join("");l.length===4&&setTimeout(()=>e(l),200)}),i.addEventListener("keydown",c=>{c.key==="Backspace"&&!i.value&&a>0&&(t[a-1].focus(),t[a-1].value=""),c.key==="Escape"&&s()}),i.addEventListener("keypress",c=>{/[0-9]/.test(c.key)||c.preventDefault()}),i.addEventListener("paste",c=>{var h;c.preventDefault();const l=(((h=c.clipboardData)==null?void 0:h.getData("text"))??"").replace(/\D/g,"").slice(0,4);if(!l)return;l.split("").forEach((_,f)=>{t[f]&&(t[f].value=_)});const u=Math.min(l.length,3);t[u].focus(),l.length===4&&setTimeout(()=>e(l),200)})});const n=r.querySelector(".__crossx-pin-inputs");n==null||n.addEventListener("click",i=>{if(!i.target.classList.contains("__crossx-pin-input")){const a=Array.from(t).find(c=>!c.value)??t[t.length-1];a==null||a.focus()}}),(o=t[0])==null||o.focus()}class Zn{constructor(e="light",s){this.theme=e,this.overrides=s,this.tokens=Zt(e,s)}setTheme(e,s){this.theme=e,s!==void 0&&(this.overrides=s),this.tokens=Zt(e,this.overrides)}setMessages(e){this.messages=e}getTheme(){return this.theme}showWalletSelector(e,s,t){return new Promise(n=>{var b;he();const o=[...e],i=Bn(o,this.tokens,t),a=document.body.style.overflow;document.body.style.overflow="hidden",pe(i);let c=!1;const l=()=>{c||(c=!0,i.remove(),document.body.style.overflow=a)},u=y=>{l(),n(y)},h=()=>{l(),n(null)};(()=>{i.querySelectorAll(".__crossx-wallet-item").forEach(y=>{y.addEventListener("click",()=>{const T=y.dataset.walletAddress??"",N=parseInt(y.dataset.walletIndex??"0",10);u({address:T,index:N})})})})();const f=i.querySelector("#__crossx-add-wallet-btn");f&&f.addEventListener("click",async()=>{f.disabled=!0;try{const y=await s();o.push(y);const T=i.querySelector("#__crossx-wallet-list");if(T){const N=document.createElement("button");N.className="__crossx-wallet-item",N.dataset.walletIndex=String(y.index),N.dataset.walletAddress=y.address,N.innerHTML=`<span class="__crossx-wallet-addr">${se(y.address)}</span>`,N.addEventListener("click",()=>u(y)),T.appendChild(N),N.scrollIntoView({behavior:"smooth",block:"nearest"})}}catch{}finally{f.disabled=!1}}),(b=i.querySelector("#__crossx-close-btn"))==null||b.addEventListener("click",h),i.addEventListener("click",y=>{y.target===i&&h()});const w=y=>{y.key==="Escape"&&(document.removeEventListener("keydown",w),h())};document.addEventListener("keydown",w)})}showLoginSelector(e){return new Promise(s=>{var c,l,u,h;he();const t=Fn(this.tokens,e==null?void 0:e.showConnectOtherWallets);pe(t);const n=()=>t.remove(),o=_=>{n(),s(_)},i=()=>{n(),s(null)};(c=t.querySelector("#__crossx-apple-btn"))==null||c.addEventListener("click",()=>o("apple")),(l=t.querySelector("#__crossx-google-btn"))==null||l.addEventListener("click",()=>o("google")),(u=t.querySelector("#__crossx-connect-btn"))==null||u.addEventListener("click",()=>o("external")),(h=t.querySelector("#__crossx-close-btn"))==null||h.addEventListener("click",i),t.addEventListener("click",_=>{_.target===t&&i()}),t.querySelectorAll(".__crossx-login-terms-link").forEach(_=>{_.addEventListener("click",f=>f.stopPropagation())});const a=_=>{_.key==="Escape"&&(document.removeEventListener("keydown",a),i())};document.addEventListener("keydown",a)})}showMigrationFoundPrompt(e){const s=(e==null?void 0:e.allowSkip)??!0;return new Promise(t=>{var a,c,l;he();const n=Gn(this.tokens,s);pe(n);const o=()=>n.remove(),i=()=>{o(),t("recover")};if((a=n.querySelector("#__crossx-recover-btn"))==null||a.addEventListener("click",i),s){const u=()=>{o(),t("skip")};(c=n.querySelector("#__crossx-skip-btn"))==null||c.addEventListener("click",u),(l=n.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",u),n.addEventListener("click",_=>{_.target===n&&u()});const h=_=>{_.key==="Escape"&&(document.removeEventListener("keydown",h),u())};document.addEventListener("keydown",h)}})}showPinSetupPrompt(e){return new Promise(s=>{he();const t=this.messages,n={title:(t==null?void 0:t.pinSetup_title)??"Create PIN",headerSubtitle:(t==null?void 0:t.pinNotice_headerSubtitle)??"Required for transactions, PK/mnemonic export & account deletion.",noticeTitle:(t==null?void 0:t.pinNotice_title)??"PIN Setup Notice",noticeDesc:(t==null?void 0:t.pinNotice_description)??"For your security, this PIN cannot be reset or recovered. Please make sure you remember it or store it in a safe place.",check1:(t==null?void 0:t.pinNotice_check1)??"I understand that losing this PIN will result in permanent loss of access to my wallet and assets.",check2:(t==null?void 0:t.pinNotice_check2)??"I understand that no one, including the support team, can recover or reset this PIN on my behalf.",nextButton:(t==null?void 0:t.pinNotice_nextButton)??"Next",submitButton:(t==null?void 0:t.pinNotice_submitButton)??"I Understand"},o={title:(t==null?void 0:t.pinSetup_title)??"Create PIN",headerSubtitle:(t==null?void 0:t.pinSetup_headerSubtitle)??"This PIN is used to authorize your transactions.",subtitle:(t==null?void 0:t.pinSetup_subtitle)??"Set a 6-digit PIN to authorize transactions.",mismatchError:(t==null?void 0:t.pinSetup_mismatchError)??"PINs do not match. Please try again."},i={title:(t==null?void 0:t.pinSetup_confirmTitle)??"Confirm PIN",headerSubtitle:(t==null?void 0:t.pinSetup_confirmSubtitle)??"Enter your PIN again to confirm."},a=es(this.tokens,Vn(n)),c=document.body.style.overflow;document.body.style.overflow="hidden",pe(a);let l=!1;const u=()=>{l||(l=!0,a.remove(),document.body.style.overflow=c)},h=N=>{u(),s(N)},_=()=>{u(),s(null)},f=a.querySelector(".__crossx-card"),w={tooShort:(t==null?void 0:t.pinValidation_tooShort)??"Please enter a 6-digit PIN.",numbersOnly:(t==null?void 0:t.pinValidation_numbersOnly)??"Only numbers (0-9) are allowed.",repeatingDigit:(t==null?void 0:t.pinValidation_repeatingDigit)??"Cannot use the same number 3+ times in a row.",sequential:(t==null?void 0:t.pinValidation_sequential)??"Sequential numbers (e.g., 123456) are not allowed.",alternatingPattern:(t==null?void 0:t.pinValidation_alternatingPattern)??"Repeating patterns (e.g., 121212) are not allowed."},b=N=>{var W;f.innerHTML=it({title:i.title,headerSubtitle:i.headerSubtitle}),(W=f.querySelector("#__crossx-close-btn"))==null||W.addEventListener("click",_),at(f,B=>{B===N?h(N):y(o.mismatchError)},_)},y=N=>{var W;f.innerHTML=it({title:o.title,headerSubtitle:o.headerSubtitle,subtitle:o.subtitle,errorMessage:N}),(W=f.querySelector("#__crossx-close-btn"))==null||W.addEventListener("click",_),at(f,B=>{const j=zn(B,w);j?y(j):b(B)},_)};(()=>{var G;const N=Array.from(f.querySelectorAll(".__crossx-pw-notice-item")),W=f.querySelector("#__crossx-pin-notice-next"),B=new Set;W.removeAttribute("disabled");const j=W.dataset.nextLabel??"Next",q=W.dataset.submitLabel??"I Understand",P=()=>{const O=B.size===N.length;W.classList.toggle("--disabled",!O),W.textContent=O?q:j},v=(O,A)=>{if(B.has(A))return;const I=O.querySelector(`#__crossx-notice-check-${A}`);B.add(A),I.classList.add("--checked"),O.setAttribute("aria-checked","true"),P()},L=(O,A)=>{if(!B.has(A))return;const I=O.querySelector(`#__crossx-notice-check-${A}`);B.delete(A),I.classList.remove("--checked"),O.setAttribute("aria-checked","false"),P()};N.forEach(O=>{const A=parseInt(O.dataset.checkIndex??"0",10);O.addEventListener("click",()=>{B.has(A)?L(O,A):v(O,A)}),O.addEventListener("keydown",I=>{(I.key===" "||I.key==="Enter")&&(I.preventDefault(),B.has(A)?L(O,A):v(O,A))})}),W.addEventListener("click",()=>{if(B.size===N.length){y(e==null?void 0:e.errorMessage);return}const O=N.find(I=>{const x=parseInt(I.dataset.checkIndex??"0",10);return!B.has(x)});if(!O)return;const A=parseInt(O.dataset.checkIndex??"0",10);O.scrollIntoView({behavior:"smooth",block:"nearest"}),O.classList.add("--highlight"),setTimeout(()=>{O.classList.remove("--highlight"),v(O,A)},400)}),(G=f.querySelector("#__crossx-close-btn"))==null||G.addEventListener("click",_)})(),a.addEventListener("click",N=>{N.target===a&&_()})})}showPinInputPrompt(e){return new Promise((s,t)=>{var y;he();const n=this.messages,o=(e==null?void 0:e.verifyMode)===!0,i=o?(n==null?void 0:n.verifyPin_title)??"Verify Your PIN":(n==null?void 0:n.pinInput_title)??"Enter PIN",a=o?(n==null?void 0:n.verifyPin_subtitle)??"Enter your PIN to authorize this transaction.":(n==null?void 0:n.pinInput_subtitle)??"Enter your 6-digit PIN to continue.",c=es(this.tokens,it({title:i,headerSubtitle:a,errorMessage:e==null?void 0:e.errorMessage,lockExpiresAt:e==null?void 0:e.lockExpiresAt})),l=document.body.style.overflow;document.body.style.overflow="hidden",pe(c);let u=!1;const h=()=>{u||(u=!0,c.remove(),document.body.style.overflow=l)},_=T=>{h(),s(T)},f=()=>{h(),s(null)},w=T=>{h(),t(T)},b=c.querySelector(".__crossx-card");(y=b.querySelector("#__crossx-close-btn"))==null||y.addEventListener("click",f),at(b,_,f,w,e==null?void 0:e.onSubmit,e==null?void 0:e.lockExpiresAt),c.addEventListener("click",T=>{T.target===c&&f()})})}showRecoveryPinInputPrompt(e){return new Promise(s=>{var a;he();const t=Wn(this.tokens,e);pe(t);const n=()=>t.remove(),o=c=>{n(),s(c)},i=()=>{n(),s(null)};Xn(t,o,i),(a=t.querySelector("#__crossx-close-btn"))==null||a.addEventListener("click",i),t.addEventListener("click",c=>{c.target===t&&i()})})}showRecoveryPinLockedPrompt(e,s){return new Promise(t=>{var l;he();const{overlay:n,startCountdown:o}=Kn(this.tokens,e,s);pe(n);const i=()=>{c(),n.remove()},a=()=>{i(),t()},c=o(a);(l=n.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",a),n.addEventListener("click",u=>{u.target===n&&a()})})}showTransactionComplete(e){return new Promise(s=>{var a,c;he();const t=Cn(e,this.tokens);pe(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",u=>{var _;u.stopPropagation();const h=l.dataset.copy;h&&((_=navigator.clipboard)==null||_.writeText(h).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=>{he();const n=Nn(e,this.tokens);pe(n);const o=()=>n.remove();let i=!1;const a=()=>{i||(i=!0,o(),t())},c=()=>{var u,h;(u=n.querySelector("#__crossx-done-btn"))==null||u.addEventListener("click",a),(h=n.querySelector("#__crossx-close-btn"))==null||h.addEventListener("click",a),n.addEventListener("click",_=>{_.target===n&&a()});const l=_=>{_.key==="Escape"&&(document.removeEventListener("keydown",l),a())};document.addEventListener("keydown",l)};s.then(l=>{i||(Ln(n,l,this.tokens),c())})})}requestConfirmation(e){return new Promise(s=>{var c,l,u;he();let t;e.type==="sign-message"?t=Dn(e,this.tokens):e.type==="sign-typed-data"?t=Mn(e,this.tokens):e.type==="sign"?t=Rn(e,this.tokens):t=kn(e,this.tokens),pe(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),(u=t.querySelector("#__crossx-close-btn"))==null||u.addEventListener("click",i),t.querySelectorAll(".__crossx-copy-btn").forEach(h=>{h.addEventListener("click",_=>{var w;_.stopPropagation();const f=h.dataset.copy;f&&((w=navigator.clipboard)==null||w.writeText(f).catch(()=>{}))})}),t.addEventListener("click",h=>{h.target===t&&i()});const a=h=>{h.key==="Escape"&&(document.removeEventListener("keydown",a),i())};document.addEventListener("keydown",a)})}}class Ms{constructor(){this._accessToken=null,this._expiresAt=0}set(e){this._accessToken=e;try{const s=JSON.parse(atob(e.split(".")[1]));this._expiresAt=typeof s.exp=="number"?s.exp*1e3:0}catch{this._expiresAt=0}}get(){return this._accessToken&&this._expiresAt>0&&Date.now()>=this._expiresAt?(this.clear(),null):this._accessToken}clear(){this._accessToken=null,this._expiresAt=0}has(){return this.get()!==null}isExpiringSoon(e=3e4){return!this._accessToken||this._expiresAt<=0?!0:Date.now()>=this._expiresAt-e}}function Qn(r,e){r.debug;const s=Ge.production,t={...r,oauthServiceUrl:s.oauthServiceUrl,authApiUrl:s.authApiUrl,walletGatewayUrl:s.walletGatewayUrl},n={gatewayUrl:s.walletGatewayUrl,projectId:r.projectId},o=t.authMode!=="cookie"&&Lt.isAvailable();!o&&t.authMode!=="cookie"&&d.warn("[CROSSx] IndexedDB 사용 불가 — LocalStorage fallback 사용 중.","refresh_token이 평문 저장되지 않도록 세션 영속성이 제한됩니다.","IndexedDB를 지원하는 브라우저 사용을 권장합니다."),t.secureStorageAvailable=o;const i=o?new Lt(r.projectId):new nr,a=new pn,c=new gn,l=new Ee,u=new Ms,h=new ht;let _;r.useMockWallet?(d.log("[CROSSx] Mock Wallet Provider 사용"),_=new wn(i,h)):(d.log("[CROSSx] Remote Wallet Provider 사용"),_=new Le(n,i,c,u,h));const f=new De(n,c),w=new Zn(r.theme??"light",r.themeTokens),b=e!=null&&e.wrapConfirmation?e.wrapConfirmation(w):w,y=new We(t,n,i,a,c,l,_,u,b,f,h);return typeof window<"u"&&(window.__crossxSDK=y),y}function eo(r){const e=to(r),s=so(e),t=JSON.parse(s);no(t);const{data:n}=t;return{status:t.status,state:t.state,firebaseToken:n.accessToken,provider:n.provider,email:n.email,providerSub:n.sub,tokenType:n.tokenType,expiresIn:n.expiresIn,raw:t}}function to(r){if(r.includes("://")&&r.includes("?")){const e=new URL(r),s=e.searchParams.get("crossx_oauth_result");if(s)return s;const t=e.searchParams.get("data");if(t)return t;throw new Error("Deeplink URL에 crossx_oauth_result 또는 data 파라미터가 없습니다")}return r}function so(r){if(r.startsWith("{"))return r;if(r.startsWith("%7B")||r.startsWith("%7b"))return decodeURIComponent(r);const e=ro(r);return decodeURIComponent(e)}function ro(r){if(typeof atob=="function")return atob(r);if(typeof Buffer<"u")return Buffer.from(r,"base64").toString("utf-8");throw new Error("Base64 디코딩을 지원하는 환경이 아닙니다")}function no(r){if(typeof r!="object"||r===null)throw new Error("Deeplink payload가 유효한 객체가 아닙니다");const e=r;if(typeof e.status!="string")throw new Error("Deeplink payload에 status 필드가 없습니다");if(typeof e.state!="string")throw new Error("Deeplink payload에 state 필드가 없습니다");if(typeof e.data!="object"||e.data===null)throw new Error("Deeplink payload에 data 필드가 없습니다");const s=e.data;if(typeof s.provider!="string")throw new Error("Deeplink data에 provider 필드가 없습니다");if(typeof s.accessToken!="string")throw new Error("Deeplink data에 accessToken 필드가 없습니다")}exports.CROSSxError=m;exports.CROSSxEthereumProvider=ts;exports.CROSSxSDK=We;exports.ChainId=Us;exports.ErrorCode=p;exports.PinMemoryStore=ht;exports.TokenMemoryStore=Ms;exports.createCROSSxSDK=Qn;exports.parseOAuthDeeplink=eo;
2174
+ </svg>`;function Qn(r,e,s){var o;const t=r.querySelectorAll(".__crossx-pin-input");t.forEach((i,a)=>{i.addEventListener("input",()=>{const c=i.value.replace(/\D/g,"");i.value=c?c[0]:"",c&&a<3&&t[a+1].focus();const l=Array.from(t).map(u=>u.value).join("");l.length===4&&setTimeout(()=>e(l),200)}),i.addEventListener("keydown",c=>{c.key==="Backspace"&&!i.value&&a>0&&(t[a-1].focus(),t[a-1].value=""),c.key==="Escape"&&s()}),i.addEventListener("keypress",c=>{/[0-9]/.test(c.key)||c.preventDefault()}),i.addEventListener("paste",c=>{var h;c.preventDefault();const l=(((h=c.clipboardData)==null?void 0:h.getData("text"))??"").replace(/\D/g,"").slice(0,4);if(!l)return;l.split("").forEach((_,f)=>{t[f]&&(t[f].value=_)});const u=Math.min(l.length,3);t[u].focus(),l.length===4&&setTimeout(()=>e(l),200)})});const n=r.querySelector(".__crossx-pin-inputs");n==null||n.addEventListener("click",i=>{if(!i.target.classList.contains("__crossx-pin-input")){const a=Array.from(t).find(c=>!c.value)??t[t.length-1];a==null||a.focus()}}),(o=t[0])==null||o.focus()}class eo{constructor(e="light",s){this.theme=e,this.overrides=s,this.tokens=es(e,s)}setTheme(e,s){this.theme=e,s!==void 0&&(this.overrides=s),this.tokens=es(e,this.overrides)}setMessages(e){this.messages=e}getTheme(){return this.theme}showWalletSelector(e,s,t){return new Promise(n=>{var E;he();const o=[...e],i=Hn(o,this.tokens,t),a=it();pe(i);let c=!1;const l=()=>{c||(c=!0,i.remove(),a())},u=y=>{l(),n(y)},h=()=>{l(),n(null)};(()=>{i.querySelectorAll(".__crossx-wallet-item").forEach(y=>{y.addEventListener("click",()=>{const R=y.dataset.walletAddress??"",N=parseInt(y.dataset.walletIndex??"0",10);u({address:R,index:N})})})})();const f=i.querySelector("#__crossx-add-wallet-btn");f&&f.addEventListener("click",async()=>{f.disabled=!0;try{const y=await s();o.push(y);const R=i.querySelector("#__crossx-wallet-list");if(R){const N=document.createElement("button");N.className="__crossx-wallet-item",N.dataset.walletIndex=String(y.index),N.dataset.walletAddress=y.address,N.innerHTML=`<span class="__crossx-wallet-addr">${re(y.address)}</span>`,N.addEventListener("click",()=>u(y)),R.appendChild(N),N.scrollIntoView({behavior:"smooth",block:"nearest"})}}catch{}finally{f.disabled=!1}}),(E=i.querySelector("#__crossx-close-btn"))==null||E.addEventListener("click",h),i.addEventListener("click",y=>{y.target===i&&h()});const w=y=>{y.key==="Escape"&&(document.removeEventListener("keydown",w),h())};document.addEventListener("keydown",w)})}showLoginSelector(e){return new Promise(s=>{var c,l,u,h;he();const t=Wn(this.tokens,e==null?void 0:e.showConnectOtherWallets);pe(t);const n=()=>t.remove(),o=_=>{n(),s(_)},i=()=>{n(),s(null)};(c=t.querySelector("#__crossx-apple-btn"))==null||c.addEventListener("click",()=>o("apple")),(l=t.querySelector("#__crossx-google-btn"))==null||l.addEventListener("click",()=>o("google")),(u=t.querySelector("#__crossx-connect-btn"))==null||u.addEventListener("click",()=>o("external")),(h=t.querySelector("#__crossx-close-btn"))==null||h.addEventListener("click",i),t.addEventListener("click",_=>{_.target===t&&i()}),t.querySelectorAll(".__crossx-login-terms-link").forEach(_=>{_.addEventListener("click",f=>f.stopPropagation())});const a=_=>{_.key==="Escape"&&(document.removeEventListener("keydown",a),i())};document.addEventListener("keydown",a)})}showMigrationFoundPrompt(e){const s=(e==null?void 0:e.allowSkip)??!0;return new Promise(t=>{var a,c,l;he();const n=qn(this.tokens,s);pe(n);const o=()=>n.remove(),i=()=>{o(),t("recover")};if((a=n.querySelector("#__crossx-recover-btn"))==null||a.addEventListener("click",i),s){const u=()=>{o(),t("skip")};(c=n.querySelector("#__crossx-skip-btn"))==null||c.addEventListener("click",u),(l=n.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",u),n.addEventListener("click",_=>{_.target===n&&u()});const h=_=>{_.key==="Escape"&&(document.removeEventListener("keydown",h),u())};document.addEventListener("keydown",h)}})}showPinSetupPrompt(e){return new Promise(s=>{he();const t=this.messages,n={title:(t==null?void 0:t.pinSetup_title)??"Create PIN",headerSubtitle:(t==null?void 0:t.pinNotice_headerSubtitle)??"Required for transactions, PK/mnemonic export & account deletion.",noticeTitle:(t==null?void 0:t.pinNotice_title)??"PIN Setup Notice",noticeDesc:(t==null?void 0:t.pinNotice_description)??"For your security, this PIN cannot be reset or recovered. Please make sure you remember it or store it in a safe place.",check1:(t==null?void 0:t.pinNotice_check1)??"I understand that losing this PIN will result in permanent loss of access to my wallet and assets.",check2:(t==null?void 0:t.pinNotice_check2)??"I understand that no one, including the support team, can recover or reset this PIN on my behalf.",nextButton:(t==null?void 0:t.pinNotice_nextButton)??"Next",submitButton:(t==null?void 0:t.pinNotice_submitButton)??"I Understand"},o={title:(t==null?void 0:t.pinSetup_title)??"Create PIN",headerSubtitle:(t==null?void 0:t.pinSetup_headerSubtitle)??"This PIN is used to authorize your transactions.",subtitle:(t==null?void 0:t.pinSetup_subtitle)??"Set a 6-digit PIN to authorize transactions.",mismatchError:(t==null?void 0:t.pinSetup_mismatchError)??"PINs do not match. Please try again."},i={title:(t==null?void 0:t.pinSetup_confirmTitle)??"Confirm PIN",headerSubtitle:(t==null?void 0:t.pinSetup_confirmSubtitle)??"Enter your PIN again to confirm."},a=ss(this.tokens,jn(n)),c=it();pe(a);let l=!1;const u=()=>{l||(l=!0,a.remove(),c())},h=N=>{u(),s(N)},_=()=>{u(),s(null)},f=a.querySelector(".__crossx-card"),w={tooShort:(t==null?void 0:t.pinValidation_tooShort)??"Please enter a 6-digit PIN.",numbersOnly:(t==null?void 0:t.pinValidation_numbersOnly)??"Only numbers (0-9) are allowed.",repeatingDigit:(t==null?void 0:t.pinValidation_repeatingDigit)??"Cannot use the same number 3+ times in a row.",sequential:(t==null?void 0:t.pinValidation_sequential)??"Sequential numbers (e.g., 123456) are not allowed.",alternatingPattern:(t==null?void 0:t.pinValidation_alternatingPattern)??"Repeating patterns (e.g., 121212) are not allowed."},E=N=>{var F;f.innerHTML=ct({title:i.title,headerSubtitle:i.headerSubtitle}),(F=f.querySelector("#__crossx-close-btn"))==null||F.addEventListener("click",_),lt(f,M=>{M===N?h(N):y(o.mismatchError)},_)},y=N=>{var F;f.innerHTML=ct({title:o.title,headerSubtitle:o.headerSubtitle,subtitle:o.subtitle,errorMessage:N}),(F=f.querySelector("#__crossx-close-btn"))==null||F.addEventListener("click",_),lt(f,M=>{const V=Yn(M,w);V?y(V):E(M)},_)};(()=>{var k;const N=Array.from(f.querySelectorAll(".__crossx-pw-notice-item")),F=f.querySelector("#__crossx-pin-notice-next"),M=new Set;F.removeAttribute("disabled");const V=F.dataset.nextLabel??"Next",G=F.dataset.submitLabel??"I Understand",J=()=>{const b=M.size===N.length;F.classList.toggle("--disabled",!b),F.textContent=b?G:V},H=(b,S)=>{if(M.has(S))return;const I=b.querySelector(`#__crossx-notice-check-${S}`);M.add(S),I.classList.add("--checked"),b.setAttribute("aria-checked","true"),J()},z=(b,S)=>{if(!M.has(S))return;const I=b.querySelector(`#__crossx-notice-check-${S}`);M.delete(S),I.classList.remove("--checked"),b.setAttribute("aria-checked","false"),J()};N.forEach(b=>{const S=parseInt(b.dataset.checkIndex??"0",10);b.addEventListener("click",()=>{M.has(S)?z(b,S):H(b,S)}),b.addEventListener("keydown",I=>{(I.key===" "||I.key==="Enter")&&(I.preventDefault(),M.has(S)?z(b,S):H(b,S))})}),F.addEventListener("click",()=>{if(M.size===N.length){y(e==null?void 0:e.errorMessage);return}const b=N.find(I=>{const x=parseInt(I.dataset.checkIndex??"0",10);return!M.has(x)});if(!b)return;const S=parseInt(b.dataset.checkIndex??"0",10);b.scrollIntoView({behavior:"smooth",block:"nearest"}),b.classList.add("--highlight"),setTimeout(()=>{b.classList.remove("--highlight"),H(b,S)},400)}),(k=f.querySelector("#__crossx-close-btn"))==null||k.addEventListener("click",_)})(),a.addEventListener("click",N=>{N.target===a&&_()})})}showPinInputPrompt(e){return new Promise((s,t)=>{var y;he();const n=this.messages,o=(e==null?void 0:e.verifyMode)===!0,i=o?(n==null?void 0:n.verifyPin_title)??"Verify Your PIN":(n==null?void 0:n.pinInput_title)??"Enter PIN",a=o?(n==null?void 0:n.verifyPin_subtitle)??"Enter your PIN to authorize this transaction.":(n==null?void 0:n.pinInput_subtitle)??"Enter your 6-digit PIN to continue.",c=ss(this.tokens,ct({title:i,headerSubtitle:a,errorMessage:e==null?void 0:e.errorMessage,lockExpiresAt:e==null?void 0:e.lockExpiresAt,attemptCount:e==null?void 0:e.attemptCount,maxAttempts:e==null?void 0:e.maxAttempts})),l=it();pe(c);let u=!1;const h=()=>{u||(u=!0,c.remove(),l())},_=R=>{h(),s(R)},f=()=>{h(),s(null)},w=R=>{h(),t(R)},E=c.querySelector(".__crossx-card");(y=E.querySelector("#__crossx-close-btn"))==null||y.addEventListener("click",f),lt(E,_,f,w,e==null?void 0:e.onSubmit,e==null?void 0:e.lockExpiresAt),c.addEventListener("click",R=>{R.target===c&&f()})})}showRecoveryPinInputPrompt(e){return new Promise(s=>{var a;he();const t=Kn(this.tokens,e);pe(t);const n=()=>t.remove(),o=c=>{n(),s(c)},i=()=>{n(),s(null)};Qn(t,o,i),(a=t.querySelector("#__crossx-close-btn"))==null||a.addEventListener("click",i),t.addEventListener("click",c=>{c.target===t&&i()})})}showRecoveryPinLockedPrompt(e,s){return new Promise(t=>{var l;he();const{overlay:n,startCountdown:o}=zn(this.tokens,e,s);pe(n);const i=()=>{c(),n.remove()},a=()=>{i(),t()},c=o(a);(l=n.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",a),n.addEventListener("click",u=>{u.target===n&&a()})})}showTransactionComplete(e){return new Promise(s=>{var a,c;he();const t=Ln(e,this.tokens);pe(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",u=>{var _;u.stopPropagation();const h=l.dataset.copy;h&&((_=navigator.clipboard)==null||_.writeText(h).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=>{he();const n=Dn(e,this.tokens);pe(n);const o=()=>n.remove();let i=!1;const a=()=>{i||(i=!0,o(),t())},c=()=>{var u,h;(u=n.querySelector("#__crossx-done-btn"))==null||u.addEventListener("click",a),(h=n.querySelector("#__crossx-close-btn"))==null||h.addEventListener("click",a),n.addEventListener("click",_=>{_.target===n&&a()});const l=_=>{_.key==="Escape"&&(document.removeEventListener("keydown",l),a())};document.addEventListener("keydown",l)};s.then(l=>{i||(Mn(n,l,this.tokens),c())})})}requestConfirmation(e){return new Promise(s=>{var c,l,u;he();let t;e.type==="sign-message"?t=$n(e,this.tokens):e.type==="sign-typed-data"?t=Bn(e,this.tokens):e.type==="sign"?t=Pn(e,this.tokens):t=On(e,this.tokens),pe(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),(u=t.querySelector("#__crossx-close-btn"))==null||u.addEventListener("click",i),t.querySelectorAll(".__crossx-copy-btn").forEach(h=>{h.addEventListener("click",_=>{var w;_.stopPropagation();const f=h.dataset.copy;f&&((w=navigator.clipboard)==null||w.writeText(f).catch(()=>{}))})}),t.addEventListener("click",h=>{h.target===t&&i()});const a=h=>{h.key==="Escape"&&(document.removeEventListener("keydown",a),i())};document.addEventListener("keydown",a)})}}class Bs{constructor(){this._accessToken=null,this._expiresAt=0}set(e){this._accessToken=e;try{const s=JSON.parse(atob(e.split(".")[1]));this._expiresAt=typeof s.exp=="number"?s.exp*1e3:0}catch{this._expiresAt=0}}get(){return this._accessToken&&this._expiresAt>0&&Date.now()>=this._expiresAt?(this.clear(),null):this._accessToken}clear(){this._accessToken=null,this._expiresAt=0}has(){return this.get()!==null}isExpiringSoon(e=3e4){return!this._accessToken||this._expiresAt<=0?!0:Date.now()>=this._expiresAt-e}}function to(r,e){r.debug;const s=We.production,t={...r,oauthServiceUrl:s.oauthServiceUrl,authApiUrl:s.authApiUrl,walletGatewayUrl:s.walletGatewayUrl},n={gatewayUrl:s.walletGatewayUrl,projectId:r.projectId},o=t.authMode!=="cookie"&&Mt.isAvailable();!o&&t.authMode!=="cookie"&&d.warn("[CROSSx] IndexedDB 사용 불가 — LocalStorage fallback 사용 중.","refresh_token이 평문 저장되지 않도록 세션 영속성이 제한됩니다.","IndexedDB를 지원하는 브라우저 사용을 권장합니다."),t.secureStorageAvailable=o;const i=o?new Mt(r.projectId):new or,a=new fn,c=new mn,l=new Ie,u=new Bs,h=new ft;let _;r.useMockWallet?(d.log("[CROSSx] Mock Wallet Provider 사용"),_=new yn(i,h)):(d.log("[CROSSx] Remote Wallet Provider 사용"),_=new ke(n,i,c,u,h));const f=new Me(n,c),w=new eo(r.theme??"light",r.themeTokens),E=e!=null&&e.wrapConfirmation?e.wrapConfirmation(w):w,y=new qe(t,n,i,a,c,l,_,u,E,f,h);return typeof window<"u"&&(window.__crossxSDK=y),y}function so(r){const e=ro(r),s=no(e),t=JSON.parse(s);io(t);const{data:n}=t;return{status:t.status,state:t.state,firebaseToken:n.accessToken,provider:n.provider,email:n.email,providerSub:n.sub,tokenType:n.tokenType,expiresIn:n.expiresIn,raw:t}}function ro(r){if(r.includes("://")&&r.includes("?")){const e=new URL(r),s=e.searchParams.get("crossx_oauth_result");if(s)return s;const t=e.searchParams.get("data");if(t)return t;throw new Error("Deeplink URL에 crossx_oauth_result 또는 data 파라미터가 없습니다")}return r}function no(r){if(r.startsWith("{"))return r;if(r.startsWith("%7B")||r.startsWith("%7b"))return decodeURIComponent(r);const e=oo(r);return decodeURIComponent(e)}function oo(r){if(typeof atob=="function")return atob(r);if(typeof Buffer<"u")return Buffer.from(r,"base64").toString("utf-8");throw new Error("Base64 디코딩을 지원하는 환경이 아닙니다")}function io(r){if(typeof r!="object"||r===null)throw new Error("Deeplink payload가 유효한 객체가 아닙니다");const e=r;if(typeof e.status!="string")throw new Error("Deeplink payload에 status 필드가 없습니다");if(typeof e.state!="string")throw new Error("Deeplink payload에 state 필드가 없습니다");if(typeof e.data!="object"||e.data===null)throw new Error("Deeplink payload에 data 필드가 없습니다");const s=e.data;if(typeof s.provider!="string")throw new Error("Deeplink data에 provider 필드가 없습니다");if(typeof s.accessToken!="string")throw new Error("Deeplink data에 accessToken 필드가 없습니다")}exports.CROSSxError=m;exports.CROSSxEthereumProvider=rs;exports.CROSSxSDK=qe;exports.ChainId=Fs;exports.ErrorCode=p;exports.PinMemoryStore=ft;exports.TokenMemoryStore=Bs;exports.createCROSSxSDK=to;exports.parseOAuthDeeplink=so;