@emblemvault/auth-sdk 2.0.0 → 2.0.2

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":"index.js","sources":["../../src/signers/http.ts","../../src/signers/validation.ts","../../src/signers/utils.ts","../../src/signers/vault.ts","../../src/signers/solana.ts","../../node_modules/tslib/tslib.es6.js","../../src/signers/web3.ts","../../src/signers/ethers.ts","../../src/signers/viem.ts"],"sourcesContent":["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 { 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","/******************************************************************************\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 { 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 let ethers: typeof import('ethers');\n try {\n ethers = await import('ethers');\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","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 const { toAccount } = await import('viem/accounts');\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"],"names":["sanitizeErrorMessage","status","text","errorMessage","substring","async","resolveAuthHeaders","config","getAuthHeaders","h","tok","jwt","getJwt","undefined","sdk","getSession","authToken","Authorization","apiKey","Error","emblemPost","path","body","baseUrl","authHeaders","res","fetch","method","headers","JSON","stringify","_key","value","toString","ok","catch","json","isBrowserEnvironment","window","document","validateBaseUrl","startsWith","includes","console","warn","toSafeNumber","fieldName","num","Number","isSafeInteger","MAX_SAFE_INTEGER","toHexIfBigInt","v","normalizeTxForEmblem","tx","out","gas","gasLimit","gasPrice","maxFeePerGas","maxPriorityFeePerGas","nonce","chainId","type","accessList","account","chain","from","isHexString","test","bytesToHex","bytes","i","length","padStart","fetchVaultInfo","data","vaultId","evmAddress","String","tokenId","address","created_by","EmblemSolanaSigner","constructor","vaultInfo","this","publicKey","signMessage","message","messageBytes","TextEncoder","encode","messageBase64","btoa","fromCharCode","response","win","bs58","decode","signature","Uint8Array","atob","c","charCodeAt","e","hex","slice","parseInt","substr","signTransaction","transaction","serializedTransaction","serializeTransaction","transactionToSign","broadcast","versionedTransaction","signedTxData","serializedSignedTransaction","signedTransaction","deserializeTransaction","serialize","serialized","instructions","recentBlockhash","decoded","split","map","error","getVaultId","signAllTransactions","transactions","results","push","canSign","signAndBroadcast","transactionSignature","__classPrivateFieldGet","receiver","state","kind","f","TypeError","has","call","get","__classPrivateFieldSet","set","SuppressedError","EmblemWeb3Adapter","_EmblemWeb3Adapter_vaultId","_EmblemWeb3Adapter_config","payload","signTypedData","domain","types","normalized","rawTransaction","process","versions","node","provider","infoOverride","ethers","Promise","resolve","then","_interopNamespace","require","AbstractSigner","resolveAddress","info","EmblemEthersWalletImpl","signerConfig","signerProvider","seed","super","_address","_vaultId","_chainId","_config","initialize","_initPromise","err","getAddress","setChainId","getChainId","connect","newProvider","cleanTypes","EIP712Domain","_signTypedData","addr","toLowerCase","toSign","populateTransaction","to","options","sendTransaction","signed","broadcastTransaction","fromAddress","BigInt","network","getNetwork","getTransactionCount","toAddress","estimateGas","getFeeData","populated","waitForReceipt","hash","waitForTransaction","toAccount","isRaw","raw","typedData","_opts","normalizedTx","hasJwt","hasGetJwt","hasHeaders","debugSecurity","log","environment","hasBaseUrl","timestamp","Date","toISOString","trim"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/signers/http.ts","../../src/signers/validation.ts","../../src/signers/utils.ts","../../src/signers/vault.ts","../../src/signers/solana.ts","../../node_modules/tslib/tslib.es6.js","../../src/signers/web3.ts","../../src/signers/ethers.ts","../../src/signers/viem.ts"],"sourcesContent":["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 { 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","/******************************************************************************\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 { 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 // webpackIgnore comment prevents webpack from trying to resolve at build time\n let ethers: typeof import('ethers');\n try {\n ethers = await import(/* webpackIgnore: true */ 'ethers');\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","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 // webpackIgnore comment prevents webpack from trying to resolve at build time\n const { toAccount } = await import(/* webpackIgnore: true */ 'viem/accounts');\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"],"names":["sanitizeErrorMessage","status","text","errorMessage","substring","async","resolveAuthHeaders","config","getAuthHeaders","h","tok","jwt","getJwt","undefined","sdk","getSession","authToken","Authorization","apiKey","Error","emblemPost","path","body","baseUrl","authHeaders","res","fetch","method","headers","JSON","stringify","_key","value","toString","ok","catch","json","isBrowserEnvironment","window","document","validateBaseUrl","startsWith","includes","console","warn","toSafeNumber","fieldName","num","Number","isSafeInteger","MAX_SAFE_INTEGER","toHexIfBigInt","v","normalizeTxForEmblem","tx","out","gas","gasLimit","gasPrice","maxFeePerGas","maxPriorityFeePerGas","nonce","chainId","type","accessList","account","chain","from","isHexString","test","bytesToHex","bytes","i","length","padStart","fetchVaultInfo","data","vaultId","evmAddress","String","tokenId","address","created_by","EmblemSolanaSigner","constructor","vaultInfo","this","publicKey","signMessage","message","messageBytes","TextEncoder","encode","messageBase64","btoa","fromCharCode","response","win","bs58","decode","signature","Uint8Array","atob","c","charCodeAt","e","hex","slice","parseInt","substr","signTransaction","transaction","serializedTransaction","serializeTransaction","transactionToSign","broadcast","versionedTransaction","signedTxData","serializedSignedTransaction","signedTransaction","deserializeTransaction","serialize","serialized","instructions","recentBlockhash","decoded","split","map","error","getVaultId","signAllTransactions","transactions","results","push","canSign","signAndBroadcast","transactionSignature","__classPrivateFieldGet","receiver","state","kind","f","TypeError","has","call","get","__classPrivateFieldSet","set","SuppressedError","EmblemWeb3Adapter","_EmblemWeb3Adapter_vaultId","_EmblemWeb3Adapter_config","payload","signTypedData","domain","types","normalized","rawTransaction","process","versions","node","provider","infoOverride","ethers","Promise","AbstractSigner","resolveAddress","info","EmblemEthersWalletImpl","signerConfig","signerProvider","seed","super","_address","_vaultId","_chainId","_config","initialize","_initPromise","then","err","getAddress","setChainId","getChainId","connect","newProvider","cleanTypes","EIP712Domain","_signTypedData","addr","toLowerCase","toSign","populateTransaction","to","options","sendTransaction","signed","broadcastTransaction","fromAddress","BigInt","network","getNetwork","getTransactionCount","toAddress","estimateGas","getFeeData","populated","waitForReceipt","hash","waitForTransaction","toAccount","resolve","_interopNamespace","require","isRaw","raw","typedData","_opts","normalizedTx","hasJwt","hasGetJwt","hasHeaders","debugSecurity","log","environment","hasBaseUrl","timestamp","Date","toISOString","trim"],"mappings":"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"}