@emblemvault/auth-sdk 2.1.0 → 2.2.0

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.
@@ -1 +1 @@
1
- {"version":3,"file":"emblem-auth.min.js","sources":["../src/SessionManager.ts","../src/EmblemAuthSDK.ts","../src/signers/http.ts","../src/signers/validation.ts","../src/signers/utils.ts","../src/signers/vault.ts","../src/signers/viem.ts","../src/signers/ethers.ts","../node_modules/tslib/tslib.es6.js","../src/signers/web3.ts","../src/signers/solana.ts"],"sourcesContent":["import type { AuthSession, SessionRefreshInfo } from './types/session';\n\ninterface SessionManagerConfig {\n /**\n * Callback to refresh an expiring session\n */\n onRefresh?: (session: AuthSession) => Promise<AuthSession | null>;\n\n /**\n * Time before expiry to trigger refresh (milliseconds)\n * @default 60000 (1 minute)\n */\n refreshSkewMs?: number;\n}\n\ntype SessionEventMap = {\n session: (session: AuthSession | null) => void;\n sessionExpired: (session: AuthSession) => void;\n sessionRefreshed: (session: AuthSession) => void;\n sessionWillRefresh: (info: SessionRefreshInfo) => void;\n};\n\ntype SessionEventKey = keyof SessionEventMap;\ntype SessionEventHandler<K extends SessionEventKey> = SessionEventMap[K];\n\nexport class SessionManager {\n private session: AuthSession | null = null;\n private timer: NodeJS.Timeout | null = null;\n private readonly onRefresh?: (session: AuthSession) => Promise<AuthSession | null>;\n private readonly events: Partial<Record<SessionEventKey, SessionEventHandler<any>[]>> = {};\n private readonly refreshSkewMs: number;\n\n constructor(config: SessionManagerConfig = {}) {\n this.onRefresh = config.onRefresh;\n this.refreshSkewMs = config.refreshSkewMs ?? 60000; // Default 60 seconds\n }\n\n /**\n * Set the current session and schedule refresh\n */\n setSession(session: AuthSession | null): void {\n this.session = session;\n this.schedule();\n this.emit('session', session);\n }\n\n /**\n * Get the current session\n */\n getSession(): AuthSession | null {\n return this.session;\n }\n\n /**\n * Clear the current session\n */\n clear(): void {\n this.session = null;\n this.cancel();\n this.emit('session', null);\n }\n\n /**\n * Subscribe to session events\n */\n on<K extends SessionEventKey>(event: K, handler: SessionEventHandler<K>): void {\n if (!this.events[event]) {\n this.events[event] = [];\n }\n this.events[event]!.push(handler as any);\n }\n\n /**\n * Unsubscribe from session events\n */\n off<K extends SessionEventKey>(event: K, handler: SessionEventHandler<K>): void {\n const handlers = this.events[event];\n if (handlers) {\n const index = handlers.indexOf(handler as any);\n if (index !== -1) {\n handlers.splice(index, 1);\n }\n }\n }\n\n /**\n * Destroy the session manager\n */\n destroy(): void {\n this.cancel();\n this.session = null;\n Object.keys(this.events).forEach(key => {\n delete this.events[key as SessionEventKey];\n });\n }\n\n private emit<K extends SessionEventKey>(\n event: K,\n payload: Parameters<SessionEventMap[K]>[0]\n ): void {\n const handlers = this.events[event];\n if (!handlers) return;\n\n for (const handler of handlers) {\n try {\n handler(payload as any);\n } catch (error) {\n console.error(`Error in session event handler for ${event}:`, error);\n }\n }\n }\n\n private cancel(): void {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n\n private schedule(): void {\n this.cancel();\n\n const session = this.session;\n if (!session?.expiresAt) return;\n\n const now = Date.now();\n const ttl = session.expiresAt - now;\n\n if (ttl <= 0) {\n this.emit('sessionExpired', session);\n return;\n }\n\n const refreshIn = Math.max(0, ttl - this.refreshSkewMs);\n this.emit('sessionWillRefresh', { inMs: refreshIn, ttl });\n\n this.timer = setTimeout(async () => {\n if (!this.onRefresh) {\n // No refresh hook; check if expired\n if (Date.now() >= session.expiresAt) {\n this.emit('sessionExpired', session);\n }\n return;\n }\n\n try {\n const refreshed = await this.onRefresh(session);\n if (refreshed?.expiresAt && refreshed.authToken) {\n this.setSession(refreshed);\n this.emit('sessionRefreshed', refreshed);\n } else {\n // Refresh failed; check if expired\n if (Date.now() >= session.expiresAt) {\n this.emit('sessionExpired', session);\n }\n }\n } catch (error) {\n console.error('Session refresh error:', error);\n if (Date.now() >= session.expiresAt) {\n this.emit('sessionExpired', session);\n }\n }\n }, refreshIn);\n }\n}\n","import { SessionManager } from './SessionManager';\nimport type {\n EmblemAuthConfig,\n AuthSession,\n WalletAuthParams,\n AuthInitResponse,\n AuthError,\n PostMessageData,\n AuthEventMap,\n AuthEventKey,\n AuthEventHandler,\n VaultInfo,\n Hex,\n SignerVaultInfo,\n} from './types';\n\n// Signer types only - actual implementations are dynamically imported\n// to keep peer dependencies (ethers, viem, @solana/web3.js) truly optional\nimport type { EmblemEthersWallet } from './signers/ethers';\nimport type { EmblemSolanaSigner } from './signers/solana';\nimport type { EmblemWeb3Adapter } from './signers/web3';\n\nexport class EmblemAuthSDK {\n private readonly config: EmblemAuthConfig & { authUrl: string; apiUrl: string; persistSession: boolean };\n private session: AuthSession | null = null;\n private pendingNonce: string | null = null;\n private readonly messageHandler: (event: MessageEvent) => void;\n private overlayEl: HTMLElement | null = null;\n private _iframeEl: HTMLIFrameElement | null = null;\n private overlayCleanup: (() => void) | null = null;\n private readonly sessionMgr: SessionManager;\n private readonly events: Partial<Record<AuthEventKey, AuthEventHandler<any>[]>> = {};\n private _cachedVaultInfo: VaultInfo | null = null;\n private readonly storageKey: string;\n\n constructor(config: EmblemAuthConfig) {\n if (!config?.appId) {\n throw new Error('appId is required');\n }\n\n this.config = {\n ...config,\n authUrl: config.authUrl ?? 'https://auth.emblemvault.ai',\n apiUrl: config.apiUrl ?? 'https://api.emblemvault.ai',\n persistSession: config.persistSession ?? true,\n };\n this.storageKey = `emblem_session_${config.appId}`;\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n\n this.sessionMgr = new SessionManager({\n onRefresh: async current => {\n try {\n const refreshed = await this.refreshSession();\n return refreshed || current;\n } catch {\n return current;\n }\n },\n });\n\n // Forward session manager events\n this.sessionMgr.on('sessionExpired', s => this.emit('sessionExpired', s));\n this.sessionMgr.on('sessionRefreshed', s => this.emit('sessionRefreshed', s));\n this.sessionMgr.on('sessionWillRefresh', info => this.emit('sessionWillRefresh', info));\n\n // Restore persisted session if enabled\n if (this.config.persistSession) {\n const restored = this.loadPersistedSession();\n if (restored) {\n this.hydrateSession(restored);\n }\n }\n }\n\n /**\n * Authenticate with a wallet signature (programmatic/headless auth)\n * Uses the external verification endpoint for cross-origin compatibility\n */\n async authenticateWallet(params: WalletAuthParams): Promise<AuthSession | null> {\n const { network, message, signature, publicKey, address } = params;\n\n if (!this.config.apiUrl) {\n throw new Error('apiUrl is required for authenticateWallet');\n }\n if (!network || !message || !signature) {\n throw new Error('network, message, signature are required');\n }\n\n const url = `${this.config.apiUrl.replace(/\\/$/, '')}/api/auth/wallet/verify-external`;\n const response = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n appId: this.config.appId,\n network,\n message,\n signature,\n publicKey,\n address,\n }),\n });\n\n if (!response.ok) {\n const errorData = await this.safeJson(response);\n const error = new Error(errorData?.error || `wallet_verify_${response.status}`) as AuthError;\n error.status = response.status;\n error.payload = errorData;\n throw error;\n }\n\n const data = await response.json();\n const session = data?.session as AuthSession | null;\n\n if (session) {\n this.session = session;\n this.persistSession(session);\n this.sessionMgr.setSession(session);\n this.config.onSuccess?.(session);\n this.emit('session', session);\n }\n\n return session;\n }\n\n /**\n * Open the authentication modal\n */\n async openAuthModal(): Promise<void> {\n const origin = window.location.origin;\n let initData: AuthInitResponse | null = null;\n let initError: AuthError | null = null;\n\n try {\n initData = await this.getAuthInit({ origin });\n } catch (error) {\n initError = error as AuthError;\n console.warn('[EmblemAuthSDK] /api/auth/init failed:', initError?.message || error);\n }\n\n const nonce = initData?.nonce || this.randomId();\n this.pendingNonce = nonce;\n\n let modalUrl = this.resolveModalUrl({ nonce, origin, state: initData?.state });\n\n // If origin not allowed, open modal error page directly\n if (initError?.payload?.error === 'origin_not_allowed') {\n try {\n const base = new URL('/connect', this.config.authUrl);\n base.searchParams.set('error', 'origin_not_allowed');\n base.searchParams.set('appId', this.config.appId);\n base.searchParams.set('origin', origin);\n modalUrl = base.toString();\n } catch {\n // Ignore URL construction errors\n }\n }\n\n const mode = this.config.modalMode || 'auto';\n let opened = false;\n\n if (mode === 'iframe' || mode === 'auto') {\n try {\n opened = this.openIframeModal(modalUrl);\n } catch (error) {\n console.warn(\n '[EmblemAuthSDK] iframe modal failed, will fallback to popup:',\n (error as Error)?.message\n );\n }\n }\n\n if (!opened) {\n const features = this.popupFeatures();\n const win = window.open(modalUrl, 'emblem-auth', features);\n if (!win) {\n const error = new Error('Popup blocked. Please allow popups for this site.') as AuthError;\n this.emitError(error);\n }\n }\n }\n\n /**\n * Get the current session\n */\n getSession(): AuthSession | null {\n return this.session;\n }\n\n /**\n * Refresh the current session\n * Supports two modes:\n * - Web apps: Uses httpOnly cookies (credentials: include, no body)\n * - Mobile/Native apps: Uses refresh token from session (sent in body)\n */\n async refreshSession(): Promise<AuthSession | null> {\n try {\n if (!this.session) return null;\n\n // Extract origin from authUrl for refresh endpoint\n const authOrigin = this.tryGetOriginFromConfig();\n if (!authOrigin) return this.session;\n\n const refreshUrl = `${authOrigin}/api/auth/refresh`;\n\n // Check if we have a refresh token in session (mobile/native mode)\n // If so, send it in the body. Otherwise, rely on httpOnly cookie (web mode)\n const hasTokenInSession = Boolean(this.session.refreshToken);\n\n const response = await fetch(refreshUrl, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(\n hasTokenInSession ? { refreshToken: this.session.refreshToken } : {}\n ),\n // Always include credentials - needed for cookie mode, harmless for token mode\n credentials: 'include',\n });\n\n if (!response.ok) return this.session;\n\n const data = await response.json();\n const nextSession = data?.session as AuthSession | null;\n\n if (nextSession) {\n // For mobile/native: preserve the new refresh token if returned\n // For web: refreshToken will be undefined (handled by cookies)\n this.session = nextSession;\n this.persistSession(nextSession);\n this.sessionMgr.setSession(nextSession);\n this.emit('session', nextSession);\n }\n\n return this.session;\n } catch {\n return this.session;\n }\n }\n\n /**\n * Get vault information\n */\n async getVaultInfo(): Promise<VaultInfo> {\n if (this._cachedVaultInfo) return this._cachedVaultInfo;\n\n const session = this.getSession();\n if (!session?.authToken) {\n throw new Error('No session');\n }\n\n if (!this.config.apiUrl) {\n throw new Error('apiUrl is required');\n }\n\n const apiBase = this.config.apiUrl.replace(/\\/$/, '');\n const resp = await fetch(`${apiBase}/vault/info`, {\n method: 'POST',\n headers: {\n 'Authorization': `Bearer ${session.authToken}`,\n 'Content-Type': 'application/json'\n },\n body: '{}'\n });\n\n if (!resp.ok) {\n throw new Error('Failed to fetch vault info');\n }\n\n const vaultInfo = await resp.json();\n this._cachedVaultInfo = vaultInfo;\n return vaultInfo;\n }\n\n /**\n * Get or create the vault API key\n */\n async getVaultApiKey(): Promise<string> {\n if (!this.config.apiUrl) {\n throw new Error('apiUrl is required');\n }\n\n const session = this.getSession();\n if (!session?.authToken) {\n throw new Error('No active session');\n }\n\n const apiBase = this.config.apiUrl.replace(/\\/$/, '');\n const token = session.authToken;\n const vaultId = session.user?.vaultId;\n\n // Try to get API key hash from vault info\n let apiKeyHash: string | null = null;\n\n try {\n const infoRes = await fetch(`${apiBase}/vault/info-complete`, {\n method: 'POST',\n headers: { Authorization: `Bearer ${token}` },\n });\n\n if (infoRes.ok) {\n const infoJson = await infoRes.json();\n apiKeyHash = infoJson?.raw?.pkp?.api_key_hash || infoJson?.raw?.pkp?.apiKeyHash || null;\n }\n } catch {\n // Ignore errors\n }\n\n // Fallback: list by created_by if info-complete didn't return a hash\n if (!apiKeyHash) {\n try {\n const appId = session.appId;\n const rawIdentifier = session.user?.identifier || '';\n const scopedIdentifier = appId ? `${appId}:${rawIdentifier}` : rawIdentifier;\n\n if (scopedIdentifier) {\n const vaultsRes = await fetch(\n `${apiBase}/api/vaults/${encodeURIComponent(scopedIdentifier)}`\n );\n if (vaultsRes.ok) {\n const vaults = await vaultsRes.json();\n const match = Array.isArray(vaults)\n ? vaults.find(v => String(v.tokenId || v.token_id) === String(vaultId)) || vaults[0]\n : null;\n apiKeyHash = match?.api_key_hash || match?.apiKeyHash || null;\n }\n }\n } catch {\n // Ignore errors\n }\n }\n\n // If no hash, generate a new key\n if (!apiKeyHash) {\n const genRes = await fetch(`${apiBase}/api/vaults/${encodeURIComponent(vaultId)}/api-key`, {\n method: 'POST',\n headers: { Authorization: `Bearer ${token}` },\n });\n\n if (!genRes.ok) {\n throw new Error(`gen_key_${genRes.status}`);\n }\n\n const genJson = await genRes.json();\n const apiKey = genJson?.apiKey || genJson?.key || null;\n\n if (!apiKey) {\n throw new Error('missing_apiKey');\n }\n\n return apiKey;\n }\n\n // Decrypt existing key\n const decRes = await fetch(`${apiBase}/decrypt`, {\n method: 'POST',\n headers: {\n Authorization: `Bearer ${token}`,\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ tokenId: vaultId, dataToEncryptHash: apiKeyHash }),\n });\n\n if (!decRes.ok) {\n throw new Error(`decrypt_${decRes.status}`);\n }\n\n const decJson = await decRes.json();\n const decrypted = decJson?.decryptedString || null;\n\n if (!decrypted) {\n throw new Error('missing_decrypted');\n }\n\n return decrypted;\n }\n\n /**\n * Hydrate a previously saved session\n */\n hydrateSession(session: AuthSession): void {\n if (!session?.authToken) return;\n\n this.session = session;\n this.persistSession(session);\n this._cachedVaultInfo = null; // Clear cache on session change\n this.sessionMgr.setSession(session);\n this.emit('session', session);\n }\n\n /**\n * Logout and clear the session\n */\n logout(): void {\n this.session = null;\n this.persistSession(null);\n this._cachedVaultInfo = null; // Clear cache on logout\n this.sessionMgr.clear();\n this.emit('session', null);\n }\n\n /**\n * Subscribe to auth events\n */\n on<K extends AuthEventKey>(event: K, handler: AuthEventHandler<K>): void {\n if (!this.events[event]) {\n this.events[event] = [];\n }\n this.events[event]!.push(handler as any);\n }\n\n /**\n * Unsubscribe from auth events\n */\n off<K extends AuthEventKey>(event: K, handler: AuthEventHandler<K>): void {\n const handlers = this.events[event];\n if (handlers) {\n const index = handlers.indexOf(handler as any);\n if (index !== -1) {\n handlers.splice(index, 1);\n }\n }\n }\n\n // ============================================================================\n // Signer Adapters\n // ============================================================================\n\n /**\n * Helper to get signer config and vault info\n */\n private async getSignerContext(): Promise<{\n config: { baseUrl?: string; getJwt: () => string | null | undefined };\n vaultInfo: SignerVaultInfo;\n }> {\n const session = this.getSession();\n if (!session?.authToken) {\n throw new Error('No active session. Call openAuthModal() or authenticateWallet() first.');\n }\n\n const vaultInfo = await this.getVaultInfo();\n\n return {\n config: {\n baseUrl: this.config.apiUrl,\n getJwt: () => this.getSession()?.authToken,\n },\n vaultInfo: {\n vaultId: vaultInfo.vaultId,\n evmAddress: (vaultInfo.evmAddress || '0x') as Hex,\n address: vaultInfo.solanaAddress || vaultInfo.address || '',\n tokenId: vaultInfo.tokenId,\n created_by: vaultInfo.created_by,\n },\n };\n }\n\n /**\n * Create a viem-compatible account adapter for EVM signing\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const account = await sdk.toViemAccount();\n * const signature = await account.signMessage({ message: 'Hello' });\n * ```\n */\n async toViemAccount(): Promise<{\n address: Hex;\n signMessage: (args: { message: unknown }) => Promise<Hex>;\n signTypedData: (typedData: unknown) => Promise<Hex>;\n signTransaction: (tx: unknown, opts?: unknown) => Promise<Hex>;\n type: 'local';\n source: 'custom';\n }> {\n const { toViemAccount } = await import('./signers/viem');\n const { config, vaultInfo } = await this.getSignerContext();\n return toViemAccount(config, vaultInfo);\n }\n\n /**\n * Create an ethers v6 compatible wallet adapter for EVM signing\n * Requires an active session with authToken\n *\n * @param provider - Optional ethers Provider for transaction population\n *\n * @example\n * ```typescript\n * const wallet = await sdk.toEthersWallet(provider);\n * const signature = await wallet.signMessage('Hello');\n * const tx = await wallet.sendTransaction({ to, value });\n * ```\n */\n async toEthersWallet(provider?: unknown | null): Promise<EmblemEthersWallet> {\n const { toEthersWallet } = await import('./signers/ethers');\n const { config, vaultInfo } = await this.getSignerContext();\n return toEthersWallet(config, provider, vaultInfo);\n }\n\n /**\n * Create a Web3.js compatible adapter for EVM signing\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const adapter = await sdk.toWeb3Adapter();\n * const signature = await adapter.signMessage('Hello');\n * ```\n */\n async toWeb3Adapter(): Promise<EmblemWeb3Adapter> {\n const { toWeb3Adapter } = await import('./signers/web3');\n const { config, vaultInfo } = await this.getSignerContext();\n return toWeb3Adapter(config, vaultInfo);\n }\n\n /**\n * Create a Solana Web3.js compatible signer\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const signer = await sdk.toSolanaWeb3Signer();\n * const signature = await signer.signMessage('Hello');\n * const signedTx = await signer.signTransaction(tx);\n * ```\n */\n async toSolanaWeb3Signer(): Promise<EmblemSolanaSigner> {\n const { toSolanaWeb3Signer } = await import('./signers/solana');\n const { config, vaultInfo } = await this.getSignerContext();\n return toSolanaWeb3Signer(config, vaultInfo);\n }\n\n /**\n * Create a Solana Kit compatible signer\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const signer = await sdk.toSolanaKitSigner();\n * const signature = await signer.signMessage('Hello');\n * ```\n */\n async toSolanaKitSigner(): Promise<EmblemSolanaSigner> {\n const { toSolanaKitSigner } = await import('./signers/solana');\n const { config, vaultInfo } = await this.getSignerContext();\n return toSolanaKitSigner(config, vaultInfo);\n }\n\n /**\n * Clean up event listeners\n */\n destroy(): void {\n window.removeEventListener('message', this.messageHandler);\n this.sessionMgr.destroy();\n this.closeOverlay();\n Object.keys(this.events).forEach(key => {\n delete this.events[key as AuthEventKey];\n });\n }\n\n private resolveModalUrl(params: { nonce: string; origin: string; state?: string }): string {\n // Derive modal URL from authUrl\n const base = `${this.config.authUrl.replace(/\\/$/, '')}/connect`;\n const url = new URL(base, window.location.href);\n url.searchParams.set('appId', this.config.appId);\n url.searchParams.set('origin', params.origin);\n url.searchParams.set('nonce', params.nonce);\n if (params.state) {\n url.searchParams.set('state', params.state);\n }\n return url.toString();\n }\n\n private onMessage(event: MessageEvent): void {\n try {\n // Validate origin\n const allowedOrigins = new Set(\n [window.location.origin, this.tryGetOriginFromConfig()].filter(Boolean)\n );\n\n if (!allowedOrigins.has(event.origin)) return;\n\n const data = event.data as PostMessageData;\n if (data?.type !== 'emblem-auth-success') return;\n\n // Nonce check\n if (!this.pendingNonce || data.nonce !== this.pendingNonce) {\n console.error('[EmblemAuthSDK] Nonce mismatch');\n return;\n }\n\n this.pendingNonce = null;\n\n // Accept the session\n const session = data.session as AuthSession | null;\n this.session = session;\n this.persistSession(session);\n this.sessionMgr.setSession(session);\n\n if (session && this.config.onSuccess) {\n this.config.onSuccess(session);\n }\n\n this.emit('session', session);\n this.closeOverlay();\n } catch (error) {\n this.emitError(error as AuthError);\n }\n }\n\n private emit<K extends AuthEventKey>(event: K, payload: Parameters<AuthEventMap[K]>[0]): void {\n const handlers = this.events[event];\n if (!handlers) return;\n\n for (const handler of handlers) {\n try {\n handler(payload as any);\n } catch (error) {\n console.error(`Error in auth event handler for ${event}:`, error);\n }\n }\n }\n\n private emitError(error: AuthError): void {\n this.config.onError?.(error);\n this.emit('authError', error);\n }\n\n private popupFeatures(): string {\n const width = 420;\n const height = 600;\n const top = Math.max(0, (window.outerHeight - height) / 2);\n const left = Math.max(0, (window.outerWidth - width) / 2);\n return `popup=yes,width=${width},height=${height},left=${left},top=${top}`;\n }\n\n private randomId(): string {\n const array = new Uint8Array(16);\n if (window.crypto?.getRandomValues) {\n window.crypto.getRandomValues(array);\n } else {\n for (let i = 0; i < array.length; i++) {\n array[i] = Math.floor(Math.random() * 256);\n }\n }\n return Array.from(array, b => b.toString(16).padStart(2, '0')).join('');\n }\n\n private tryGetOriginFromConfig(): string | null {\n try {\n if (!this.config.authUrl) return null;\n const url = new URL(this.config.authUrl, window.location.href);\n return url.origin;\n } catch {\n return null;\n }\n }\n\n private async getAuthInit(params: { origin: string }): Promise<AuthInitResponse> {\n // Use authUrl (registration site) for init - it proxies to backend\n const response = await fetch(`${this.config.authUrl.replace(/\\/$/, '')}/api/auth/init`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n appId: this.config.appId,\n origin: params.origin,\n }),\n });\n\n const data = await response.json().catch(() => null);\n\n if (!response.ok) {\n const error = new Error(`init ${response.status}`) as AuthError;\n error.status = response.status;\n error.payload = data || {};\n throw error;\n }\n\n return data as AuthInitResponse;\n }\n\n private openIframeModal(url: string): boolean {\n // Clean up any existing overlay\n if (this.overlayEl) {\n this.closeOverlay();\n }\n\n // Create overlay\n const overlay = document.createElement('div');\n overlay.setAttribute('data-emblem-overlay', '');\n overlay.style.position = 'fixed';\n overlay.style.inset = '0';\n overlay.style.background = 'rgba(0,0,0,0.5)';\n overlay.style.zIndex = '999999';\n overlay.style.display = 'flex';\n overlay.style.alignItems = 'center';\n overlay.style.justifyContent = 'center';\n\n // Create container\n const container = document.createElement('div');\n container.style.width = 'min(420px, 95vw)';\n container.style.height = 'min(600px, 90vh)';\n container.style.background = '#12161b';\n container.style.border = '1px solid #222b35';\n container.style.borderRadius = '12px';\n container.style.boxShadow = '0 12px 48px rgba(0,0,0,0.7)';\n container.style.overflow = 'hidden';\n container.style.position = 'relative';\n\n // Create close button\n const closeBtn = document.createElement('button');\n closeBtn.textContent = '×';\n closeBtn.setAttribute('aria-label', 'Close');\n closeBtn.style.position = 'absolute';\n closeBtn.style.top = '6px';\n closeBtn.style.right = '8px';\n closeBtn.style.zIndex = '2';\n closeBtn.style.background = 'transparent';\n closeBtn.style.color = '#e6eef8';\n closeBtn.style.border = 'none';\n closeBtn.style.fontSize = '20px';\n closeBtn.style.cursor = 'pointer';\n closeBtn.onclick = () => this.closeOverlay();\n\n // Create iframe\n const iframe = document.createElement('iframe');\n iframe.src = url;\n iframe.style.width = '100%';\n iframe.style.height = '100%';\n iframe.style.border = '0';\n iframe.referrerPolicy = 'no-referrer';\n iframe.allow = 'clipboard-read; clipboard-write;';\n\n container.appendChild(closeBtn);\n container.appendChild(iframe);\n overlay.appendChild(container);\n document.body.appendChild(overlay);\n\n // Close on Escape\n const onKey = (e: KeyboardEvent): void => {\n if (e.key === 'Escape') {\n this.closeOverlay();\n }\n };\n document.addEventListener('keydown', onKey, { capture: true });\n\n this.overlayEl = overlay;\n this._iframeEl = iframe;\n this.overlayCleanup = () => {\n document.removeEventListener('keydown', onKey, { capture: true });\n };\n\n return true;\n }\n\n private closeOverlay(): void {\n try {\n this.overlayCleanup?.();\n } catch {\n // Ignore errors\n }\n this.overlayCleanup = null;\n\n if (this.overlayEl?.parentNode) {\n this.overlayEl.parentNode.removeChild(this.overlayEl);\n }\n\n this.overlayEl = null;\n this._iframeEl = null;\n }\n\n private async safeJson(response: Response): Promise<any> {\n try {\n return await response.json();\n } catch {\n return null;\n }\n }\n\n private loadPersistedSession(): AuthSession | null {\n try {\n if (typeof localStorage === 'undefined') return null;\n const stored = localStorage.getItem(this.storageKey);\n if (!stored) return null;\n\n const session = JSON.parse(stored) as AuthSession;\n\n // Validate session has required fields and hasn't expired\n if (!session?.authToken || !session?.expiresAt) return null;\n if (Date.now() >= session.expiresAt) {\n localStorage.removeItem(this.storageKey);\n return null;\n }\n\n return session;\n } catch {\n return null;\n }\n }\n\n private persistSession(session: AuthSession | null): void {\n try {\n if (typeof localStorage === 'undefined') return;\n\n if (session && this.config.persistSession) {\n localStorage.setItem(this.storageKey, JSON.stringify(session));\n } else {\n localStorage.removeItem(this.storageKey);\n }\n } catch {\n // Ignore storage errors (e.g., private browsing mode)\n }\n }\n}\n","import type { SignerConfig } from '../types/signers';\n\nfunction sanitizeErrorMessage(status: number, text: string): string {\n // Sanitize error messages to avoid leaking sensitive server information\n let errorMessage = `Emblem signer error ${status}`;\n\n if (status >= 500) {\n errorMessage += ': Internal server error';\n } else if (status === 401 || status === 403) {\n errorMessage += ': Authentication failed';\n } else if (status === 404) {\n errorMessage += ': Resource not found';\n } else if (status === 405) {\n errorMessage += ': Method not allowed';\n } else if (text) {\n // For 4xx client errors, include limited error details\n errorMessage += `: ${text.substring(0, 200)}`; // Limit to 200 chars\n }\n\n return errorMessage;\n}\n\nasync function resolveAuthHeaders(config: SignerConfig): Promise<Record<string, string>> {\n // Priority: custom headers -> jwt/getJwt/sdk -> apiKey (deprecated)\n if (typeof config.getAuthHeaders === 'function') {\n const h = await config.getAuthHeaders();\n if (h && typeof h === 'object') return h;\n }\n\n const tok =\n config.jwt ??\n (typeof config.getJwt === 'function' ? await config.getJwt() : undefined) ??\n config.sdk?.getSession()?.authToken ??\n undefined;\n\n if (tok) {\n return { Authorization: `Bearer ${tok}` };\n }\n\n // apiKey is deprecated but still supported as fallback\n if (config.apiKey) {\n return { 'x-api-key': config.apiKey };\n }\n\n throw new Error(\n 'No authentication available: provide jwt, getJwt(), getAuthHeaders(), sdk, or apiKey'\n );\n}\n\nexport async function emblemPost<T = unknown>(\n path: string,\n body: unknown,\n config: SignerConfig\n): Promise<T> {\n const baseUrl = config.baseUrl ?? 'https://api.emblemvault.ai';\n const authHeaders = await resolveAuthHeaders(config);\n const res = await fetch(`${baseUrl}${path}`, {\n method: 'POST',\n headers: {\n 'content-type': 'application/json',\n ...authHeaders,\n },\n body: JSON.stringify(body, (_key: string, value: unknown) =>\n typeof value === 'bigint' ? value.toString() : value\n ),\n });\n\n if (!res.ok) {\n const text = await res.text().catch(() => '');\n throw new Error(sanitizeErrorMessage(res.status, text));\n }\n\n return res.json() as Promise<T>;\n}\n\nexport async function emblemGet<T = unknown>(path: string, config: SignerConfig): Promise<T> {\n const baseUrl = config.baseUrl ?? 'https://api.emblemvault.ai';\n const authHeaders = await resolveAuthHeaders(config);\n const res = await fetch(`${baseUrl}${path}`, {\n method: 'GET',\n headers: authHeaders,\n });\n\n if (!res.ok) {\n const text = await res.text().catch(() => '');\n throw new Error(sanitizeErrorMessage(res.status, text));\n }\n\n return res.json() as Promise<T>;\n}\n","import type { SignerConfig } from '../types/signers';\n\n/**\n * Environment detection utilities for warning about unsafe usage patterns\n */\n\n/**\n * Detect if code is running in a browser environment\n */\nexport function isBrowserEnvironment(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/**\n * Check if we're in a Node.js server environment\n */\nexport function isNodeEnvironment(): boolean {\n return (\n typeof process !== 'undefined' && process.versions != null && process.versions.node != null\n );\n}\n\n/**\n * Validate baseUrl format\n */\nexport function validateBaseUrl(baseUrl?: string): void {\n if (!baseUrl) return; // undefined is ok, will use default\n\n if (!baseUrl.startsWith('http://') && !baseUrl.startsWith('https://')) {\n throw new Error('baseUrl must be a valid HTTP(S) URL');\n }\n\n // Warn about http (not https)\n if (\n baseUrl.startsWith('http://') &&\n !baseUrl.includes('localhost') &&\n !baseUrl.includes('127.0.0.1')\n ) {\n console.warn(\n '[Emblem Security Warning] baseUrl uses HTTP instead of HTTPS. This is insecure for production use.'\n );\n }\n}\n\n/**\n * Validate Ethereum address format\n */\nexport function validateEthereumAddress(address: string): void {\n if (!address || typeof address !== 'string') {\n throw new Error('Address is required');\n }\n\n if (!address.startsWith('0x')) {\n throw new Error('Address must start with 0x');\n }\n\n if (!/^0x[0-9a-fA-F]{40}$/.test(address)) {\n throw new Error('Invalid Ethereum address format');\n }\n}\n\n/**\n * Validate vault ID\n */\nexport function validateVaultId(vaultId: string): void {\n if (!vaultId || typeof vaultId !== 'string') {\n throw new Error('vaultId is required');\n }\n\n if (vaultId.trim() === '') {\n throw new Error('vaultId cannot be empty');\n }\n}\n\n/**\n * Safe number conversion with bounds checking\n */\nexport function toSafeNumber(value: unknown, fieldName: string): number {\n const num = Number(value);\n\n if (!Number.isSafeInteger(num)) {\n throw new Error(\n `${fieldName} value ${value} exceeds safe integer range (max: ${Number.MAX_SAFE_INTEGER})`\n );\n }\n\n return num;\n}\n\n/**\n * Extended config with security options\n */\nexport interface SignerSecurityConfig extends SignerConfig {\n /**\n * Enable debug logging for security-related checks\n * @default false\n */\n debugSecurity?: boolean;\n}\n\n/**\n * Validate signer configuration\n */\nexport function validateSignerConfig(config: SignerSecurityConfig): void {\n // Validate auth: require at least one method (jwt, getJwt, getAuthHeaders)\n const hasJwt = !!config.jwt;\n const hasGetJwt = typeof config.getJwt === 'function';\n const hasHeaders = typeof config.getAuthHeaders === 'function';\n\n if (!hasJwt && !hasGetJwt && !hasHeaders) {\n throw new Error('Authentication required: provide jwt, getJwt(), or getAuthHeaders()');\n }\n\n // Validate baseUrl if provided\n if (config.baseUrl) {\n validateBaseUrl(config.baseUrl);\n }\n\n // Security audit logging\n if (config.debugSecurity) {\n console.log('[Emblem Security Debug]', {\n environment: isBrowserEnvironment() ? 'browser' : 'node',\n hasBaseUrl: !!config.baseUrl,\n timestamp: new Date().toISOString(),\n });\n }\n}\n","import type { Hex } from '../types/signers';\nimport { toSafeNumber } from './validation';\n\nexport function toHexIfBigInt(v: unknown): unknown {\n return typeof v === 'bigint' ? '0x' + v.toString(16) : v;\n}\n\n/**\n * viem txs sometimes have bigint / hex / optional fields. Ethers serializers\n * accept hex strings for numeric fields. Normalize where helpful.\n */\nexport function normalizeTxForEmblem(tx: Record<string, unknown>): Record<string, unknown> {\n const out: Record<string, unknown> = { ...tx };\n\n if (out.value !== undefined) out.value = toHexIfBigInt(out.value);\n if (out.gas !== undefined) {\n out.gasLimit = toHexIfBigInt(out.gas);\n delete out.gas;\n }\n if (out.gasLimit !== undefined) out.gasLimit = toHexIfBigInt(out.gasLimit);\n if (out.gasPrice !== undefined) out.gasPrice = toHexIfBigInt(out.gasPrice);\n if (out.maxFeePerGas !== undefined) out.maxFeePerGas = toHexIfBigInt(out.maxFeePerGas);\n if (out.maxPriorityFeePerGas !== undefined)\n out.maxPriorityFeePerGas = toHexIfBigInt(out.maxPriorityFeePerGas);\n if (out.nonce !== undefined) out.nonce = toSafeNumber(out.nonce, 'nonce');\n if (out.chainId !== undefined) out.chainId = toSafeNumber(out.chainId, 'chainId');\n\n // Some backends only accept legacy fields; fold EIP-1559 into gasPrice and drop unsupported keys\n if (out.maxFeePerGas !== undefined || out.maxPriorityFeePerGas !== undefined) {\n if (out.gasPrice === undefined && out.maxFeePerGas !== undefined) {\n out.gasPrice = out.maxFeePerGas;\n }\n delete out.maxFeePerGas;\n delete out.maxPriorityFeePerGas;\n }\n\n // Remove fields commonly unsupported by legacy serializers\n delete out.type;\n delete out.accessList;\n delete out.account;\n delete out.chain;\n delete out.from;\n\n return out;\n}\n\nexport function isHexString(value: unknown): value is Hex {\n return typeof value === 'string' && /^0x[0-9a-fA-F]*$/.test(value);\n}\n\nexport function bytesToHex(bytes: ArrayLike<number>): Hex {\n let out = '0x';\n for (let i = 0; i < bytes.length; i++) {\n out += (bytes[i] as number).toString(16).padStart(2, '0');\n }\n return out as Hex;\n}\n","import type { SignerConfig, SignerVaultInfo, Hex } from '../types/signers';\nimport { emblemPost } from './http';\n\nexport async function fetchVaultInfo(config: SignerConfig): Promise<SignerVaultInfo> {\n // Note: The server only supports POST for /vault/info\n const data: Partial<{\n vaultId: string;\n address: string;\n evmAddress: Hex;\n created_by?: string;\n }> = await emblemPost('/vault/info', {}, config);\n\n // Validate required response data (vaultId + evmAddress are required for EVM)\n if (!data || !data.vaultId || !data.evmAddress) {\n throw new Error('Invalid vault info response: missing required fields');\n }\n\n if (!String(data.evmAddress).startsWith('0x')) {\n throw new Error('Invalid evmAddress format in response');\n }\n\n return {\n vaultId: data.vaultId,\n tokenId: data.vaultId,\n address: data.address || '', // Solana address may be absent; keep optional\n evmAddress: data.evmAddress as Hex,\n created_by: data.created_by,\n };\n}\n","import type { Hex, SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { bytesToHex, isHexString, normalizeTxForEmblem } from './utils';\nimport { fetchVaultInfo } from './vault';\n\n// Minimal viem types to avoid hard dependency\ninterface ViemAccount {\n address: Hex;\n signMessage: (args: { message: unknown }) => Promise<Hex>;\n signTypedData: (typedData: unknown) => Promise<Hex>;\n signTransaction: (tx: unknown, opts?: unknown) => Promise<Hex>;\n type: 'local';\n source: 'custom';\n publicKey?: Hex;\n}\n\nexport async function toViemAccount(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<ViemAccount> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n const { evmAddress, vaultId } = info;\n\n // Dynamically import viem's toAccount\n // String concatenation prevents bundlers from statically analyzing the import\n const viemAccounts = 'viem/accounts';\n const { toAccount } = await import(/* @vite-ignore */ viemAccounts);\n\n return toAccount({\n address: evmAddress,\n\n async signMessage({ message }: { message: unknown }): Promise<Hex> {\n let payload: string;\n let isRaw = false;\n\n if (typeof message === 'string') {\n payload = message;\n isRaw = false;\n } else if (message && typeof (message as { raw?: unknown }).raw !== 'undefined') {\n const raw = (message as { raw: unknown }).raw;\n payload = typeof raw === 'string' ? raw : bytesToHex(raw as ArrayLike<number>);\n isRaw = true;\n } else if (message instanceof Uint8Array) {\n payload = bytesToHex(message);\n isRaw = false;\n } else if (isHexString(message)) {\n payload = message as string;\n isRaw = false;\n } else {\n // Don't silently convert objects to \"[object Object]\"\n throw new Error(\n `Unsupported message type: ${typeof message}. Expected string, Uint8Array, or hex string.`\n );\n }\n\n const data = await emblemPost<{\n signerAddress: string;\n signature: Hex;\n }>('/sign-eth-message', { vaultId, message: payload, raw: isRaw }, config);\n\n return data.signature;\n },\n\n async signTypedData(typedData: unknown): Promise<Hex> {\n const { domain, types, message } = typedData as {\n domain: unknown;\n types: unknown;\n message: unknown;\n };\n const data = await emblemPost<{\n signerAddress: string;\n signature: Hex;\n }>('/sign-typed-message', { vaultId, domain, types, message }, config);\n\n return data.signature;\n },\n\n async signTransaction(tx: unknown, _opts?: unknown): Promise<Hex> {\n const normalizedTx = normalizeTxForEmblem(tx as Record<string, unknown>);\n\n const data = await emblemPost<{\n signedTransaction: Hex;\n }>('/sign-eth-tx', { vaultId, transaction: normalizedTx }, config);\n\n return data.signedTransaction;\n },\n }) as ViemAccount;\n}\n","import type { Hex, SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { bytesToHex, normalizeTxForEmblem } from './utils';\nimport { fetchVaultInfo } from './vault';\n\n// ethers v6 compatible interface (like solana pattern - no runtime dependency)\nexport interface EmblemEthersWallet {\n getAddress(): Promise<string>;\n signMessage(message: string | Uint8Array): Promise<string>;\n signTypedData(\n domain: unknown,\n types: Record<string, Array<{ name: string; type: string }>>,\n value: Record<string, unknown>\n ): Promise<string>;\n signTransaction(tx: unknown): Promise<string>;\n sendTransaction(tx: unknown): Promise<unknown>;\n connect(provider: unknown): EmblemEthersWallet;\n provider: unknown;\n // Additional methods\n initialize(): Promise<void>;\n getVaultId(): string;\n setChainId(chainId: number): void;\n getChainId(): number;\n signAndBroadcast(transaction: unknown, waitForReceipt?: boolean): Promise<string>;\n}\n\nexport async function toEthersWallet(\n config: SignerConfig,\n provider?: unknown | null,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemEthersWallet> {\n // Dynamic import - only loads ethers when this function is called\n // String concatenation prevents bundlers from statically analyzing the import\n let ethers: typeof import('ethers');\n try {\n const moduleName = 'ethers';\n ethers = await import(/* @vite-ignore */ moduleName);\n } catch {\n throw new Error('ethers is required for toEthersWallet(). Install it with: npm install ethers');\n }\n\n const { AbstractSigner, resolveAddress } = ethers;\n type AbstractProvider = import('ethers').AbstractProvider;\n type TransactionRequest = import('ethers').TransactionRequest;\n type TransactionResponse = import('ethers').TransactionResponse;\n type TransactionLike = import('ethers').TransactionLike<string>;\n type TypedDataDomain = import('ethers').TypedDataDomain;\n type TypedDataField = import('ethers').TypedDataField;\n\n const info = infoOverride ?? (await fetchVaultInfo(config));\n\n // Class defined inside function after dynamic import\n class EmblemEthersWalletImpl extends AbstractSigner {\n private readonly _config: SignerConfig;\n private _address: Hex | null = null;\n private _vaultId: string | null = null;\n private _chainId = 1;\n private _initPromise?: Promise<void>;\n\n constructor(\n signerConfig: SignerConfig,\n signerProvider?: AbstractProvider | null,\n seed?: { address?: Hex; vaultId?: string; chainId?: number }\n ) {\n super(signerProvider ?? null);\n this._config = signerConfig;\n if (seed?.address) this._address = seed.address;\n if (seed?.vaultId) this._vaultId = seed.vaultId;\n if (seed?.chainId) this._chainId = seed.chainId;\n }\n\n async initialize(): Promise<void> {\n if (this._initPromise) return this._initPromise;\n\n this._initPromise = fetchVaultInfo(this._config)\n .then((vaultInfo) => {\n this._address = vaultInfo.evmAddress;\n this._vaultId = vaultInfo.vaultId;\n })\n .catch((err) => {\n this._initPromise = undefined;\n throw err;\n });\n\n return this._initPromise;\n }\n\n async getAddress(): Promise<string> {\n if (!this._address) await this.initialize();\n return this._address!;\n }\n\n getVaultId(): string {\n if (!this._vaultId) throw new Error('Wallet not initialized. Call initialize() first.');\n return this._vaultId;\n }\n\n setChainId(chainId: number): void {\n this._chainId = chainId;\n }\n\n getChainId(): number {\n return this._chainId;\n }\n\n connect(newProvider: AbstractProvider): EmblemEthersWalletImpl {\n if (!newProvider) throw new Error('Provider cannot be null');\n return new EmblemEthersWalletImpl(this._config, newProvider, {\n address: this._address ?? undefined,\n vaultId: this._vaultId ?? undefined,\n chainId: this._chainId,\n });\n }\n\n async signMessage(message: string | Uint8Array): Promise<string> {\n if (!this._vaultId) await this.initialize();\n const payload = typeof message === 'string' ? message : bytesToHex(message);\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-eth-message',\n { vaultId: this._vaultId!, message: payload },\n this._config\n );\n return data.signature;\n }\n\n async signTypedData(\n domain: TypedDataDomain,\n types: Record<string, Array<TypedDataField>>,\n value: Record<string, unknown>\n ): Promise<string> {\n if (!this._vaultId) await this.initialize();\n const cleanTypes = { ...types };\n if (cleanTypes && (cleanTypes as Record<string, unknown>).EIP712Domain) {\n delete (cleanTypes as Record<string, unknown>).EIP712Domain;\n }\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-typed-message',\n { vaultId: this._vaultId!, domain, types: cleanTypes, message: value },\n this._config\n );\n return data.signature;\n }\n\n async _signTypedData(\n domain: TypedDataDomain,\n types: Record<string, Array<TypedDataField>>,\n value: Record<string, unknown>\n ): Promise<string> {\n return this.signTypedData(domain, types, value);\n }\n\n async signTransaction(tx: TransactionRequest): Promise<string> {\n if (!this._vaultId) await this.initialize();\n const from = (tx as Record<string, unknown>).from as string | undefined;\n const addr = await this.getAddress();\n\n if (from && from.toLowerCase() !== addr.toLowerCase()) {\n throw new Error('transaction from does not match signer address');\n }\n\n const toSign = this.provider\n ? ({ ...await this.populateTransaction(tx) } as Record<string, unknown>)\n : ({ ...tx } as Record<string, unknown>);\n if (toSign.from) delete toSign.from;\n if (!('to' in toSign) || !toSign.to) {\n throw new Error(\"Transaction must have a 'to' address\");\n }\n if (toSign.nonce === undefined || toSign.nonce === null) {\n throw new Error('Transaction must have a nonce');\n }\n const normalized = normalizeTxForEmblem(toSign);\n const resp = await emblemPost<{ signedTransaction: Hex }>(\n '/sign-eth-tx',\n { vaultId: this._vaultId!, transaction: normalized, options: { chainId: this._chainId } },\n this._config\n );\n return resp.signedTransaction;\n }\n\n async sendTransaction(tx: TransactionRequest): Promise<TransactionResponse> {\n if (!this.provider) throw new Error('Provider required to send transaction');\n const signed = await this.signTransaction(tx);\n return await this.provider.broadcastTransaction(signed);\n }\n\n async populateTransaction(transaction: TransactionRequest): Promise<TransactionLike> {\n const tx = { ...transaction } as TransactionRequest;\n if (!this.provider) throw new Error('Provider required to populate transaction');\n const fromAddress = tx.from\n ? await resolveAddress(tx.from, this.provider)\n : await this.getAddress();\n\n let chainId: bigint;\n if (!tx.chainId) {\n const network = await this.provider.getNetwork();\n chainId = network.chainId;\n this._chainId = Number(network.chainId);\n } else {\n chainId = BigInt(tx.chainId);\n this._chainId = Number(tx.chainId);\n }\n\n const nonce =\n tx.nonce != null\n ? Number(tx.nonce)\n : await this.provider.getTransactionCount(fromAddress, 'pending');\n const toAddress = tx.to ? await resolveAddress(tx.to, this.provider) : null;\n const value = tx.value ? BigInt(tx.value.toString()) : 0n;\n\n let gasLimit: bigint;\n if (!tx.gasLimit) {\n try {\n gasLimit = await this.provider.estimateGas({ ...tx, from: fromAddress });\n } catch {\n gasLimit = 21000n;\n }\n } else {\n gasLimit = BigInt(tx.gasLimit.toString());\n }\n\n let gasPrice: bigint | null = null;\n if (!tx.gasPrice && tx.type !== 2) {\n const feeData = await this.provider.getFeeData();\n gasPrice = feeData.gasPrice ?? null;\n } else if (tx.gasPrice) {\n gasPrice = BigInt(tx.gasPrice.toString());\n }\n\n const populated: TransactionLike = {\n from: fromAddress,\n to: toAddress,\n value,\n nonce,\n gasLimit,\n data: tx.data as string | undefined,\n chainId,\n type: tx.type || undefined,\n };\n if (gasPrice !== null) populated.gasPrice = gasPrice;\n if (tx.maxFeePerGas) populated.maxFeePerGas = BigInt(tx.maxFeePerGas.toString());\n if (tx.maxPriorityFeePerGas)\n populated.maxPriorityFeePerGas = BigInt(tx.maxPriorityFeePerGas.toString());\n return populated;\n }\n\n async signAndBroadcast(\n transaction: TransactionRequest,\n waitForReceipt: boolean = false\n ): Promise<string> {\n if (!this.provider) throw new Error('Provider required to send transaction');\n const signed = await this.signTransaction(transaction);\n const resp = await this.provider.broadcastTransaction(signed);\n const hash = resp.hash as string;\n if (waitForReceipt) {\n await this.provider.waitForTransaction(hash);\n }\n return hash;\n }\n }\n\n return new EmblemEthersWalletImpl(config, provider as AbstractProvider | null, {\n address: info.evmAddress,\n vaultId: info.vaultId,\n });\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import type { Hex, SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { bytesToHex, normalizeTxForEmblem } from './utils';\nimport { fetchVaultInfo } from './vault';\n\nexport class EmblemWeb3Adapter {\n readonly address: Hex;\n readonly #vaultId: string;\n readonly #config: SignerConfig;\n\n constructor(address: Hex, vaultId: string, config: SignerConfig) {\n this.address = address;\n this.#vaultId = vaultId;\n this.#config = config;\n }\n\n async signMessage(message: string | Uint8Array): Promise<Hex> {\n const payload = typeof message === 'string' ? message : bytesToHex(message);\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-eth-message',\n { vaultId: this.#vaultId, message: payload },\n this.#config\n );\n return data.signature;\n }\n\n async signTypedData(\n domain: Record<string, unknown>,\n types: Record<string, unknown>,\n message: Record<string, unknown>\n ): Promise<Hex> {\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-typed-message',\n { vaultId: this.#vaultId, domain, types, message },\n this.#config\n );\n return data.signature;\n }\n\n async signTransaction(tx: Record<string, unknown>): Promise<{ rawTransaction: Hex }> {\n const normalized = normalizeTxForEmblem(tx);\n const resp = await emblemPost<{ signedTransaction: Hex }>(\n '/sign-eth-tx',\n { vaultId: this.#vaultId, transaction: normalized },\n this.#config\n );\n return { rawTransaction: resp.signedTransaction };\n }\n}\n\nexport async function toWeb3Adapter(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemWeb3Adapter> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n return new EmblemWeb3Adapter(info.evmAddress, info.vaultId, config);\n}\n","import type { SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { fetchVaultInfo } from './vault';\n\n// @solana/web3.js compatible interfaces\nexport interface SolanaSignerInterface {\n publicKey: string;\n signMessage(message: Uint8Array | string): Promise<Uint8Array>;\n signTransaction(transaction: unknown): Promise<unknown>;\n}\n\n// For Solana Kit compatibility\nexport interface SolanaKitSignerInterface {\n publicKey: string;\n signMessage(message: Uint8Array | string): Promise<Uint8Array>;\n signTransaction(transaction: unknown): Promise<unknown>;\n}\n\nexport class EmblemSolanaSigner implements SolanaSignerInterface, SolanaKitSignerInterface {\n readonly publicKey: string; // base58 address\n private readonly config: SignerConfig;\n private readonly vaultId: string;\n\n constructor(config: SignerConfig, vaultInfo: SignerVaultInfo) {\n this.publicKey = vaultInfo.address;\n this.config = config;\n this.vaultId = vaultInfo.vaultId;\n }\n\n async signMessage(message: Uint8Array | string): Promise<Uint8Array> {\n // Convert message to bytes if it's a string\n const messageBytes = typeof message === 'string' ? new TextEncoder().encode(message) : message;\n\n // Convert to base64 for API transmission\n const messageBase64 = btoa(String.fromCharCode(...messageBytes));\n\n const response = await emblemPost<{ signature: string }>(\n '/sign-solana-message',\n { vaultId: this.vaultId, message: messageBase64 },\n this.config\n );\n\n // The server returns a signature - could be base64, base58, or hex\n // Let's check what format we're getting and handle accordingly\n\n // Try to decode as base58 first (Solana standard)\n try {\n // Use @solana/web3.js bs58 decoder if available, otherwise fallback\n const win = typeof window !== 'undefined' ? (window as unknown as { bs58?: { decode(s: string): Uint8Array } }) : undefined;\n if (win?.bs58) {\n return win.bs58.decode(response.signature);\n }\n // For Node.js environments or if bs58 is not globally available\n // The signature might be base64 encoded\n const signatureBytes = Uint8Array.from(atob(response.signature), (c) => c.charCodeAt(0));\n return signatureBytes;\n } catch (e) {\n // If base64 decode fails, try treating as hex\n if (response.signature.startsWith('0x')) {\n const hex = response.signature.slice(2);\n const bytes = new Uint8Array(hex.length / 2);\n for (let i = 0; i < hex.length; i += 2) {\n bytes[i / 2] = parseInt(hex.substr(i, 2), 16);\n }\n return bytes;\n }\n throw new Error(`Unable to decode signature format: ${e}`);\n }\n }\n\n async signTransaction(transaction: unknown): Promise<unknown> {\n // Serialize transaction for API transmission\n const serializedTransaction = this.serializeTransaction(transaction);\n\n const response = await emblemPost<{\n serializedSignedTransaction?: string;\n signedTransaction?: string;\n }>(\n '/sign-solana-transaction',\n {\n vaultId: this.vaultId,\n transactionToSign: serializedTransaction, // Pass the base64 string directly\n broadcast: false, // Don't broadcast, just sign\n versionedTransaction: true, // Match API test format\n },\n this.config\n );\n\n // Parse the signed transaction response - handle both response formats\n const signedTxData = response.serializedSignedTransaction || response.signedTransaction;\n if (!signedTxData) {\n throw new Error('No signed transaction data received from server');\n }\n\n return this.deserializeTransaction(signedTxData);\n }\n\n private serializeTransaction(tx: unknown): string {\n // Handle different transaction formats from @solana/web3.js\n if (tx && typeof tx === 'object') {\n // For VersionedTransaction or Transaction objects\n if ((tx as { serialize?: () => Uint8Array }).serialize) {\n // Server expects just the base64 string, not an object\n const serialized = (tx as { serialize: () => Uint8Array }).serialize();\n const base64 = btoa(String.fromCharCode(...serialized));\n return base64;\n }\n // For transaction objects with instructions\n if (\n (tx as { instructions?: unknown }).instructions ||\n (tx as { recentBlockhash?: unknown }).recentBlockhash\n ) {\n throw new Error(\n 'Cannot serialize unsigned transaction objects. Please use VersionedTransaction.'\n );\n }\n }\n\n // Fallback: assume it's already a string\n return tx as string;\n }\n\n private deserializeTransaction(signedTxData: unknown): unknown {\n // If it's already an object (shouldn't happen based on type), handle it\n if (\n typeof signedTxData === 'object' &&\n signedTxData &&\n (signedTxData as { serializedSignedTransaction?: string }).serializedSignedTransaction\n ) {\n signedTxData = (signedTxData as { serializedSignedTransaction: string })\n .serializedSignedTransaction;\n }\n\n // If it's a string, decode from base64\n if (typeof signedTxData === 'string') {\n try {\n // The server returns base64, so decode it\n const decoded = atob(signedTxData);\n return new Uint8Array(decoded.split('').map((c) => c.charCodeAt(0)));\n } catch (e) {\n console.error('Failed to decode transaction:', e);\n throw new Error(`Unable to deserialize transaction response: ${e}`);\n }\n }\n\n // If it's already a Uint8Array or other type, return as-is\n return signedTxData;\n }\n\n // Additional utility methods for @solana/web3.js compatibility\n\n /** Get the vault ID for this signer */\n getVaultId(): string {\n return this.vaultId;\n }\n\n /** Sign multiple transactions in batch */\n async signAllTransactions(transactions: unknown[]): Promise<unknown[]> {\n // Sign each transaction individually for now\n // Could be optimized with a batch API endpoint in the future\n const results = [];\n for (const tx of transactions) {\n results.push(await this.signTransaction(tx));\n }\n return results;\n }\n\n /** Check if this signer can sign for a given public key */\n canSign(publicKey: string): boolean {\n return publicKey === this.publicKey;\n }\n\n /** Sign and optionally broadcast a transaction */\n async signAndBroadcast(transaction: unknown, broadcast: boolean = true): Promise<string> {\n // Serialize transaction for API transmission\n const serializedTransaction = this.serializeTransaction(transaction);\n\n const response = await emblemPost<{\n transactionSignature?: string;\n serializedSignedTransaction?: string;\n }>(\n '/sign-solana-transaction',\n {\n vaultId: this.vaultId,\n transactionToSign: serializedTransaction, // Pass the base64 string directly\n broadcast: broadcast,\n versionedTransaction: true, // Match API test format\n },\n this.config\n );\n\n if (broadcast) {\n // Return the transaction signature\n if (!response.transactionSignature) {\n throw new Error('No transaction signature received from broadcast');\n }\n return response.transactionSignature;\n } else {\n // Return the signed transaction data\n if (!response.serializedSignedTransaction) {\n throw new Error('No signed transaction data received from server');\n }\n return response.serializedSignedTransaction;\n }\n }\n}\n\nexport async function toSolanaWeb3Signer(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemSolanaSigner> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n return new EmblemSolanaSigner(config, info);\n}\n\nexport async function toSolanaKitSigner(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemSolanaSigner> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n return new EmblemSolanaSigner(config, info);\n}\n"],"names":["SessionManager","constructor","config","this","session","timer","events","onRefresh","refreshSkewMs","setSession","schedule","emit","getSession","clear","cancel","on","event","handler","push","off","handlers","index","indexOf","splice","destroy","Object","keys","forEach","key","payload","error","clearTimeout","expiresAt","now","Date","ttl","refreshIn","Math","max","inMs","setTimeout","async","refreshed","authToken","EmblemAuthSDK","pendingNonce","overlayEl","_iframeEl","overlayCleanup","_cachedVaultInfo","appId","Error","authUrl","apiUrl","persistSession","storageKey","messageHandler","onMessage","bind","window","addEventListener","sessionMgr","current","refreshSession","s","info","restored","loadPersistedSession","hydrateSession","authenticateWallet","params","network","message","signature","publicKey","address","url","replace","response","fetch","method","headers","body","JSON","stringify","ok","errorData","safeJson","status","data","json","onSuccess","openAuthModal","origin","location","initData","initError","getAuthInit","nonce","randomId","modalUrl","resolveModalUrl","state","base","URL","searchParams","set","toString","mode","modalMode","opened","openIframeModal","features","popupFeatures","open","emitError","authOrigin","tryGetOriginFromConfig","refreshUrl","hasTokenInSession","Boolean","refreshToken","credentials","nextSession","getVaultInfo","apiBase","resp","Authorization","vaultInfo","getVaultApiKey","token","vaultId","user","apiKeyHash","infoRes","infoJson","raw","pkp","api_key_hash","rawIdentifier","identifier","scopedIdentifier","vaultsRes","encodeURIComponent","vaults","match","Array","isArray","find","v","String","tokenId","token_id","genRes","genJson","apiKey","decRes","dataToEncryptHash","decJson","decrypted","decryptedString","logout","getSignerContext","baseUrl","getJwt","evmAddress","solanaAddress","created_by","toViemAccount","Promise","toEthersWallet","provider","toWeb3Adapter","toSolanaWeb3Signer","toSolanaKitSigner","removeEventListener","closeOverlay","href","Set","filter","has","type","onError","top","outerHeight","outerWidth","array","Uint8Array","crypto","getRandomValues","i","length","floor","random","from","b","padStart","join","catch","overlay","document","createElement","setAttribute","style","position","inset","background","zIndex","display","alignItems","justifyContent","container","width","height","border","borderRadius","boxShadow","overflow","closeBtn","textContent","right","color","fontSize","cursor","onclick","iframe","src","referrerPolicy","allow","appendChild","onKey","e","capture","parentNode","removeChild","localStorage","stored","getItem","parse","removeItem","setItem","emblemPost","path","authHeaders","getAuthHeaders","h","tok","jwt","undefined","sdk","resolveAuthHeaders","res","_key","value","text","errorMessage","substring","sanitizeErrorMessage","toSafeNumber","fieldName","num","Number","isSafeInteger","MAX_SAFE_INTEGER","toHexIfBigInt","normalizeTxForEmblem","tx","out","gas","gasLimit","gasPrice","maxFeePerGas","maxPriorityFeePerGas","chainId","accessList","account","chain","bytesToHex","bytes","fetchVaultInfo","startsWith","infoOverride","toAccount","import","signMessage","isRaw","test","signTypedData","typedData","domain","types","signTransaction","_opts","normalizedTx","transaction","signedTransaction","ethers","moduleName","AbstractSigner","resolveAddress","EmblemEthersWalletImpl","signerConfig","signerProvider","seed","super","_address","_vaultId","_chainId","_config","initialize","_initPromise","then","err","getAddress","getVaultId","setChainId","getChainId","connect","newProvider","cleanTypes","EIP712Domain","_signTypedData","addr","toLowerCase","toSign","populateTransaction","to","normalized","options","sendTransaction","signed","broadcastTransaction","fromAddress","BigInt","getNetwork","getTransactionCount","toAddress","estimateGas","getFeeData","populated","signAndBroadcast","waitForReceipt","hash","waitForTransaction","__classPrivateFieldGet","receiver","kind","f","TypeError","call","get","__classPrivateFieldSet","SuppressedError","EmblemWeb3Adapter","_EmblemWeb3Adapter_vaultId","_EmblemWeb3Adapter_config","rawTransaction","EmblemSolanaSigner","messageBytes","TextEncoder","encode","messageBase64","btoa","fromCharCode","win","bs58","decode","atob","c","charCodeAt","hex","slice","parseInt","substr","serializedTransaction","serializeTransaction","transactionToSign","broadcast","versionedTransaction","signedTxData","serializedSignedTransaction","deserializeTransaction","serialize","serialized","instructions","recentBlockhash","decoded","split","map","signAllTransactions","transactions","results","canSign","transactionSignature"],"mappings":"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"}
1
+ {"version":3,"file":"emblem-auth.min.js","sources":["../src/SessionManager.ts","../src/EmblemAuthSDK.ts","../src/signers/http.ts","../src/signers/validation.ts","../src/signers/utils.ts","../src/signers/vault.ts","../src/signers/viem.ts","../src/signers/ethers.ts","../node_modules/tslib/tslib.es6.js","../src/signers/web3.ts","../src/signers/solana.ts"],"sourcesContent":["import type { AuthSession, SessionRefreshInfo } from './types/session';\n\ninterface SessionManagerConfig {\n /**\n * Callback to refresh an expiring session\n */\n onRefresh?: (session: AuthSession) => Promise<AuthSession | null>;\n\n /**\n * Time before expiry to trigger refresh (milliseconds)\n * @default 60000 (1 minute)\n */\n refreshSkewMs?: number;\n}\n\ntype SessionEventMap = {\n session: (session: AuthSession | null) => void;\n sessionExpired: (session: AuthSession) => void;\n sessionRefreshed: (session: AuthSession) => void;\n sessionWillRefresh: (info: SessionRefreshInfo) => void;\n};\n\ntype SessionEventKey = keyof SessionEventMap;\ntype SessionEventHandler<K extends SessionEventKey> = SessionEventMap[K];\n\nexport class SessionManager {\n private session: AuthSession | null = null;\n private timer: NodeJS.Timeout | null = null;\n private readonly onRefresh?: (session: AuthSession) => Promise<AuthSession | null>;\n private readonly events: Partial<Record<SessionEventKey, SessionEventHandler<any>[]>> = {};\n private readonly refreshSkewMs: number;\n\n constructor(config: SessionManagerConfig = {}) {\n this.onRefresh = config.onRefresh;\n this.refreshSkewMs = config.refreshSkewMs ?? 60000; // Default 60 seconds\n }\n\n /**\n * Set the current session and schedule refresh\n */\n setSession(session: AuthSession | null): void {\n this.session = session;\n this.schedule();\n this.emit('session', session);\n }\n\n /**\n * Get the current session\n */\n getSession(): AuthSession | null {\n return this.session;\n }\n\n /**\n * Clear the current session\n */\n clear(): void {\n this.session = null;\n this.cancel();\n this.emit('session', null);\n }\n\n /**\n * Subscribe to session events\n */\n on<K extends SessionEventKey>(event: K, handler: SessionEventHandler<K>): void {\n if (!this.events[event]) {\n this.events[event] = [];\n }\n this.events[event]!.push(handler as any);\n }\n\n /**\n * Unsubscribe from session events\n */\n off<K extends SessionEventKey>(event: K, handler: SessionEventHandler<K>): void {\n const handlers = this.events[event];\n if (handlers) {\n const index = handlers.indexOf(handler as any);\n if (index !== -1) {\n handlers.splice(index, 1);\n }\n }\n }\n\n /**\n * Destroy the session manager\n */\n destroy(): void {\n this.cancel();\n this.session = null;\n Object.keys(this.events).forEach(key => {\n delete this.events[key as SessionEventKey];\n });\n }\n\n private emit<K extends SessionEventKey>(\n event: K,\n payload: Parameters<SessionEventMap[K]>[0]\n ): void {\n const handlers = this.events[event];\n if (!handlers) return;\n\n for (const handler of handlers) {\n try {\n handler(payload as any);\n } catch (error) {\n console.error(`Error in session event handler for ${event}:`, error);\n }\n }\n }\n\n private cancel(): void {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n\n private schedule(): void {\n this.cancel();\n\n const session = this.session;\n if (!session?.expiresAt) return;\n\n const now = Date.now();\n const ttl = session.expiresAt - now;\n\n if (ttl <= 0) {\n this.emit('sessionExpired', session);\n return;\n }\n\n const refreshIn = Math.max(0, ttl - this.refreshSkewMs);\n this.emit('sessionWillRefresh', { inMs: refreshIn, ttl });\n\n this.timer = setTimeout(async () => {\n if (!this.onRefresh) {\n // No refresh hook; check if expired\n if (Date.now() >= session.expiresAt) {\n this.emit('sessionExpired', session);\n }\n return;\n }\n\n try {\n const refreshed = await this.onRefresh(session);\n if (refreshed?.expiresAt && refreshed.authToken) {\n this.setSession(refreshed);\n this.emit('sessionRefreshed', refreshed);\n } else {\n // Refresh failed; check if expired\n if (Date.now() >= session.expiresAt) {\n this.emit('sessionExpired', session);\n }\n }\n } catch (error) {\n console.error('Session refresh error:', error);\n if (Date.now() >= session.expiresAt) {\n this.emit('sessionExpired', session);\n }\n }\n }, refreshIn);\n }\n}\n","import { SessionManager } from './SessionManager';\nimport type {\n EmblemAuthConfig,\n AuthSession,\n WalletAuthParams,\n AuthInitResponse,\n AuthError,\n PostMessageData,\n AuthEventMap,\n AuthEventKey,\n AuthEventHandler,\n VaultInfo,\n Hex,\n SignerVaultInfo,\n} from './types';\n\n// Signer types only - actual implementations are dynamically imported\n// to keep peer dependencies (ethers, viem, @solana/web3.js) truly optional\nimport type { EmblemEthersWallet } from './signers/ethers';\nimport type { EmblemSolanaSigner } from './signers/solana';\nimport type { EmblemWeb3Adapter } from './signers/web3';\n\nexport class EmblemAuthSDK {\n private readonly config: EmblemAuthConfig & { authUrl: string; apiUrl: string; persistSession: boolean };\n private session: AuthSession | null = null;\n private pendingNonce: string | null = null;\n private readonly messageHandler: (event: MessageEvent) => void;\n private overlayEl: HTMLElement | null = null;\n private _iframeEl: HTMLIFrameElement | null = null;\n private overlayCleanup: (() => void) | null = null;\n private readonly sessionMgr: SessionManager;\n private readonly events: Partial<Record<AuthEventKey, AuthEventHandler<any>[]>> = {};\n private _cachedVaultInfo: VaultInfo | null = null;\n private readonly storageKey: string;\n\n constructor(config: EmblemAuthConfig) {\n if (!config?.appId) {\n throw new Error('appId is required');\n }\n\n this.config = {\n ...config,\n authUrl: config.authUrl ?? 'https://auth.emblemvault.ai',\n apiUrl: config.apiUrl ?? 'https://api.emblemvault.ai',\n persistSession: config.persistSession ?? true,\n };\n this.storageKey = `emblem_session_${config.appId}`;\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n\n this.sessionMgr = new SessionManager({\n onRefresh: async current => {\n try {\n const refreshed = await this.refreshSession();\n return refreshed || current;\n } catch {\n return current;\n }\n },\n });\n\n // Forward session manager events\n this.sessionMgr.on('sessionExpired', s => this.emit('sessionExpired', s));\n this.sessionMgr.on('sessionRefreshed', s => this.emit('sessionRefreshed', s));\n this.sessionMgr.on('sessionWillRefresh', info => this.emit('sessionWillRefresh', info));\n\n // Restore persisted session if enabled\n if (this.config.persistSession) {\n const restored = this.loadPersistedSession();\n if (restored) {\n this.hydrateSession(restored);\n }\n }\n }\n\n /**\n * Authenticate with a wallet signature (programmatic/headless auth)\n * Uses the external verification endpoint for cross-origin compatibility\n */\n async authenticateWallet(params: WalletAuthParams): Promise<AuthSession | null> {\n const { network, message, signature, publicKey, address } = params;\n\n if (!this.config.apiUrl) {\n throw new Error('apiUrl is required for authenticateWallet');\n }\n if (!network || !message || !signature) {\n throw new Error('network, message, signature are required');\n }\n\n const url = `${this.config.apiUrl.replace(/\\/$/, '')}/api/auth/wallet/verify-external`;\n const response = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n appId: this.config.appId,\n network,\n message,\n signature,\n publicKey,\n address,\n }),\n });\n\n if (!response.ok) {\n const errorData = await this.safeJson(response);\n const error = new Error(errorData?.error || `wallet_verify_${response.status}`) as AuthError;\n error.status = response.status;\n error.payload = errorData;\n throw error;\n }\n\n const data = await response.json();\n const session = data?.session as AuthSession | null;\n\n if (session) {\n this.session = session;\n this.persistSession(session);\n this.sessionMgr.setSession(session);\n this.config.onSuccess?.(session);\n this.emit('session', session);\n }\n\n return session;\n }\n\n /**\n * Open the authentication modal\n */\n async openAuthModal(): Promise<void> {\n const origin = window.location.origin;\n let initData: AuthInitResponse | null = null;\n let initError: AuthError | null = null;\n\n try {\n initData = await this.getAuthInit({ origin });\n } catch (error) {\n initError = error as AuthError;\n console.warn('[EmblemAuthSDK] /api/auth/init failed:', initError?.message || error);\n }\n\n const nonce = initData?.nonce || this.randomId();\n this.pendingNonce = nonce;\n\n let modalUrl = this.resolveModalUrl({ nonce, origin, state: initData?.state });\n\n // If origin not allowed, open modal error page directly\n if (initError?.payload?.error === 'origin_not_allowed') {\n try {\n const base = new URL('/connect', this.config.authUrl);\n base.searchParams.set('error', 'origin_not_allowed');\n base.searchParams.set('appId', this.config.appId);\n base.searchParams.set('origin', origin);\n modalUrl = base.toString();\n } catch {\n // Ignore URL construction errors\n }\n }\n\n const mode = this.config.modalMode || 'auto';\n let opened = false;\n\n if (mode === 'iframe' || mode === 'auto') {\n try {\n opened = this.openIframeModal(modalUrl);\n } catch (error) {\n console.warn(\n '[EmblemAuthSDK] iframe modal failed, will fallback to popup:',\n (error as Error)?.message\n );\n }\n }\n\n if (!opened) {\n const features = this.popupFeatures();\n const win = window.open(modalUrl, 'emblem-auth', features);\n if (!win) {\n const error = new Error('Popup blocked. Please allow popups for this site.') as AuthError;\n this.emitError(error);\n }\n }\n }\n\n /**\n * Get the current session\n */\n getSession(): AuthSession | null {\n return this.session;\n }\n\n /**\n * Refresh the current session\n * Supports two modes:\n * - Web apps: Uses httpOnly cookies (credentials: include, no body)\n * - Mobile/Native apps: Uses refresh token from session (sent in body)\n */\n async refreshSession(): Promise<AuthSession | null> {\n try {\n if (!this.session) return null;\n\n // Extract origin from authUrl for refresh endpoint\n const authOrigin = this.tryGetOriginFromConfig();\n if (!authOrigin) return this.session;\n\n const refreshUrl = `${authOrigin}/api/auth/refresh`;\n\n // Check if we have a refresh token in session (mobile/native mode)\n // If so, send it in the body. Otherwise, rely on httpOnly cookie (web mode)\n const hasTokenInSession = Boolean(this.session.refreshToken);\n\n const response = await fetch(refreshUrl, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(\n hasTokenInSession ? { refreshToken: this.session.refreshToken } : {}\n ),\n // Always include credentials - needed for cookie mode, harmless for token mode\n credentials: 'include',\n });\n\n if (!response.ok) return this.session;\n\n const data = await response.json();\n const nextSession = data?.session as AuthSession | null;\n\n if (nextSession) {\n // For mobile/native: preserve the new refresh token if returned\n // For web: refreshToken will be undefined (handled by cookies)\n this.session = nextSession;\n this.persistSession(nextSession);\n this.sessionMgr.setSession(nextSession);\n this.emit('session', nextSession);\n }\n\n return this.session;\n } catch {\n return this.session;\n }\n }\n\n /**\n * Get vault information\n */\n async getVaultInfo(): Promise<VaultInfo> {\n if (this._cachedVaultInfo) return this._cachedVaultInfo;\n\n const session = this.getSession();\n if (!session?.authToken) {\n throw new Error('No session');\n }\n\n if (!this.config.apiUrl) {\n throw new Error('apiUrl is required');\n }\n\n const apiBase = this.config.apiUrl.replace(/\\/$/, '');\n const resp = await fetch(`${apiBase}/vault/info`, {\n method: 'POST',\n headers: {\n 'Authorization': `Bearer ${session.authToken}`,\n 'Content-Type': 'application/json'\n },\n body: '{}'\n });\n\n if (!resp.ok) {\n throw new Error('Failed to fetch vault info');\n }\n\n const vaultInfo = await resp.json();\n this._cachedVaultInfo = vaultInfo;\n return vaultInfo;\n }\n\n /**\n * Get or create the vault API key\n */\n async getVaultApiKey(): Promise<string> {\n if (!this.config.apiUrl) {\n throw new Error('apiUrl is required');\n }\n\n const session = this.getSession();\n if (!session?.authToken) {\n throw new Error('No active session');\n }\n\n const apiBase = this.config.apiUrl.replace(/\\/$/, '');\n const token = session.authToken;\n const vaultId = session.user?.vaultId;\n\n // Try to get API key hash from vault info\n let apiKeyHash: string | null = null;\n\n try {\n const infoRes = await fetch(`${apiBase}/vault/info-complete`, {\n method: 'POST',\n headers: { Authorization: `Bearer ${token}` },\n });\n\n if (infoRes.ok) {\n const infoJson = await infoRes.json();\n apiKeyHash = infoJson?.raw?.pkp?.api_key_hash || infoJson?.raw?.pkp?.apiKeyHash || null;\n }\n } catch {\n // Ignore errors\n }\n\n // Fallback: list by created_by if info-complete didn't return a hash\n if (!apiKeyHash) {\n try {\n const appId = session.appId;\n const rawIdentifier = session.user?.identifier || '';\n const scopedIdentifier = appId ? `${appId}:${rawIdentifier}` : rawIdentifier;\n\n if (scopedIdentifier) {\n const vaultsRes = await fetch(\n `${apiBase}/api/vaults/${encodeURIComponent(scopedIdentifier)}`\n );\n if (vaultsRes.ok) {\n const vaults = await vaultsRes.json();\n const match = Array.isArray(vaults)\n ? vaults.find(v => String(v.tokenId || v.token_id) === String(vaultId)) || vaults[0]\n : null;\n apiKeyHash = match?.api_key_hash || match?.apiKeyHash || null;\n }\n }\n } catch {\n // Ignore errors\n }\n }\n\n // If no hash, generate a new key\n if (!apiKeyHash) {\n const genRes = await fetch(`${apiBase}/api/vaults/${encodeURIComponent(vaultId)}/api-key`, {\n method: 'POST',\n headers: { Authorization: `Bearer ${token}` },\n });\n\n if (!genRes.ok) {\n throw new Error(`gen_key_${genRes.status}`);\n }\n\n const genJson = await genRes.json();\n const apiKey = genJson?.apiKey || genJson?.key || null;\n\n if (!apiKey) {\n throw new Error('missing_apiKey');\n }\n\n return apiKey;\n }\n\n // Decrypt existing key\n const decRes = await fetch(`${apiBase}/decrypt`, {\n method: 'POST',\n headers: {\n Authorization: `Bearer ${token}`,\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ tokenId: vaultId, dataToEncryptHash: apiKeyHash }),\n });\n\n if (!decRes.ok) {\n throw new Error(`decrypt_${decRes.status}`);\n }\n\n const decJson = await decRes.json();\n const decrypted = decJson?.decryptedString || null;\n\n if (!decrypted) {\n throw new Error('missing_decrypted');\n }\n\n return decrypted;\n }\n\n /**\n * Hydrate a previously saved session\n */\n hydrateSession(session: AuthSession): void {\n if (!session?.authToken) return;\n\n this.session = session;\n this.persistSession(session);\n this._cachedVaultInfo = null; // Clear cache on session change\n this.sessionMgr.setSession(session);\n this.emit('session', session);\n }\n\n /**\n * Logout and clear the session\n */\n logout(): void {\n this.session = null;\n this.persistSession(null);\n this._cachedVaultInfo = null; // Clear cache on logout\n this.sessionMgr.clear();\n this.emit('session', null);\n }\n\n /**\n * Subscribe to auth events\n */\n on<K extends AuthEventKey>(event: K, handler: AuthEventHandler<K>): void {\n if (!this.events[event]) {\n this.events[event] = [];\n }\n this.events[event]!.push(handler as any);\n }\n\n /**\n * Unsubscribe from auth events\n */\n off<K extends AuthEventKey>(event: K, handler: AuthEventHandler<K>): void {\n const handlers = this.events[event];\n if (handlers) {\n const index = handlers.indexOf(handler as any);\n if (index !== -1) {\n handlers.splice(index, 1);\n }\n }\n }\n\n // ============================================================================\n // Signer Adapters\n // ============================================================================\n\n /**\n * Helper to get signer config and vault info\n */\n private async getSignerContext(): Promise<{\n config: { baseUrl?: string; getJwt: () => string | null | undefined };\n vaultInfo: SignerVaultInfo;\n }> {\n const session = this.getSession();\n if (!session?.authToken) {\n throw new Error('No active session. Call openAuthModal() or authenticateWallet() first.');\n }\n\n const vaultInfo = await this.getVaultInfo();\n\n return {\n config: {\n baseUrl: this.config.apiUrl,\n getJwt: () => this.getSession()?.authToken,\n },\n vaultInfo: {\n vaultId: vaultInfo.vaultId,\n evmAddress: (vaultInfo.evmAddress || '0x') as Hex,\n address: vaultInfo.solanaAddress || vaultInfo.address || '',\n tokenId: vaultInfo.tokenId,\n created_by: vaultInfo.created_by,\n },\n };\n }\n\n /**\n * Create a viem-compatible account adapter for EVM signing\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const account = await sdk.toViemAccount();\n * const signature = await account.signMessage({ message: 'Hello' });\n * ```\n */\n async toViemAccount(): Promise<{\n address: Hex;\n signMessage: (args: { message: unknown }) => Promise<Hex>;\n signTypedData: (typedData: unknown) => Promise<Hex>;\n signTransaction: (tx: unknown, opts?: unknown) => Promise<Hex>;\n type: 'local';\n source: 'custom';\n }> {\n const { toViemAccount } = await import('./signers/viem');\n const { config, vaultInfo } = await this.getSignerContext();\n return toViemAccount(config, vaultInfo);\n }\n\n /**\n * Create an ethers v6 compatible wallet adapter for EVM signing\n * Requires an active session with authToken\n *\n * @param provider - Optional ethers Provider for transaction population\n *\n * @example\n * ```typescript\n * const wallet = await sdk.toEthersWallet(provider);\n * const signature = await wallet.signMessage('Hello');\n * const tx = await wallet.sendTransaction({ to, value });\n * ```\n */\n async toEthersWallet(provider?: unknown | null): Promise<EmblemEthersWallet> {\n const { toEthersWallet } = await import('./signers/ethers');\n const { config, vaultInfo } = await this.getSignerContext();\n return toEthersWallet(config, provider, vaultInfo);\n }\n\n /**\n * Create a Web3.js compatible adapter for EVM signing\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const adapter = await sdk.toWeb3Adapter();\n * const signature = await adapter.signMessage('Hello');\n * ```\n */\n async toWeb3Adapter(): Promise<EmblemWeb3Adapter> {\n const { toWeb3Adapter } = await import('./signers/web3');\n const { config, vaultInfo } = await this.getSignerContext();\n return toWeb3Adapter(config, vaultInfo);\n }\n\n /**\n * Create a Solana Web3.js compatible signer\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const signer = await sdk.toSolanaWeb3Signer();\n * const signature = await signer.signMessage('Hello');\n * const signedTx = await signer.signTransaction(tx);\n * ```\n */\n async toSolanaWeb3Signer(): Promise<EmblemSolanaSigner> {\n const { toSolanaWeb3Signer } = await import('./signers/solana');\n const { config, vaultInfo } = await this.getSignerContext();\n return toSolanaWeb3Signer(config, vaultInfo);\n }\n\n /**\n * Create a Solana Kit compatible signer\n * Requires an active session with authToken\n *\n * @example\n * ```typescript\n * const signer = await sdk.toSolanaKitSigner();\n * const signature = await signer.signMessage('Hello');\n * ```\n */\n async toSolanaKitSigner(): Promise<EmblemSolanaSigner> {\n const { toSolanaKitSigner } = await import('./signers/solana');\n const { config, vaultInfo } = await this.getSignerContext();\n return toSolanaKitSigner(config, vaultInfo);\n }\n\n /**\n * Clean up event listeners\n */\n destroy(): void {\n window.removeEventListener('message', this.messageHandler);\n this.sessionMgr.destroy();\n this.closeOverlay();\n Object.keys(this.events).forEach(key => {\n delete this.events[key as AuthEventKey];\n });\n }\n\n private resolveModalUrl(params: { nonce: string; origin: string; state?: string }): string {\n // Derive modal URL from authUrl\n const base = `${this.config.authUrl.replace(/\\/$/, '')}/connect`;\n const url = new URL(base, window.location.href);\n url.searchParams.set('appId', this.config.appId);\n url.searchParams.set('origin', params.origin);\n url.searchParams.set('nonce', params.nonce);\n if (params.state) {\n url.searchParams.set('state', params.state);\n }\n return url.toString();\n }\n\n private onMessage(event: MessageEvent): void {\n try {\n // Validate origin\n const allowedOrigins = new Set(\n [window.location.origin, this.tryGetOriginFromConfig()].filter(Boolean)\n );\n\n if (!allowedOrigins.has(event.origin)) return;\n\n const data = event.data as PostMessageData;\n\n // Handle cancel message\n if (data?.type === 'emblem-auth-cancelled') {\n // Nonce check for cancel\n if (!this.pendingNonce || data.nonce !== this.pendingNonce) {\n return;\n }\n\n this.pendingNonce = null;\n this.closeOverlay();\n\n // Call onCancel callback if provided\n if (this.config.onCancel) {\n this.config.onCancel();\n }\n\n // Emit cancelled event\n this.emit('cancelled', undefined as never);\n return;\n }\n\n if (data?.type !== 'emblem-auth-success') return;\n\n // Nonce check\n if (!this.pendingNonce || data.nonce !== this.pendingNonce) {\n console.error('[EmblemAuthSDK] Nonce mismatch');\n return;\n }\n\n this.pendingNonce = null;\n\n // Accept the session\n const session = data.session as AuthSession | null;\n this.session = session;\n this.persistSession(session);\n this.sessionMgr.setSession(session);\n\n if (session && this.config.onSuccess) {\n this.config.onSuccess(session);\n }\n\n this.emit('session', session);\n this.closeOverlay();\n } catch (error) {\n this.emitError(error as AuthError);\n }\n }\n\n private emit<K extends AuthEventKey>(event: K, payload: Parameters<AuthEventMap[K]>[0]): void {\n const handlers = this.events[event];\n if (!handlers) return;\n\n for (const handler of handlers) {\n try {\n handler(payload as any);\n } catch (error) {\n console.error(`Error in auth event handler for ${event}:`, error);\n }\n }\n }\n\n private emitError(error: AuthError): void {\n this.config.onError?.(error);\n this.emit('authError', error);\n }\n\n private popupFeatures(): string {\n const width = 420;\n const height = 600;\n const top = Math.max(0, (window.outerHeight - height) / 2);\n const left = Math.max(0, (window.outerWidth - width) / 2);\n return `popup=yes,width=${width},height=${height},left=${left},top=${top}`;\n }\n\n private randomId(): string {\n const array = new Uint8Array(16);\n if (window.crypto?.getRandomValues) {\n window.crypto.getRandomValues(array);\n } else {\n for (let i = 0; i < array.length; i++) {\n array[i] = Math.floor(Math.random() * 256);\n }\n }\n return Array.from(array, b => b.toString(16).padStart(2, '0')).join('');\n }\n\n private tryGetOriginFromConfig(): string | null {\n try {\n if (!this.config.authUrl) return null;\n const url = new URL(this.config.authUrl, window.location.href);\n return url.origin;\n } catch {\n return null;\n }\n }\n\n private async getAuthInit(params: { origin: string }): Promise<AuthInitResponse> {\n // Use authUrl (registration site) for init - it proxies to backend\n const response = await fetch(`${this.config.authUrl.replace(/\\/$/, '')}/api/auth/init`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n appId: this.config.appId,\n origin: params.origin,\n }),\n });\n\n const data = await response.json().catch(() => null);\n\n if (!response.ok) {\n const error = new Error(`init ${response.status}`) as AuthError;\n error.status = response.status;\n error.payload = data || {};\n throw error;\n }\n\n return data as AuthInitResponse;\n }\n\n private openIframeModal(url: string): boolean {\n // Clean up any existing overlay\n if (this.overlayEl) {\n this.closeOverlay();\n }\n\n // Create overlay\n const overlay = document.createElement('div');\n overlay.setAttribute('data-emblem-overlay', '');\n overlay.style.position = 'fixed';\n overlay.style.inset = '0';\n overlay.style.background = 'rgba(0,0,0,0.5)';\n overlay.style.zIndex = '999999';\n overlay.style.display = 'flex';\n overlay.style.alignItems = 'center';\n overlay.style.justifyContent = 'center';\n\n // Create container\n const container = document.createElement('div');\n container.style.width = 'min(420px, 95vw)';\n container.style.height = 'min(600px, 90vh)';\n container.style.background = '#12161b';\n container.style.border = '1px solid #222b35';\n container.style.borderRadius = '12px';\n container.style.boxShadow = '0 12px 48px rgba(0,0,0,0.7)';\n container.style.overflow = 'hidden';\n container.style.position = 'relative';\n\n // Create close button\n const closeBtn = document.createElement('button');\n closeBtn.textContent = '×';\n closeBtn.setAttribute('aria-label', 'Close');\n closeBtn.style.position = 'absolute';\n closeBtn.style.top = '6px';\n closeBtn.style.right = '8px';\n closeBtn.style.zIndex = '2';\n closeBtn.style.background = 'transparent';\n closeBtn.style.color = '#e6eef8';\n closeBtn.style.border = 'none';\n closeBtn.style.fontSize = '20px';\n closeBtn.style.cursor = 'pointer';\n closeBtn.onclick = () => this.closeOverlay();\n\n // Create iframe\n const iframe = document.createElement('iframe');\n iframe.src = url;\n iframe.style.width = '100%';\n iframe.style.height = '100%';\n iframe.style.border = '0';\n iframe.referrerPolicy = 'no-referrer';\n iframe.allow = 'clipboard-read; clipboard-write;';\n\n container.appendChild(closeBtn);\n container.appendChild(iframe);\n overlay.appendChild(container);\n document.body.appendChild(overlay);\n\n // Close on Escape\n const onKey = (e: KeyboardEvent): void => {\n if (e.key === 'Escape') {\n this.closeOverlay();\n }\n };\n document.addEventListener('keydown', onKey, { capture: true });\n\n this.overlayEl = overlay;\n this._iframeEl = iframe;\n this.overlayCleanup = () => {\n document.removeEventListener('keydown', onKey, { capture: true });\n };\n\n return true;\n }\n\n private closeOverlay(): void {\n try {\n this.overlayCleanup?.();\n } catch {\n // Ignore errors\n }\n this.overlayCleanup = null;\n\n if (this.overlayEl?.parentNode) {\n this.overlayEl.parentNode.removeChild(this.overlayEl);\n }\n\n this.overlayEl = null;\n this._iframeEl = null;\n }\n\n private async safeJson(response: Response): Promise<any> {\n try {\n return await response.json();\n } catch {\n return null;\n }\n }\n\n private loadPersistedSession(): AuthSession | null {\n try {\n if (typeof localStorage === 'undefined') return null;\n const stored = localStorage.getItem(this.storageKey);\n if (!stored) return null;\n\n const session = JSON.parse(stored) as AuthSession;\n\n // Validate session has required fields and hasn't expired\n if (!session?.authToken || !session?.expiresAt) return null;\n if (Date.now() >= session.expiresAt) {\n localStorage.removeItem(this.storageKey);\n return null;\n }\n\n return session;\n } catch {\n return null;\n }\n }\n\n private persistSession(session: AuthSession | null): void {\n try {\n if (typeof localStorage === 'undefined') return;\n\n if (session && this.config.persistSession) {\n localStorage.setItem(this.storageKey, JSON.stringify(session));\n } else {\n localStorage.removeItem(this.storageKey);\n }\n } catch {\n // Ignore storage errors (e.g., private browsing mode)\n }\n }\n}\n","import type { SignerConfig } from '../types/signers';\n\nfunction sanitizeErrorMessage(status: number, text: string): string {\n // Sanitize error messages to avoid leaking sensitive server information\n let errorMessage = `Emblem signer error ${status}`;\n\n if (status >= 500) {\n errorMessage += ': Internal server error';\n } else if (status === 401 || status === 403) {\n errorMessage += ': Authentication failed';\n } else if (status === 404) {\n errorMessage += ': Resource not found';\n } else if (status === 405) {\n errorMessage += ': Method not allowed';\n } else if (text) {\n // For 4xx client errors, include limited error details\n errorMessage += `: ${text.substring(0, 200)}`; // Limit to 200 chars\n }\n\n return errorMessage;\n}\n\nasync function resolveAuthHeaders(config: SignerConfig): Promise<Record<string, string>> {\n // Priority: custom headers -> jwt/getJwt/sdk -> apiKey (deprecated)\n if (typeof config.getAuthHeaders === 'function') {\n const h = await config.getAuthHeaders();\n if (h && typeof h === 'object') return h;\n }\n\n const tok =\n config.jwt ??\n (typeof config.getJwt === 'function' ? await config.getJwt() : undefined) ??\n config.sdk?.getSession()?.authToken ??\n undefined;\n\n if (tok) {\n return { Authorization: `Bearer ${tok}` };\n }\n\n // apiKey is deprecated but still supported as fallback\n if (config.apiKey) {\n return { 'x-api-key': config.apiKey };\n }\n\n throw new Error(\n 'No authentication available: provide jwt, getJwt(), getAuthHeaders(), sdk, or apiKey'\n );\n}\n\nexport async function emblemPost<T = unknown>(\n path: string,\n body: unknown,\n config: SignerConfig\n): Promise<T> {\n const baseUrl = config.baseUrl ?? 'https://api.emblemvault.ai';\n const authHeaders = await resolveAuthHeaders(config);\n const res = await fetch(`${baseUrl}${path}`, {\n method: 'POST',\n headers: {\n 'content-type': 'application/json',\n ...authHeaders,\n },\n body: JSON.stringify(body, (_key: string, value: unknown) =>\n typeof value === 'bigint' ? value.toString() : value\n ),\n });\n\n if (!res.ok) {\n const text = await res.text().catch(() => '');\n throw new Error(sanitizeErrorMessage(res.status, text));\n }\n\n return res.json() as Promise<T>;\n}\n\nexport async function emblemGet<T = unknown>(path: string, config: SignerConfig): Promise<T> {\n const baseUrl = config.baseUrl ?? 'https://api.emblemvault.ai';\n const authHeaders = await resolveAuthHeaders(config);\n const res = await fetch(`${baseUrl}${path}`, {\n method: 'GET',\n headers: authHeaders,\n });\n\n if (!res.ok) {\n const text = await res.text().catch(() => '');\n throw new Error(sanitizeErrorMessage(res.status, text));\n }\n\n return res.json() as Promise<T>;\n}\n","import type { SignerConfig } from '../types/signers';\n\n/**\n * Environment detection utilities for warning about unsafe usage patterns\n */\n\n/**\n * Detect if code is running in a browser environment\n */\nexport function isBrowserEnvironment(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/**\n * Check if we're in a Node.js server environment\n */\nexport function isNodeEnvironment(): boolean {\n return (\n typeof process !== 'undefined' && process.versions != null && process.versions.node != null\n );\n}\n\n/**\n * Validate baseUrl format\n */\nexport function validateBaseUrl(baseUrl?: string): void {\n if (!baseUrl) return; // undefined is ok, will use default\n\n if (!baseUrl.startsWith('http://') && !baseUrl.startsWith('https://')) {\n throw new Error('baseUrl must be a valid HTTP(S) URL');\n }\n\n // Warn about http (not https)\n if (\n baseUrl.startsWith('http://') &&\n !baseUrl.includes('localhost') &&\n !baseUrl.includes('127.0.0.1')\n ) {\n console.warn(\n '[Emblem Security Warning] baseUrl uses HTTP instead of HTTPS. This is insecure for production use.'\n );\n }\n}\n\n/**\n * Validate Ethereum address format\n */\nexport function validateEthereumAddress(address: string): void {\n if (!address || typeof address !== 'string') {\n throw new Error('Address is required');\n }\n\n if (!address.startsWith('0x')) {\n throw new Error('Address must start with 0x');\n }\n\n if (!/^0x[0-9a-fA-F]{40}$/.test(address)) {\n throw new Error('Invalid Ethereum address format');\n }\n}\n\n/**\n * Validate vault ID\n */\nexport function validateVaultId(vaultId: string): void {\n if (!vaultId || typeof vaultId !== 'string') {\n throw new Error('vaultId is required');\n }\n\n if (vaultId.trim() === '') {\n throw new Error('vaultId cannot be empty');\n }\n}\n\n/**\n * Safe number conversion with bounds checking\n */\nexport function toSafeNumber(value: unknown, fieldName: string): number {\n const num = Number(value);\n\n if (!Number.isSafeInteger(num)) {\n throw new Error(\n `${fieldName} value ${value} exceeds safe integer range (max: ${Number.MAX_SAFE_INTEGER})`\n );\n }\n\n return num;\n}\n\n/**\n * Extended config with security options\n */\nexport interface SignerSecurityConfig extends SignerConfig {\n /**\n * Enable debug logging for security-related checks\n * @default false\n */\n debugSecurity?: boolean;\n}\n\n/**\n * Validate signer configuration\n */\nexport function validateSignerConfig(config: SignerSecurityConfig): void {\n // Validate auth: require at least one method (jwt, getJwt, getAuthHeaders)\n const hasJwt = !!config.jwt;\n const hasGetJwt = typeof config.getJwt === 'function';\n const hasHeaders = typeof config.getAuthHeaders === 'function';\n\n if (!hasJwt && !hasGetJwt && !hasHeaders) {\n throw new Error('Authentication required: provide jwt, getJwt(), or getAuthHeaders()');\n }\n\n // Validate baseUrl if provided\n if (config.baseUrl) {\n validateBaseUrl(config.baseUrl);\n }\n\n // Security audit logging\n if (config.debugSecurity) {\n console.log('[Emblem Security Debug]', {\n environment: isBrowserEnvironment() ? 'browser' : 'node',\n hasBaseUrl: !!config.baseUrl,\n timestamp: new Date().toISOString(),\n });\n }\n}\n","import type { Hex } from '../types/signers';\nimport { toSafeNumber } from './validation';\n\nexport function toHexIfBigInt(v: unknown): unknown {\n return typeof v === 'bigint' ? '0x' + v.toString(16) : v;\n}\n\n/**\n * viem txs sometimes have bigint / hex / optional fields. Ethers serializers\n * accept hex strings for numeric fields. Normalize where helpful.\n */\nexport function normalizeTxForEmblem(tx: Record<string, unknown>): Record<string, unknown> {\n const out: Record<string, unknown> = { ...tx };\n\n if (out.value !== undefined) out.value = toHexIfBigInt(out.value);\n if (out.gas !== undefined) {\n out.gasLimit = toHexIfBigInt(out.gas);\n delete out.gas;\n }\n if (out.gasLimit !== undefined) out.gasLimit = toHexIfBigInt(out.gasLimit);\n if (out.gasPrice !== undefined) out.gasPrice = toHexIfBigInt(out.gasPrice);\n if (out.maxFeePerGas !== undefined) out.maxFeePerGas = toHexIfBigInt(out.maxFeePerGas);\n if (out.maxPriorityFeePerGas !== undefined)\n out.maxPriorityFeePerGas = toHexIfBigInt(out.maxPriorityFeePerGas);\n if (out.nonce !== undefined) out.nonce = toSafeNumber(out.nonce, 'nonce');\n if (out.chainId !== undefined) out.chainId = toSafeNumber(out.chainId, 'chainId');\n\n // Some backends only accept legacy fields; fold EIP-1559 into gasPrice and drop unsupported keys\n if (out.maxFeePerGas !== undefined || out.maxPriorityFeePerGas !== undefined) {\n if (out.gasPrice === undefined && out.maxFeePerGas !== undefined) {\n out.gasPrice = out.maxFeePerGas;\n }\n delete out.maxFeePerGas;\n delete out.maxPriorityFeePerGas;\n }\n\n // Remove fields commonly unsupported by legacy serializers\n delete out.type;\n delete out.accessList;\n delete out.account;\n delete out.chain;\n delete out.from;\n\n return out;\n}\n\nexport function isHexString(value: unknown): value is Hex {\n return typeof value === 'string' && /^0x[0-9a-fA-F]*$/.test(value);\n}\n\nexport function bytesToHex(bytes: ArrayLike<number>): Hex {\n let out = '0x';\n for (let i = 0; i < bytes.length; i++) {\n out += (bytes[i] as number).toString(16).padStart(2, '0');\n }\n return out as Hex;\n}\n","import type { SignerConfig, SignerVaultInfo, Hex } from '../types/signers';\nimport { emblemPost } from './http';\n\nexport async function fetchVaultInfo(config: SignerConfig): Promise<SignerVaultInfo> {\n // Note: The server only supports POST for /vault/info\n const data: Partial<{\n vaultId: string;\n address: string;\n evmAddress: Hex;\n created_by?: string;\n }> = await emblemPost('/vault/info', {}, config);\n\n // Validate required response data (vaultId + evmAddress are required for EVM)\n if (!data || !data.vaultId || !data.evmAddress) {\n throw new Error('Invalid vault info response: missing required fields');\n }\n\n if (!String(data.evmAddress).startsWith('0x')) {\n throw new Error('Invalid evmAddress format in response');\n }\n\n return {\n vaultId: data.vaultId,\n tokenId: data.vaultId,\n address: data.address || '', // Solana address may be absent; keep optional\n evmAddress: data.evmAddress as Hex,\n created_by: data.created_by,\n };\n}\n","import type { Hex, SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { bytesToHex, isHexString, normalizeTxForEmblem } from './utils';\nimport { fetchVaultInfo } from './vault';\n\n// Minimal viem types to avoid hard dependency\ninterface ViemAccount {\n address: Hex;\n signMessage: (args: { message: unknown }) => Promise<Hex>;\n signTypedData: (typedData: unknown) => Promise<Hex>;\n signTransaction: (tx: unknown, opts?: unknown) => Promise<Hex>;\n type: 'local';\n source: 'custom';\n publicKey?: Hex;\n}\n\nexport async function toViemAccount(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<ViemAccount> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n const { evmAddress, vaultId } = info;\n\n // Dynamically import viem's toAccount\n // String concatenation prevents bundlers from statically analyzing the import\n const viemAccounts = 'viem/accounts';\n const { toAccount } = await import(/* @vite-ignore */ viemAccounts);\n\n return toAccount({\n address: evmAddress,\n\n async signMessage({ message }: { message: unknown }): Promise<Hex> {\n let payload: string;\n let isRaw = false;\n\n if (typeof message === 'string') {\n payload = message;\n isRaw = false;\n } else if (message && typeof (message as { raw?: unknown }).raw !== 'undefined') {\n const raw = (message as { raw: unknown }).raw;\n payload = typeof raw === 'string' ? raw : bytesToHex(raw as ArrayLike<number>);\n isRaw = true;\n } else if (message instanceof Uint8Array) {\n payload = bytesToHex(message);\n isRaw = false;\n } else if (isHexString(message)) {\n payload = message as string;\n isRaw = false;\n } else {\n // Don't silently convert objects to \"[object Object]\"\n throw new Error(\n `Unsupported message type: ${typeof message}. Expected string, Uint8Array, or hex string.`\n );\n }\n\n const data = await emblemPost<{\n signerAddress: string;\n signature: Hex;\n }>('/sign-eth-message', { vaultId, message: payload, raw: isRaw }, config);\n\n return data.signature;\n },\n\n async signTypedData(typedData: unknown): Promise<Hex> {\n const { domain, types, message } = typedData as {\n domain: unknown;\n types: unknown;\n message: unknown;\n };\n const data = await emblemPost<{\n signerAddress: string;\n signature: Hex;\n }>('/sign-typed-message', { vaultId, domain, types, message }, config);\n\n return data.signature;\n },\n\n async signTransaction(tx: unknown, _opts?: unknown): Promise<Hex> {\n const normalizedTx = normalizeTxForEmblem(tx as Record<string, unknown>);\n\n const data = await emblemPost<{\n signedTransaction: Hex;\n }>('/sign-eth-tx', { vaultId, transaction: normalizedTx }, config);\n\n return data.signedTransaction;\n },\n }) as ViemAccount;\n}\n","import type { Hex, SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { bytesToHex, normalizeTxForEmblem } from './utils';\nimport { fetchVaultInfo } from './vault';\n\n// ethers v6 compatible interface (like solana pattern - no runtime dependency)\nexport interface EmblemEthersWallet {\n getAddress(): Promise<string>;\n signMessage(message: string | Uint8Array): Promise<string>;\n signTypedData(\n domain: unknown,\n types: Record<string, Array<{ name: string; type: string }>>,\n value: Record<string, unknown>\n ): Promise<string>;\n signTransaction(tx: unknown): Promise<string>;\n sendTransaction(tx: unknown): Promise<unknown>;\n connect(provider: unknown): EmblemEthersWallet;\n provider: unknown;\n // Additional methods\n initialize(): Promise<void>;\n getVaultId(): string;\n setChainId(chainId: number): void;\n getChainId(): number;\n signAndBroadcast(transaction: unknown, waitForReceipt?: boolean): Promise<string>;\n}\n\nexport async function toEthersWallet(\n config: SignerConfig,\n provider?: unknown | null,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemEthersWallet> {\n // Dynamic import - only loads ethers when this function is called\n // String concatenation prevents bundlers from statically analyzing the import\n let ethers: typeof import('ethers');\n try {\n const moduleName = 'ethers';\n ethers = await import(/* @vite-ignore */ moduleName);\n } catch {\n throw new Error('ethers is required for toEthersWallet(). Install it with: npm install ethers');\n }\n\n const { AbstractSigner, resolveAddress } = ethers;\n type AbstractProvider = import('ethers').AbstractProvider;\n type TransactionRequest = import('ethers').TransactionRequest;\n type TransactionResponse = import('ethers').TransactionResponse;\n type TransactionLike = import('ethers').TransactionLike<string>;\n type TypedDataDomain = import('ethers').TypedDataDomain;\n type TypedDataField = import('ethers').TypedDataField;\n\n const info = infoOverride ?? (await fetchVaultInfo(config));\n\n // Class defined inside function after dynamic import\n class EmblemEthersWalletImpl extends AbstractSigner {\n private readonly _config: SignerConfig;\n private _address: Hex | null = null;\n private _vaultId: string | null = null;\n private _chainId = 1;\n private _initPromise?: Promise<void>;\n\n constructor(\n signerConfig: SignerConfig,\n signerProvider?: AbstractProvider | null,\n seed?: { address?: Hex; vaultId?: string; chainId?: number }\n ) {\n super(signerProvider ?? null);\n this._config = signerConfig;\n if (seed?.address) this._address = seed.address;\n if (seed?.vaultId) this._vaultId = seed.vaultId;\n if (seed?.chainId) this._chainId = seed.chainId;\n }\n\n async initialize(): Promise<void> {\n if (this._initPromise) return this._initPromise;\n\n this._initPromise = fetchVaultInfo(this._config)\n .then((vaultInfo) => {\n this._address = vaultInfo.evmAddress;\n this._vaultId = vaultInfo.vaultId;\n })\n .catch((err) => {\n this._initPromise = undefined;\n throw err;\n });\n\n return this._initPromise;\n }\n\n async getAddress(): Promise<string> {\n if (!this._address) await this.initialize();\n return this._address!;\n }\n\n getVaultId(): string {\n if (!this._vaultId) throw new Error('Wallet not initialized. Call initialize() first.');\n return this._vaultId;\n }\n\n setChainId(chainId: number): void {\n this._chainId = chainId;\n }\n\n getChainId(): number {\n return this._chainId;\n }\n\n connect(newProvider: AbstractProvider): EmblemEthersWalletImpl {\n if (!newProvider) throw new Error('Provider cannot be null');\n return new EmblemEthersWalletImpl(this._config, newProvider, {\n address: this._address ?? undefined,\n vaultId: this._vaultId ?? undefined,\n chainId: this._chainId,\n });\n }\n\n async signMessage(message: string | Uint8Array): Promise<string> {\n if (!this._vaultId) await this.initialize();\n const payload = typeof message === 'string' ? message : bytesToHex(message);\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-eth-message',\n { vaultId: this._vaultId!, message: payload },\n this._config\n );\n return data.signature;\n }\n\n async signTypedData(\n domain: TypedDataDomain,\n types: Record<string, Array<TypedDataField>>,\n value: Record<string, unknown>\n ): Promise<string> {\n if (!this._vaultId) await this.initialize();\n const cleanTypes = { ...types };\n if (cleanTypes && (cleanTypes as Record<string, unknown>).EIP712Domain) {\n delete (cleanTypes as Record<string, unknown>).EIP712Domain;\n }\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-typed-message',\n { vaultId: this._vaultId!, domain, types: cleanTypes, message: value },\n this._config\n );\n return data.signature;\n }\n\n async _signTypedData(\n domain: TypedDataDomain,\n types: Record<string, Array<TypedDataField>>,\n value: Record<string, unknown>\n ): Promise<string> {\n return this.signTypedData(domain, types, value);\n }\n\n async signTransaction(tx: TransactionRequest): Promise<string> {\n if (!this._vaultId) await this.initialize();\n const from = (tx as Record<string, unknown>).from as string | undefined;\n const addr = await this.getAddress();\n\n if (from && from.toLowerCase() !== addr.toLowerCase()) {\n throw new Error('transaction from does not match signer address');\n }\n\n const toSign = this.provider\n ? ({ ...await this.populateTransaction(tx) } as Record<string, unknown>)\n : ({ ...tx } as Record<string, unknown>);\n if (toSign.from) delete toSign.from;\n if (!('to' in toSign) || !toSign.to) {\n throw new Error(\"Transaction must have a 'to' address\");\n }\n if (toSign.nonce === undefined || toSign.nonce === null) {\n throw new Error('Transaction must have a nonce');\n }\n const normalized = normalizeTxForEmblem(toSign);\n const resp = await emblemPost<{ signedTransaction: Hex }>(\n '/sign-eth-tx',\n { vaultId: this._vaultId!, transaction: normalized, options: { chainId: this._chainId } },\n this._config\n );\n return resp.signedTransaction;\n }\n\n async sendTransaction(tx: TransactionRequest): Promise<TransactionResponse> {\n if (!this.provider) throw new Error('Provider required to send transaction');\n const signed = await this.signTransaction(tx);\n return await this.provider.broadcastTransaction(signed);\n }\n\n async populateTransaction(transaction: TransactionRequest): Promise<TransactionLike> {\n const tx = { ...transaction } as TransactionRequest;\n if (!this.provider) throw new Error('Provider required to populate transaction');\n const fromAddress = tx.from\n ? await resolveAddress(tx.from, this.provider)\n : await this.getAddress();\n\n let chainId: bigint;\n if (!tx.chainId) {\n const network = await this.provider.getNetwork();\n chainId = network.chainId;\n this._chainId = Number(network.chainId);\n } else {\n chainId = BigInt(tx.chainId);\n this._chainId = Number(tx.chainId);\n }\n\n const nonce =\n tx.nonce != null\n ? Number(tx.nonce)\n : await this.provider.getTransactionCount(fromAddress, 'pending');\n const toAddress = tx.to ? await resolveAddress(tx.to, this.provider) : null;\n const value = tx.value ? BigInt(tx.value.toString()) : 0n;\n\n let gasLimit: bigint;\n if (!tx.gasLimit) {\n try {\n gasLimit = await this.provider.estimateGas({ ...tx, from: fromAddress });\n } catch {\n gasLimit = 21000n;\n }\n } else {\n gasLimit = BigInt(tx.gasLimit.toString());\n }\n\n let gasPrice: bigint | null = null;\n if (!tx.gasPrice && tx.type !== 2) {\n const feeData = await this.provider.getFeeData();\n gasPrice = feeData.gasPrice ?? null;\n } else if (tx.gasPrice) {\n gasPrice = BigInt(tx.gasPrice.toString());\n }\n\n const populated: TransactionLike = {\n from: fromAddress,\n to: toAddress,\n value,\n nonce,\n gasLimit,\n data: tx.data as string | undefined,\n chainId,\n type: tx.type || undefined,\n };\n if (gasPrice !== null) populated.gasPrice = gasPrice;\n if (tx.maxFeePerGas) populated.maxFeePerGas = BigInt(tx.maxFeePerGas.toString());\n if (tx.maxPriorityFeePerGas)\n populated.maxPriorityFeePerGas = BigInt(tx.maxPriorityFeePerGas.toString());\n return populated;\n }\n\n async signAndBroadcast(\n transaction: TransactionRequest,\n waitForReceipt: boolean = false\n ): Promise<string> {\n if (!this.provider) throw new Error('Provider required to send transaction');\n const signed = await this.signTransaction(transaction);\n const resp = await this.provider.broadcastTransaction(signed);\n const hash = resp.hash as string;\n if (waitForReceipt) {\n await this.provider.waitForTransaction(hash);\n }\n return hash;\n }\n }\n\n return new EmblemEthersWalletImpl(config, provider as AbstractProvider | null, {\n address: info.evmAddress,\n vaultId: info.vaultId,\n });\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import type { Hex, SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { bytesToHex, normalizeTxForEmblem } from './utils';\nimport { fetchVaultInfo } from './vault';\n\nexport class EmblemWeb3Adapter {\n readonly address: Hex;\n readonly #vaultId: string;\n readonly #config: SignerConfig;\n\n constructor(address: Hex, vaultId: string, config: SignerConfig) {\n this.address = address;\n this.#vaultId = vaultId;\n this.#config = config;\n }\n\n async signMessage(message: string | Uint8Array): Promise<Hex> {\n const payload = typeof message === 'string' ? message : bytesToHex(message);\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-eth-message',\n { vaultId: this.#vaultId, message: payload },\n this.#config\n );\n return data.signature;\n }\n\n async signTypedData(\n domain: Record<string, unknown>,\n types: Record<string, unknown>,\n message: Record<string, unknown>\n ): Promise<Hex> {\n const data = await emblemPost<{ signerAddress: string; signature: Hex }>(\n '/sign-typed-message',\n { vaultId: this.#vaultId, domain, types, message },\n this.#config\n );\n return data.signature;\n }\n\n async signTransaction(tx: Record<string, unknown>): Promise<{ rawTransaction: Hex }> {\n const normalized = normalizeTxForEmblem(tx);\n const resp = await emblemPost<{ signedTransaction: Hex }>(\n '/sign-eth-tx',\n { vaultId: this.#vaultId, transaction: normalized },\n this.#config\n );\n return { rawTransaction: resp.signedTransaction };\n }\n}\n\nexport async function toWeb3Adapter(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemWeb3Adapter> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n return new EmblemWeb3Adapter(info.evmAddress, info.vaultId, config);\n}\n","import type { SignerConfig, SignerVaultInfo } from '../types/signers';\nimport { emblemPost } from './http';\nimport { fetchVaultInfo } from './vault';\n\n// @solana/web3.js compatible interfaces\nexport interface SolanaSignerInterface {\n publicKey: string;\n signMessage(message: Uint8Array | string): Promise<Uint8Array>;\n signTransaction(transaction: unknown): Promise<unknown>;\n}\n\n// For Solana Kit compatibility\nexport interface SolanaKitSignerInterface {\n publicKey: string;\n signMessage(message: Uint8Array | string): Promise<Uint8Array>;\n signTransaction(transaction: unknown): Promise<unknown>;\n}\n\nexport class EmblemSolanaSigner implements SolanaSignerInterface, SolanaKitSignerInterface {\n readonly publicKey: string; // base58 address\n private readonly config: SignerConfig;\n private readonly vaultId: string;\n\n constructor(config: SignerConfig, vaultInfo: SignerVaultInfo) {\n this.publicKey = vaultInfo.address;\n this.config = config;\n this.vaultId = vaultInfo.vaultId;\n }\n\n async signMessage(message: Uint8Array | string): Promise<Uint8Array> {\n // Convert message to bytes if it's a string\n const messageBytes = typeof message === 'string' ? new TextEncoder().encode(message) : message;\n\n // Convert to base64 for API transmission\n const messageBase64 = btoa(String.fromCharCode(...messageBytes));\n\n const response = await emblemPost<{ signature: string }>(\n '/sign-solana-message',\n { vaultId: this.vaultId, message: messageBase64 },\n this.config\n );\n\n // The server returns a signature - could be base64, base58, or hex\n // Let's check what format we're getting and handle accordingly\n\n // Try to decode as base58 first (Solana standard)\n try {\n // Use @solana/web3.js bs58 decoder if available, otherwise fallback\n const win = typeof window !== 'undefined' ? (window as unknown as { bs58?: { decode(s: string): Uint8Array } }) : undefined;\n if (win?.bs58) {\n return win.bs58.decode(response.signature);\n }\n // For Node.js environments or if bs58 is not globally available\n // The signature might be base64 encoded\n const signatureBytes = Uint8Array.from(atob(response.signature), (c) => c.charCodeAt(0));\n return signatureBytes;\n } catch (e) {\n // If base64 decode fails, try treating as hex\n if (response.signature.startsWith('0x')) {\n const hex = response.signature.slice(2);\n const bytes = new Uint8Array(hex.length / 2);\n for (let i = 0; i < hex.length; i += 2) {\n bytes[i / 2] = parseInt(hex.substr(i, 2), 16);\n }\n return bytes;\n }\n throw new Error(`Unable to decode signature format: ${e}`);\n }\n }\n\n async signTransaction(transaction: unknown): Promise<unknown> {\n // Serialize transaction for API transmission\n const serializedTransaction = this.serializeTransaction(transaction);\n\n const response = await emblemPost<{\n serializedSignedTransaction?: string;\n signedTransaction?: string;\n }>(\n '/sign-solana-transaction',\n {\n vaultId: this.vaultId,\n transactionToSign: serializedTransaction, // Pass the base64 string directly\n broadcast: false, // Don't broadcast, just sign\n versionedTransaction: true, // Match API test format\n },\n this.config\n );\n\n // Parse the signed transaction response - handle both response formats\n const signedTxData = response.serializedSignedTransaction || response.signedTransaction;\n if (!signedTxData) {\n throw new Error('No signed transaction data received from server');\n }\n\n return this.deserializeTransaction(signedTxData);\n }\n\n private serializeTransaction(tx: unknown): string {\n // Handle different transaction formats from @solana/web3.js\n if (tx && typeof tx === 'object') {\n // For VersionedTransaction or Transaction objects\n if ((tx as { serialize?: () => Uint8Array }).serialize) {\n // Server expects just the base64 string, not an object\n const serialized = (tx as { serialize: () => Uint8Array }).serialize();\n const base64 = btoa(String.fromCharCode(...serialized));\n return base64;\n }\n // For transaction objects with instructions\n if (\n (tx as { instructions?: unknown }).instructions ||\n (tx as { recentBlockhash?: unknown }).recentBlockhash\n ) {\n throw new Error(\n 'Cannot serialize unsigned transaction objects. Please use VersionedTransaction.'\n );\n }\n }\n\n // Fallback: assume it's already a string\n return tx as string;\n }\n\n private deserializeTransaction(signedTxData: unknown): unknown {\n // If it's already an object (shouldn't happen based on type), handle it\n if (\n typeof signedTxData === 'object' &&\n signedTxData &&\n (signedTxData as { serializedSignedTransaction?: string }).serializedSignedTransaction\n ) {\n signedTxData = (signedTxData as { serializedSignedTransaction: string })\n .serializedSignedTransaction;\n }\n\n // If it's a string, decode from base64\n if (typeof signedTxData === 'string') {\n try {\n // The server returns base64, so decode it\n const decoded = atob(signedTxData);\n return new Uint8Array(decoded.split('').map((c) => c.charCodeAt(0)));\n } catch (e) {\n console.error('Failed to decode transaction:', e);\n throw new Error(`Unable to deserialize transaction response: ${e}`);\n }\n }\n\n // If it's already a Uint8Array or other type, return as-is\n return signedTxData;\n }\n\n // Additional utility methods for @solana/web3.js compatibility\n\n /** Get the vault ID for this signer */\n getVaultId(): string {\n return this.vaultId;\n }\n\n /** Sign multiple transactions in batch */\n async signAllTransactions(transactions: unknown[]): Promise<unknown[]> {\n // Sign each transaction individually for now\n // Could be optimized with a batch API endpoint in the future\n const results = [];\n for (const tx of transactions) {\n results.push(await this.signTransaction(tx));\n }\n return results;\n }\n\n /** Check if this signer can sign for a given public key */\n canSign(publicKey: string): boolean {\n return publicKey === this.publicKey;\n }\n\n /** Sign and optionally broadcast a transaction */\n async signAndBroadcast(transaction: unknown, broadcast: boolean = true): Promise<string> {\n // Serialize transaction for API transmission\n const serializedTransaction = this.serializeTransaction(transaction);\n\n const response = await emblemPost<{\n transactionSignature?: string;\n serializedSignedTransaction?: string;\n }>(\n '/sign-solana-transaction',\n {\n vaultId: this.vaultId,\n transactionToSign: serializedTransaction, // Pass the base64 string directly\n broadcast: broadcast,\n versionedTransaction: true, // Match API test format\n },\n this.config\n );\n\n if (broadcast) {\n // Return the transaction signature\n if (!response.transactionSignature) {\n throw new Error('No transaction signature received from broadcast');\n }\n return response.transactionSignature;\n } else {\n // Return the signed transaction data\n if (!response.serializedSignedTransaction) {\n throw new Error('No signed transaction data received from server');\n }\n return response.serializedSignedTransaction;\n }\n }\n}\n\nexport async function toSolanaWeb3Signer(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemSolanaSigner> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n return new EmblemSolanaSigner(config, info);\n}\n\nexport async function toSolanaKitSigner(\n config: SignerConfig,\n infoOverride?: SignerVaultInfo\n): Promise<EmblemSolanaSigner> {\n const info = infoOverride ?? (await fetchVaultInfo(config));\n return new EmblemSolanaSigner(config, info);\n}\n"],"names":["SessionManager","constructor","config","this","session","timer","events","onRefresh","refreshSkewMs","setSession","schedule","emit","getSession","clear","cancel","on","event","handler","push","off","handlers","index","indexOf","splice","destroy","Object","keys","forEach","key","payload","error","clearTimeout","expiresAt","now","Date","ttl","refreshIn","Math","max","inMs","setTimeout","async","refreshed","authToken","EmblemAuthSDK","pendingNonce","overlayEl","_iframeEl","overlayCleanup","_cachedVaultInfo","appId","Error","authUrl","apiUrl","persistSession","storageKey","messageHandler","onMessage","bind","window","addEventListener","sessionMgr","current","refreshSession","s","info","restored","loadPersistedSession","hydrateSession","authenticateWallet","params","network","message","signature","publicKey","address","url","replace","response","fetch","method","headers","body","JSON","stringify","ok","errorData","safeJson","status","data","json","onSuccess","openAuthModal","origin","location","initData","initError","getAuthInit","nonce","randomId","modalUrl","resolveModalUrl","state","base","URL","searchParams","set","toString","mode","modalMode","opened","openIframeModal","features","popupFeatures","open","emitError","authOrigin","tryGetOriginFromConfig","refreshUrl","hasTokenInSession","Boolean","refreshToken","credentials","nextSession","getVaultInfo","apiBase","resp","Authorization","vaultInfo","getVaultApiKey","token","vaultId","user","apiKeyHash","infoRes","infoJson","raw","pkp","api_key_hash","rawIdentifier","identifier","scopedIdentifier","vaultsRes","encodeURIComponent","vaults","match","Array","isArray","find","v","String","tokenId","token_id","genRes","genJson","apiKey","decRes","dataToEncryptHash","decJson","decrypted","decryptedString","logout","getSignerContext","baseUrl","getJwt","evmAddress","solanaAddress","created_by","toViemAccount","Promise","toEthersWallet","provider","toWeb3Adapter","toSolanaWeb3Signer","toSolanaKitSigner","removeEventListener","closeOverlay","href","Set","filter","has","type","onCancel","undefined","onError","top","outerHeight","outerWidth","array","Uint8Array","crypto","getRandomValues","i","length","floor","random","from","b","padStart","join","catch","overlay","document","createElement","setAttribute","style","position","inset","background","zIndex","display","alignItems","justifyContent","container","width","height","border","borderRadius","boxShadow","overflow","closeBtn","textContent","right","color","fontSize","cursor","onclick","iframe","src","referrerPolicy","allow","appendChild","onKey","e","capture","parentNode","removeChild","localStorage","stored","getItem","parse","removeItem","setItem","emblemPost","path","authHeaders","getAuthHeaders","h","tok","jwt","sdk","resolveAuthHeaders","res","_key","value","text","errorMessage","substring","sanitizeErrorMessage","toSafeNumber","fieldName","num","Number","isSafeInteger","MAX_SAFE_INTEGER","toHexIfBigInt","normalizeTxForEmblem","tx","out","gas","gasLimit","gasPrice","maxFeePerGas","maxPriorityFeePerGas","chainId","accessList","account","chain","bytesToHex","bytes","fetchVaultInfo","startsWith","infoOverride","toAccount","import","signMessage","isRaw","test","signTypedData","typedData","domain","types","signTransaction","_opts","normalizedTx","transaction","signedTransaction","ethers","moduleName","AbstractSigner","resolveAddress","EmblemEthersWalletImpl","signerConfig","signerProvider","seed","super","_address","_vaultId","_chainId","_config","initialize","_initPromise","then","err","getAddress","getVaultId","setChainId","getChainId","connect","newProvider","cleanTypes","EIP712Domain","_signTypedData","addr","toLowerCase","toSign","populateTransaction","to","normalized","options","sendTransaction","signed","broadcastTransaction","fromAddress","BigInt","getNetwork","getTransactionCount","toAddress","estimateGas","getFeeData","populated","signAndBroadcast","waitForReceipt","hash","waitForTransaction","__classPrivateFieldGet","receiver","kind","f","TypeError","call","get","__classPrivateFieldSet","SuppressedError","EmblemWeb3Adapter","_EmblemWeb3Adapter_vaultId","_EmblemWeb3Adapter_config","rawTransaction","EmblemSolanaSigner","messageBytes","TextEncoder","encode","messageBase64","btoa","fromCharCode","win","bs58","decode","atob","c","charCodeAt","hex","slice","parseInt","substr","serializedTransaction","serializeTransaction","transactionToSign","broadcast","versionedTransaction","signedTxData","serializedSignedTransaction","deserializeTransaction","serialize","serialized","instructions","recentBlockhash","decoded","split","map","signAllTransactions","transactions","results","canSign","transactionSignature"],"mappings":"uPAyBaA,EAOX,WAAAC,CAAYC,EAA+B,IANnCC,KAAOC,QAAuB,KAC9BD,KAAKE,MAA0B,KAEtBF,KAAMG,OAAiE,GAItFH,KAAKI,UAAYL,EAAOK,UACxBJ,KAAKK,cAAgBN,EAAOM,eAAiB,GAC9C,CAKD,UAAAC,CAAWL,GACTD,KAAKC,QAAUA,EACfD,KAAKO,WACLP,KAAKQ,KAAK,UAAWP,EACtB,CAKD,UAAAQ,GACE,OAAOT,KAAKC,OACb,CAKD,KAAAS,GACEV,KAAKC,QAAU,KACfD,KAAKW,SACLX,KAAKQ,KAAK,UAAW,KACtB,CAKD,EAAAI,CAA8BC,EAAUC,GACjCd,KAAKG,OAAOU,KACfb,KAAKG,OAAOU,GAAS,IAEvBb,KAAKG,OAAOU,GAAQE,KAAKD,EAC1B,CAKD,GAAAE,CAA+BH,EAAUC,GACvC,MAAMG,EAAWjB,KAAKG,OAAOU,GAC7B,GAAII,EAAU,CACZ,MAAMC,EAAQD,EAASE,QAAQL,IAChB,IAAXI,GACFD,EAASG,OAAOF,EAAO,EAE1B,CACF,CAKD,OAAAG,GACErB,KAAKW,SACLX,KAAKC,QAAU,KACfqB,OAAOC,KAAKvB,KAAKG,QAAQqB,QAAQC,WACxBzB,KAAKG,OAAOsB,IAEtB,CAEO,IAAAjB,CACNK,EACAa,GAEA,MAAMT,EAAWjB,KAAKG,OAAOU,GAC7B,GAAKI,EAEL,IAAK,MAAMH,KAAWG,EACpB,IACEH,EAAQY,EACT,CAAC,MAAOC,GAER,CAEJ,CAEO,MAAAhB,GACFX,KAAKE,QACP0B,aAAa5B,KAAKE,OAClBF,KAAKE,MAAQ,KAEhB,CAEO,QAAAK,GACNP,KAAKW,SAEL,MAAMV,EAAUD,KAAKC,QACrB,IAAKA,GAAS4B,UAAW,OAEzB,MAAMC,EAAMC,KAAKD,MACXE,EAAM/B,EAAQ4B,UAAYC,EAEhC,GAAIE,GAAO,EAET,YADAhC,KAAKQ,KAAK,iBAAkBP,GAI9B,MAAMgC,EAAYC,KAAKC,IAAI,EAAGH,EAAMhC,KAAKK,eACzCL,KAAKQ,KAAK,qBAAsB,CAAE4B,KAAMH,EAAWD,QAEnDhC,KAAKE,MAAQmC,WAAWC,UACtB,GAAKtC,KAAKI,UAQV,IACE,MAAMmC,QAAkBvC,KAAKI,UAAUH,GACnCsC,GAAWV,WAAaU,EAAUC,WACpCxC,KAAKM,WAAWiC,GAChBvC,KAAKQ,KAAK,mBAAoB+B,IAG1BR,KAAKD,OAAS7B,EAAQ4B,WACxB7B,KAAKQ,KAAK,iBAAkBP,EAGjC,CAAC,MAAO0B,GAEHI,KAAKD,OAAS7B,EAAQ4B,WACxB7B,KAAKQ,KAAK,iBAAkBP,EAE/B,MAtBK8B,KAAKD,OAAS7B,EAAQ4B,WACxB7B,KAAKQ,KAAK,iBAAkBP,IAsB/BgC,EACJ,QC7IUQ,EAaX,WAAA3C,CAAYC,GACV,GAZMC,KAAOC,QAAuB,KAC9BD,KAAY0C,aAAkB,KAE9B1C,KAAS2C,UAAuB,KAChC3C,KAAS4C,UAA6B,KACtC5C,KAAc6C,eAAwB,KAE7B7C,KAAMG,OAA2D,GAC1EH,KAAgB8C,iBAAqB,MAItC/C,GAAQgD,MACX,MAAM,IAAIC,MAAM,qBA8BlB,GA3BAhD,KAAKD,OAAS,IACTA,EACHkD,QAASlD,EAAOkD,SAAW,8BAC3BC,OAAQnD,EAAOmD,QAAU,6BACzBC,eAAgBpD,EAAOoD,iBAAkB,GAE3CnD,KAAKoD,WAAa,kBAAkBrD,EAAOgD,QAC3C/C,KAAKqD,eAAiBrD,KAAKsD,UAAUC,KAAKvD,MAC1CwD,OAAOC,iBAAiB,UAAWzD,KAAKqD,gBAExCrD,KAAK0D,WAAa,IAAI7D,EAAe,CACnCO,UAAWkC,MAAMqB,IACf,IAEE,aADwB3D,KAAK4D,kBACTD,CACrB,CAAC,MACA,OAAOA,CACR,KAKL3D,KAAK0D,WAAW9C,GAAG,iBAAkBiD,GAAK7D,KAAKQ,KAAK,iBAAkBqD,IACtE7D,KAAK0D,WAAW9C,GAAG,mBAAoBiD,GAAK7D,KAAKQ,KAAK,mBAAoBqD,IAC1E7D,KAAK0D,WAAW9C,GAAG,qBAAsBkD,GAAQ9D,KAAKQ,KAAK,qBAAsBsD,IAG7E9D,KAAKD,OAAOoD,eAAgB,CAC9B,MAAMY,EAAW/D,KAAKgE,uBAClBD,GACF/D,KAAKiE,eAAeF,EAEvB,CACF,CAMD,wBAAMG,CAAmBC,GACvB,MAAMC,QAAEA,EAAOC,QAAEA,EAAOC,UAAEA,EAASC,UAAEA,EAASC,QAAEA,GAAYL,EAE5D,IAAKnE,KAAKD,OAAOmD,OACf,MAAM,IAAIF,MAAM,6CAElB,IAAKoB,IAAYC,IAAYC,EAC3B,MAAM,IAAItB,MAAM,4CAGlB,MAAMyB,EAAM,GAAGzE,KAAKD,OAAOmD,OAAOwB,QAAQ,MAAO,sCAC3CC,QAAiBC,MAAMH,EAAK,CAChCI,OAAQ,OACRC,QAAS,CAAE,eAAgB,oBAC3BC,KAAMC,KAAKC,UAAU,CACnBlC,MAAO/C,KAAKD,OAAOgD,MACnBqB,UACAC,UACAC,YACAC,YACAC,cAIJ,IAAKG,EAASO,GAAI,CAChB,MAAMC,QAAkBnF,KAAKoF,SAAST,GAChChD,EAAQ,IAAIqB,MAAMmC,GAAWxD,OAAS,iBAAiBgD,EAASU,UAGtE,MAFA1D,EAAM0D,OAASV,EAASU,OACxB1D,EAAMD,QAAUyD,EACVxD,CACP,CAED,MAAM2D,QAAaX,EAASY,OACtBtF,EAAUqF,GAAMrF,QAUtB,OARIA,IACFD,KAAKC,QAAUA,EACfD,KAAKmD,eAAelD,GACpBD,KAAK0D,WAAWpD,WAAWL,GAC3BD,KAAKD,OAAOyF,YAAYvF,GACxBD,KAAKQ,KAAK,UAAWP,IAGhBA,CACR,CAKD,mBAAMwF,GACJ,MAAMC,EAASlC,OAAOmC,SAASD,OAC/B,IAAIE,EAAoC,KACpCC,EAA8B,KAElC,IACED,QAAiB5F,KAAK8F,YAAY,CAAEJ,UACrC,CAAC,MAAO/D,GACPkE,EAAYlE,CAEb,CAED,MAAMoE,EAAQH,GAAUG,OAAS/F,KAAKgG,WACtChG,KAAK0C,aAAeqD,EAEpB,IAAIE,EAAWjG,KAAKkG,gBAAgB,CAAEH,QAAOL,SAAQS,MAAOP,GAAUO,QAGtE,GAAkC,uBAA9BN,GAAWnE,SAASC,MACtB,IACE,MAAMyE,EAAO,IAAIC,IAAI,WAAYrG,KAAKD,OAAOkD,SAC7CmD,EAAKE,aAAaC,IAAI,QAAS,sBAC/BH,EAAKE,aAAaC,IAAI,QAASvG,KAAKD,OAAOgD,OAC3CqD,EAAKE,aAAaC,IAAI,SAAUb,GAChCO,EAAWG,EAAKI,UACjB,CAAC,MAED,CAGH,MAAMC,EAAOzG,KAAKD,OAAO2G,WAAa,OACtC,IAAIC,GAAS,EAEb,GAAa,WAATF,GAA8B,SAATA,EACvB,IACEE,EAAS3G,KAAK4G,gBAAgBX,EAC/B,CAAC,MAAOtE,GAKR,CAGH,IAAKgF,EAAQ,CACX,MAAME,EAAW7G,KAAK8G,gBAEtB,IADYtD,OAAOuD,KAAKd,EAAU,cAAeY,GACvC,CACR,MAAMlF,EAAQ,IAAIqB,MAAM,qDACxBhD,KAAKgH,UAAUrF,EAChB,CACF,CACF,CAKD,UAAAlB,GACE,OAAOT,KAAKC,OACb,CAQD,oBAAM2D,GACJ,IACE,IAAK5D,KAAKC,QAAS,OAAO,KAG1B,MAAMgH,EAAajH,KAAKkH,yBACxB,IAAKD,EAAY,OAAOjH,KAAKC,QAE7B,MAAMkH,EAAa,GAAGF,qBAIhBG,EAAoBC,QAAQrH,KAAKC,QAAQqH,cAEzC3C,QAAiBC,MAAMuC,EAAY,CACvCtC,OAAQ,OACRC,QAAS,CAAE,eAAgB,oBAC3BC,KAAMC,KAAKC,UACTmC,EAAoB,CAAEE,aAActH,KAAKC,QAAQqH,cAAiB,IAGpEC,YAAa,YAGf,IAAK5C,EAASO,GAAI,OAAOlF,KAAKC,QAE9B,MAAMqF,QAAaX,EAASY,OACtBiC,EAAclC,GAAMrF,QAW1B,OATIuH,IAGFxH,KAAKC,QAAUuH,EACfxH,KAAKmD,eAAeqE,GACpBxH,KAAK0D,WAAWpD,WAAWkH,GAC3BxH,KAAKQ,KAAK,UAAWgH,IAGhBxH,KAAKC,OACb,CAAC,MACA,OAAOD,KAAKC,OACb,CACF,CAKD,kBAAMwH,GACJ,GAAIzH,KAAK8C,iBAAkB,OAAO9C,KAAK8C,iBAEvC,MAAM7C,EAAUD,KAAKS,aACrB,IAAKR,GAASuC,UACZ,MAAM,IAAIQ,MAAM,cAGlB,IAAKhD,KAAKD,OAAOmD,OACf,MAAM,IAAIF,MAAM,sBAGlB,MAAM0E,EAAU1H,KAAKD,OAAOmD,OAAOwB,QAAQ,MAAO,IAC5CiD,QAAa/C,MAAM,GAAG8C,eAAsB,CAChD7C,OAAQ,OACRC,QAAS,CACP8C,cAAiB,UAAU3H,EAAQuC,YACnC,eAAgB,oBAElBuC,KAAM,OAGR,IAAK4C,EAAKzC,GACR,MAAM,IAAIlC,MAAM,8BAGlB,MAAM6E,QAAkBF,EAAKpC,OAE7B,OADAvF,KAAK8C,iBAAmB+E,EACjBA,CACR,CAKD,oBAAMC,GACJ,IAAK9H,KAAKD,OAAOmD,OACf,MAAM,IAAIF,MAAM,sBAGlB,MAAM/C,EAAUD,KAAKS,aACrB,IAAKR,GAASuC,UACZ,MAAM,IAAIQ,MAAM,qBAGlB,MAAM0E,EAAU1H,KAAKD,OAAOmD,OAAOwB,QAAQ,MAAO,IAC5CqD,EAAQ9H,EAAQuC,UAChBwF,EAAU/H,EAAQgI,MAAMD,QAG9B,IAAIE,EAA4B,KAEhC,IACE,MAAMC,QAAgBvD,MAAM,GAAG8C,wBAA+B,CAC5D7C,OAAQ,OACRC,QAAS,CAAE8C,cAAe,UAAUG,OAGtC,GAAII,EAAQjD,GAAI,CACd,MAAMkD,QAAiBD,EAAQ5C,OAC/B2C,EAAaE,GAAUC,KAAKC,KAAKC,cAAgBH,GAAUC,KAAKC,KAAKJ,YAAc,IACpF,CACF,CAAC,MAED,CAGD,IAAKA,EACH,IACE,MAAMnF,EAAQ9C,EAAQ8C,MAChByF,EAAgBvI,EAAQgI,MAAMQ,YAAc,GAC5CC,EAAmB3F,EAAQ,GAAGA,KAASyF,IAAkBA,EAE/D,GAAIE,EAAkB,CACpB,MAAMC,QAAkB/D,MACtB,GAAG8C,gBAAsBkB,mBAAmBF,MAE9C,GAAIC,EAAUzD,GAAI,CAChB,MAAM2D,QAAeF,EAAUpD,OACzBuD,EAAQC,MAAMC,QAAQH,GACxBA,EAAOI,KAAKC,GAAKC,OAAOD,EAAEE,SAAWF,EAAEG,YAAcF,OAAOnB,KAAaa,EAAO,GAChF,KACJX,EAAaY,GAAOP,cAAgBO,GAAOZ,YAAc,IAC1D,CACF,CACF,CAAC,MAED,CAIH,IAAKA,EAAY,CACf,MAAMoB,QAAe1E,MAAM,GAAG8C,gBAAsBkB,mBAAmBZ,aAAoB,CACzFnD,OAAQ,OACRC,QAAS,CAAE8C,cAAe,UAAUG,OAGtC,IAAKuB,EAAOpE,GACV,MAAM,IAAIlC,MAAM,WAAWsG,EAAOjE,UAGpC,MAAMkE,QAAgBD,EAAO/D,OACvBiE,EAASD,GAASC,QAAUD,GAAS9H,KAAO,KAElD,IAAK+H,EACH,MAAM,IAAIxG,MAAM,kBAGlB,OAAOwG,CACR,CAGD,MAAMC,QAAe7E,MAAM,GAAG8C,YAAmB,CAC/C7C,OAAQ,OACRC,QAAS,CACP8C,cAAe,UAAUG,IACzB,eAAgB,oBAElBhD,KAAMC,KAAKC,UAAU,CAAEmE,QAASpB,EAAS0B,kBAAmBxB,MAG9D,IAAKuB,EAAOvE,GACV,MAAM,IAAIlC,MAAM,WAAWyG,EAAOpE,UAGpC,MAAMsE,QAAgBF,EAAOlE,OACvBqE,EAAYD,GAASE,iBAAmB,KAE9C,IAAKD,EACH,MAAM,IAAI5G,MAAM,qBAGlB,OAAO4G,CACR,CAKD,cAAA3F,CAAehE,GACRA,GAASuC,YAEdxC,KAAKC,QAAUA,EACfD,KAAKmD,eAAelD,GACpBD,KAAK8C,iBAAmB,KACxB9C,KAAK0D,WAAWpD,WAAWL,GAC3BD,KAAKQ,KAAK,UAAWP,GACtB,CAKD,MAAA6J,GACE9J,KAAKC,QAAU,KACfD,KAAKmD,eAAe,MACpBnD,KAAK8C,iBAAmB,KACxB9C,KAAK0D,WAAWhD,QAChBV,KAAKQ,KAAK,UAAW,KACtB,CAKD,EAAAI,CAA2BC,EAAUC,GAC9Bd,KAAKG,OAAOU,KACfb,KAAKG,OAAOU,GAAS,IAEvBb,KAAKG,OAAOU,GAAQE,KAAKD,EAC1B,CAKD,GAAAE,CAA4BH,EAAUC,GACpC,MAAMG,EAAWjB,KAAKG,OAAOU,GAC7B,GAAII,EAAU,CACZ,MAAMC,EAAQD,EAASE,QAAQL,IAChB,IAAXI,GACFD,EAASG,OAAOF,EAAO,EAE1B,CACF,CASO,sBAAM6I,GAIZ,MAAM9J,EAAUD,KAAKS,aACrB,IAAKR,GAASuC,UACZ,MAAM,IAAIQ,MAAM,0EAGlB,MAAM6E,QAAkB7H,KAAKyH,eAE7B,MAAO,CACL1H,OAAQ,CACNiK,QAAShK,KAAKD,OAAOmD,OACrB+G,OAAQ,IAAMjK,KAAKS,cAAc+B,WAEnCqF,UAAW,CACTG,QAASH,EAAUG,QACnBkC,WAAarC,EAAUqC,YAAc,KACrC1F,QAASqD,EAAUsC,eAAiBtC,EAAUrD,SAAW,GACzD4E,QAASvB,EAAUuB,QACnBgB,WAAYvC,EAAUuC,YAG3B,CAYD,mBAAMC,GAQJ,MAAMA,cAAEA,SAAwBC,8CAC1BvK,OAAEA,EAAM8H,UAAEA,SAAoB7H,KAAK+J,mBACzC,OAAOM,EAActK,EAAQ8H,EAC9B,CAeD,oBAAM0C,CAAeC,GACnB,MAAMD,eAAEA,SAAyBD,8CAC3BvK,OAAEA,EAAM8H,UAAEA,SAAoB7H,KAAK+J,mBACzC,OAAOQ,EAAexK,EAAQyK,EAAU3C,EACzC,CAYD,mBAAM4C,GACJ,MAAMA,cAAEA,SAAwBH,8CAC1BvK,OAAEA,EAAM8H,UAAEA,SAAoB7H,KAAK+J,mBACzC,OAAOU,EAAc1K,EAAQ8H,EAC9B,CAaD,wBAAM6C,GACJ,MAAMA,mBAAEA,SAA6BJ,8CAC/BvK,OAAEA,EAAM8H,UAAEA,SAAoB7H,KAAK+J,mBACzC,OAAOW,EAAmB3K,EAAQ8H,EACnC,CAYD,uBAAM8C,GACJ,MAAMA,kBAAEA,SAA4BL,8CAC9BvK,OAAEA,EAAM8H,UAAEA,SAAoB7H,KAAK+J,mBACzC,OAAOY,EAAkB5K,EAAQ8H,EAClC,CAKD,OAAAxG,GACEmC,OAAOoH,oBAAoB,UAAW5K,KAAKqD,gBAC3CrD,KAAK0D,WAAWrC,UAChBrB,KAAK6K,eACLvJ,OAAOC,KAAKvB,KAAKG,QAAQqB,QAAQC,WACxBzB,KAAKG,OAAOsB,IAEtB,CAEO,eAAAyE,CAAgB/B,GAEtB,MAAMiC,EAAO,GAAGpG,KAAKD,OAAOkD,QAAQyB,QAAQ,MAAO,cAC7CD,EAAM,IAAI4B,IAAID,EAAM5C,OAAOmC,SAASmF,MAO1C,OANArG,EAAI6B,aAAaC,IAAI,QAASvG,KAAKD,OAAOgD,OAC1C0B,EAAI6B,aAAaC,IAAI,SAAUpC,EAAOuB,QACtCjB,EAAI6B,aAAaC,IAAI,QAASpC,EAAO4B,OACjC5B,EAAOgC,OACT1B,EAAI6B,aAAaC,IAAI,QAASpC,EAAOgC,OAEhC1B,EAAI+B,UACZ,CAEO,SAAAlD,CAAUzC,GAChB,IAME,IAJuB,IAAIkK,IACzB,CAACvH,OAAOmC,SAASD,OAAQ1F,KAAKkH,0BAA0B8D,OAAO3D,UAG7C4D,IAAIpK,EAAM6E,QAAS,OAEvC,MAAMJ,EAAOzE,EAAMyE,KAGnB,GAAmB,0BAAfA,GAAM4F,KAAkC,CAE1C,IAAKlL,KAAK0C,cAAgB4C,EAAKS,QAAU/F,KAAK0C,aAC5C,OAaF,OAVA1C,KAAK0C,aAAe,KACpB1C,KAAK6K,eAGD7K,KAAKD,OAAOoL,UACdnL,KAAKD,OAAOoL,gBAIdnL,KAAKQ,KAAK,iBAAa4K,EAExB,CAED,GAAmB,wBAAf9F,GAAM4F,KAAgC,OAG1C,IAAKlL,KAAK0C,cAAgB4C,EAAKS,QAAU/F,KAAK0C,aAE5C,OAGF1C,KAAK0C,aAAe,KAGpB,MAAMzC,EAAUqF,EAAKrF,QACrBD,KAAKC,QAAUA,EACfD,KAAKmD,eAAelD,GACpBD,KAAK0D,WAAWpD,WAAWL,GAEvBA,GAAWD,KAAKD,OAAOyF,WACzBxF,KAAKD,OAAOyF,UAAUvF,GAGxBD,KAAKQ,KAAK,UAAWP,GACrBD,KAAK6K,cACN,CAAC,MAAOlJ,GACP3B,KAAKgH,UAAUrF,EAChB,CACF,CAEO,IAAAnB,CAA6BK,EAAUa,GAC7C,MAAMT,EAAWjB,KAAKG,OAAOU,GAC7B,GAAKI,EAEL,IAAK,MAAMH,KAAWG,EACpB,IACEH,EAAQY,EACT,CAAC,MAAOC,GAER,CAEJ,CAEO,SAAAqF,CAAUrF,GAChB3B,KAAKD,OAAOsL,UAAU1J,GACtB3B,KAAKQ,KAAK,YAAamB,EACxB,CAEO,aAAAmF,GACN,MAEMwE,EAAMpJ,KAAKC,IAAI,GAAIqB,OAAO+H,YADjB,KACyC,GAExD,MAAO,uCADMrJ,KAAKC,IAAI,GAAIqB,OAAOgI,WAHnB,KAGyC,UACcF,GACtE,CAEO,QAAAtF,GACN,MAAMyF,EAAQ,IAAIC,WAAW,IAC7B,GAAIlI,OAAOmI,QAAQC,gBACjBpI,OAAOmI,OAAOC,gBAAgBH,QAE9B,IAAK,IAAII,EAAI,EAAGA,EAAIJ,EAAMK,OAAQD,IAChCJ,EAAMI,GAAK3J,KAAK6J,MAAsB,IAAhB7J,KAAK8J,UAG/B,OAAOjD,MAAMkD,KAAKR,EAAOS,GAAKA,EAAE1F,SAAS,IAAI2F,SAAS,EAAG,MAAMC,KAAK,GACrE,CAEO,sBAAAlF,GACN,IACE,IAAKlH,KAAKD,OAAOkD,QAAS,OAAO,KAEjC,OADY,IAAIoD,IAAIrG,KAAKD,OAAOkD,QAASO,OAAOmC,SAASmF,MAC9CpF,MACZ,CAAC,MACA,OAAO,IACR,CACF,CAEO,iBAAMI,CAAY3B,GAExB,MAAMQ,QAAiBC,MAAM,GAAG5E,KAAKD,OAAOkD,QAAQyB,QAAQ,MAAO,oBAAqB,CACtFG,OAAQ,OACRC,QAAS,CAAE,eAAgB,oBAC3BC,KAAMC,KAAKC,UAAU,CACnBlC,MAAO/C,KAAKD,OAAOgD,MACnB2C,OAAQvB,EAAOuB,WAIbJ,QAAaX,EAASY,OAAO8G,MAAM,IAAM,MAE/C,IAAK1H,EAASO,GAAI,CAChB,MAAMvD,EAAQ,IAAIqB,MAAM,QAAQ2B,EAASU,UAGzC,MAFA1D,EAAM0D,OAASV,EAASU,OACxB1D,EAAMD,QAAU4D,GAAQ,GAClB3D,CACP,CAED,OAAO2D,CACR,CAEO,eAAAsB,CAAgBnC,GAElBzE,KAAK2C,WACP3C,KAAK6K,eAIP,MAAMyB,EAAUC,SAASC,cAAc,OACvCF,EAAQG,aAAa,sBAAuB,IAC5CH,EAAQI,MAAMC,SAAW,QACzBL,EAAQI,MAAME,MAAQ,IACtBN,EAAQI,MAAMG,WAAa,kBAC3BP,EAAQI,MAAMI,OAAS,SACvBR,EAAQI,MAAMK,QAAU,OACxBT,EAAQI,MAAMM,WAAa,SAC3BV,EAAQI,MAAMO,eAAiB,SAG/B,MAAMC,EAAYX,SAASC,cAAc,OACzCU,EAAUR,MAAMS,MAAQ,mBACxBD,EAAUR,MAAMU,OAAS,mBACzBF,EAAUR,MAAMG,WAAa,UAC7BK,EAAUR,MAAMW,OAAS,oBACzBH,EAAUR,MAAMY,aAAe,OAC/BJ,EAAUR,MAAMa,UAAY,8BAC5BL,EAAUR,MAAMc,SAAW,SAC3BN,EAAUR,MAAMC,SAAW,WAG3B,MAAMc,EAAWlB,SAASC,cAAc,UACxCiB,EAASC,YAAc,IACvBD,EAAShB,aAAa,aAAc,SACpCgB,EAASf,MAAMC,SAAW,WAC1Bc,EAASf,MAAMpB,IAAM,MACrBmC,EAASf,MAAMiB,MAAQ,MACvBF,EAASf,MAAMI,OAAS,IACxBW,EAASf,MAAMG,WAAa,cAC5BY,EAASf,MAAMkB,MAAQ,UACvBH,EAASf,MAAMW,OAAS,OACxBI,EAASf,MAAMmB,SAAW,OAC1BJ,EAASf,MAAMoB,OAAS,UACxBL,EAASM,QAAU,IAAM/N,KAAK6K,eAG9B,MAAMmD,EAASzB,SAASC,cAAc,UACtCwB,EAAOC,IAAMxJ,EACbuJ,EAAOtB,MAAMS,MAAQ,OACrBa,EAAOtB,MAAMU,OAAS,OACtBY,EAAOtB,MAAMW,OAAS,IACtBW,EAAOE,eAAiB,cACxBF,EAAOG,MAAQ,mCAEfjB,EAAUkB,YAAYX,GACtBP,EAAUkB,YAAYJ,GACtB1B,EAAQ8B,YAAYlB,GACpBX,SAASxH,KAAKqJ,YAAY9B,GAG1B,MAAM+B,EAASC,IACC,WAAVA,EAAE7M,KACJzB,KAAK6K,gBAWT,OARA0B,SAAS9I,iBAAiB,UAAW4K,EAAO,CAAEE,SAAS,IAEvDvO,KAAK2C,UAAY2J,EACjBtM,KAAK4C,UAAYoL,EACjBhO,KAAK6C,eAAiB,KACpB0J,SAAS3B,oBAAoB,UAAWyD,EAAO,CAAEE,SAAS,MAGrD,CACR,CAEO,YAAA1D,GACN,IACE7K,KAAK6C,kBACN,CAAC,MAED,CACD7C,KAAK6C,eAAiB,KAElB7C,KAAK2C,WAAW6L,YAClBxO,KAAK2C,UAAU6L,WAAWC,YAAYzO,KAAK2C,WAG7C3C,KAAK2C,UAAY,KACjB3C,KAAK4C,UAAY,IAClB,CAEO,cAAMwC,CAAST,GACrB,IACE,aAAaA,EAASY,MACvB,CAAC,MACA,OAAO,IACR,CACF,CAEO,oBAAAvB,GACN,IACE,GAA4B,oBAAjB0K,aAA8B,OAAO,KAChD,MAAMC,EAASD,aAAaE,QAAQ5O,KAAKoD,YACzC,IAAKuL,EAAQ,OAAO,KAEpB,MAAM1O,EAAU+E,KAAK6J,MAAMF,GAG3B,OAAK1O,GAASuC,WAAcvC,GAAS4B,UACjCE,KAAKD,OAAS7B,EAAQ4B,WACxB6M,aAAaI,WAAW9O,KAAKoD,YACtB,MAGFnD,EANgD,IAOxD,CAAC,MACA,OAAO,IACR,CACF,CAEO,cAAAkD,CAAelD,GACrB,IACE,GAA4B,oBAAjByO,aAA8B,OAErCzO,GAAWD,KAAKD,OAAOoD,eACzBuL,aAAaK,QAAQ/O,KAAKoD,WAAY4B,KAAKC,UAAUhF,IAErDyO,aAAaI,WAAW9O,KAAKoD,WAEhC,CAAC,MAED,CACF,EC/wBId,eAAe0M,EACpBC,EACAlK,EACAhF,GAEA,MAAMiK,EAAUjK,EAAOiK,SAAW,6BAC5BkF,QAjCR5M,eAAkCvC,GAEhC,GAAqC,mBAA1BA,EAAOoP,eAA+B,CAC/C,MAAMC,QAAUrP,EAAOoP,iBACvB,GAAIC,GAAkB,iBAANA,EAAgB,OAAOA,CACxC,CAED,MAAMC,EACJtP,EAAOuP,MACmB,mBAAlBvP,EAAOkK,aAA8BlK,EAAOkK,cAAWmB,IAC/DrL,EAAOwP,KAAK9O,cAAc+B,gBAC1B4I,EAEF,GAAIiE,EACF,MAAO,CAAEzH,cAAe,UAAUyH,KAIpC,GAAItP,EAAOyJ,OACT,MAAO,CAAE,YAAazJ,EAAOyJ,QAG/B,MAAM,IAAIxG,MACR,uFAEJ,CAQ4BwM,CAAmBzP,GACvC0P,QAAY7K,MAAM,GAAGoF,IAAUiF,IAAQ,CAC3CpK,OAAQ,OACRC,QAAS,CACP,eAAgB,sBACboK,GAELnK,KAAMC,KAAKC,UAAUF,EAAM,CAAC2K,EAAcC,IACvB,iBAAVA,EAAqBA,EAAMnJ,WAAamJ,KAInD,IAAKF,EAAIvK,GAAI,CACX,MAAM0K,QAAaH,EAAIG,OAAOvD,MAAM,IAAM,IAC1C,MAAM,IAAIrJ,MAnEd,SAA8BqC,EAAgBuK,GAE5C,IAAIC,EAAe,uBAAuBxK,IAe1C,OAbIA,GAAU,IACZwK,GAAgB,0BACI,MAAXxK,GAA6B,MAAXA,EAC3BwK,GAAgB,0BACI,MAAXxK,EACTwK,GAAgB,uBACI,MAAXxK,EACTwK,GAAgB,uBACPD,IAETC,GAAgB,KAAKD,EAAKE,UAAU,EAAG,QAGlCD,CACT,CAiDoBE,CAAqBN,EAAIpK,OAAQuK,GAClD,CAED,OAAOH,EAAIlK,MACb,CCIgB,SAAAyK,EAAaL,EAAgBM,GAC3C,MAAMC,EAAMC,OAAOR,GAEnB,IAAKQ,OAAOC,cAAcF,GACxB,MAAM,IAAIlN,MACR,GAAGiN,WAAmBN,sCAA0CQ,OAAOE,qBAI3E,OAAOH,CACT,CCpFM,SAAUI,EAAcpH,GAC5B,MAAoB,iBAANA,EAAiB,KAAOA,EAAE1C,SAAS,IAAM0C,CACzD,CAMM,SAAUqH,EAAqBC,GACnC,MAAMC,EAA+B,IAAKD,GA+B1C,YA7BkBpF,IAAdqF,EAAId,QAAqBc,EAAId,MAAQW,EAAcG,EAAId,aAC3CvE,IAAZqF,EAAIC,MACND,EAAIE,SAAWL,EAAcG,EAAIC,YAC1BD,EAAIC,UAEQtF,IAAjBqF,EAAIE,WAAwBF,EAAIE,SAAWL,EAAcG,EAAIE,gBAC5CvF,IAAjBqF,EAAIG,WAAwBH,EAAIG,SAAWN,EAAcG,EAAIG,gBACxCxF,IAArBqF,EAAII,eAA4BJ,EAAII,aAAeP,EAAcG,EAAII,oBACxCzF,IAA7BqF,EAAIK,uBACNL,EAAIK,qBAAuBR,EAAcG,EAAIK,4BAC7B1F,IAAdqF,EAAI1K,QAAqB0K,EAAI1K,MAAQiK,EAAaS,EAAI1K,MAAO,eAC7CqF,IAAhBqF,EAAIM,UAAuBN,EAAIM,QAAUf,EAAaS,EAAIM,QAAS,iBAG9C3F,IAArBqF,EAAII,mBAA2DzF,IAA7BqF,EAAIK,4BACnB1F,IAAjBqF,EAAIG,eAA+CxF,IAArBqF,EAAII,eACpCJ,EAAIG,SAAWH,EAAII,qBAEdJ,EAAII,oBACJJ,EAAIK,6BAINL,EAAIvF,YACJuF,EAAIO,kBACJP,EAAIQ,eACJR,EAAIS,aACJT,EAAIxE,KAEJwE,CACT,CAMM,SAAUU,EAAWC,GACzB,IAAIX,EAAM,KACV,IAAK,IAAI5E,EAAI,EAAGA,EAAIuF,EAAMtF,OAAQD,IAChC4E,GAAQW,EAAMvF,GAAcrF,SAAS,IAAI2F,SAAS,EAAG,KAEvD,OAAOsE,CACT,CCrDOnO,eAAe+O,EAAetR,GAEnC,MAAMuF,QAKK0J,EAAW,cAAe,CAAE,EAAEjP,GAGzC,IAAKuF,IAASA,EAAK0C,UAAY1C,EAAK4E,WAClC,MAAM,IAAIlH,MAAM,wDAGlB,IAAKmG,OAAO7D,EAAK4E,YAAYoH,WAAW,MACtC,MAAM,IAAItO,MAAM,yCAGlB,MAAO,CACLgF,QAAS1C,EAAK0C,QACdoB,QAAS9D,EAAK0C,QACdxD,QAASc,EAAKd,SAAW,GACzB0F,WAAY5E,EAAK4E,WACjBE,WAAY9E,EAAK8E,WAErB,mDCZO9H,eACLvC,EACAwR,GAEA,MAAMzN,EAAOyN,SAAuBF,EAAetR,IAC7CmK,WAAEA,EAAUlC,QAAEA,GAAYlE,GAK1B0N,UAAEA,SAAoBC,OADP,iBAGrB,OAAOD,EAAU,CACfhN,QAAS0F,EAET,iBAAMwH,EAAYrN,QAAEA,IAClB,IAAI3C,EACAiQ,GAAQ,EAEZ,GAAuB,iBAAZtN,EACT3C,EAAU2C,EACVsN,GAAQ,OACH,GAAItN,QAAyD,IAAtCA,EAA8BgE,IAAqB,CAC/E,MAAMA,EAAOhE,EAA6BgE,IAC1C3G,EAAyB,iBAAR2G,EAAmBA,EAAM8I,EAAW9I,GACrDsJ,GAAQ,CACT,MAAM,GAAItN,aAAmBqH,WAC5BhK,EAAUyP,EAAW9M,GACrBsN,GAAQ,MACH,IFEa,iBADEhC,EEDCtL,KFES,mBAAmBuN,KAAKjC,GEGtD,MAAM,IAAI3M,MACR,oCAAoCqB,kDALtC3C,EAAU2C,EACVsN,GAAQ,CAMT,CFPD,IAAsBhC,EEctB,aALmBX,EAGhB,oBAAqB,CAAEhH,UAAS3D,QAAS3C,EAAS2G,IAAKsJ,GAAS5R,IAEvDuE,SACb,EAED,mBAAMuN,CAAcC,GAClB,MAAMC,OAAEA,EAAMC,MAAEA,EAAK3N,QAAEA,GAAYyN,EAUnC,aALmB9C,EAGhB,sBAAuB,CAAEhH,UAAS+J,SAAQC,QAAO3N,WAAWtE,IAEnDuE,SACb,EAED,qBAAM2N,CAAgBzB,EAAa0B,GACjC,MAAMC,EAAe5B,EAAqBC,GAM1C,aAJmBxB,EAEhB,eAAgB,CAAEhH,UAASoK,YAAaD,GAAgBpS,IAE/CsS,iBACb,GAEL,2DC7DO/P,eACLvC,EACAyK,EACA+G,GAIA,IAAIe,EACJ,IACE,MAAMC,EAAa,SACnBD,QAAeb,OAA0Bc,EAC1C,CAAC,MACA,MAAM,IAAIvP,MAAM,+EACjB,CAED,MAAMwP,eAAEA,EAAcC,eAAEA,GAAmBH,EAQrCxO,EAAOyN,SAAuBF,EAAetR,GAGnD,MAAM2S,UAA+BF,EAOnC,WAAA1S,CACE6S,EACAC,EACAC,GAEAC,MAAMF,GAAkB,MAVlB5S,KAAQ+S,SAAe,KACvB/S,KAAQgT,SAAkB,KAC1BhT,KAAQiT,SAAG,EASjBjT,KAAKkT,QAAUP,EACXE,GAAMrO,UAASxE,KAAK+S,SAAWF,EAAKrO,SACpCqO,GAAM7K,UAAShI,KAAKgT,SAAWH,EAAK7K,SACpC6K,GAAM9B,UAAS/Q,KAAKiT,SAAWJ,EAAK9B,QACzC,CAED,gBAAMoC,GACJ,OAAInT,KAAKoT,eAETpT,KAAKoT,aAAe/B,EAAerR,KAAKkT,SACrCG,KAAMxL,IACL7H,KAAK+S,SAAWlL,EAAUqC,WAC1BlK,KAAKgT,SAAWnL,EAAUG,UAE3BqE,MAAOiH,IAEN,MADAtT,KAAKoT,kBAAehI,EACdkI,KAToBtT,KAAKoT,YAapC,CAED,gBAAMG,GAEJ,OADKvT,KAAK+S,gBAAgB/S,KAAKmT,aACxBnT,KAAK+S,QACb,CAED,UAAAS,GACE,IAAKxT,KAAKgT,SAAU,MAAM,IAAIhQ,MAAM,oDACpC,OAAOhD,KAAKgT,QACb,CAED,UAAAS,CAAW1C,GACT/Q,KAAKiT,SAAWlC,CACjB,CAED,UAAA2C,GACE,OAAO1T,KAAKiT,QACb,CAED,OAAAU,CAAQC,GACN,IAAKA,EAAa,MAAM,IAAI5Q,MAAM,2BAClC,OAAO,IAAI0P,EAAuB1S,KAAKkT,QAASU,EAAa,CAC3DpP,QAASxE,KAAK+S,eAAY3H,EAC1BpD,QAAShI,KAAKgT,eAAY5H,EAC1B2F,QAAS/Q,KAAKiT,UAEjB,CAED,iBAAMvB,CAAYrN,GACXrE,KAAKgT,gBAAgBhT,KAAKmT,aAC/B,MAAMzR,EAA6B,iBAAZ2C,EAAuBA,EAAU8M,EAAW9M,GAMnE,aALmB2K,EACjB,oBACA,CAAEhH,QAAShI,KAAKgT,SAAW3O,QAAS3C,GACpC1B,KAAKkT,UAEK5O,SACb,CAED,mBAAMuN,CACJE,EACAC,EACArC,GAEK3P,KAAKgT,gBAAgBhT,KAAKmT,aAC/B,MAAMU,EAAa,IAAK7B,GACpB6B,GAAeA,EAAuCC,qBAChDD,EAAuCC,aAOjD,aALmB9E,EACjB,sBACA,CAAEhH,QAAShI,KAAKgT,SAAWjB,SAAQC,MAAO6B,EAAYxP,QAASsL,GAC/D3P,KAAKkT,UAEK5O,SACb,CAED,oBAAMyP,CACJhC,EACAC,EACArC,GAEA,OAAO3P,KAAK6R,cAAcE,EAAQC,EAAOrC,EAC1C,CAED,qBAAMsC,CAAgBzB,GACfxQ,KAAKgT,gBAAgBhT,KAAKmT,aAC/B,MAAMlH,EAAQuE,EAA+BvE,KACvC+H,QAAahU,KAAKuT,aAExB,GAAItH,GAAQA,EAAKgI,gBAAkBD,EAAKC,cACtC,MAAM,IAAIjR,MAAM,kDAGlB,MAAMkR,EAASlU,KAAKwK,SACf,UAAWxK,KAAKmU,oBAAoB3D,IACpC,IAAKA,GAEV,GADI0D,EAAOjI,aAAaiI,EAAOjI,OACzB,OAAQiI,KAAYA,EAAOE,GAC/B,MAAM,IAAIpR,MAAM,wCAElB,QAAqBoI,IAAjB8I,EAAOnO,OAAwC,OAAjBmO,EAAOnO,MACvC,MAAM,IAAI/C,MAAM,iCAElB,MAAMqR,EAAa9D,EAAqB2D,GAMxC,aALmBlF,EACjB,eACA,CAAEhH,QAAShI,KAAKgT,SAAWZ,YAAaiC,EAAYC,QAAS,CAAEvD,QAAS/Q,KAAKiT,WAC7EjT,KAAKkT,UAEKb,iBACb,CAED,qBAAMkC,CAAgB/D,GACpB,IAAKxQ,KAAKwK,SAAU,MAAM,IAAIxH,MAAM,yCACpC,MAAMwR,QAAexU,KAAKiS,gBAAgBzB,GAC1C,aAAaxQ,KAAKwK,SAASiK,qBAAqBD,EACjD,CAED,yBAAML,CAAoB/B,GACxB,MAAM5B,EAAK,IAAK4B,GAChB,IAAKpS,KAAKwK,SAAU,MAAM,IAAIxH,MAAM,6CACpC,MAAM0R,EAAclE,EAAGvE,WACbwG,EAAejC,EAAGvE,KAAMjM,KAAKwK,gBAC7BxK,KAAKuT,aAEf,IAAIxC,EACJ,GAAKP,EAAGO,QAKNA,EAAU4D,OAAOnE,EAAGO,SACpB/Q,KAAKiT,SAAW9C,OAAOK,EAAGO,aANX,CACf,MAAM3M,QAAgBpE,KAAKwK,SAASoK,aACpC7D,EAAU3M,EAAQ2M,QAClB/Q,KAAKiT,SAAW9C,OAAO/L,EAAQ2M,QAChC,CAKD,MAAMhL,EACQ,MAAZyK,EAAGzK,MACCoK,OAAOK,EAAGzK,aACJ/F,KAAKwK,SAASqK,oBAAoBH,EAAa,WACrDI,EAAYtE,EAAG4D,SAAW3B,EAAejC,EAAG4D,GAAIpU,KAAKwK,UAAY,KACjEmF,EAAQa,EAAGb,MAAQgF,OAAOnE,EAAGb,MAAMnJ,YAAc,GAEvD,IAAImK,EACJ,GAAKH,EAAGG,SAONA,EAAWgE,OAAOnE,EAAGG,SAASnK,iBAN9B,IACEmK,QAAiB3Q,KAAKwK,SAASuK,YAAY,IAAKvE,EAAIvE,KAAMyI,GAC3D,CAAC,MACA/D,EAAW,MACZ,CAKH,IAAIC,EAA0B,KAC9B,GAAKJ,EAAGI,UAAwB,IAAZJ,EAAGtF,KAGZsF,EAAGI,WACZA,EAAW+D,OAAOnE,EAAGI,SAASpK,iBAJG,CAEjCoK,SADsB5Q,KAAKwK,SAASwK,cACjBpE,UAAY,IAChC,CAID,MAAMqE,EAA6B,CACjChJ,KAAMyI,EACNN,GAAIU,EACJnF,QACA5J,QACA4K,WACArL,KAAMkL,EAAGlL,KACTyL,UACA7F,KAAMsF,EAAGtF,WAAQE,GAMnB,OAJiB,OAAbwF,IAAmBqE,EAAUrE,SAAWA,GACxCJ,EAAGK,eAAcoE,EAAUpE,aAAe8D,OAAOnE,EAAGK,aAAarK,aACjEgK,EAAGM,uBACLmE,EAAUnE,qBAAuB6D,OAAOnE,EAAGM,qBAAqBtK,aAC3DyO,CACR,CAED,sBAAMC,CACJ9C,EACA+C,GAA0B,GAE1B,IAAKnV,KAAKwK,SAAU,MAAM,IAAIxH,MAAM,yCACpC,MAAMwR,QAAexU,KAAKiS,gBAAgBG,GAEpCgD,SADapV,KAAKwK,SAASiK,qBAAqBD,IACpCY,KAIlB,OAHID,SACInV,KAAKwK,SAAS6K,mBAAmBD,GAElCA,CACR,EAGH,OAAO,IAAI1C,EAAuB3S,EAAQyK,EAAqC,CAC7EhG,QAASV,EAAKoG,WACdlC,QAASlE,EAAKkE,SAElB,ICsBO,SAASsN,EAAuBC,EAAUpP,EAAOqP,EAAMC,GAC1D,GAAa,MAATD,IAAiBC,EAAG,MAAM,IAAIC,UAAU,iDAC5C,GAAqB,mBAAVvP,EAAuBoP,IAAapP,IAAUsP,GAAKtP,EAAM8E,IAAIsK,GAAW,MAAM,IAAIG,UAAU,4EACvG,MAAgB,MAATF,EAAeC,EAAa,MAATD,EAAeC,EAAEE,KAAKJ,GAAYE,EAAIA,EAAE9F,MAAQxJ,EAAMyP,IAAIL,EACxF,CAEO,SAASM,EAAuBN,EAAUpP,EAAOwJ,EAAO6F,EAAMC,GACjE,GAAa,MAATD,EAAc,MAAM,IAAIE,UAAU,kCACtC,GAAa,MAATF,IAAiBC,EAAG,MAAM,IAAIC,UAAU,iDAC5C,GAAqB,mBAAVvP,EAAuBoP,IAAapP,IAAUsP,GAAKtP,EAAM8E,IAAIsK,GAAW,MAAM,IAAIG,UAAU,2EACvG,MAAiB,MAATF,EAAeC,EAAEE,KAAKJ,EAAU5F,GAAS8F,EAAIA,EAAE9F,MAAQA,EAAQxJ,EAAMI,IAAIgP,EAAU5F,GAASA,CACxG,CA+BkD,mBAApBmG,iBAAiCA,sBCnUlDC,EAKX,WAAAjW,CAAY0E,EAAcwD,EAAiBjI,GAHlCiW,EAAiBzP,IAAAvG,UAAA,GACjBiW,EAAsB1P,IAAAvG,UAAA,GAG7BA,KAAKwE,QAAUA,EACfqR,EAAA7V,KAAIgW,EAAYhO,EAAO,KACvB6N,EAAA7V,KAAIiW,EAAWlW,EAAM,IACtB,CAED,iBAAM2R,CAAYrN,GAChB,MAAM3C,EAA6B,iBAAZ2C,EAAuBA,EAAU8M,EAAW9M,GAMnE,aALmB2K,EACjB,oBACA,CAAEhH,QAASsN,EAAAtV,KAAagW,EAAA,KAAE3R,QAAS3C,GACnC4T,EAAAtV,KAAYiW,EAAA,OAEF3R,SACb,CAED,mBAAMuN,CACJE,EACAC,EACA3N,GAOA,aALmB2K,EACjB,sBACA,CAAEhH,QAASsN,EAAAtV,YAAe+R,SAAQC,QAAO3N,WACzCiR,EAAAtV,KAAYiW,EAAA,OAEF3R,SACb,CAED,qBAAM2N,CAAgBzB,GACpB,MAAM6D,EAAa9D,EAAqBC,GAMxC,MAAO,CAAE0F,sBALUlH,EACjB,eACA,CAAEhH,QAASsN,EAAAtV,KAAagW,EAAA,KAAE5D,YAAaiC,GACvCiB,EAAAtV,KAAYiW,EAAA,OAEgB5D,kBAC/B,oGAGI/P,eACLvC,EACAwR,GAEA,MAAMzN,EAAOyN,SAAuBF,EAAetR,GACnD,OAAO,IAAIgW,EAAkBjS,EAAKoG,WAAYpG,EAAKkE,QAASjI,EAC9D,UCtCaoW,EAKX,WAAArW,CAAYC,EAAsB8H,GAChC7H,KAAKuE,UAAYsD,EAAUrD,QAC3BxE,KAAKD,OAASA,EACdC,KAAKgI,QAAUH,EAAUG,OAC1B,CAED,iBAAM0J,CAAYrN,GAEhB,MAAM+R,EAAkC,iBAAZ/R,GAAuB,IAAIgS,aAAcC,OAAOjS,GAAWA,EAGjFkS,EAAgBC,KAAKrN,OAAOsN,gBAAgBL,IAE5CzR,QAAiBqK,EACrB,uBACA,CAAEhH,QAAShI,KAAKgI,QAAS3D,QAASkS,GAClCvW,KAAKD,QAOP,IAEE,MAAM2W,EAAwB,oBAAXlT,OAA0BA,YAAqE4H,EAClH,GAAIsL,GAAKC,KACP,OAAOD,EAAIC,KAAKC,OAAOjS,EAASL,WAKlC,OADuBoH,WAAWO,KAAK4K,KAAKlS,EAASL,WAAawS,GAAMA,EAAEC,WAAW,GAEtF,CAAC,MAAOzI,GAEP,GAAI3J,EAASL,UAAUgN,WAAW,MAAO,CACvC,MAAM0F,EAAMrS,EAASL,UAAU2S,MAAM,GAC/B7F,EAAQ,IAAI1F,WAAWsL,EAAIlL,OAAS,GAC1C,IAAK,IAAID,EAAI,EAAGA,EAAImL,EAAIlL,OAAQD,GAAK,EACnCuF,EAAMvF,EAAI,GAAKqL,SAASF,EAAIG,OAAOtL,EAAG,GAAI,IAE5C,OAAOuF,CACR,CACD,MAAM,IAAIpO,MAAM,sCAAsCsL,IACvD,CACF,CAED,qBAAM2D,CAAgBG,GAEpB,MAAMgF,EAAwBpX,KAAKqX,qBAAqBjF,GAElDzN,QAAiBqK,EAIrB,2BACA,CACEhH,QAAShI,KAAKgI,QACdsP,kBAAmBF,EACnBG,WAAW,EACXC,sBAAsB,GAExBxX,KAAKD,QAID0X,EAAe9S,EAAS+S,6BAA+B/S,EAAS0N,kBACtE,IAAKoF,EACH,MAAM,IAAIzU,MAAM,mDAGlB,OAAOhD,KAAK2X,uBAAuBF,EACpC,CAEO,oBAAAJ,CAAqB7G,GAE3B,GAAIA,GAAoB,iBAAPA,EAAiB,CAEhC,GAAKA,EAAwCoH,UAAW,CAEtD,MAAMC,EAAcrH,EAAuCoH,YAE3D,OADepB,KAAKrN,OAAOsN,gBAAgBoB,GAE5C,CAED,GACGrH,EAAkCsH,cAClCtH,EAAqCuH,gBAEtC,MAAM,IAAI/U,MACR,kFAGL,CAGD,OAAOwN,CACR,CAEO,sBAAAmH,CAAuBF,GAY7B,GAT0B,iBAAjBA,GACPA,GACCA,EAA0DC,8BAE3DD,EAAgBA,EACbC,6BAIuB,iBAAjBD,EACT,IAEE,MAAMO,EAAUnB,KAAKY,GACrB,OAAO,IAAI/L,WAAWsM,EAAQC,MAAM,IAAIC,IAAKpB,GAAMA,EAAEC,WAAW,IACjE,CAAC,MAAOzI,GAEP,MAAM,IAAItL,MAAM,+CAA+CsL,IAChE,CAIH,OAAOmJ,CACR,CAKD,UAAAjE,GACE,OAAOxT,KAAKgI,OACb,CAGD,yBAAMmQ,CAAoBC,GAGxB,MAAMC,EAAU,GAChB,IAAK,MAAM7H,KAAM4H,EACfC,EAAQtX,WAAWf,KAAKiS,gBAAgBzB,IAE1C,OAAO6H,CACR,CAGD,OAAAC,CAAQ/T,GACN,OAAOA,IAAcvE,KAAKuE,SAC3B,CAGD,sBAAM2Q,CAAiB9C,EAAsBmF,GAAqB,GAEhE,MAAMH,EAAwBpX,KAAKqX,qBAAqBjF,GAElDzN,QAAiBqK,EAIrB,2BACA,CACEhH,QAAShI,KAAKgI,QACdsP,kBAAmBF,EACnBG,UAAWA,EACXC,sBAAsB,GAExBxX,KAAKD,QAGP,GAAIwX,EAAW,CAEb,IAAK5S,EAAS4T,qBACZ,MAAM,IAAIvV,MAAM,oDAElB,OAAO2B,EAAS4T,oBACjB,CAEC,IAAK5T,EAAS+S,4BACZ,MAAM,IAAI1U,MAAM,mDAElB,OAAO2B,EAAS+S,2BAEnB,8EAGIpV,eACLvC,EACAwR,GAEA,MAAMzN,EAAOyN,SAAuBF,EAAetR,GACnD,OAAO,IAAIoW,EAAmBpW,EAAQ+D,EACxC,oBAEOxB,eACLvC,EACAwR,GAEA,MAAMzN,EAAOyN,SAAuBF,EAAetR,GACnD,OAAO,IAAIoW,EAAmBpW,EAAQ+D,EACxC"}