signet.js 0.0.12-beta.16 → 0.0.12-beta.17

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,"sources":["../../src/constants.ts","../../src/utils/index.ts","../../src/utils/cryptography.ts","../../src/chain-adapters/index.ts","../../src/chain-adapters/ChainAdapter.ts","../../src/chain-adapters/EVM/index.ts","../../src/chain-adapters/EVM/utils.ts","../../src/chain-adapters/EVM/EVM.ts","../../src/chain-adapters/Bitcoin/index.ts","../../src/chain-adapters/Bitcoin/utils.ts","../../src/chain-adapters/Bitcoin/Bitcoin.ts","../../src/chain-adapters/Bitcoin/BTCRpcAdapter/BTCRpcAdapter.ts","../../src/chain-adapters/Bitcoin/BTCRpcAdapter/Mempool/Mempool.ts","../../src/chain-adapters/Bitcoin/BTCRpcAdapter/index.ts","../../src/chain-adapters/Cosmos/index.ts","../../src/chain-adapters/Cosmos/utils.ts","../../src/chain-adapters/Cosmos/Cosmos.ts","../../src/contracts/index.ts","../../src/contracts/ChainSignatureContract.ts","../../src/contracts/evm/index.ts","../../src/contracts/evm/ChainSignaturesContractABI.ts","../../src/contracts/evm/errors.ts","../../src/utils/publicKey.ts","../../src/contracts/evm/utils.ts","../../src/contracts/evm/ChainSignaturesContract.ts","../../src/contracts/solana/index.ts","../../src/contracts/solana/errors.ts","../../src/contracts/solana/types/chain_signatures_project.json","../../src/contracts/solana/CpiEventParser.ts","../../src/contracts/solana/utils.ts","../../src/contracts/solana/ChainSignaturesContract.ts"],"names":["constants_exports","__export","CHAINS","CONTRACT_ADDRESSES","ENVS","KDF_CHAIN_IDS","ROOT_PUBLIC_KEYS","utils_exports","cryptography_exports","compressPubKey","deriveChildPublicKey","najToUncompressedPubKeySEC1","toRSV","verifyRecoveredAddress","EC","elliptic","signature","uncompressedPubKeySEC1","slicedPubKey","x","y","najPublicKey","decodedKey","base58","rootUncompressedPubKeySEC1","predecessorId","path","chainId","ec","derivationPath","scalarHex","keccak256","oldPublicKeyPoint","scalarTimesG","newPublicKeyPoint","newX","newY","payload","requesterAddress","contract","evm","chain_adapters_exports","createPublicClient","http","expectedAddress","recoverAddress","error","ChainAdapter","Bitcoin_exports","Cosmos_exports","EVM_exports","EVM","fetchEVMFeeProperties","client","transaction","gas","feeData","maxFeePerGas","maxPriorityFeePerGas","publicClient","fees","nonce","from","rest","r","s","yParity","concatHex","numberToHex","predecessor","uncompressedPubKey","publicKeyNoPrefix","hash","getAddress","address","serializeTransaction","serialized","parseTransaction","transactionRequest","serializedTx","txHash","toBytes","message","hashMessage","typedDataRequest","hashTypedData","userOp","entryPointAddress","chainIdArgs","entryPoint","encoded","encodeAbiParameters","hexToBigInt","concat","pad","isAddress","userOpHash","rsvSignatures","rsvSignature","txSerialized","BTCRpcAdapter","BTCRpcAdapters","Bitcoin","parseBTCNetwork","network","z","_Bitcoin","btcRpcAdapter","satoshis","btc","transactionId","data","tx","vout","scriptPubKey","rawSignature","inputs","outputs","psbt","input","prevOut","out","derivedKey","publicKeyBuffer","payment","transactionJSON","psbtHex","hashesToSign","mockKeyPair","index","publicKey","keyPair","mpcSignature","Mempool","providerUrl","confirmationTarget","targets","utxos","feeRate","ret","coinselect","transactionHex","response","txid","Cosmos","fetchChainInfo","chainInfo","chains","chain","prefix","expectedChainId","denom","rpcUrl","restUrl","gasPrice","asset","assets","decimals","unit","endpoints","Registry","fromHex","amount","b","pubKeySha256","sha256","ripemd160Hash","ripemd160","bech32","TxRaw","toBase64","fromBase64","publicKeyBytes","gasLimit","fee","calculateFee","GasPrice","accountOnChain","StargateClient","accountNumber","sequence","txBodyEncodeObject","txBodyBytes","pubkey","encodePubkey","encodeSecp256k1Pubkey","authInfoBytes","makeAuthInfoBytes","SignMode","signDoc","makeSignDoc","signBytes","makeSignBytes","sig","txBytes","broadcastResponse","contracts_exports","ChainSignatureContract","evm_exports","solana_exports","BaseChainSignatureContract","utils","ChainSignaturesContractABI_exports","abi","errors_exports","ChainSignatureError","SignatureContractError","SignatureNotFoundError","SigningError","requestId","receipt","errorCode","originalError","getRootPublicKey","contractAddress","environment","_","getRequestId","request","args","rootPublicKey","deposit","BN","version","options","requestParams","pollResult","fromBlock","delay","retryCount","result","withRetry","count","encodeFunctionData","errorLogs","errorData","logs","signatureData","ResponseError","metadata","chain_signatures_project_exports","accounts","chain_signatures_project_default","errors","events","instructions","types","EMIT_CPI_INSTRUCTION_DISCRIMINATOR","CpiEventParser","connection","targetProgramId","program","innerIxSet","instruction","parsedEvent","instructionData","ixData","ixDiscriminator","eventDiscriminator","event","idlDiscriminator","fullEventData","eventHandlers","context","handler","generateRequestIdSolana","keyVersion","algo","dest","params","payloadHex","parseAbiParameters","PublicKey","idl","Program","programStatePDA","programState","pda","fixedRemainingAccounts","acc","signer","Transaction","signers","blockhash","startTime","timeout","status","resolve","TransactionExpiredTimeoutError","_payload","_path","afterSignature","lastCheckedSignature","i","signatures","cpiEvents","mapped","parser","EventParser","evt","name","eventRequestIdHex","d","handlers","commitment","cpiHandlers","onSignatureResponded","e","onSignatureError","cpiSubId","subId"],"mappings":"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","file":"index.browser.js","sourcesContent":["import { type NajPublicKey } from '@types'\n\nexport const ENVS = {\n TESTNET_DEV: 'TESTNET_DEV',\n TESTNET: 'TESTNET',\n MAINNET: 'MAINNET',\n} as const\n\nexport const CHAINS = {\n ETHEREUM: 'ETHEREUM',\n SOLANA: 'SOLANA',\n} as const\n\n/**\n * Root public keys for the Sig Network Smart Contracts across different environments.\n *\n * These keys should never change.\n */\nexport const ROOT_PUBLIC_KEYS: Record<keyof typeof ENVS, NajPublicKey> = {\n [ENVS.TESTNET_DEV]:\n 'secp256k1:54hU5wcCmVUPFWLDALXMh1fFToZsVXrx9BbTbHzSfQq1Kd1rJZi52iPa4QQxo6s5TgjWqgpY8HamYuUDzG6fAaUq',\n [ENVS.TESTNET]:\n 'secp256k1:3Ww8iFjqTHufye5aRGUvrQqETegR4gVUcW8FX5xzscaN9ENhpkffojsxJwi6N1RbbHMTxYa9UyKeqK3fsMuwxjR5',\n [ENVS.MAINNET]:\n 'secp256k1:4tY4qMzusmgX5wYdG35663Y3Qar3CTbpApotwk9ZKLoF79XA4DjG8XoByaKdNHKQX9Lz5hd7iJqsWdTKyA7dKa6Z',\n}\n\n/**\n * Chain IDs used in the key derivation function (KDF) for deriving child public keys to\n * distinguish between different chains.\n *\n * @see {@link deriveChildPublicKey} in cryptography.ts for usage details\n */\nexport const KDF_CHAIN_IDS = {\n [CHAINS.ETHEREUM]: '0x1',\n [CHAINS.SOLANA]: '0x800001f5',\n} as const\n\n/**\n * Contract addresses for different chains and environments.\n *\n * - Testnet Dev: Used for internal development, very unstable\n * - Testnet: Used for external development, stable\n * - Mainnet: Production contract address\n *\n * @see ChainSignatureContract documentation for implementation details\n */\nexport const CONTRACT_ADDRESSES: Record<\n keyof typeof CHAINS,\n Record<keyof typeof ENVS, string>\n> = {\n [CHAINS.ETHEREUM]: {\n [ENVS.TESTNET_DEV]: '0x69C6b28Fdc74618817fa380De29a653060e14009',\n [ENVS.TESTNET]: '0x83458E8Bf8206131Fe5c05127007FA164c0948A2',\n [ENVS.MAINNET]: '0xf8bdC0612361a1E49a8E01423d4C0cFc5dF4791A',\n },\n [CHAINS.SOLANA]: {\n [ENVS.TESTNET_DEV]: 'SigDuEPNeDjh3oJv7MUraPN7zaTFomS6ZWfpXwjUg4B',\n [ENVS.TESTNET]: 'SigTVbfRK9LsXWpSv9KgpabrQcFKr5hDdUwMhYsXyKg',\n [ENVS.MAINNET]: 'SigMcRMjKfnC7RDG5q4yUMZM1s5KJ9oYTPP4NmJRDRw',\n },\n}\n","export * as cryptography from './cryptography'\n","import { base58 } from '@scure/base'\nimport elliptic from 'elliptic'\nimport { keccak256, recoverAddress, createPublicClient, http } from 'viem'\n\nimport { KDF_CHAIN_IDS } from '@constants'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport {\n type NajPublicKey,\n type MPCSignature,\n type RSVSignature,\n type UncompressedPubKeySEC1,\n} from '@types'\n\nimport { chainAdapters } from '..'\nconst { ec: EC } = elliptic\n\nexport const toRSV = (signature: MPCSignature): RSVSignature => {\n if (\n 'bigR' in signature &&\n 'x' in signature.bigR &&\n 's' in signature &&\n typeof signature.s === 'bigint'\n ) {\n return {\n r: signature.bigR.x.toString(16).padStart(64, '0'),\n s: signature.s.toString(16).padStart(64, '0'),\n v: signature.recoveryId + 27,\n }\n }\n\n throw new Error('Invalid signature format')\n}\n\n/**\n * Compresses an uncompressed public key to its compressed format following SEC1 standards.\n * In SEC1, a compressed public key consists of a prefix (02 or 03) followed by the x-coordinate.\n * The prefix indicates whether the y-coordinate is even (02) or odd (03).\n *\n * @param uncompressedPubKeySEC1 - The uncompressed public key in hex format, with or without '04' prefix\n * @returns The compressed public key in hex format\n * @throws Error if the uncompressed public key length is invalid\n */\nexport const compressPubKey = (\n uncompressedPubKeySEC1: UncompressedPubKeySEC1\n): string => {\n const slicedPubKey = uncompressedPubKeySEC1.slice(2)\n\n if (slicedPubKey.length !== 128) {\n throw new Error('Invalid uncompressed public key length')\n }\n\n const x = slicedPubKey.slice(0, 64)\n const y = slicedPubKey.slice(64)\n\n const isEven = parseInt(y.slice(-1), 16) % 2 === 0\n const prefix = isEven ? '02' : '03'\n\n return prefix + x\n}\n\n/**\n * Converts a NAJ public key to an uncompressed SEC1 public key.\n *\n * @param najPublicKey - The NAJ public key to convert (e.g. secp 256k1:3Ww8iFjqTHufye5aRGUvrQqETegR4gVUcW8FX5xzscaN9ENhpkffojsxJwi6N1RbbHMTxYa9UyKeqK3fsMuwxjR5)\n * @returns The uncompressed SEC1 public key (e.g. 04 || x || y)\n */\nexport const najToUncompressedPubKeySEC1 = (\n najPublicKey: NajPublicKey\n): UncompressedPubKeySEC1 => {\n const decodedKey = base58.decode(najPublicKey.split(':')[1])\n return `04${Buffer.from(decodedKey).toString('hex')}`\n}\n\n/**\n * Derives a child public key from a parent public key using the sig.network v1.0.0 epsilon derivation scheme.\n * The parent public keys are defined in @constants.ts\n *\n * @param najPublicKey - The parent public key in uncompressed SEC1 format (e.g. 04 || x || y)\n * @param predecessorId - The predecessor ID is the address of the account calling the signer contract (e.g EOA or Contract Address)\n * @param path - Optional derivation path suffix (defaults to empty string)\n * @returns The derived child public key in uncompressed SEC1 format (04 || x || y)\n */\nexport function deriveChildPublicKey(\n rootUncompressedPubKeySEC1: UncompressedPubKeySEC1,\n predecessorId: string,\n path: string = '',\n chainId: string\n): UncompressedPubKeySEC1 {\n const ec = new EC('secp256k1')\n\n const EPSILON_DERIVATION_PREFIX = 'sig.network v1.0.0 epsilon derivation'\n const derivationPath = `${EPSILON_DERIVATION_PREFIX},${chainId},${predecessorId},${path}`\n\n let scalarHex = ''\n\n if (chainId === KDF_CHAIN_IDS.ETHEREUM) {\n scalarHex = keccak256(Buffer.from(derivationPath)).slice(2)\n } else if (chainId === KDF_CHAIN_IDS.SOLANA) {\n scalarHex = keccak256(Buffer.from(derivationPath)).slice(2)\n } else {\n throw new Error('Invalid chain ID')\n }\n\n const x = rootUncompressedPubKeySEC1.substring(2, 66)\n const y = rootUncompressedPubKeySEC1.substring(66)\n\n const oldPublicKeyPoint = ec.curve.point(x, y)\n const scalarTimesG = ec.g.mul(scalarHex)\n const newPublicKeyPoint = oldPublicKeyPoint.add(scalarTimesG)\n\n const newX = newPublicKeyPoint.getX().toString('hex').padStart(64, '0')\n const newY = newPublicKeyPoint.getY().toString('hex').padStart(64, '0')\n\n return `04${newX}${newY}`\n}\n\n/**\n * Verifies that a secp256k1 signature was created by the expected derived address\n * by recovering the signing address and comparing it with the address derived from the contract.\n *\n * @param signature - The RSV signature to verify\n * @param payload - The original message that was signed (as byte array)\n * @param requesterAddress - The address of the requester\n * @param path - The derivation path used for key generation\n * @param contract - The contract instance for deriving addresses\n * @returns Promise resolving to true if the recovered address matches the expected address\n */\nexport async function verifyRecoveredAddress(\n signature: RSVSignature,\n payload: number[] | Uint8Array,\n requesterAddress: string,\n path: string,\n contract: BaseChainSignatureContract\n): Promise<boolean> {\n try {\n // Derive the expected address using EVM chain adapter\n // We use EVM adapter even for non-EVM chains since we're dealing with secp256k1 signatures\n const evm = new chainAdapters.evm.EVM({\n publicClient: createPublicClient({\n transport: http('https://dontcare.com'),\n }),\n contract,\n })\n\n const { address: expectedAddress } = await evm.deriveAddressAndPublicKey(\n requesterAddress,\n path\n )\n\n const recoveredAddress = await recoverAddress({\n hash: new Uint8Array(payload),\n signature: {\n r: `0x${signature.r}`,\n s: `0x${signature.s}`,\n yParity: signature.v,\n },\n })\n\n return recoveredAddress.toLowerCase() === expectedAddress.toLowerCase()\n } catch (error) {\n console.error('Signature verification failed:', error)\n return false\n }\n}\n","export { ChainAdapter } from './ChainAdapter'\n\nexport * as evm from './EVM'\nexport * as btc from './Bitcoin'\nexport * as cosmos from './Cosmos'\n","import type { KeyDerivationPath, HashToSign, RSVSignature } from '@types'\n\nexport abstract class ChainAdapter<TransactionRequest, UnsignedTransaction> {\n /**\n * Gets the native token balance and decimals for a given address\n *\n * @param address - The address to check\n * @returns Promise resolving to an object containing:\n * - balance: The balance as a bigint, in the chain's base units\n * - decimals: The number of decimals used to format the balance\n */\n abstract getBalance(address: string): Promise<{\n balance: bigint\n decimals: number\n }>\n\n /**\n * Uses Sig Network Key Derivation Function to derive the address and public key. from a signer ID and string path.\n *\n * @param predecessor - The id/address of the account requesting signature\n * @param path - The string path used to derive the key\n * @returns Promise resolving to the derived address and public key\n */\n abstract deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath\n ): Promise<{\n address: string\n publicKey: string\n }>\n\n /**\n * Serializes an unsigned transaction to a string format.\n * This is useful for storing or transmitting the transaction.\n *\n * @param transaction - The unsigned transaction to serialize\n * @returns The serialized transaction string\n */\n abstract serializeTransaction(transaction: UnsignedTransaction): string\n\n /**\n * Deserializes a transaction string back into an unsigned transaction object.\n * This reverses the serialization done by serializeTransaction().\n *\n * @param serialized - The serialized transaction string\n * @returns The deserialized unsigned transaction\n */\n abstract deserializeTransaction(serialized: string): UnsignedTransaction\n\n /**\n * Prepares a transaction for Sig Network MPC signing by creating the necessary payloads.\n * This method handles chain-specific transaction preparation including:\n * - Fee calculation\n * - Nonce/sequence management\n * - UTXO selection (for UTXO-based chains)\n * - Transaction encoding\n *\n * @param transactionRequest - The transaction request containing parameters like recipient, amount, etc.\n * @returns Promise resolving to an object containing:\n * - transaction: The unsigned transaction\n * - hashesToSign: Array of payloads to be signed by MPC. The order of these payloads must match\n * the order of signatures provided to finalizeTransactionSigning()\n */\n abstract prepareTransactionForSigning(\n transactionRequest: TransactionRequest\n ): Promise<{\n transaction: UnsignedTransaction\n hashesToSign: HashToSign[]\n }>\n\n /**\n * Adds Sig Network MPC-generated signatures to an unsigned transaction.\n *\n * @param params - Parameters for adding signatures\n * @param params.transaction - The unsigned transaction to add signatures to\n * @param params.rsvSignatures - Array of RSV signatures generated through MPC. Must be in the same order\n * as the payloads returned by prepareTransactionForSigning()\n * @returns The serialized signed transaction ready for broadcast\n */\n abstract finalizeTransactionSigning(params: {\n transaction: UnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): string\n\n /**\n * Broadcasts a signed transaction to the network.\n *\n * @param txSerialized - The serialized signed transaction\n * @returns Promise resolving to the transaction hash/ID\n */\n abstract broadcastTx(txSerialized: string): Promise<string>\n}\n","// EVM\nexport { EVM } from './EVM'\n\nexport { fetchEVMFeeProperties } from './utils'\n\nexport type {\n EVMTransactionRequest,\n EVMUnsignedTransaction,\n EVMMessage,\n EVMTypedData,\n} from './types'\n","import { type PublicClient, type TransactionRequest } from 'viem'\n\nexport interface EVMFeeProperties {\n gas: bigint\n maxFeePerGas: bigint\n maxPriorityFeePerGas: bigint\n}\n\nexport async function fetchEVMFeeProperties(\n client: PublicClient,\n transaction: TransactionRequest\n): Promise<EVMFeeProperties> {\n const [gas, feeData] = await Promise.all([\n client.estimateGas(transaction),\n client.estimateFeesPerGas(),\n ])\n\n const maxFeePerGas = feeData.maxFeePerGas ?? BigInt(10_000_000_000) // 10 gwei\n const maxPriorityFeePerGas =\n feeData.maxPriorityFeePerGas ?? BigInt(10_000_000_000) // 10 gwei\n\n return {\n gas,\n maxFeePerGas,\n maxPriorityFeePerGas,\n }\n}\n","import {\n parseTransaction,\n type PublicClient,\n hashMessage,\n hashTypedData,\n keccak256,\n toBytes,\n type Hex,\n serializeTransaction,\n type Signature,\n numberToHex,\n getAddress,\n type Address,\n type Hash,\n concatHex,\n encodeAbiParameters,\n hexToBigInt,\n concat,\n pad,\n isAddress,\n} from 'viem'\n\nimport { ChainAdapter } from '@chain-adapters/ChainAdapter'\nimport type {\n EVMTransactionRequest,\n EVMUnsignedTransaction,\n EVMMessage,\n EVMTypedData,\n UserOperationV6,\n UserOperationV7,\n} from '@chain-adapters/EVM/types'\nimport { fetchEVMFeeProperties } from '@chain-adapters/EVM/utils'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@types'\n\n/**\n * Implementation of the ChainAdapter interface for EVM-compatible networks.\n * Handles interactions with Ethereum Virtual Machine based blockchains like Ethereum, BSC, Polygon, etc.\n */\nexport class EVM extends ChainAdapter<\n EVMTransactionRequest,\n EVMUnsignedTransaction\n> {\n private readonly client: PublicClient\n private readonly contract: BaseChainSignatureContract\n\n /**\n * Creates a new EVM chain instance\n * @param params - Configuration parameters\n * @param params.publicClient - A Viem PublicClient instance for reading from the blockchain\n * @param params.contract - Instance of the chain signature contract for MPC operations\n */\n constructor({\n publicClient,\n contract,\n }: {\n publicClient: PublicClient\n contract: BaseChainSignatureContract\n }) {\n super()\n\n this.contract = contract\n this.client = publicClient\n }\n\n private async attachGasAndNonce(\n transaction: EVMTransactionRequest\n ): Promise<EVMUnsignedTransaction> {\n const fees = await fetchEVMFeeProperties(this.client, transaction)\n const nonce = await this.client.getTransactionCount({\n address: transaction.from,\n })\n\n const { from, ...rest } = transaction\n\n return {\n ...fees,\n nonce,\n chainId: Number(await this.client.getChainId()),\n type: 'eip1559',\n ...rest,\n }\n }\n\n private transformRSVSignature(signature: RSVSignature): Signature {\n return {\n r: `0x${signature.r}`,\n s: `0x${signature.s}`,\n yParity: signature.v - 27,\n }\n }\n\n private assembleSignature(signature: RSVSignature): Hex {\n const { r, s, yParity } = this.transformRSVSignature(signature)\n\n if (yParity === undefined) {\n throw new Error('Missing yParity')\n }\n\n return concatHex([r, s, numberToHex(yParity + 27, { size: 1 })])\n }\n\n async deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath\n ): Promise<{\n address: string\n publicKey: string\n }> {\n const uncompressedPubKey = await this.contract.getDerivedPublicKey({\n path,\n predecessor,\n })\n\n if (!uncompressedPubKey) {\n throw new Error('Failed to get derived public key')\n }\n\n const publicKeyNoPrefix = uncompressedPubKey.startsWith('04')\n ? uncompressedPubKey.slice(2)\n : uncompressedPubKey\n\n const hash = keccak256(Buffer.from(publicKeyNoPrefix, 'hex'))\n const address = getAddress(`0x${hash.slice(-40)}`)\n\n return {\n address,\n publicKey: uncompressedPubKey,\n }\n }\n\n async getBalance(\n address: string\n ): Promise<{ balance: bigint; decimals: number }> {\n const balance = await this.client.getBalance({\n address: address as Address,\n })\n return {\n balance,\n decimals: 18,\n }\n }\n\n serializeTransaction(transaction: EVMUnsignedTransaction): `0x${string}` {\n return serializeTransaction(transaction)\n }\n\n deserializeTransaction(serialized: `0x${string}`): EVMUnsignedTransaction {\n return parseTransaction(serialized) as EVMUnsignedTransaction\n }\n\n async prepareTransactionForSigning(\n transactionRequest: EVMTransactionRequest\n ): Promise<{\n transaction: EVMUnsignedTransaction\n hashesToSign: HashToSign[]\n }> {\n const transaction = await this.attachGasAndNonce(transactionRequest)\n\n const serializedTx = serializeTransaction(transaction)\n const txHash = toBytes(keccak256(serializedTx))\n\n return {\n transaction,\n hashesToSign: [Array.from(txHash)],\n }\n }\n\n async prepareMessageForSigning(message: EVMMessage): Promise<{\n hashToSign: HashToSign\n }> {\n return {\n hashToSign: Array.from(toBytes(hashMessage(message))),\n }\n }\n\n async prepareTypedDataForSigning(typedDataRequest: EVMTypedData): Promise<{\n hashToSign: HashToSign\n }> {\n return {\n hashToSign: Array.from(toBytes(hashTypedData(typedDataRequest))),\n }\n }\n\n /**\n * This implementation is a common step for Biconomy and Alchemy.\n * Key differences between implementations:\n * - Signature format: Biconomy omits 0x00 prefix when concatenating, Alchemy includes it\n * - Version support: Biconomy only supports v6, Alchemy supports both v6 and v7\n * - Validation: Biconomy uses modules for signature validation, Alchemy uses built-in validation\n */\n async prepareUserOpForSigning(\n userOp: UserOperationV7 | UserOperationV6,\n entryPointAddress?: Address,\n chainIdArgs?: number\n ): Promise<{\n userOp: UserOperationV7 | UserOperationV6\n hashToSign: HashToSign\n }> {\n const chainId = chainIdArgs ?? (await this.client.getChainId())\n const entryPoint =\n entryPointAddress || '0x0000000071727De22E5E9d8BAf0edAc6f37da032'\n\n const encoded = encodeAbiParameters(\n [{ type: 'bytes32' }, { type: 'address' }, { type: 'uint256' }],\n [\n keccak256(\n encodeAbiParameters(\n [\n { type: 'address' },\n { type: 'uint256' },\n { type: 'bytes32' },\n { type: 'bytes32' },\n { type: 'bytes32' },\n { type: 'uint256' },\n { type: 'bytes32' },\n { type: 'bytes32' },\n ],\n [\n userOp.sender,\n hexToBigInt(userOp.nonce),\n keccak256(\n 'factory' in userOp &&\n 'factoryData' in userOp &&\n userOp.factory &&\n userOp.factoryData\n ? concat([userOp.factory, userOp.factoryData])\n : 'initCode' in userOp\n ? userOp.initCode\n : '0x'\n ),\n keccak256(userOp.callData),\n concat([\n pad(userOp.verificationGasLimit, { size: 16 }),\n pad(userOp.callGasLimit, { size: 16 }),\n ]),\n hexToBigInt(userOp.preVerificationGas),\n concat([\n pad(userOp.maxPriorityFeePerGas, { size: 16 }),\n pad(userOp.maxFeePerGas, { size: 16 }),\n ]),\n keccak256(\n 'paymaster' in userOp &&\n userOp.paymaster &&\n isAddress(userOp.paymaster)\n ? concat([\n userOp.paymaster,\n pad(userOp.paymasterVerificationGasLimit, { size: 16 }),\n pad(userOp.paymasterPostOpGasLimit, { size: 16 }),\n userOp.paymasterData,\n ])\n : 'paymasterAndData' in userOp\n ? userOp.paymasterAndData\n : '0x'\n ),\n ]\n )\n ),\n entryPoint,\n BigInt(chainId),\n ]\n )\n\n const userOpHash = keccak256(encoded)\n\n return {\n userOp,\n hashToSign: Array.from(toBytes(hashMessage({ raw: userOpHash }))),\n }\n }\n\n finalizeTransactionSigning({\n transaction,\n rsvSignatures,\n }: {\n transaction: EVMUnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): `0x02${string}` {\n const signature = this.transformRSVSignature(rsvSignatures[0])\n\n return serializeTransaction(transaction, signature)\n }\n\n finalizeMessageSigning({\n rsvSignature,\n }: {\n rsvSignature: RSVSignature\n }): Hex {\n return this.assembleSignature(rsvSignature)\n }\n\n finalizeTypedDataSigning({\n rsvSignature,\n }: {\n rsvSignature: RSVSignature\n }): Hex {\n return this.assembleSignature(rsvSignature)\n }\n\n finalizeUserOpSigning({\n userOp,\n rsvSignature,\n }: {\n userOp: UserOperationV7 | UserOperationV6\n rsvSignature: RSVSignature\n }): UserOperationV7 | UserOperationV6 {\n const { r, s, yParity } = this.transformRSVSignature(rsvSignature)\n if (yParity === undefined) {\n throw new Error('Missing yParity')\n }\n\n return {\n ...userOp,\n signature: concatHex([\n '0x00', // Alchemy specific implementation. Biconomy doesn't include the 0x00 prefix.\n r,\n s,\n numberToHex(Number(yParity + 27), { size: 1 }),\n ]),\n }\n }\n\n async broadcastTx(txSerialized: `0x${string}`): Promise<Hash> {\n try {\n return await this.client.sendRawTransaction({\n serializedTransaction: txSerialized,\n })\n } catch (error) {\n console.error('Transaction broadcast failed:', error)\n throw new Error('Failed to broadcast transaction.')\n }\n }\n}\n","// Bitcoin\nexport { Bitcoin } from './Bitcoin'\n\nexport { BTCRpcAdapters, BTCRpcAdapter } from './BTCRpcAdapter'\n\nexport type {\n BTCTransactionRequest,\n BTCUnsignedTransaction,\n BTCTransaction,\n BTCOutput,\n BTCInput,\n BTCNetworkIds,\n} from './types'\n","import * as bitcoin from 'bitcoinjs-lib'\n\nexport function parseBTCNetwork(network: string): bitcoin.networks.Network {\n switch (network.toLowerCase()) {\n case 'mainnet':\n return bitcoin.networks.bitcoin\n case 'testnet':\n return bitcoin.networks.testnet\n case 'regtest':\n return bitcoin.networks.regtest\n default:\n throw new Error(`Unknown Bitcoin network: ${network}`)\n }\n}\n","import * as bitcoin from 'bitcoinjs-lib'\n\nimport { type BTCRpcAdapter } from '@chain-adapters/Bitcoin/BTCRpcAdapter'\nimport type {\n BTCInput,\n BTCNetworkIds,\n BTCOutput,\n BTCTransactionRequest,\n BTCUnsignedTransaction,\n} from '@chain-adapters/Bitcoin/types'\nimport { parseBTCNetwork } from '@chain-adapters/Bitcoin/utils'\nimport { ChainAdapter } from '@chain-adapters/ChainAdapter'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@types'\nimport { cryptography } from '@utils'\n\n/**\n * Implementation of the ChainAdapter interface for Bitcoin network.\n * Handles interactions with both Bitcoin mainnet and testnet, supporting P2WPKH transactions.\n */\nexport class Bitcoin extends ChainAdapter<\n BTCTransactionRequest,\n BTCUnsignedTransaction\n> {\n private static readonly SATOSHIS_PER_BTC = 100_000_000\n\n private readonly network: BTCNetworkIds\n private readonly btcRpcAdapter: BTCRpcAdapter\n private readonly contract: BaseChainSignatureContract\n\n /**\n * Creates a new Bitcoin chain instance\n * @param params - Configuration parameters\n * @param params.network - Network identifier (mainnet/testnet)\n * @param params.contract - Instance of the chain signature contract for MPC operations\n * @param params.btcRpcAdapter - Bitcoin RPC adapter for network interactions\n */\n constructor({\n network,\n contract,\n btcRpcAdapter,\n }: {\n network: BTCNetworkIds\n contract: BaseChainSignatureContract\n btcRpcAdapter: BTCRpcAdapter\n }) {\n super()\n\n this.network = network\n this.btcRpcAdapter = btcRpcAdapter\n this.contract = contract\n }\n\n /**\n * Converts satoshis to BTC\n * @param satoshis - Amount in satoshis\n * @returns Amount in BTC\n */\n static toBTC(satoshis: number): number {\n return satoshis / Bitcoin.SATOSHIS_PER_BTC\n }\n\n /**\n * Converts BTC to satoshis\n * @param btc - Amount in BTC\n * @returns Amount in satoshis (rounded)\n */\n static toSatoshi(btc: number): number {\n return Math.round(btc * Bitcoin.SATOSHIS_PER_BTC)\n }\n\n private async fetchTransaction(\n transactionId: string\n ): Promise<bitcoin.Transaction> {\n const data = await this.btcRpcAdapter.getTransaction(transactionId)\n const tx = new bitcoin.Transaction()\n\n data.vout.forEach((vout) => {\n const scriptPubKey = Buffer.from(vout.scriptpubkey, 'hex')\n tx.addOutput(scriptPubKey, Number(vout.value))\n })\n\n return tx\n }\n\n private static transformRSVSignature(signature: RSVSignature): Buffer {\n const r = signature.r.padStart(64, '0')\n const s = signature.s.padStart(64, '0')\n\n const rawSignature = Buffer.from(r + s, 'hex')\n\n if (rawSignature.length !== 64) {\n throw new Error('Invalid signature length.')\n }\n\n return rawSignature\n }\n\n /**\n * Creates a Partially Signed Bitcoin Transaction (PSBT)\n * @param params - Parameters for creating the PSBT\n * @param params.transactionRequest - Transaction request containing inputs and outputs\n * @returns Created PSBT instance\n */\n async createPSBT({\n transactionRequest,\n }: {\n transactionRequest: BTCTransactionRequest\n }): Promise<bitcoin.Psbt> {\n const { inputs, outputs } =\n transactionRequest.inputs && transactionRequest.outputs\n ? transactionRequest\n : await this.btcRpcAdapter.selectUTXOs(transactionRequest.from, [\n {\n address: transactionRequest.to,\n value: parseFloat(transactionRequest.value),\n },\n ])\n\n const psbt = new bitcoin.Psbt({ network: parseBTCNetwork(this.network) })\n\n await Promise.all(\n inputs.map(async (input: BTCInput) => {\n if (!input.scriptPubKey) {\n const transaction = await this.fetchTransaction(input.txid)\n const prevOut = transaction.outs[input.vout]\n input.scriptPubKey = prevOut.script\n }\n\n // Prepare the input as P2WPKH\n psbt.addInput({\n hash: input.txid,\n index: input.vout,\n witnessUtxo: {\n script: input.scriptPubKey,\n value: input.value,\n },\n })\n })\n )\n\n outputs.forEach((out: BTCOutput) => {\n if ('address' in out) {\n psbt.addOutput({\n address: out.address,\n value: out.value,\n })\n } else if ('script' in out) {\n psbt.addOutput({\n script: out.script,\n value: out.value,\n })\n } else if (transactionRequest.from !== undefined) {\n // Include change address from coinselect\n psbt.addOutput({\n value: Number(out.value),\n address: transactionRequest.from,\n })\n }\n })\n\n return psbt\n }\n\n async getBalance(\n address: string\n ): Promise<{ balance: bigint; decimals: number }> {\n const balance = BigInt(await this.btcRpcAdapter.getBalance(address))\n return {\n balance,\n decimals: 8,\n }\n }\n\n async deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath\n ): Promise<{ address: string; publicKey: string }> {\n const uncompressedPubKey = await this.contract.getDerivedPublicKey({\n path,\n predecessor,\n })\n\n if (!uncompressedPubKey) {\n throw new Error('Failed to get derived public key')\n }\n\n const derivedKey = cryptography.compressPubKey(uncompressedPubKey)\n const publicKeyBuffer = Buffer.from(derivedKey, 'hex')\n const network = parseBTCNetwork(this.network)\n\n const payment = bitcoin.payments.p2wpkh({\n pubkey: publicKeyBuffer,\n network,\n })\n\n const { address } = payment\n\n if (!address) {\n throw new Error('Failed to generate Bitcoin address')\n }\n\n return { address, publicKey: derivedKey }\n }\n\n serializeTransaction(transaction: BTCUnsignedTransaction): string {\n return JSON.stringify({\n psbt: transaction.psbt.toHex(),\n publicKey: transaction.publicKey,\n })\n }\n\n deserializeTransaction(serialized: string): BTCUnsignedTransaction {\n const transactionJSON = JSON.parse(serialized)\n return {\n psbt: bitcoin.Psbt.fromHex(transactionJSON.psbt as string),\n publicKey: transactionJSON.publicKey,\n }\n }\n\n async prepareTransactionForSigning(\n transactionRequest: BTCTransactionRequest\n ): Promise<{\n transaction: BTCUnsignedTransaction\n hashesToSign: HashToSign[]\n }> {\n const publicKeyBuffer = Buffer.from(transactionRequest.publicKey, 'hex')\n const psbt = await this.createPSBT({\n transactionRequest,\n })\n\n // We can't double sign a PSBT, therefore we serialize the payload before to return it\n const psbtHex = psbt.toHex()\n\n const hashesToSign: HashToSign[] = []\n\n const mockKeyPair = (index: number): bitcoin.Signer => ({\n publicKey: publicKeyBuffer,\n sign: (hash: Buffer): Buffer => {\n hashesToSign[index] = Array.from(hash)\n // Return dummy signature to satisfy the interface\n return Buffer.alloc(64)\n },\n })\n\n for (let index = 0; index < psbt.inputCount; index++) {\n psbt.signInput(index, mockKeyPair(index))\n }\n\n return {\n transaction: {\n psbt: bitcoin.Psbt.fromHex(psbtHex),\n publicKey: transactionRequest.publicKey,\n },\n hashesToSign,\n }\n }\n\n finalizeTransactionSigning({\n transaction: { psbt, publicKey },\n rsvSignatures,\n }: {\n transaction: BTCUnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): string {\n const publicKeyBuffer = Buffer.from(publicKey, 'hex')\n\n const keyPair = (index: number): bitcoin.Signer => ({\n publicKey: publicKeyBuffer,\n sign: () => {\n const mpcSignature = rsvSignatures[index]\n return Bitcoin.transformRSVSignature(mpcSignature)\n },\n })\n\n for (let index = 0; index < psbt.inputCount; index++) {\n psbt.signInput(index, keyPair(index))\n }\n\n psbt.finalizeAllInputs()\n return psbt.extractTransaction().toHex()\n }\n\n async broadcastTx(txSerialized: string): Promise<string> {\n return await this.btcRpcAdapter.broadcastTransaction(txSerialized)\n }\n}\n","import type {\n BTCTransaction,\n BTCInput,\n BTCOutput,\n} from '@chain-adapters/Bitcoin/types'\n\nexport abstract class BTCRpcAdapter {\n abstract selectUTXOs(\n from: string,\n targets: BTCOutput[]\n ): Promise<{ inputs: BTCInput[]; outputs: BTCOutput[] }>\n abstract broadcastTransaction(transactionHex: string): Promise<string>\n abstract getBalance(address: string): Promise<number>\n abstract getTransaction(txid: string): Promise<BTCTransaction>\n}\n","// There is no types for coinselect\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-expect-error\n\nimport coinselect from 'coinselect'\n\nimport { BTCRpcAdapter } from '@chain-adapters/Bitcoin/BTCRpcAdapter/BTCRpcAdapter'\nimport {\n type BTCFeeRecommendation,\n type UTXO,\n} from '@chain-adapters/Bitcoin/BTCRpcAdapter/Mempool/types'\nimport type {\n BTCTransaction,\n BTCInput,\n BTCOutput,\n} from '@chain-adapters/Bitcoin/types'\n\nexport class Mempool extends BTCRpcAdapter {\n private readonly providerUrl: string\n\n constructor(providerUrl: string) {\n super()\n this.providerUrl = providerUrl\n }\n\n private async fetchFeeRate(confirmationTarget = 6): Promise<number> {\n const response = await fetch(`${this.providerUrl}/v1/fees/recommended`)\n const data = (await response.json()) as BTCFeeRecommendation\n\n if (confirmationTarget <= 1) {\n return data.fastestFee\n } else if (confirmationTarget <= 3) {\n return data.halfHourFee\n } else if (confirmationTarget <= 6) {\n return data.hourFee\n } else {\n return data.economyFee\n }\n }\n\n private async fetchUTXOs(address: string): Promise<UTXO[]> {\n try {\n const response = await fetch(\n `${this.providerUrl}/address/${address}/utxo`\n )\n return (await response.json()) as UTXO[]\n } catch (error) {\n console.error('Failed to fetch UTXOs:', error)\n return []\n }\n }\n\n async selectUTXOs(\n from: string,\n targets: BTCOutput[],\n confirmationTarget = 6\n ): Promise<{ inputs: BTCInput[]; outputs: BTCOutput[] }> {\n const utxos = await this.fetchUTXOs(from)\n const feeRate = await this.fetchFeeRate(confirmationTarget)\n\n // Add a small amount to the fee rate to ensure the transaction is confirmed\n const ret = coinselect(utxos, targets, Math.ceil(feeRate + 1))\n\n if (!ret.inputs || !ret.outputs) {\n throw new Error(\n 'Invalid transaction: coinselect failed to find a suitable set of inputs and outputs. This could be due to insufficient funds, or no inputs being available that meet the criteria.'\n )\n }\n\n return {\n inputs: ret.inputs,\n outputs: ret.outputs,\n }\n }\n\n async broadcastTransaction(transactionHex: string): Promise<string> {\n const response = await fetch(`${this.providerUrl}/tx`, {\n method: 'POST',\n body: transactionHex,\n })\n\n if (response.ok) {\n return await response.text()\n }\n\n throw new Error(`Failed to broadcast transaction: ${await response.text()}`)\n }\n\n async getBalance(address: string): Promise<number> {\n const response = await fetch(`${this.providerUrl}/address/${address}`)\n const data = (await response.json()) as {\n chain_stats: { funded_txo_sum: number; spent_txo_sum: number }\n }\n return data.chain_stats.funded_txo_sum - data.chain_stats.spent_txo_sum\n }\n\n async getTransaction(txid: string): Promise<BTCTransaction> {\n const response = await fetch(`${this.providerUrl}/tx/${txid}`)\n return (await response.json()) as BTCTransaction\n }\n}\n","import { Mempool } from './Mempool'\nexport { BTCRpcAdapter } from './BTCRpcAdapter'\n\nexport const BTCRpcAdapters = {\n Mempool,\n}\n","// Cosmos\nexport { Cosmos } from './Cosmos'\n\nexport type {\n CosmosNetworkIds,\n CosmosTransactionRequest,\n CosmosUnsignedTransaction,\n} from './types'\n","import { chains, assets } from 'chain-registry'\n\nimport { type ChainInfo } from '@chain-adapters/Cosmos/types'\n\nexport const fetchChainInfo = async (chainId: string): Promise<ChainInfo> => {\n const chainInfo = chains.find((chain) => chain.chain_id === chainId)\n if (!chainInfo) {\n throw new Error(`Chain info not found for chainId: ${chainId}`)\n }\n\n const { bech32_prefix: prefix, chain_id: expectedChainId } = chainInfo\n const denom = chainInfo.staking?.staking_tokens?.[0]?.denom\n const rpcUrl = chainInfo.apis?.rpc?.[0]?.address\n const restUrl = chainInfo.apis?.rest?.[0]?.address\n const gasPrice = chainInfo.fees?.fee_tokens?.[0]?.average_gas_price\n\n if (\n !prefix ||\n !denom ||\n !rpcUrl ||\n !restUrl ||\n !expectedChainId ||\n gasPrice === undefined\n ) {\n throw new Error(\n `Missing required chain information for ${chainInfo.chain_name}`\n )\n }\n\n const assetList = assets.find(\n (asset) => asset.chain_name === chainInfo.chain_name\n )\n const asset = assetList?.assets.find((asset) => asset.base === denom)\n const decimals = asset?.denom_units.find(\n (unit) => unit.denom === asset.display\n )?.exponent\n\n if (decimals === undefined) {\n throw new Error(\n `Could not find decimals for ${denom} on chain ${chainInfo.chain_name}`\n )\n }\n\n return { prefix, denom, rpcUrl, restUrl, expectedChainId, gasPrice, decimals }\n}\n","import { encodeSecp256k1Pubkey } from '@cosmjs/amino'\nimport { ripemd160, sha256 } from '@cosmjs/crypto'\nimport { toBase64, fromBase64, fromHex } from '@cosmjs/encoding'\nimport {\n Registry,\n makeSignBytes,\n encodePubkey,\n makeAuthInfoBytes,\n makeSignDoc,\n type TxBodyEncodeObject,\n} from '@cosmjs/proto-signing'\nimport { GasPrice, StargateClient, calculateFee } from '@cosmjs/stargate'\nimport { bech32 } from 'bech32'\nimport { SignMode } from 'cosmjs-types/cosmos/tx/signing/v1beta1/signing.js'\nimport { TxRaw } from 'cosmjs-types/cosmos/tx/v1beta1/tx.js'\n\nimport { ChainAdapter } from '@chain-adapters/ChainAdapter'\nimport type {\n CosmosNetworkIds,\n CosmosTransactionRequest,\n CosmosUnsignedTransaction,\n ChainInfo,\n BalanceResponse,\n} from '@chain-adapters/Cosmos/types'\nimport { fetchChainInfo } from '@chain-adapters/Cosmos/utils'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@types'\nimport { cryptography } from '@utils'\n\n/**\n * Implementation of the ChainAdapter interface for Cosmos-based networks.\n * Handles interactions with Cosmos SDK chains like Cosmos Hub, Osmosis, etc.\n */\nexport class Cosmos extends ChainAdapter<\n CosmosTransactionRequest,\n CosmosUnsignedTransaction\n> {\n private readonly registry: Registry\n private readonly chainId: CosmosNetworkIds\n private readonly contract: BaseChainSignatureContract\n private readonly endpoints?: {\n rpcUrl?: string\n restUrl?: string\n }\n\n /**\n * Creates a new Cosmos chain instance\n * @param params - Configuration parameters\n * @param params.chainId - Chain id for the Cosmos network\n * @param params.contract - Instance of the chain signature contract for MPC operations\n * @param params.endpoints - Optional RPC and REST endpoints\n * @param params.endpoints.rpcUrl - Optional RPC endpoint URL\n * @param params.endpoints.restUrl - Optional REST endpoint URL\n */\n constructor({\n chainId,\n contract,\n endpoints,\n }: {\n contract: BaseChainSignatureContract\n chainId: CosmosNetworkIds\n endpoints?: {\n rpcUrl?: string\n restUrl?: string\n }\n }) {\n super()\n\n this.contract = contract\n this.registry = new Registry()\n this.chainId = chainId\n this.endpoints = endpoints\n }\n\n private transformRSVSignature(rsvSignature: RSVSignature): Uint8Array {\n return new Uint8Array([\n ...fromHex(rsvSignature.r),\n ...fromHex(rsvSignature.s),\n ])\n }\n\n private async getChainInfo(): Promise<ChainInfo> {\n return {\n ...(await fetchChainInfo(this.chainId)),\n ...this.endpoints,\n }\n }\n\n async getBalance(\n address: string\n ): Promise<{ balance: bigint; decimals: number }> {\n try {\n const { restUrl, denom, decimals } = await this.getChainInfo()\n\n const response = await fetch(\n `${restUrl}/cosmos/bank/v1beta1/balances/${address}`\n )\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`)\n }\n\n const data = (await response.json()) as BalanceResponse\n const balance = data.balances.find((b) => b.denom === denom)\n const amount = balance?.amount ?? '0'\n\n return {\n balance: BigInt(amount),\n decimals,\n }\n } catch (error) {\n console.error('Failed to fetch Cosmos balance:', error)\n throw new Error('Failed to fetch Cosmos balance')\n }\n }\n\n async deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath\n ): Promise<{\n address: string\n publicKey: string\n }> {\n const { prefix } = await this.getChainInfo()\n const uncompressedPubKey = await this.contract.getDerivedPublicKey({\n path,\n predecessor,\n })\n\n if (!uncompressedPubKey) {\n throw new Error('Failed to get derived public key')\n }\n\n const derivedKey = cryptography.compressPubKey(uncompressedPubKey)\n const pubKeySha256 = sha256(fromHex(derivedKey))\n const ripemd160Hash = ripemd160(pubKeySha256)\n const address = bech32.encode(prefix, bech32.toWords(ripemd160Hash))\n\n return { address, publicKey: derivedKey }\n }\n\n serializeTransaction(transaction: CosmosUnsignedTransaction): string {\n const serialized = TxRaw.encode(transaction).finish()\n return toBase64(serialized)\n }\n\n deserializeTransaction(serialized: string): CosmosUnsignedTransaction {\n return TxRaw.decode(fromBase64(serialized))\n }\n\n async prepareTransactionForSigning(\n transactionRequest: CosmosTransactionRequest\n ): Promise<{\n transaction: CosmosUnsignedTransaction\n hashesToSign: HashToSign[]\n }> {\n const { denom, rpcUrl, gasPrice } = await this.getChainInfo()\n const publicKeyBytes = fromHex(transactionRequest.publicKey)\n\n const gasLimit = transactionRequest.gas || 200_000\n\n const fee = calculateFee(\n gasLimit,\n GasPrice.fromString(`${gasPrice}${denom}`)\n )\n\n const client = await StargateClient.connect(rpcUrl)\n const accountOnChain = await client.getAccount(transactionRequest.address)\n if (!accountOnChain) {\n throw new Error(\n `Account ${transactionRequest.address} does not exist on chain`\n )\n }\n\n const { accountNumber, sequence } = accountOnChain\n\n const txBodyEncodeObject: TxBodyEncodeObject = {\n typeUrl: '/cosmos.tx.v1beta1.TxBody',\n value: {\n messages: transactionRequest.messages,\n memo: transactionRequest.memo || '',\n },\n }\n\n const txBodyBytes = this.registry.encode(txBodyEncodeObject)\n\n const pubkey = encodePubkey(encodeSecp256k1Pubkey(publicKeyBytes))\n\n // TODO: Allow caller to provide: multiple signers, fee payer, fee granter\n const authInfoBytes = makeAuthInfoBytes(\n [\n {\n pubkey,\n sequence,\n },\n ],\n fee.amount,\n Number(fee.gas),\n undefined,\n undefined,\n SignMode.SIGN_MODE_DIRECT\n )\n\n const signDoc = makeSignDoc(\n txBodyBytes,\n authInfoBytes,\n this.chainId,\n accountNumber\n )\n\n const signBytes = makeSignBytes(signDoc)\n const payload = Array.from(sha256(signBytes))\n\n return {\n transaction: TxRaw.fromPartial({\n bodyBytes: txBodyBytes,\n authInfoBytes,\n signatures: [],\n }),\n hashesToSign: [payload],\n }\n }\n\n finalizeTransactionSigning({\n transaction,\n rsvSignatures,\n }: {\n transaction: CosmosUnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): string {\n // Allow support for multi-sig but the package only supports single-sig\n transaction.signatures = rsvSignatures.map((sig) =>\n this.transformRSVSignature(sig)\n )\n\n const txBytes = TxRaw.encode(transaction).finish()\n return Buffer.from(txBytes).toString('hex')\n }\n\n async broadcastTx(txSerialized: string): Promise<string> {\n try {\n const { rpcUrl } = await this.getChainInfo()\n const client = await StargateClient.connect(rpcUrl)\n\n const txBytes = fromHex(txSerialized)\n const broadcastResponse = await client.broadcastTx(txBytes)\n\n if (broadcastResponse.code !== 0) {\n throw new Error(`Broadcast error: ${broadcastResponse.rawLog}`)\n }\n\n return broadcastResponse.transactionHash\n } catch (error) {\n console.error('Transaction broadcast failed:', error)\n throw new Error('Failed to broadcast transaction.')\n }\n }\n}\n","export { ChainSignatureContract, type SignArgs } from './ChainSignatureContract'\n\nexport * as evm from './evm'\nexport * as solana from './solana'\n","import type BN from 'bn.js'\n\nimport type { RSVSignature, UncompressedPubKeySEC1 } from '@types'\n\nexport interface SignArgs {\n /** The payload to sign as an array of 32 bytes */\n payload: number[]\n /** The derivation path for key generation */\n path: string\n /** Version of the key to use */\n key_version: number\n}\n\n/**\n * Base contract interface required for compatibility with ChainAdapter instances like EVM and Bitcoin.\n *\n * See {@link EVM} and {@link Bitcoin} for example implementations.\n */\nexport abstract class BaseChainSignatureContract {\n /**\n * Gets the current signature deposit required by the contract.\n * This deposit amount helps manage network congestion.\n *\n * @returns Promise resolving to the required deposit amount as a BigNumber\n */\n abstract getCurrentSignatureDeposit(): Promise<BN>\n\n /**\n * Derives a child public key using a\\ derivation path and predecessor.\n *\n * @param args - Arguments for key derivation\n * @param args.path - The string path to use derive the key\n * @param args.predecessor - The id/address of the account requesting signature\n * @returns Promise resolving to the derived SEC1 uncompressed public key\n */\n abstract getDerivedPublicKey(\n args: {\n path: string\n predecessor: string\n } & Record<string, unknown>\n ): Promise<UncompressedPubKeySEC1>\n}\n\n/**\n * Full contract interface that extends BaseChainSignatureContract to provide all Sig Network Smart Contract capabilities.\n */\nexport abstract class ChainSignatureContract extends BaseChainSignatureContract {\n /**\n * Signs a payload using Sig Network MPC.\n *\n * @param args - Arguments for the signing operation\n * @param args.payload - The data to sign as an array of 32 bytes\n * @param args.path - The string path to use derive the key\n * @param args.key_version - Version of the key to use\n * @returns Promise resolving to the RSV signature\n */\n abstract sign(args: SignArgs & Record<string, unknown>): Promise<RSVSignature>\n\n /**\n * Gets the public key associated with this contract instance.\n *\n * @returns Promise resolving to the SEC1 uncompressed public key\n */\n abstract getPublicKey(): Promise<UncompressedPubKeySEC1>\n}\n","import * as ChainSignaturesContractABI from './ChainSignaturesContractABI'\nimport * as errors from './errors'\nexport * from './ChainSignaturesContract'\n\nconst utils = {\n ChainSignaturesContractABI,\n errors,\n}\n\nexport { utils }\n","export const abi = [\n {\n inputs: [\n { internalType: 'address', name: '_mpc_network', type: 'address' },\n { internalType: 'uint256', name: '_signatureDeposit', type: 'uint256' },\n ],\n stateMutability: 'nonpayable',\n type: 'constructor',\n },\n { inputs: [], name: 'AccessControlBadConfirmation', type: 'error' },\n {\n inputs: [\n { internalType: 'address', name: 'account', type: 'address' },\n { internalType: 'bytes32', name: 'neededRole', type: 'bytes32' },\n ],\n name: 'AccessControlUnauthorizedAccount',\n type: 'error',\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: 'bytes32', name: 'role', type: 'bytes32' },\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'previousAdminRole',\n type: 'bytes32',\n },\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'newAdminRole',\n type: 'bytes32',\n },\n ],\n name: 'RoleAdminChanged',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: 'bytes32', name: 'role', type: 'bytes32' },\n {\n indexed: true,\n internalType: 'address',\n name: 'account',\n type: 'address',\n },\n {\n indexed: true,\n internalType: 'address',\n name: 'sender',\n type: 'address',\n },\n ],\n name: 'RoleGranted',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: 'bytes32', name: 'role', type: 'bytes32' },\n {\n indexed: true,\n internalType: 'address',\n name: 'account',\n type: 'address',\n },\n {\n indexed: true,\n internalType: 'address',\n name: 'sender',\n type: 'address',\n },\n ],\n name: 'RoleRevoked',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'requestId',\n type: 'bytes32',\n },\n {\n indexed: false,\n internalType: 'address',\n name: 'responder',\n type: 'address',\n },\n { indexed: false, internalType: 'string', name: 'error', type: 'string' },\n ],\n name: 'SignatureError',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: false,\n internalType: 'address',\n name: 'sender',\n type: 'address',\n },\n {\n indexed: false,\n internalType: 'bytes32',\n name: 'payload',\n type: 'bytes32',\n },\n {\n indexed: false,\n internalType: 'uint32',\n name: 'keyVersion',\n type: 'uint32',\n },\n {\n indexed: false,\n internalType: 'uint256',\n name: 'deposit',\n type: 'uint256',\n },\n {\n indexed: false,\n internalType: 'uint256',\n name: 'chainId',\n type: 'uint256',\n },\n { indexed: false, internalType: 'string', name: 'path', type: 'string' },\n { indexed: false, internalType: 'string', name: 'algo', type: 'string' },\n { indexed: false, internalType: 'string', name: 'dest', type: 'string' },\n {\n indexed: false,\n internalType: 'string',\n name: 'params',\n type: 'string',\n },\n ],\n name: 'SignatureRequested',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'requestId',\n type: 'bytes32',\n },\n {\n indexed: false,\n internalType: 'address',\n name: 'responder',\n type: 'address',\n },\n {\n components: [\n {\n components: [\n { internalType: 'uint256', name: 'x', type: 'uint256' },\n { internalType: 'uint256', name: 'y', type: 'uint256' },\n ],\n internalType: 'struct ChainSignatures.AffinePoint',\n name: 'bigR',\n type: 'tuple',\n },\n { internalType: 'uint256', name: 's', type: 'uint256' },\n { internalType: 'uint8', name: 'recoveryId', type: 'uint8' },\n ],\n indexed: false,\n internalType: 'struct ChainSignatures.Signature',\n name: 'signature',\n type: 'tuple',\n },\n ],\n name: 'SignatureResponded',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: true,\n internalType: 'address',\n name: 'owner',\n type: 'address',\n },\n {\n indexed: false,\n internalType: 'uint256',\n name: 'amount',\n type: 'uint256',\n },\n ],\n name: 'Withdraw',\n type: 'event',\n },\n {\n inputs: [],\n name: 'DEFAULT_ADMIN_ROLE',\n outputs: [{ internalType: 'bytes32', name: '', type: 'bytes32' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [{ internalType: 'bytes32', name: 'role', type: 'bytes32' }],\n name: 'getRoleAdmin',\n outputs: [{ internalType: 'bytes32', name: '', type: 'bytes32' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [],\n name: 'getSignatureDeposit',\n outputs: [{ internalType: 'uint256', name: '', type: 'uint256' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'account', type: 'address' },\n ],\n name: 'grantRole',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'account', type: 'address' },\n ],\n name: 'hasRole',\n outputs: [{ internalType: 'bool', name: '', type: 'bool' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'callerConfirmation', type: 'address' },\n ],\n name: 'renounceRole',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n {\n components: [\n { internalType: 'bytes32', name: 'requestId', type: 'bytes32' },\n {\n components: [\n {\n components: [\n { internalType: 'uint256', name: 'x', type: 'uint256' },\n { internalType: 'uint256', name: 'y', type: 'uint256' },\n ],\n internalType: 'struct ChainSignatures.AffinePoint',\n name: 'bigR',\n type: 'tuple',\n },\n { internalType: 'uint256', name: 's', type: 'uint256' },\n { internalType: 'uint8', name: 'recoveryId', type: 'uint8' },\n ],\n internalType: 'struct ChainSignatures.Signature',\n name: 'signature',\n type: 'tuple',\n },\n ],\n internalType: 'struct ChainSignatures.Response[]',\n name: '_responses',\n type: 'tuple[]',\n },\n ],\n name: 'respond',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n {\n components: [\n { internalType: 'bytes32', name: 'requestId', type: 'bytes32' },\n { internalType: 'string', name: 'errorMessage', type: 'string' },\n ],\n internalType: 'struct ChainSignatures.ErrorResponse[]',\n name: '_errors',\n type: 'tuple[]',\n },\n ],\n name: 'respondError',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'account', type: 'address' },\n ],\n name: 'revokeRole',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [{ internalType: 'uint256', name: '_amount', type: 'uint256' }],\n name: 'setSignatureDeposit',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n {\n components: [\n { internalType: 'bytes32', name: 'payload', type: 'bytes32' },\n { internalType: 'string', name: 'path', type: 'string' },\n { internalType: 'uint32', name: 'keyVersion', type: 'uint32' },\n { internalType: 'string', name: 'algo', type: 'string' },\n { internalType: 'string', name: 'dest', type: 'string' },\n { internalType: 'string', name: 'params', type: 'string' },\n ],\n internalType: 'struct ChainSignatures.SignRequest',\n name: '_request',\n type: 'tuple',\n },\n ],\n name: 'sign',\n outputs: [],\n stateMutability: 'payable',\n type: 'function',\n },\n {\n inputs: [{ internalType: 'bytes4', name: 'interfaceId', type: 'bytes4' }],\n name: 'supportsInterface',\n outputs: [{ internalType: 'bool', name: '', type: 'bool' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'uint256', name: '_amount', type: 'uint256' },\n { internalType: 'address', name: '_receiver', type: 'address' },\n ],\n name: 'withdraw',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n]\n","import type { TransactionReceipt } from 'viem'\n\nexport class ChainSignatureError extends Error {\n requestId: `0x${string}`\n receipt: TransactionReceipt\n\n constructor(\n message: string,\n requestId: `0x${string}`,\n receipt: TransactionReceipt\n ) {\n super(message)\n this.name = 'ChainSignatureError'\n this.requestId = requestId\n this.receipt = receipt\n }\n}\n\nexport class SignatureNotFoundError extends ChainSignatureError {\n constructor(requestId: `0x${string}`, receipt: TransactionReceipt) {\n super('Signature not found after maximum retries', requestId, receipt)\n this.name = 'SignatureNotFoundError'\n }\n}\n\nexport class SignatureContractError extends ChainSignatureError {\n errorCode: string\n\n constructor(\n errorCode: string,\n requestId: `0x${string}`,\n receipt: TransactionReceipt\n ) {\n super(`Signature error: ${errorCode}`, requestId, receipt)\n this.name = 'SignatureContractError'\n this.errorCode = errorCode\n }\n}\n\nexport class SigningError extends ChainSignatureError {\n originalError?: Error\n\n constructor(\n requestId: `0x${string}`,\n receipt: TransactionReceipt,\n originalError?: Error\n ) {\n super('Error signing request', requestId, receipt)\n this.name = 'SigningError'\n this.originalError = originalError\n }\n}\n","import { CONTRACT_ADDRESSES, ROOT_PUBLIC_KEYS, type CHAINS } from '@constants'\nimport type { NajPublicKey } from '@types'\n\nexport const getRootPublicKey = (\n contractAddress: string,\n chain: keyof typeof CHAINS\n): NajPublicKey | undefined => {\n const environment = Object.entries(CONTRACT_ADDRESSES[chain]).find(\n ([_, address]) => address.toLowerCase() === contractAddress.toLowerCase()\n )?.[0] as keyof typeof ROOT_PUBLIC_KEYS | undefined\n\n if (environment) {\n return ROOT_PUBLIC_KEYS[environment]\n }\n\n return undefined\n}\n","import { encodeAbiParameters, keccak256 } from 'viem'\nimport * as chains from 'viem/chains'\nimport type { Chain } from 'viem/chains'\n\nimport { type RequestIdArgs } from './types'\n\nexport const getChain = (chainId: number): Chain => {\n for (const chain of Object.values(chains)) {\n if (chain.id === chainId) {\n return chain\n }\n }\n throw new Error('Chain not found')\n}\n\nexport const getRequestId = (request: RequestIdArgs): `0x${string}` => {\n const encoded = encodeAbiParameters(\n [\n { type: 'address' },\n { type: 'bytes' },\n { type: 'string' },\n { type: 'uint32' },\n { type: 'uint256' },\n { type: 'string' },\n { type: 'string' },\n { type: 'string' },\n ],\n [\n request.address,\n request.payload,\n request.path,\n Number(request.keyVersion),\n request.chainId,\n request.algo,\n request.dest,\n request.params,\n ]\n )\n\n return keccak256(encoded)\n}\n","import {\n najToUncompressedPubKeySEC1,\n verifyRecoveredAddress,\n} from '@utils/cryptography'\nimport { getRootPublicKey } from '@utils/publicKey'\nimport BN from 'bn.js'\nimport {\n withRetry,\n type PublicClient,\n type WalletClient,\n type Hex,\n encodeFunctionData,\n} from 'viem'\n\nimport { CHAINS, KDF_CHAIN_IDS } from '@constants'\nimport { ChainSignatureContract as AbstractChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { SignArgs } from '@contracts/ChainSignatureContract'\nimport type {\n NajPublicKey,\n RSVSignature,\n SigNetEvmMpcSignature,\n UncompressedPubKeySEC1,\n} from '@types'\nimport { cryptography } from '@utils'\n\nimport { abi } from './ChainSignaturesContractABI'\nimport {\n SignatureNotFoundError,\n SignatureContractError,\n SigningError,\n} from './errors'\nimport type {\n RetryOptions,\n SignOptions,\n SignRequest,\n SignatureErrorData,\n} from './types'\nimport { getRequestId } from './utils'\n\n/**\n * Implementation of the ChainSignatureContract for EVM chains.\n *\n * When signing data, the contract emits a SignatureRequested event with a requestId.\n * This requestId is used to track the signature request and retrieve the signature\n * once it's available. The sign method handles this process automatically by polling\n * for the signature using the requestId.\n */\nexport class ChainSignatureContract extends AbstractChainSignatureContract {\n private readonly publicClient: PublicClient\n private readonly walletClient: WalletClient\n private readonly contractAddress: Hex\n private readonly rootPublicKey: NajPublicKey\n\n /**\n * Creates a new instance of the ChainSignatureContract for EVM chains.\n *\n * @param args - Configuration options for the contract\n * @param args.publicClient - A Viem PublicClient instance for reading from the blockchain\n * @param args.walletClient - A Viem WalletClient instance for sending transactions\n * @param args.contractAddress - The address of the deployed ChainSignatures contract (e.g. `0x857ED3A242B59cC24144814a0DF41C397a3811E6`)\n * @param args.rootPublicKey - Optional root public key. If not provided, it will be derived from the contract address\n */\n constructor(args: {\n publicClient: PublicClient\n walletClient: WalletClient\n contractAddress: Hex\n rootPublicKey?: NajPublicKey\n }) {\n super()\n this.publicClient = args.publicClient\n this.walletClient = args.walletClient\n this.contractAddress = args.contractAddress\n\n const rootPublicKey =\n args.rootPublicKey ||\n getRootPublicKey(this.contractAddress, CHAINS.ETHEREUM)\n\n if (!rootPublicKey) {\n throw new Error(\n `Invalid public key, please provide a valid root public key or contract address`\n )\n }\n\n this.rootPublicKey = rootPublicKey\n }\n\n async getCurrentSignatureDeposit(): Promise<BN> {\n const deposit = (await this.publicClient.readContract({\n address: this.contractAddress,\n abi,\n functionName: 'getSignatureDeposit',\n })) as bigint\n\n return new BN(deposit.toString())\n }\n\n async getDerivedPublicKey(args: {\n path: string\n predecessor: string\n }): Promise<UncompressedPubKeySEC1> {\n const pubKey = cryptography.deriveChildPublicKey(\n await this.getPublicKey(),\n args.predecessor.toLowerCase(),\n args.path,\n KDF_CHAIN_IDS.ETHEREUM\n )\n\n return pubKey\n }\n\n async getPublicKey(): Promise<UncompressedPubKeySEC1> {\n return najToUncompressedPubKeySEC1(this.rootPublicKey)\n }\n\n async getLatestKeyVersion(): Promise<number> {\n const version = (await this.publicClient.readContract({\n address: this.contractAddress,\n abi,\n functionName: 'latestKeyVersion',\n })) as bigint\n\n return Number(version)\n }\n\n /**\n * Sends a sign request transaction and return the transaction hash.\n *\n * @param args - The signature arguments\n * @param options - The signing options\n * @returns The transaction hash\n */\n async createSignatureRequest(\n args: SignArgs,\n options: Pick<SignOptions, 'sign' | 'transaction'> = {\n sign: {\n algo: '',\n dest: '',\n params: '',\n },\n }\n ): Promise<{\n txHash: Hex\n requestId: Hex\n }> {\n if (!this.walletClient?.account) {\n throw new Error('Wallet client required for signing operations')\n }\n\n const requestParams = await this.getSignRequestParams(args, options.sign)\n\n const requestId = this.getRequestId(args, options.sign)\n\n const hash = await this.walletClient.sendTransaction({\n ...options.transaction,\n account: this.walletClient.account,\n to: requestParams.target,\n data: requestParams.data,\n value: requestParams.value,\n chain: this.walletClient.chain,\n })\n\n return {\n txHash: hash,\n requestId,\n }\n }\n\n /**\n * Sends a transaction to the contract to request a signature, then\n * polls for the signature result. If the signature is not found within the retry\n * parameters, it will throw an error.\n */\n async sign(\n args: SignArgs,\n options: SignOptions = {\n sign: {\n algo: '',\n dest: '',\n params: '',\n },\n retry: {\n delay: 5000,\n retryCount: 12,\n },\n }\n ): Promise<RSVSignature> {\n const { txHash, requestId } = await this.createSignatureRequest(\n args,\n options\n )\n\n const receipt = await this.publicClient.waitForTransactionReceipt({\n hash: txHash,\n })\n\n try {\n const pollResult = await this.pollForRequestId({\n requestId,\n payload: args.payload,\n path: args.path,\n fromBlock: receipt.blockNumber,\n options: options.retry,\n })\n\n if (!pollResult) {\n throw new SignatureNotFoundError(requestId, receipt)\n }\n\n if ('error' in pollResult) {\n throw new SignatureContractError(pollResult.error, requestId, receipt)\n }\n\n return pollResult\n } catch (error) {\n if (\n error instanceof SignatureNotFoundError ||\n error instanceof SignatureContractError\n ) {\n throw error\n } else {\n throw new SigningError(\n requestId,\n receipt,\n error instanceof Error ? error : undefined\n )\n }\n }\n }\n\n async pollForRequestId({\n requestId,\n payload,\n path,\n fromBlock,\n options,\n }: {\n requestId: Hex\n payload: number[]\n path: string\n fromBlock: bigint\n options?: RetryOptions\n }): Promise<RSVSignature | SignatureErrorData | undefined> {\n const delay = options?.delay ?? 5000\n const retryCount = options?.retryCount ?? 12\n\n const result = await withRetry(\n async () => {\n const result = await this.getSignatureFromEvents(requestId, fromBlock)\n\n if (result) {\n // Verify the signature\n const isValid = await verifyRecoveredAddress(\n result,\n payload,\n this.walletClient.account?.address as string,\n path,\n this\n )\n\n if (!isValid) {\n throw new Error('Signature not found yet')\n }\n return result\n } else {\n throw new Error('Signature not found yet')\n }\n },\n {\n delay,\n retryCount,\n shouldRetry: ({ count, error }) => {\n // TODO: Should be enabled only on debug mode\n console.log(`Retrying get signature: ${count}/${retryCount}`)\n return error.message === 'Signature not found yet'\n },\n }\n )\n\n if (result) {\n return result\n }\n\n return await this.getErrorFromEvents(requestId, fromBlock)\n }\n\n async getSignRequestParams(\n args: SignArgs,\n options: SignOptions['sign'] = {\n algo: '',\n dest: '',\n params: '',\n }\n ): Promise<{\n target: Hex\n data: Hex\n value: bigint\n }> {\n const request: SignRequest = {\n payload: `0x${Buffer.from(args.payload).toString('hex')}`,\n path: args.path,\n keyVersion: args.key_version,\n algo: options.algo ?? '',\n dest: options.dest ?? '',\n params: options.params ?? '',\n }\n\n return {\n target: this.contractAddress,\n data: encodeFunctionData({\n abi,\n functionName: 'sign',\n args: [request],\n }),\n value: BigInt((await this.getCurrentSignatureDeposit()).toString()),\n }\n }\n\n /**\n * Generates the request ID for a signature request allowing to track the response.\n *\n * @param args - The signature request object containing:\n * @param args.payload - The data payload to be signed as a hex string\n * @param args.path - The derivation path for the key\n * @param args.keyVersion - The version of the key to use\n * @param options - The signature request object containing:\n * @param options.algo - The signing algorithm to use\n * @param options.dest - The destination for the signature\n * @param options.params - Additional parameters for the signing process\n * @returns A hex string representing the unique request ID\n *\n * @example\n * ```typescript\n * const requestId = ChainSignatureContract.getRequestId({\n * payload: payload: `0x${Buffer.from(args.payload).toString('hex')}`,,\n * path: '',\n * keyVersion: 0\n * });\n * console.log(requestId); // 0x...\n * ```\n */\n getRequestId(\n args: SignArgs,\n options: SignOptions['sign'] = {\n algo: '',\n dest: '',\n params: '',\n }\n ): Hex {\n if (!this.walletClient.account) {\n throw new Error('Wallet client account required to compute requestId')\n }\n if (!this.publicClient.chain?.id) {\n throw new Error('Public client chain required to compute requestId')\n }\n return getRequestId({\n payload: `0x${Buffer.from(args.payload).toString('hex')}`,\n path: args.path,\n keyVersion: args.key_version,\n algo: options.algo ?? '',\n dest: options.dest ?? '',\n params: options.params ?? '',\n address: this.walletClient.account.address,\n chainId: BigInt(this.publicClient.chain.id),\n })\n }\n\n async getErrorFromEvents(\n requestId: Hex,\n fromBlock: bigint\n ): Promise<SignatureErrorData | undefined> {\n const errorLogs = await this.publicClient.getContractEvents({\n address: this.contractAddress,\n abi,\n eventName: 'SignatureError',\n args: {\n requestId,\n },\n fromBlock,\n toBlock: 'latest',\n })\n\n if (errorLogs.length > 0) {\n const { args: errorData } = errorLogs[\n errorLogs.length - 1\n ] as unknown as {\n args: SignatureErrorData\n }\n\n return errorData\n }\n\n return undefined\n }\n\n /**\n * Searches for SignatureResponded events that match the given requestId.\n * It works in conjunction with the getRequestId method which generates the unique\n * identifier for a signature request.\n *\n * @param requestId - The identifier for the signature request\n * @param fromBlock - The block number to start searching from\n * @returns The RSV signature if found, undefined otherwise\n */\n async getSignatureFromEvents(\n requestId: Hex,\n fromBlock: bigint\n ): Promise<RSVSignature | undefined> {\n const logs = await this.publicClient.getContractEvents({\n address: this.contractAddress,\n abi,\n eventName: 'SignatureResponded',\n args: {\n requestId,\n },\n fromBlock,\n toBlock: 'latest',\n })\n\n if (logs.length > 0) {\n const { args: signatureData } = logs[logs.length - 1] as unknown as {\n args: {\n signature: SigNetEvmMpcSignature\n }\n }\n\n return cryptography.toRSV(signatureData.signature)\n }\n\n return undefined\n }\n}\n","import * as errors from './errors'\nimport * as ChainSignaturesContractIdl from './types/chain_signatures_project.json'\nexport * from './ChainSignaturesContract'\nexport type { ChainSignaturesProject } from './types/chain_signatures_project'\n\nconst utils = {\n ChainSignaturesContractIdl,\n errors,\n}\n\nexport { utils }\n","export class SignatureNotFoundError extends Error {\n public readonly requestId?: string\n public readonly hash?: string\n\n constructor(requestId?: string, metadata?: { hash?: string }) {\n const message = requestId\n ? `Signature not found for request ID: ${requestId}`\n : 'Signature not found'\n\n super(message)\n this.name = 'SignatureNotFoundError'\n this.requestId = requestId\n this.hash = metadata?.hash\n }\n}\n\nexport class SignatureContractError extends Error {\n public readonly requestId?: string\n public readonly hash?: string\n public readonly originalError?: { hash: string }\n\n constructor(\n message: string,\n requestId?: string,\n metadata?: { hash?: string }\n ) {\n super(message)\n this.name = 'SignatureContractError'\n this.requestId = requestId\n this.hash = metadata?.hash\n }\n}\n\nexport class SigningError extends Error {\n public readonly requestId: string\n public readonly hash?: string\n public readonly originalError?: Error\n\n constructor(\n requestId: string,\n metadata?: { hash?: string },\n originalError?: Error\n ) {\n super(`Signing error for request ID: ${requestId}`)\n this.name = 'SigningError'\n this.requestId = requestId\n this.hash = metadata?.hash\n this.originalError = originalError\n }\n}\n\nexport class ResponseError extends Error {\n constructor(message: string) {\n super(message)\n this.name = 'ResponseError'\n }\n}\n","{\n \"address\": \"4uvZW8K4g4jBg7dzPNbb9XDxJLFBK7V6iC76uofmYvEU\",\n \"metadata\": {\n \"name\": \"chain_signatures_project\",\n \"version\": \"0.1.0\",\n \"spec\": \"0.1.0\",\n \"description\": \"Created with Anchor\"\n },\n \"instructions\": [\n {\n \"name\": \"initialize\",\n \"discriminator\": [175, 175, 109, 31, 13, 152, 155, 237],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"admin\",\n \"writable\": true,\n \"signer\": true\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n }\n ],\n \"args\": [\n {\n \"name\": \"signature_deposit\",\n \"type\": \"u64\"\n }\n ]\n },\n {\n \"name\": \"respond\",\n \"discriminator\": [72, 65, 227, 97, 42, 255, 147, 12],\n \"accounts\": [\n {\n \"name\": \"responder\",\n \"signer\": true\n }\n ],\n \"args\": [\n {\n \"name\": \"request_ids\",\n \"type\": {\n \"vec\": {\n \"array\": [\"u8\", 32]\n }\n }\n },\n {\n \"name\": \"signatures\",\n \"type\": {\n \"vec\": {\n \"defined\": {\n \"name\": \"Signature\"\n }\n }\n }\n }\n ]\n },\n {\n \"name\": \"respond_error\",\n \"discriminator\": [3, 170, 41, 132, 72, 184, 252, 69],\n \"accounts\": [\n {\n \"name\": \"responder\",\n \"signer\": true\n }\n ],\n \"args\": [\n {\n \"name\": \"request_ids\",\n \"type\": {\n \"vec\": {\n \"array\": [\"u8\", 32]\n }\n }\n },\n {\n \"name\": \"errors\",\n \"type\": {\n \"vec\": \"string\"\n }\n }\n ]\n },\n {\n \"name\": \"sign\",\n \"discriminator\": [5, 221, 155, 46, 237, 91, 28, 236],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"requester\",\n \"writable\": true,\n \"signer\": true\n },\n {\n \"name\": \"fee_payer\",\n \"writable\": true,\n \"signer\": true,\n \"optional\": true\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n }\n ],\n \"args\": [\n {\n \"name\": \"payload\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"key_version\",\n \"type\": \"u32\"\n },\n {\n \"name\": \"path\",\n \"type\": \"string\"\n },\n {\n \"name\": \"algo\",\n \"type\": \"string\"\n },\n {\n \"name\": \"dest\",\n \"type\": \"string\"\n },\n {\n \"name\": \"params\",\n \"type\": \"string\"\n }\n ]\n },\n {\n \"name\": \"update_deposit\",\n \"discriminator\": [126, 116, 15, 164, 238, 179, 155, 59],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"admin\",\n \"writable\": true,\n \"signer\": true,\n \"relations\": [\"program_state\"]\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n }\n ],\n \"args\": [\n {\n \"name\": \"new_deposit\",\n \"type\": \"u64\"\n }\n ]\n },\n {\n \"name\": \"withdraw_funds\",\n \"discriminator\": [241, 36, 29, 111, 208, 31, 104, 217],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"admin\",\n \"writable\": true,\n \"signer\": true,\n \"relations\": [\"program_state\"]\n },\n {\n \"name\": \"recipient\",\n \"docs\": [\"function by checking it is not the zero address.\"],\n \"writable\": true\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n }\n ],\n \"args\": [\n {\n \"name\": \"amount\",\n \"type\": \"u64\"\n }\n ]\n }\n ],\n \"accounts\": [\n {\n \"name\": \"ProgramState\",\n \"discriminator\": [77, 209, 137, 229, 149, 67, 167, 230]\n }\n ],\n \"events\": [\n {\n \"name\": \"DepositUpdatedEvent\",\n \"discriminator\": [215, 193, 53, 27, 221, 101, 249, 108]\n },\n {\n \"name\": \"FundsWithdrawnEvent\",\n \"discriminator\": [86, 232, 194, 4, 211, 69, 172, 202]\n },\n {\n \"name\": \"SignatureErrorEvent\",\n \"discriminator\": [42, 28, 210, 105, 9, 196, 189, 51]\n },\n {\n \"name\": \"SignatureRequestedEvent\",\n \"discriminator\": [171, 129, 105, 91, 154, 49, 160, 34]\n },\n {\n \"name\": \"SignatureRespondedEvent\",\n \"discriminator\": [118, 146, 248, 151, 194, 93, 18, 86]\n }\n ],\n \"errors\": [\n {\n \"code\": 6000,\n \"name\": \"InsufficientDeposit\",\n \"msg\": \"Insufficient deposit amount\"\n },\n {\n \"code\": 6001,\n \"name\": \"InvalidInputLength\",\n \"msg\": \"Arrays must have the same length\"\n },\n {\n \"code\": 6002,\n \"name\": \"Unauthorized\",\n \"msg\": \"Unauthorized access\"\n },\n {\n \"code\": 6003,\n \"name\": \"InsufficientFunds\",\n \"msg\": \"Insufficient funds for withdrawal\"\n },\n {\n \"code\": 6004,\n \"name\": \"InvalidRecipient\",\n \"msg\": \"Invalid recipient address\"\n }\n ],\n \"types\": [\n {\n \"name\": \"AffinePoint\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"x\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"y\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n }\n ]\n }\n },\n {\n \"name\": \"DepositUpdatedEvent\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"old_deposit\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"new_deposit\",\n \"type\": \"u64\"\n }\n ]\n }\n },\n {\n \"name\": \"FundsWithdrawnEvent\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"amount\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"recipient\",\n \"type\": \"pubkey\"\n }\n ]\n }\n },\n {\n \"name\": \"ProgramState\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"admin\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"signature_deposit\",\n \"type\": \"u64\"\n }\n ]\n }\n },\n {\n \"name\": \"Signature\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"big_r\",\n \"type\": {\n \"defined\": {\n \"name\": \"AffinePoint\"\n }\n }\n },\n {\n \"name\": \"s\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"recovery_id\",\n \"type\": \"u8\"\n }\n ]\n }\n },\n {\n \"name\": \"SignatureErrorEvent\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"request_id\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"responder\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"error\",\n \"type\": \"string\"\n }\n ]\n }\n },\n {\n \"name\": \"SignatureRequestedEvent\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"sender\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"payload\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"key_version\",\n \"type\": \"u32\"\n },\n {\n \"name\": \"deposit\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"chain_id\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"path\",\n \"type\": \"string\"\n },\n {\n \"name\": \"algo\",\n \"type\": \"string\"\n },\n {\n \"name\": \"dest\",\n \"type\": \"string\"\n },\n {\n \"name\": \"params\",\n \"type\": \"string\"\n },\n {\n \"name\": \"fee_payer\",\n \"type\": {\n \"option\": \"pubkey\"\n }\n }\n ]\n }\n },\n {\n \"name\": \"SignatureRespondedEvent\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"request_id\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"responder\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"signature\",\n \"type\": {\n \"defined\": {\n \"name\": \"Signature\"\n }\n }\n }\n ]\n }\n }\n ]\n}\n","import * as anchor from '@coral-xyz/anchor'\nimport { type Connection } from '@solana/web3.js'\n\nimport type { ChainSignaturesEvent } from './types/events'\n\n// Anchor's emit_cpi! instruction discriminator: Sha256(\"anchor:event\")[..8]\nconst EMIT_CPI_INSTRUCTION_DISCRIMINATOR = Buffer.from([\n 0xe4, 0x45, 0xa5, 0x2e, 0x51, 0xcb, 0x9a, 0x1d,\n])\n\n// eslint-disable-next-line @typescript-eslint/no-extraneous-class\nexport class CpiEventParser {\n /**\n * Parse CPI events from a transaction (emit_cpi! pattern)\n */\n static async parseCpiEvents<T extends anchor.Idl>(\n connection: Connection,\n signature: string,\n targetProgramId: string,\n program: anchor.Program<T>\n ): Promise<ChainSignaturesEvent[]> {\n const events: ChainSignaturesEvent[] = []\n\n try {\n const tx = await connection.getParsedTransaction(signature, {\n commitment: 'confirmed',\n maxSupportedTransactionVersion: 0,\n })\n\n if (!tx?.meta?.innerInstructions) return events\n\n for (const innerIxSet of tx.meta.innerInstructions) {\n for (const instruction of innerIxSet.instructions) {\n if (!('programId' in instruction) || !('data' in instruction)) {\n continue\n }\n\n if (instruction.programId.toString() !== targetProgramId) {\n continue\n }\n\n const parsedEvent = this.parseInstruction(instruction.data, program)\n if (parsedEvent) {\n events.push(parsedEvent)\n }\n }\n }\n } catch {}\n\n return events\n }\n\n /**\n * Parse CPI event from instruction data\n * Structure: [8 bytes: anchor discriminator][8 bytes: event discriminator][event data]\n */\n private static parseInstruction<T extends anchor.Idl>(\n instructionData: string,\n program: anchor.Program<T>\n ): ChainSignaturesEvent | null {\n try {\n const ixData = anchor.utils.bytes.bs58.decode(instructionData)\n\n if (ixData.length < 16) {\n return null\n }\n\n const ixDiscriminator = ixData.subarray(0, 8)\n if (\n Buffer.compare(ixDiscriminator, EMIT_CPI_INSTRUCTION_DISCRIMINATOR) !==\n 0\n ) {\n return null\n }\n\n const eventDiscriminator = ixData.subarray(8, 16)\n\n const matchedEvent = program.idl.events?.find((event) => {\n const idlDiscriminator = Buffer.from(event.discriminator)\n return Buffer.compare(eventDiscriminator, idlDiscriminator) === 0\n })\n\n if (!matchedEvent) {\n return null\n }\n\n const fullEventData = ixData.subarray(8)\n\n const decodedEvent = program.coder.events.decode(\n anchor.utils.bytes.base64.encode(fullEventData)\n )\n\n return decodedEvent as ChainSignaturesEvent | null\n } catch {\n return null\n }\n }\n\n /**\n * Subscribe to CPI events for a program\n */\n static subscribeToCpiEvents<T extends anchor.Idl>(\n connection: Connection,\n program: anchor.Program<T>,\n eventHandlers: Map<\n ChainSignaturesEvent['name'],\n (event: ChainSignaturesEvent['data'], slot: number) => Promise<void>\n >\n ): number {\n return connection.onLogs(\n program.programId,\n (logs, context) => {\n if (logs.err) return\n\n void (async () => {\n const events = await this.parseCpiEvents(\n connection,\n logs.signature,\n program.programId.toString(),\n program\n )\n\n for (const event of events) {\n const handler = eventHandlers.get(event.name)\n if (handler) {\n try {\n await handler(event.data, context.slot)\n } catch {}\n }\n }\n })()\n },\n 'confirmed'\n )\n }\n}\n","import { encodeAbiParameters, parseAbiParameters, keccak256 } from 'viem'\n\nexport function generateRequestIdSolana({\n address,\n payload,\n path,\n keyVersion,\n algo,\n dest,\n params,\n}: {\n address: string\n payload: Uint8Array | number[]\n path: string\n keyVersion: number\n algo: string\n dest: string\n params: string\n}): string {\n const payloadHex: `0x${string}` = ('0x' +\n Buffer.from(payload as any).toString('hex')) as `0x${string}`\n\n const encoded = encodeAbiParameters(\n parseAbiParameters(\n 'string, bytes, string, uint32, uint256, string, string, string'\n ),\n [address, payloadHex, path, keyVersion, 0n, algo, dest, params]\n )\n\n return keccak256(encoded)\n}\n","import {\n type AnchorProvider,\n Program,\n EventParser,\n type Idl,\n} from '@coral-xyz/anchor'\nimport {\n type AccountMeta,\n PublicKey,\n type Signer,\n Transaction,\n type TransactionInstruction,\n TransactionExpiredTimeoutError,\n type Connection,\n} from '@solana/web3.js'\nimport {\n najToUncompressedPubKeySEC1,\n verifyRecoveredAddress,\n} from '@utils/cryptography'\nimport { getRootPublicKey } from '@utils/publicKey'\nimport BN from 'bn.js'\n\nimport { CHAINS, KDF_CHAIN_IDS } from '@constants'\nimport { ChainSignatureContract as AbstractChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { SignArgs } from '@contracts/ChainSignatureContract'\nimport type { NajPublicKey, RSVSignature, UncompressedPubKeySEC1 } from '@types'\nimport { cryptography } from '@utils'\n\nimport type {\n RetryOptions,\n SignOptions,\n SignatureErrorData,\n} from '../evm/types'\n\nimport { CpiEventParser } from './CpiEventParser'\nimport {\n SignatureNotFoundError,\n SignatureContractError,\n SigningError,\n} from './errors'\nimport { type ChainSignaturesProject } from './types/chain_signatures_project'\nimport IDL from './types/chain_signatures_project.json'\nimport type {\n SignatureErrorEvent,\n SignatureRespondedEvent,\n ChainSignaturesEventName,\n} from './types/events'\nimport { generateRequestIdSolana } from './utils'\n\nexport class ChainSignatureContract extends AbstractChainSignatureContract {\n private readonly provider: AnchorProvider\n private readonly program: Program<ChainSignaturesProject>\n private readonly programId: PublicKey\n private readonly rootPublicKey: NajPublicKey\n private readonly requesterAddress: string\n\n /**\n * Creates a new instance of the ChainSignatureContract for Solana chains.\n *\n * @param args - Configuration options for the contract\n * @param args.provider - An Anchor Provider for interacting with Solana\n * @param args.programId - The program ID as a string or PublicKey\n * @param args.config - Optional configuration\n * @param args.config.rootPublicKey - Optional root public key. If not provided, it will be derived from the program ID\n * @param args.config.requesterAddress - Provider wallet address is always the fee payer but requester can be overridden\n * @param args.config.idl - Optional custom IDL. If not provided, the default ChainSignatures IDL will be used\n */\n constructor(args: {\n provider: AnchorProvider\n programId: string | PublicKey\n config?: {\n rootPublicKey?: NajPublicKey\n requesterAddress?: string\n idl?: ChainSignaturesProject & Idl\n }\n }) {\n super()\n this.provider = args.provider\n this.requesterAddress =\n args.config?.requesterAddress ?? this.provider.wallet.publicKey.toString()\n\n this.programId =\n typeof args.programId === 'string'\n ? new PublicKey(args.programId)\n : args.programId\n\n const idl = args.config?.idl || (IDL as ChainSignaturesProject & Idl)\n this.program = new Program<ChainSignaturesProject>(\n { ...idl, address: this.programId.toString() },\n this.provider\n )\n\n const rootPublicKey =\n args.config?.rootPublicKey ||\n getRootPublicKey(this.programId.toString(), CHAINS.SOLANA)\n\n if (!rootPublicKey) {\n throw new Error(\n `Invalid public key, please provide a valid root public key or program ID`\n )\n }\n\n this.rootPublicKey = rootPublicKey\n }\n\n /**\n * Gets the connection from the provider\n */\n get connection(): Connection {\n return this.provider.connection\n }\n\n async getCurrentSignatureDeposit(): Promise<BN> {\n try {\n const programStatePDA = await this.getProgramStatePDA()\n\n const programState =\n await this.program.account.programState.fetch(programStatePDA)\n\n return new BN(programState.signatureDeposit.toString())\n } catch (error) {\n throw new Error(\n `Failed to get signature deposit: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n }\n }\n\n /**\n * Get the Program State PDA\n */\n async getProgramStatePDA(): Promise<PublicKey> {\n const [pda] = PublicKey.findProgramAddressSync(\n [Buffer.from('program-state')],\n this.programId\n )\n return pda\n }\n\n async getDerivedPublicKey(args: {\n path: string\n predecessor: string\n }): Promise<UncompressedPubKeySEC1> {\n const pubKey = cryptography.deriveChildPublicKey(\n await this.getPublicKey(),\n args.predecessor,\n args.path,\n KDF_CHAIN_IDS.SOLANA\n )\n\n return pubKey\n }\n\n async getPublicKey(): Promise<UncompressedPubKeySEC1> {\n return najToUncompressedPubKeySEC1(this.rootPublicKey)\n }\n\n async getSignRequestInstruction(\n args: SignArgs,\n options?: Pick<SignOptions, 'sign'> & {\n remainingAccounts?: AccountMeta[]\n }\n ): Promise<TransactionInstruction> {\n const fixedRemainingAccounts: AccountMeta[] = [\n {\n pubkey: PublicKey.findProgramAddressSync(\n [Buffer.from('__event_authority')],\n this.program.programId\n )[0],\n isWritable: false,\n isSigner: false,\n },\n {\n pubkey: this.program.programId,\n isWritable: false,\n isSigner: false,\n },\n ]\n\n return await this.program.methods\n .sign(\n Array.from(args.payload),\n args.key_version,\n args.path,\n options?.sign?.algo || '',\n options?.sign?.dest || '',\n options?.sign?.params || ''\n )\n .accounts({\n requester: this.requesterAddress,\n feePayer: this.provider.wallet.publicKey,\n })\n .remainingAccounts([\n ...fixedRemainingAccounts,\n ...(options?.remainingAccounts ?? []),\n ])\n .instruction()\n }\n\n /**\n * Sends a transaction to the program to request a signature, then\n * polls for the signature result. If the signature is not found within the retry\n * parameters, it will throw an error.\n */\n async sign(\n args: SignArgs,\n options?: Partial<SignOptions> & {\n remainingAccounts?: AccountMeta[]\n remainingSigners?: Signer[]\n }\n ): Promise<RSVSignature> {\n const algo = options?.sign?.algo ?? ''\n const dest = options?.sign?.dest ?? ''\n const params = options?.sign?.params ?? ''\n const delay = options?.retry?.delay ?? 5000\n const retryCount = options?.retry?.retryCount ?? 12\n\n const missingSigners = options?.remainingAccounts\n ?.filter((acc) => acc.isSigner)\n ?.some(\n (acc) =>\n !options?.remainingSigners?.some((signer) =>\n signer.publicKey.equals(acc.pubkey)\n )\n )\n\n if (missingSigners) {\n throw new Error(\n 'All accounts marked as signers must have a corresponding signer'\n )\n }\n\n const requestId = this.getRequestId(args, {\n algo,\n dest,\n params,\n })\n\n const instruction = await this.getSignRequestInstruction(args, {\n sign: {\n algo,\n dest,\n params,\n },\n remainingAccounts: options?.remainingAccounts,\n })\n const transaction = new Transaction().add(instruction)\n transaction.feePayer = this.provider.wallet.publicKey\n const hash = await this.sendAndConfirmWithoutWebSocket(\n transaction,\n options?.remainingSigners\n )\n\n try {\n const pollResult = await this.pollForRequestId({\n requestId,\n payload: args.payload,\n path: args.path,\n afterSignature: hash,\n options: {\n delay,\n retryCount,\n },\n })\n\n if (!pollResult) {\n throw new SignatureNotFoundError(requestId, { hash })\n }\n\n if ('error' in pollResult) {\n throw new SignatureContractError(pollResult.error, requestId, { hash })\n }\n\n const isValid = await verifyRecoveredAddress(\n pollResult,\n args.payload,\n this.requesterAddress,\n args.path,\n this\n )\n if (!isValid) {\n throw new SigningError(\n requestId,\n { hash },\n new Error(\n 'Signature verification failed: recovered address does not match expected address'\n )\n )\n }\n\n return pollResult\n } catch (error) {\n if (\n error instanceof SignatureNotFoundError ||\n error instanceof SignatureContractError\n ) {\n throw error\n } else {\n throw new SigningError(\n requestId,\n { hash },\n error instanceof Error ? error : undefined\n )\n }\n }\n }\n\n private async sendAndConfirmWithoutWebSocket(\n transaction: Transaction,\n signers?: Signer[]\n ): Promise<string> {\n const { blockhash } =\n await this.provider.connection.getLatestBlockhash('confirmed')\n transaction.recentBlockhash = blockhash\n\n transaction = await this.provider.wallet.signTransaction(transaction)\n\n if (signers && signers.length > 0) {\n transaction.partialSign(...signers)\n }\n\n const signature = await this.provider.connection.sendRawTransaction(\n transaction.serialize(),\n {\n skipPreflight: false,\n preflightCommitment: 'processed',\n maxRetries: 3,\n }\n )\n\n const startTime = Date.now()\n const timeout = 30000 // 30 seconds, same as default sendAndConfirm\n\n while (Date.now() - startTime < timeout) {\n const status =\n await this.provider.connection.getSignatureStatus(signature)\n\n if (status.value?.err) {\n throw new Error(\n `Transaction failed: ${JSON.stringify(status.value.err)}`\n )\n }\n\n if (\n status.value?.confirmationStatus === 'confirmed' ||\n status.value?.confirmationStatus === 'finalized'\n ) {\n return signature\n }\n\n await new Promise((resolve) => setTimeout(resolve, 2000))\n }\n\n throw new TransactionExpiredTimeoutError(signature, timeout / 1000)\n }\n\n /**\n * Polls for signature or error events matching the given requestId starting from the solana transaction with signature afterSignature.\n * Returns a signature, error data, or undefined if nothing is found.\n */\n async pollForRequestId({\n requestId,\n payload: _payload,\n path: _path,\n afterSignature,\n options,\n }: {\n requestId: string\n payload: number[]\n path: string\n afterSignature: string\n options?: RetryOptions\n }): Promise<RSVSignature | SignatureErrorData | undefined> {\n const delay = options?.delay ?? 5000\n const retryCount = options?.retryCount ?? 12\n\n let lastCheckedSignature = afterSignature\n\n for (let i = 0; i < retryCount; i++) {\n try {\n // Get all transactions since last check\n const signatures = await this.connection.getSignaturesForAddress(\n this.programId,\n {\n until: lastCheckedSignature,\n limit: 50,\n },\n 'confirmed'\n )\n\n if (signatures.length > 0) {\n lastCheckedSignature = signatures[signatures.length - 1].signature\n }\n\n for (const sig of signatures) {\n const tx = await this.connection.getParsedTransaction(sig.signature, {\n commitment: 'confirmed',\n maxSupportedTransactionVersion: 0,\n })\n\n if (tx?.meta?.logMessages) {\n const result = await this.parseLogsForEvents(\n tx.meta.logMessages,\n requestId,\n sig.signature\n )\n\n if (result) {\n return result\n }\n }\n }\n } catch (error) {\n console.error('Error checking for events:', error)\n }\n\n if (i < retryCount - 1) {\n console.log(`Retrying get signature: ${i + 1}/${retryCount}`)\n await new Promise((resolve) => setTimeout(resolve, delay))\n }\n }\n\n return undefined\n }\n\n /**\n * Parses transaction logs for signature or error events.\n */\n private async parseLogsForEvents(\n logs: string[],\n requestId: string,\n signature: string\n ): Promise<RSVSignature | SignatureErrorData | undefined> {\n const cpiEvents = await CpiEventParser.parseCpiEvents(\n this.connection,\n signature,\n this.programId.toString(),\n this.program\n )\n for (const event of cpiEvents) {\n const mapped = this.mapEventToResult(\n event.name,\n event.name === 'signatureRespondedEvent' ? event.data : event.data,\n requestId\n )\n if (mapped) return mapped\n }\n\n // 2) Parse regular Anchor events from logs (emit!)\n const parser = new EventParser(this.program.programId, this.program.coder)\n for (const evt of parser.parseLogs(logs)) {\n if (!evt) continue\n const mapped = this.mapEventToResult(\n evt.name as ChainSignaturesEventName,\n evt.name === 'signatureRespondedEvent'\n ? (evt.data as SignatureRespondedEvent)\n : (evt.data as SignatureErrorEvent),\n requestId\n )\n if (mapped) return mapped\n }\n\n return undefined\n }\n\n private mapEventToResult(\n name: ChainSignaturesEventName,\n data: SignatureRespondedEvent | SignatureErrorEvent,\n requestId: string\n ): RSVSignature | SignatureErrorData | undefined {\n const eventRequestIdHex = '0x' + Buffer.from(data.requestId).toString('hex')\n if (name === 'signatureRespondedEvent' && eventRequestIdHex === requestId) {\n const d = data as SignatureRespondedEvent\n return {\n r: Buffer.from(d.signature.bigR.x).toString('hex'),\n s: Buffer.from(d.signature.s).toString('hex'),\n v: d.signature.recoveryId + 27,\n }\n }\n if (name === 'signatureErrorEvent' && eventRequestIdHex === requestId) {\n const d = data as SignatureErrorEvent\n return {\n requestId: eventRequestIdHex,\n error: d.error,\n }\n }\n return undefined\n }\n\n /**\n * Generates the request ID for a signature request allowing to track the response.\n */\n getRequestId(\n args: SignArgs,\n options: SignOptions['sign'] = {\n algo: '',\n dest: '',\n params: '',\n }\n ): string {\n return generateRequestIdSolana({\n payload: args.payload,\n path: args.path,\n keyVersion: args.key_version,\n algo: options.algo || '',\n dest: options.dest || '',\n params: options.params || '',\n address: this.requesterAddress,\n })\n }\n\n /**\n * Subscribes to program events using Anchor's EventParser for regular events,\n * and CPI parsing for emit_cpi!-emitted events. Returns an unsubscribe fn.\n */\n async subscribeToEvents(handlers: {\n onSignatureResponded?: (\n event: SignatureRespondedEvent,\n slot: number\n ) => Promise<void> | void\n onSignatureError?: (\n event: SignatureErrorEvent,\n slot: number\n ) => Promise<void> | void\n }): Promise<() => Promise<void>> {\n const commitment: 'processed' | 'confirmed' | 'finalized' = 'confirmed'\n // Subscribe to CPI events (emit_cpi!)\n const cpiHandlers = new Map<\n ChainSignaturesEventName,\n (\n event: SignatureRespondedEvent | SignatureErrorEvent,\n slot: number\n ) => Promise<void>\n >()\n if (handlers.onSignatureResponded) {\n const onSignatureResponded = handlers.onSignatureResponded\n cpiHandlers.set('signatureRespondedEvent', async (e, s) => {\n await onSignatureResponded(e as SignatureRespondedEvent, s)\n })\n }\n if (handlers.onSignatureError) {\n const onSignatureError = handlers.onSignatureError\n cpiHandlers.set('signatureErrorEvent', async (e, s) => {\n await onSignatureError(e as SignatureErrorEvent, s)\n })\n }\n const cpiSubId = CpiEventParser.subscribeToCpiEvents(\n this.connection,\n this.program,\n cpiHandlers\n )\n\n const parser = new EventParser(this.program.programId, this.program.coder)\n const subId = this.connection.onLogs(\n this.program.programId,\n (logs, context) => {\n if (logs.err) return\n for (const evt of parser.parseLogs(logs.logs)) {\n if (!evt) continue\n if (evt.name === 'signatureRespondedEvent') {\n const onSignatureResponded = handlers.onSignatureResponded\n if (onSignatureResponded) {\n void onSignatureResponded(\n evt.data as SignatureRespondedEvent,\n context.slot\n )\n }\n }\n if (evt.name === 'signatureErrorEvent') {\n const onSignatureError = handlers.onSignatureError\n if (onSignatureError) {\n void onSignatureError(\n evt.data as SignatureErrorEvent,\n context.slot\n )\n }\n }\n }\n },\n commitment\n )\n\n return async () => {\n await this.connection.removeOnLogsListener(subId)\n await this.connection.removeOnLogsListener(cpiSubId)\n }\n }\n}\n"]}
1
+ {"version":3,"sources":["../../src/constants.ts","../../src/utils/index.ts","../../src/utils/cryptography.ts","../../src/chain-adapters/index.ts","../../src/chain-adapters/ChainAdapter.ts","../../src/chain-adapters/EVM/index.ts","../../src/chain-adapters/EVM/utils.ts","../../src/chain-adapters/EVM/EVM.ts","../../src/chain-adapters/Bitcoin/index.ts","../../src/chain-adapters/Bitcoin/utils.ts","../../src/chain-adapters/Bitcoin/Bitcoin.ts","../../src/chain-adapters/Bitcoin/BTCRpcAdapter/BTCRpcAdapter.ts","../../src/chain-adapters/Bitcoin/BTCRpcAdapter/Mempool/Mempool.ts","../../src/chain-adapters/Bitcoin/BTCRpcAdapter/index.ts","../../src/chain-adapters/Cosmos/index.ts","../../src/chain-adapters/Cosmos/utils.ts","../../src/chain-adapters/Cosmos/Cosmos.ts","../../src/contracts/index.ts","../../src/contracts/ChainSignatureContract.ts","../../src/contracts/evm/index.ts","../../src/contracts/evm/ChainSignaturesContractABI.ts","../../src/contracts/evm/errors.ts","../../src/utils/publicKey.ts","../../src/contracts/evm/utils.ts","../../src/contracts/evm/ChainSignaturesContract.ts","../../src/contracts/solana/index.ts","../../src/contracts/solana/errors.ts","../../src/contracts/solana/types/chain_signatures_project.json","../../src/contracts/solana/CpiEventParser.ts","../../src/contracts/solana/utils.ts","../../src/contracts/solana/ChainSignaturesContract.ts"],"names":["constants_exports","__export","CHAINS","CONTRACT_ADDRESSES","ENVS","KDF_CHAIN_IDS","ROOT_PUBLIC_KEYS","utils_exports","cryptography_exports","compressPubKey","deriveChildPublicKey","najToUncompressedPubKeySEC1","toRSV","verifyRecoveredAddress","EC","elliptic","signature","uncompressedPubKeySEC1","slicedPubKey","x","y","najPublicKey","decodedKey","base58","EPSILON_DERIVATION_PREFIX_V1","EPSILON_DERIVATION_PREFIX_V2","rootUncompressedPubKeySEC1","predecessorId","path","chainId","keyVersion","ec","derivationPath","scalarHex","keccak256","oldPublicKeyPoint","scalarTimesG","newPublicKeyPoint","newX","newY","payload","requesterAddress","contract","evm","chain_adapters_exports","createPublicClient","http","expectedAddress","recoverAddress","error","ChainAdapter","Bitcoin_exports","Cosmos_exports","EVM_exports","EVM","fetchEVMFeeProperties","client","transaction","gas","feeData","maxFeePerGas","maxPriorityFeePerGas","publicClient","fees","nonce","from","rest","r","s","yParity","concatHex","numberToHex","predecessor","uncompressedPubKey","publicKeyNoPrefix","hash","getAddress","address","serializeTransaction","serialized","parseTransaction","transactionRequest","serializedTx","txHash","toBytes","message","hashMessage","typedDataRequest","hashTypedData","userOp","entryPointAddress","chainIdArgs","entryPoint","encoded","encodeAbiParameters","hexToBigInt","concat","pad","isAddress","userOpHash","rsvSignatures","rsvSignature","txSerialized","BTCRpcAdapter","BTCRpcAdapters","Bitcoin","parseBTCNetwork","network","L","_Bitcoin","btcRpcAdapter","satoshis","btc","transactionId","data","tx","vout","scriptPubKey","rawSignature","inputs","outputs","psbt","input","prevOut","out","derivedKey","publicKeyBuffer","payment","transactionJSON","psbtHex","hashesToSign","mockKeyPair","index","publicKey","keyPair","mpcSignature","Mempool","providerUrl","confirmationTarget","targets","utxos","feeRate","ret","coinselect","transactionHex","response","txid","Cosmos","fetchChainInfo","chainInfo","chains","chain","prefix","expectedChainId","denom","rpcUrl","restUrl","gasPrice","asset","assets","decimals","unit","endpoints","Registry","fromHex","amount","b","pubKeySha256","sha256","ripemd160Hash","ripemd160","bech32","TxRaw","toBase64","fromBase64","publicKeyBytes","gasLimit","fee","calculateFee","GasPrice","accountOnChain","StargateClient","accountNumber","sequence","txBodyEncodeObject","txBodyBytes","pubkey","encodePubkey","encodeSecp256k1Pubkey","authInfoBytes","makeAuthInfoBytes","SignMode","signDoc","makeSignDoc","signBytes","makeSignBytes","sig","txBytes","broadcastResponse","contracts_exports","ChainSignatureContract","evm_exports","solana_exports","BaseChainSignatureContract","utils","ChainSignaturesContractABI_exports","abi","errors_exports","ChainSignatureError","SignatureContractError","SignatureNotFoundError","SigningError","requestId","receipt","errorCode","originalError","getRootPublicKey","contractAddress","environment","_","getRequestId","request","args","rootPublicKey","deposit","BN","version","options","requestParams","pollResult","fromBlock","delay","retryCount","result","withRetry","count","encodeFunctionData","errorLogs","errorData","logs","signatureData","ResponseError","metadata","chain_signatures_project_exports","accounts","chain_signatures_project_default","errors","events","instructions","types","EMIT_CPI_INSTRUCTION_DISCRIMINATOR","CpiEventParser","connection","targetProgramId","program","innerIxSet","instruction","parsedEvent","instructionData","ixData","ixDiscriminator","eventDiscriminator","event","idlDiscriminator","fullEventData","eventHandlers","context","handler","generateRequestIdSolana","algo","dest","params","payloadHex","parseAbiParameters","PublicKey","idl","Program","programStatePDA","programState","pda","fixedRemainingAccounts","acc","signer","Transaction","signers","blockhash","startTime","timeout","status","resolve","TransactionExpiredTimeoutError","_payload","_path","afterSignature","lastCheckedSignature","i","signatures","cpiEvents","mapped","parser","EventParser","evt","name","eventRequestIdHex","d","handlers","commitment","cpiHandlers","onSignatureResponded","e","onSignatureError","cpiSubId","subId"],"mappings":"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","file":"index.browser.js","sourcesContent":["import { type NajPublicKey } from '@types'\n\nexport const ENVS = {\n TESTNET_DEV: 'TESTNET_DEV',\n TESTNET: 'TESTNET',\n MAINNET: 'MAINNET',\n} as const\n\nexport const CHAINS = {\n ETHEREUM: 'ETHEREUM',\n SOLANA: 'SOLANA',\n} as const\n\n/**\n * Root public keys for the Sig Network Smart Contracts across different environments.\n *\n * These keys should never change.\n */\nexport const ROOT_PUBLIC_KEYS: Record<keyof typeof ENVS, NajPublicKey> = {\n [ENVS.TESTNET_DEV]:\n 'secp256k1:54hU5wcCmVUPFWLDALXMh1fFToZsVXrx9BbTbHzSfQq1Kd1rJZi52iPa4QQxo6s5TgjWqgpY8HamYuUDzG6fAaUq',\n [ENVS.TESTNET]:\n 'secp256k1:3Ww8iFjqTHufye5aRGUvrQqETegR4gVUcW8FX5xzscaN9ENhpkffojsxJwi6N1RbbHMTxYa9UyKeqK3fsMuwxjR5',\n [ENVS.MAINNET]:\n 'secp256k1:4tY4qMzusmgX5wYdG35663Y3Qar3CTbpApotwk9ZKLoF79XA4DjG8XoByaKdNHKQX9Lz5hd7iJqsWdTKyA7dKa6Z',\n}\n\n/**\n * Chain IDs used in the key derivation function (KDF) for deriving child public keys to\n * distinguish between different chains.\n *\n * @see {@link deriveChildPublicKey} in cryptography.ts for usage details\n */\nexport const KDF_CHAIN_IDS = {\n [CHAINS.ETHEREUM]: 'eip155:1',\n [CHAINS.SOLANA]: 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp',\n} as const\n\n/**\n * Contract addresses for different chains and environments.\n *\n * - Testnet Dev: Used for internal development, very unstable\n * - Testnet: Used for external development, stable\n * - Mainnet: Production contract address\n *\n * @see ChainSignatureContract documentation for implementation details\n */\nexport const CONTRACT_ADDRESSES: Record<\n keyof typeof CHAINS,\n Record<keyof typeof ENVS, string>\n> = {\n [CHAINS.ETHEREUM]: {\n [ENVS.TESTNET_DEV]: '0x69C6b28Fdc74618817fa380De29a653060e14009',\n [ENVS.TESTNET]: '0x83458E8Bf8206131Fe5c05127007FA164c0948A2',\n [ENVS.MAINNET]: '0xf8bdC0612361a1E49a8E01423d4C0cFc5dF4791A',\n },\n [CHAINS.SOLANA]: {\n [ENVS.TESTNET_DEV]: 'SigDuEPNeDjh3oJv7MUraPN7zaTFomS6ZWfpXwjUg4B',\n [ENVS.TESTNET]: 'SigTVbfRK9LsXWpSv9KgpabrQcFKr5hDdUwMhYsXyKg',\n [ENVS.MAINNET]: 'SigMcRMjKfnC7RDG5q4yUMZM1s5KJ9oYTPP4NmJRDRw',\n },\n}\n","export * as cryptography from './cryptography'\n","import { base58 } from '@scure/base'\nimport elliptic from 'elliptic'\nimport { keccak256, recoverAddress, createPublicClient, http } from 'viem'\n\nimport { KDF_CHAIN_IDS } from '@constants'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport {\n type NajPublicKey,\n type MPCSignature,\n type RSVSignature,\n type UncompressedPubKeySEC1,\n} from '@types'\n\nimport { chainAdapters } from '..'\nconst { ec: EC } = elliptic\n\nexport const toRSV = (signature: MPCSignature): RSVSignature => {\n if (\n 'bigR' in signature &&\n 'x' in signature.bigR &&\n 's' in signature &&\n typeof signature.s === 'bigint'\n ) {\n return {\n r: signature.bigR.x.toString(16).padStart(64, '0'),\n s: signature.s.toString(16).padStart(64, '0'),\n v: signature.recoveryId + 27,\n }\n }\n\n throw new Error('Invalid signature format')\n}\n\n/**\n * Compresses an uncompressed public key to its compressed format following SEC1 standards.\n * In SEC1, a compressed public key consists of a prefix (02 or 03) followed by the x-coordinate.\n * The prefix indicates whether the y-coordinate is even (02) or odd (03).\n *\n * @param uncompressedPubKeySEC1 - The uncompressed public key in hex format, with or without '04' prefix\n * @returns The compressed public key in hex format\n * @throws Error if the uncompressed public key length is invalid\n */\nexport const compressPubKey = (\n uncompressedPubKeySEC1: UncompressedPubKeySEC1\n): string => {\n const slicedPubKey = uncompressedPubKeySEC1.slice(2)\n\n if (slicedPubKey.length !== 128) {\n throw new Error('Invalid uncompressed public key length')\n }\n\n const x = slicedPubKey.slice(0, 64)\n const y = slicedPubKey.slice(64)\n\n const isEven = parseInt(y.slice(-1), 16) % 2 === 0\n const prefix = isEven ? '02' : '03'\n\n return prefix + x\n}\n\n/**\n * Converts a NAJ public key to an uncompressed SEC1 public key.\n *\n * @param najPublicKey - The NAJ public key to convert (e.g. secp 256k1:3Ww8iFjqTHufye5aRGUvrQqETegR4gVUcW8FX5xzscaN9ENhpkffojsxJwi6N1RbbHMTxYa9UyKeqK3fsMuwxjR5)\n * @returns The uncompressed SEC1 public key (e.g. 04 || x || y)\n */\nexport const najToUncompressedPubKeySEC1 = (\n najPublicKey: NajPublicKey\n): UncompressedPubKeySEC1 => {\n const decodedKey = base58.decode(najPublicKey.split(':')[1])\n return `04${Buffer.from(decodedKey).toString('hex')}`\n}\n\nconst EPSILON_DERIVATION_PREFIX_V1 = 'sig.network v1.0.0 epsilon derivation'\nconst EPSILON_DERIVATION_PREFIX_V2 = 'sig.network v2.0.0 epsilon derivation'\n\n/**\n * Derives a child public key from a parent public key using the Sig.Network epsilon derivation scheme.\n * The parent public keys are defined in @constants.ts\n *\n * @param rootUncompressedPubKeySEC1 - The parent public key in uncompressed SEC1 format (e.g. 04 || x || y)\n * @param predecessorId - The predecessor ID is the address of the account calling the signer contract (e.g EOA or Contract Address)\n * @param path - Optional derivation path suffix (defaults to empty string)\n * @param chainId - CAIP-2 chain identifier used for derivation\n * @param keyVersion - Key version controlling which derivation prefix to use (legacy v1 for 0, CAIP-2 v2 otherwise)\n * @returns The derived child public key in uncompressed SEC1 format (04 || x || y)\n */\nexport function deriveChildPublicKey(\n rootUncompressedPubKeySEC1: UncompressedPubKeySEC1,\n predecessorId: string,\n path: string = '',\n chainId: string,\n keyVersion: number\n): UncompressedPubKeySEC1 {\n const ec = new EC('secp256k1')\n const derivationPath =\n keyVersion <= 0\n ? `${EPSILON_DERIVATION_PREFIX_V1},${chainId},${predecessorId},${path}`\n : `${EPSILON_DERIVATION_PREFIX_V2}:${chainId}:${predecessorId}:${path}`\n\n let scalarHex = ''\n\n if (chainId === KDF_CHAIN_IDS.ETHEREUM) {\n scalarHex = keccak256(Buffer.from(derivationPath)).slice(2)\n } else if (chainId === KDF_CHAIN_IDS.SOLANA) {\n scalarHex = keccak256(Buffer.from(derivationPath)).slice(2)\n } else {\n throw new Error('Invalid chain ID')\n }\n\n const x = rootUncompressedPubKeySEC1.substring(2, 66)\n const y = rootUncompressedPubKeySEC1.substring(66)\n\n const oldPublicKeyPoint = ec.curve.point(x, y)\n const scalarTimesG = ec.g.mul(scalarHex)\n const newPublicKeyPoint = oldPublicKeyPoint.add(scalarTimesG)\n\n const newX = newPublicKeyPoint.getX().toString('hex').padStart(64, '0')\n const newY = newPublicKeyPoint.getY().toString('hex').padStart(64, '0')\n\n return `04${newX}${newY}`\n}\n\n/**\n * Verifies that a secp256k1 signature was created by the expected derived address\n * by recovering the signing address and comparing it with the address derived from the contract.\n *\n * @param signature - The RSV signature to verify\n * @param payload - The original message that was signed (as byte array)\n * @param requesterAddress - The address of the requester\n * @param path - The derivation path used for key generation\n * @param contract - The contract instance for deriving addresses\n * @returns Promise resolving to true if the recovered address matches the expected address\n */\nexport async function verifyRecoveredAddress(\n signature: RSVSignature,\n payload: number[] | Uint8Array,\n requesterAddress: string,\n path: string,\n contract: BaseChainSignatureContract,\n keyVersion: number\n): Promise<boolean> {\n try {\n // Derive the expected address using EVM chain adapter\n // We use EVM adapter even for non-EVM chains since we're dealing with secp256k1 signatures\n const evm = new chainAdapters.evm.EVM({\n publicClient: createPublicClient({\n transport: http('https://dontcare.com'),\n }),\n contract,\n })\n\n const { address: expectedAddress } = await evm.deriveAddressAndPublicKey(\n requesterAddress,\n path,\n keyVersion\n )\n\n const recoveredAddress = await recoverAddress({\n hash: new Uint8Array(payload),\n signature: {\n r: `0x${signature.r}`,\n s: `0x${signature.s}`,\n yParity: signature.v,\n },\n })\n\n return recoveredAddress.toLowerCase() === expectedAddress.toLowerCase()\n } catch (error) {\n console.error('Signature verification failed:', error)\n return false\n }\n}\n","export { ChainAdapter } from './ChainAdapter'\n\nexport * as evm from './EVM'\nexport * as btc from './Bitcoin'\nexport * as cosmos from './Cosmos'\n","import type { KeyDerivationPath, HashToSign, RSVSignature } from '@types'\n\nexport abstract class ChainAdapter<TransactionRequest, UnsignedTransaction> {\n /**\n * Gets the native token balance and decimals for a given address\n *\n * @param address - The address to check\n * @returns Promise resolving to an object containing:\n * - balance: The balance as a bigint, in the chain's base units\n * - decimals: The number of decimals used to format the balance\n */\n abstract getBalance(address: string): Promise<{\n balance: bigint\n decimals: number\n }>\n\n /**\n * Uses Sig Network Key Derivation Function to derive the address and public key. from a signer ID and string path.\n *\n * @param predecessor - The id/address of the account requesting signature\n * @param path - The string path used to derive the key\n * @returns Promise resolving to the derived address and public key\n */\n abstract deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath,\n keyVersion: number\n ): Promise<{\n address: string\n publicKey: string\n }>\n\n /**\n * Serializes an unsigned transaction to a string format.\n * This is useful for storing or transmitting the transaction.\n *\n * @param transaction - The unsigned transaction to serialize\n * @returns The serialized transaction string\n */\n abstract serializeTransaction(transaction: UnsignedTransaction): string\n\n /**\n * Deserializes a transaction string back into an unsigned transaction object.\n * This reverses the serialization done by serializeTransaction().\n *\n * @param serialized - The serialized transaction string\n * @returns The deserialized unsigned transaction\n */\n abstract deserializeTransaction(serialized: string): UnsignedTransaction\n\n /**\n * Prepares a transaction for Sig Network MPC signing by creating the necessary payloads.\n * This method handles chain-specific transaction preparation including:\n * - Fee calculation\n * - Nonce/sequence management\n * - UTXO selection (for UTXO-based chains)\n * - Transaction encoding\n *\n * @param transactionRequest - The transaction request containing parameters like recipient, amount, etc.\n * @returns Promise resolving to an object containing:\n * - transaction: The unsigned transaction\n * - hashesToSign: Array of payloads to be signed by MPC. The order of these payloads must match\n * the order of signatures provided to finalizeTransactionSigning()\n */\n abstract prepareTransactionForSigning(\n transactionRequest: TransactionRequest\n ): Promise<{\n transaction: UnsignedTransaction\n hashesToSign: HashToSign[]\n }>\n\n /**\n * Adds Sig Network MPC-generated signatures to an unsigned transaction.\n *\n * @param params - Parameters for adding signatures\n * @param params.transaction - The unsigned transaction to add signatures to\n * @param params.rsvSignatures - Array of RSV signatures generated through MPC. Must be in the same order\n * as the payloads returned by prepareTransactionForSigning()\n * @returns The serialized signed transaction ready for broadcast\n */\n abstract finalizeTransactionSigning(params: {\n transaction: UnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): string\n\n /**\n * Broadcasts a signed transaction to the network.\n *\n * @param txSerialized - The serialized signed transaction\n * @returns Promise resolving to the transaction hash/ID\n */\n abstract broadcastTx(txSerialized: string): Promise<string>\n}\n","// EVM\nexport { EVM } from './EVM'\n\nexport { fetchEVMFeeProperties } from './utils'\n\nexport type {\n EVMTransactionRequest,\n EVMUnsignedTransaction,\n EVMMessage,\n EVMTypedData,\n} from './types'\n","import { type PublicClient, type TransactionRequest } from 'viem'\n\nexport interface EVMFeeProperties {\n gas: bigint\n maxFeePerGas: bigint\n maxPriorityFeePerGas: bigint\n}\n\nexport async function fetchEVMFeeProperties(\n client: PublicClient,\n transaction: TransactionRequest\n): Promise<EVMFeeProperties> {\n const [gas, feeData] = await Promise.all([\n client.estimateGas(transaction),\n client.estimateFeesPerGas(),\n ])\n\n const maxFeePerGas = feeData.maxFeePerGas ?? BigInt(10_000_000_000) // 10 gwei\n const maxPriorityFeePerGas =\n feeData.maxPriorityFeePerGas ?? BigInt(10_000_000_000) // 10 gwei\n\n return {\n gas,\n maxFeePerGas,\n maxPriorityFeePerGas,\n }\n}\n","import {\n parseTransaction,\n type PublicClient,\n hashMessage,\n hashTypedData,\n keccak256,\n toBytes,\n type Hex,\n serializeTransaction,\n type Signature,\n numberToHex,\n getAddress,\n type Address,\n type Hash,\n concatHex,\n encodeAbiParameters,\n hexToBigInt,\n concat,\n pad,\n isAddress,\n} from 'viem'\n\nimport { ChainAdapter } from '@chain-adapters/ChainAdapter'\nimport type {\n EVMTransactionRequest,\n EVMUnsignedTransaction,\n EVMMessage,\n EVMTypedData,\n UserOperationV6,\n UserOperationV7,\n} from '@chain-adapters/EVM/types'\nimport { fetchEVMFeeProperties } from '@chain-adapters/EVM/utils'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@types'\n\n/**\n * Implementation of the ChainAdapter interface for EVM-compatible networks.\n * Handles interactions with Ethereum Virtual Machine based blockchains like Ethereum, BSC, Polygon, etc.\n */\nexport class EVM extends ChainAdapter<\n EVMTransactionRequest,\n EVMUnsignedTransaction\n> {\n private readonly client: PublicClient\n private readonly contract: BaseChainSignatureContract\n\n /**\n * Creates a new EVM chain instance\n * @param params - Configuration parameters\n * @param params.publicClient - A Viem PublicClient instance for reading from the blockchain\n * @param params.contract - Instance of the chain signature contract for MPC operations\n */\n constructor({\n publicClient,\n contract,\n }: {\n publicClient: PublicClient\n contract: BaseChainSignatureContract\n }) {\n super()\n\n this.contract = contract\n this.client = publicClient\n }\n\n private async attachGasAndNonce(\n transaction: EVMTransactionRequest\n ): Promise<EVMUnsignedTransaction> {\n const fees = await fetchEVMFeeProperties(this.client, transaction)\n const nonce = await this.client.getTransactionCount({\n address: transaction.from,\n })\n\n const { from, ...rest } = transaction\n\n return {\n ...fees,\n nonce,\n chainId: Number(await this.client.getChainId()),\n type: 'eip1559',\n ...rest,\n }\n }\n\n private transformRSVSignature(signature: RSVSignature): Signature {\n return {\n r: `0x${signature.r}`,\n s: `0x${signature.s}`,\n yParity: signature.v - 27,\n }\n }\n\n private assembleSignature(signature: RSVSignature): Hex {\n const { r, s, yParity } = this.transformRSVSignature(signature)\n\n if (yParity === undefined) {\n throw new Error('Missing yParity')\n }\n\n return concatHex([r, s, numberToHex(yParity + 27, { size: 1 })])\n }\n\n async deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath,\n keyVersion: number\n ): Promise<{\n address: string\n publicKey: string\n }> {\n const uncompressedPubKey = await this.contract.getDerivedPublicKey({\n path,\n predecessor,\n keyVersion,\n })\n\n if (!uncompressedPubKey) {\n throw new Error('Failed to get derived public key')\n }\n\n const publicKeyNoPrefix = uncompressedPubKey.startsWith('04')\n ? uncompressedPubKey.slice(2)\n : uncompressedPubKey\n\n const hash = keccak256(Buffer.from(publicKeyNoPrefix, 'hex'))\n const address = getAddress(`0x${hash.slice(-40)}`)\n\n return {\n address,\n publicKey: uncompressedPubKey,\n }\n }\n\n async getBalance(\n address: string\n ): Promise<{ balance: bigint; decimals: number }> {\n const balance = await this.client.getBalance({\n address: address as Address,\n })\n return {\n balance,\n decimals: 18,\n }\n }\n\n serializeTransaction(transaction: EVMUnsignedTransaction): `0x${string}` {\n return serializeTransaction(transaction)\n }\n\n deserializeTransaction(serialized: `0x${string}`): EVMUnsignedTransaction {\n return parseTransaction(serialized) as EVMUnsignedTransaction\n }\n\n async prepareTransactionForSigning(\n transactionRequest: EVMTransactionRequest\n ): Promise<{\n transaction: EVMUnsignedTransaction\n hashesToSign: HashToSign[]\n }> {\n const transaction = await this.attachGasAndNonce(transactionRequest)\n\n const serializedTx = serializeTransaction(transaction)\n const txHash = toBytes(keccak256(serializedTx))\n\n return {\n transaction,\n hashesToSign: [Array.from(txHash)],\n }\n }\n\n async prepareMessageForSigning(message: EVMMessage): Promise<{\n hashToSign: HashToSign\n }> {\n return {\n hashToSign: Array.from(toBytes(hashMessage(message))),\n }\n }\n\n async prepareTypedDataForSigning(typedDataRequest: EVMTypedData): Promise<{\n hashToSign: HashToSign\n }> {\n return {\n hashToSign: Array.from(toBytes(hashTypedData(typedDataRequest))),\n }\n }\n\n /**\n * This implementation is a common step for Biconomy and Alchemy.\n * Key differences between implementations:\n * - Signature format: Biconomy omits 0x00 prefix when concatenating, Alchemy includes it\n * - Version support: Biconomy only supports v6, Alchemy supports both v6 and v7\n * - Validation: Biconomy uses modules for signature validation, Alchemy uses built-in validation\n */\n async prepareUserOpForSigning(\n userOp: UserOperationV7 | UserOperationV6,\n entryPointAddress?: Address,\n chainIdArgs?: number\n ): Promise<{\n userOp: UserOperationV7 | UserOperationV6\n hashToSign: HashToSign\n }> {\n const chainId = chainIdArgs ?? (await this.client.getChainId())\n const entryPoint =\n entryPointAddress || '0x0000000071727De22E5E9d8BAf0edAc6f37da032'\n\n const encoded = encodeAbiParameters(\n [{ type: 'bytes32' }, { type: 'address' }, { type: 'uint256' }],\n [\n keccak256(\n encodeAbiParameters(\n [\n { type: 'address' },\n { type: 'uint256' },\n { type: 'bytes32' },\n { type: 'bytes32' },\n { type: 'bytes32' },\n { type: 'uint256' },\n { type: 'bytes32' },\n { type: 'bytes32' },\n ],\n [\n userOp.sender,\n hexToBigInt(userOp.nonce),\n keccak256(\n 'factory' in userOp &&\n 'factoryData' in userOp &&\n userOp.factory &&\n userOp.factoryData\n ? concat([userOp.factory, userOp.factoryData])\n : 'initCode' in userOp\n ? userOp.initCode\n : '0x'\n ),\n keccak256(userOp.callData),\n concat([\n pad(userOp.verificationGasLimit, { size: 16 }),\n pad(userOp.callGasLimit, { size: 16 }),\n ]),\n hexToBigInt(userOp.preVerificationGas),\n concat([\n pad(userOp.maxPriorityFeePerGas, { size: 16 }),\n pad(userOp.maxFeePerGas, { size: 16 }),\n ]),\n keccak256(\n 'paymaster' in userOp &&\n userOp.paymaster &&\n isAddress(userOp.paymaster)\n ? concat([\n userOp.paymaster,\n pad(userOp.paymasterVerificationGasLimit, { size: 16 }),\n pad(userOp.paymasterPostOpGasLimit, { size: 16 }),\n userOp.paymasterData,\n ])\n : 'paymasterAndData' in userOp\n ? userOp.paymasterAndData\n : '0x'\n ),\n ]\n )\n ),\n entryPoint,\n BigInt(chainId),\n ]\n )\n\n const userOpHash = keccak256(encoded)\n\n return {\n userOp,\n hashToSign: Array.from(toBytes(hashMessage({ raw: userOpHash }))),\n }\n }\n\n finalizeTransactionSigning({\n transaction,\n rsvSignatures,\n }: {\n transaction: EVMUnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): `0x02${string}` {\n const signature = this.transformRSVSignature(rsvSignatures[0])\n\n return serializeTransaction(transaction, signature)\n }\n\n finalizeMessageSigning({\n rsvSignature,\n }: {\n rsvSignature: RSVSignature\n }): Hex {\n return this.assembleSignature(rsvSignature)\n }\n\n finalizeTypedDataSigning({\n rsvSignature,\n }: {\n rsvSignature: RSVSignature\n }): Hex {\n return this.assembleSignature(rsvSignature)\n }\n\n finalizeUserOpSigning({\n userOp,\n rsvSignature,\n }: {\n userOp: UserOperationV7 | UserOperationV6\n rsvSignature: RSVSignature\n }): UserOperationV7 | UserOperationV6 {\n const { r, s, yParity } = this.transformRSVSignature(rsvSignature)\n if (yParity === undefined) {\n throw new Error('Missing yParity')\n }\n\n return {\n ...userOp,\n signature: concatHex([\n '0x00', // Alchemy specific implementation. Biconomy doesn't include the 0x00 prefix.\n r,\n s,\n numberToHex(Number(yParity + 27), { size: 1 }),\n ]),\n }\n }\n\n async broadcastTx(txSerialized: `0x${string}`): Promise<Hash> {\n try {\n return await this.client.sendRawTransaction({\n serializedTransaction: txSerialized,\n })\n } catch (error) {\n console.error('Transaction broadcast failed:', error)\n throw new Error('Failed to broadcast transaction.')\n }\n }\n}\n","// Bitcoin\nexport { Bitcoin } from './Bitcoin'\n\nexport { BTCRpcAdapters, BTCRpcAdapter } from './BTCRpcAdapter'\n\nexport type {\n BTCTransactionRequest,\n BTCUnsignedTransaction,\n BTCTransaction,\n BTCOutput,\n BTCInput,\n BTCNetworkIds,\n} from './types'\n","import * as bitcoin from 'bitcoinjs-lib'\n\nexport function parseBTCNetwork(network: string): bitcoin.networks.Network {\n switch (network.toLowerCase()) {\n case 'mainnet':\n return bitcoin.networks.bitcoin\n case 'testnet':\n return bitcoin.networks.testnet\n case 'regtest':\n return bitcoin.networks.regtest\n default:\n throw new Error(`Unknown Bitcoin network: ${network}`)\n }\n}\n","import * as bitcoin from 'bitcoinjs-lib'\n\nimport { type BTCRpcAdapter } from '@chain-adapters/Bitcoin/BTCRpcAdapter'\nimport type {\n BTCInput,\n BTCNetworkIds,\n BTCOutput,\n BTCTransactionRequest,\n BTCUnsignedTransaction,\n} from '@chain-adapters/Bitcoin/types'\nimport { parseBTCNetwork } from '@chain-adapters/Bitcoin/utils'\nimport { ChainAdapter } from '@chain-adapters/ChainAdapter'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@types'\nimport { cryptography } from '@utils'\n\n/**\n * Implementation of the ChainAdapter interface for Bitcoin network.\n * Handles interactions with both Bitcoin mainnet and testnet, supporting P2WPKH transactions.\n */\nexport class Bitcoin extends ChainAdapter<\n BTCTransactionRequest,\n BTCUnsignedTransaction\n> {\n private static readonly SATOSHIS_PER_BTC = 100_000_000\n\n private readonly network: BTCNetworkIds\n private readonly btcRpcAdapter: BTCRpcAdapter\n private readonly contract: BaseChainSignatureContract\n\n /**\n * Creates a new Bitcoin chain instance\n * @param params - Configuration parameters\n * @param params.network - Network identifier (mainnet/testnet)\n * @param params.contract - Instance of the chain signature contract for MPC operations\n * @param params.btcRpcAdapter - Bitcoin RPC adapter for network interactions\n */\n constructor({\n network,\n contract,\n btcRpcAdapter,\n }: {\n network: BTCNetworkIds\n contract: BaseChainSignatureContract\n btcRpcAdapter: BTCRpcAdapter\n }) {\n super()\n\n this.network = network\n this.btcRpcAdapter = btcRpcAdapter\n this.contract = contract\n }\n\n /**\n * Converts satoshis to BTC\n * @param satoshis - Amount in satoshis\n * @returns Amount in BTC\n */\n static toBTC(satoshis: number): number {\n return satoshis / Bitcoin.SATOSHIS_PER_BTC\n }\n\n /**\n * Converts BTC to satoshis\n * @param btc - Amount in BTC\n * @returns Amount in satoshis (rounded)\n */\n static toSatoshi(btc: number): number {\n return Math.round(btc * Bitcoin.SATOSHIS_PER_BTC)\n }\n\n private async fetchTransaction(\n transactionId: string\n ): Promise<bitcoin.Transaction> {\n const data = await this.btcRpcAdapter.getTransaction(transactionId)\n const tx = new bitcoin.Transaction()\n\n data.vout.forEach((vout) => {\n const scriptPubKey = Buffer.from(vout.scriptpubkey, 'hex')\n tx.addOutput(scriptPubKey, Number(vout.value))\n })\n\n return tx\n }\n\n private static transformRSVSignature(signature: RSVSignature): Buffer {\n const r = signature.r.padStart(64, '0')\n const s = signature.s.padStart(64, '0')\n\n const rawSignature = Buffer.from(r + s, 'hex')\n\n if (rawSignature.length !== 64) {\n throw new Error('Invalid signature length.')\n }\n\n return rawSignature\n }\n\n /**\n * Creates a Partially Signed Bitcoin Transaction (PSBT)\n * @param params - Parameters for creating the PSBT\n * @param params.transactionRequest - Transaction request containing inputs and outputs\n * @returns Created PSBT instance\n */\n async createPSBT({\n transactionRequest,\n }: {\n transactionRequest: BTCTransactionRequest\n }): Promise<bitcoin.Psbt> {\n const { inputs, outputs } =\n transactionRequest.inputs && transactionRequest.outputs\n ? transactionRequest\n : await this.btcRpcAdapter.selectUTXOs(transactionRequest.from, [\n {\n address: transactionRequest.to,\n value: parseFloat(transactionRequest.value),\n },\n ])\n\n const psbt = new bitcoin.Psbt({ network: parseBTCNetwork(this.network) })\n\n await Promise.all(\n inputs.map(async (input: BTCInput) => {\n if (!input.scriptPubKey) {\n const transaction = await this.fetchTransaction(input.txid)\n const prevOut = transaction.outs[input.vout]\n input.scriptPubKey = prevOut.script\n }\n\n // Prepare the input as P2WPKH\n psbt.addInput({\n hash: input.txid,\n index: input.vout,\n witnessUtxo: {\n script: input.scriptPubKey,\n value: input.value,\n },\n })\n })\n )\n\n outputs.forEach((out: BTCOutput) => {\n if ('address' in out) {\n psbt.addOutput({\n address: out.address,\n value: out.value,\n })\n } else if ('script' in out) {\n psbt.addOutput({\n script: out.script,\n value: out.value,\n })\n } else if (transactionRequest.from !== undefined) {\n // Include change address from coinselect\n psbt.addOutput({\n value: Number(out.value),\n address: transactionRequest.from,\n })\n }\n })\n\n return psbt\n }\n\n async getBalance(\n address: string\n ): Promise<{ balance: bigint; decimals: number }> {\n const balance = BigInt(await this.btcRpcAdapter.getBalance(address))\n return {\n balance,\n decimals: 8,\n }\n }\n\n async deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath,\n keyVersion: number\n ): Promise<{ address: string; publicKey: string }> {\n const uncompressedPubKey = await this.contract.getDerivedPublicKey({\n path,\n predecessor,\n keyVersion,\n })\n\n if (!uncompressedPubKey) {\n throw new Error('Failed to get derived public key')\n }\n\n const derivedKey = cryptography.compressPubKey(uncompressedPubKey)\n const publicKeyBuffer = Buffer.from(derivedKey, 'hex')\n const network = parseBTCNetwork(this.network)\n\n const payment = bitcoin.payments.p2wpkh({\n pubkey: publicKeyBuffer,\n network,\n })\n\n const { address } = payment\n\n if (!address) {\n throw new Error('Failed to generate Bitcoin address')\n }\n\n return { address, publicKey: derivedKey }\n }\n\n serializeTransaction(transaction: BTCUnsignedTransaction): string {\n return JSON.stringify({\n psbt: transaction.psbt.toHex(),\n publicKey: transaction.publicKey,\n })\n }\n\n deserializeTransaction(serialized: string): BTCUnsignedTransaction {\n const transactionJSON = JSON.parse(serialized)\n return {\n psbt: bitcoin.Psbt.fromHex(transactionJSON.psbt as string),\n publicKey: transactionJSON.publicKey,\n }\n }\n\n async prepareTransactionForSigning(\n transactionRequest: BTCTransactionRequest\n ): Promise<{\n transaction: BTCUnsignedTransaction\n hashesToSign: HashToSign[]\n }> {\n const publicKeyBuffer = Buffer.from(transactionRequest.publicKey, 'hex')\n const psbt = await this.createPSBT({\n transactionRequest,\n })\n\n // We can't double sign a PSBT, therefore we serialize the payload before to return it\n const psbtHex = psbt.toHex()\n\n const hashesToSign: HashToSign[] = []\n\n const mockKeyPair = (index: number): bitcoin.Signer => ({\n publicKey: publicKeyBuffer,\n sign: (hash: Buffer): Buffer => {\n hashesToSign[index] = Array.from(hash)\n // Return dummy signature to satisfy the interface\n return Buffer.alloc(64)\n },\n })\n\n for (let index = 0; index < psbt.inputCount; index++) {\n psbt.signInput(index, mockKeyPair(index))\n }\n\n return {\n transaction: {\n psbt: bitcoin.Psbt.fromHex(psbtHex),\n publicKey: transactionRequest.publicKey,\n },\n hashesToSign,\n }\n }\n\n finalizeTransactionSigning({\n transaction: { psbt, publicKey },\n rsvSignatures,\n }: {\n transaction: BTCUnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): string {\n const publicKeyBuffer = Buffer.from(publicKey, 'hex')\n\n const keyPair = (index: number): bitcoin.Signer => ({\n publicKey: publicKeyBuffer,\n sign: () => {\n const mpcSignature = rsvSignatures[index]\n return Bitcoin.transformRSVSignature(mpcSignature)\n },\n })\n\n for (let index = 0; index < psbt.inputCount; index++) {\n psbt.signInput(index, keyPair(index))\n }\n\n psbt.finalizeAllInputs()\n return psbt.extractTransaction().toHex()\n }\n\n async broadcastTx(txSerialized: string): Promise<string> {\n return await this.btcRpcAdapter.broadcastTransaction(txSerialized)\n }\n}\n","import type {\n BTCTransaction,\n BTCInput,\n BTCOutput,\n} from '@chain-adapters/Bitcoin/types'\n\nexport abstract class BTCRpcAdapter {\n abstract selectUTXOs(\n from: string,\n targets: BTCOutput[]\n ): Promise<{ inputs: BTCInput[]; outputs: BTCOutput[] }>\n abstract broadcastTransaction(transactionHex: string): Promise<string>\n abstract getBalance(address: string): Promise<number>\n abstract getTransaction(txid: string): Promise<BTCTransaction>\n}\n","// There is no types for coinselect\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-expect-error\n\nimport coinselect from 'coinselect'\n\nimport { BTCRpcAdapter } from '@chain-adapters/Bitcoin/BTCRpcAdapter/BTCRpcAdapter'\nimport {\n type BTCFeeRecommendation,\n type UTXO,\n} from '@chain-adapters/Bitcoin/BTCRpcAdapter/Mempool/types'\nimport type {\n BTCTransaction,\n BTCInput,\n BTCOutput,\n} from '@chain-adapters/Bitcoin/types'\n\nexport class Mempool extends BTCRpcAdapter {\n private readonly providerUrl: string\n\n constructor(providerUrl: string) {\n super()\n this.providerUrl = providerUrl\n }\n\n private async fetchFeeRate(confirmationTarget = 6): Promise<number> {\n const response = await fetch(`${this.providerUrl}/v1/fees/recommended`)\n const data = (await response.json()) as BTCFeeRecommendation\n\n if (confirmationTarget <= 1) {\n return data.fastestFee\n } else if (confirmationTarget <= 3) {\n return data.halfHourFee\n } else if (confirmationTarget <= 6) {\n return data.hourFee\n } else {\n return data.economyFee\n }\n }\n\n private async fetchUTXOs(address: string): Promise<UTXO[]> {\n try {\n const response = await fetch(\n `${this.providerUrl}/address/${address}/utxo`\n )\n return (await response.json()) as UTXO[]\n } catch (error) {\n console.error('Failed to fetch UTXOs:', error)\n return []\n }\n }\n\n async selectUTXOs(\n from: string,\n targets: BTCOutput[],\n confirmationTarget = 6\n ): Promise<{ inputs: BTCInput[]; outputs: BTCOutput[] }> {\n const utxos = await this.fetchUTXOs(from)\n const feeRate = await this.fetchFeeRate(confirmationTarget)\n\n // Add a small amount to the fee rate to ensure the transaction is confirmed\n const ret = coinselect(utxos, targets, Math.ceil(feeRate + 1))\n\n if (!ret.inputs || !ret.outputs) {\n throw new Error(\n 'Invalid transaction: coinselect failed to find a suitable set of inputs and outputs. This could be due to insufficient funds, or no inputs being available that meet the criteria.'\n )\n }\n\n return {\n inputs: ret.inputs,\n outputs: ret.outputs,\n }\n }\n\n async broadcastTransaction(transactionHex: string): Promise<string> {\n const response = await fetch(`${this.providerUrl}/tx`, {\n method: 'POST',\n body: transactionHex,\n })\n\n if (response.ok) {\n return await response.text()\n }\n\n throw new Error(`Failed to broadcast transaction: ${await response.text()}`)\n }\n\n async getBalance(address: string): Promise<number> {\n const response = await fetch(`${this.providerUrl}/address/${address}`)\n const data = (await response.json()) as {\n chain_stats: { funded_txo_sum: number; spent_txo_sum: number }\n }\n return data.chain_stats.funded_txo_sum - data.chain_stats.spent_txo_sum\n }\n\n async getTransaction(txid: string): Promise<BTCTransaction> {\n const response = await fetch(`${this.providerUrl}/tx/${txid}`)\n return (await response.json()) as BTCTransaction\n }\n}\n","import { Mempool } from './Mempool'\nexport { BTCRpcAdapter } from './BTCRpcAdapter'\n\nexport const BTCRpcAdapters = {\n Mempool,\n}\n","// Cosmos\nexport { Cosmos } from './Cosmos'\n\nexport type {\n CosmosNetworkIds,\n CosmosTransactionRequest,\n CosmosUnsignedTransaction,\n} from './types'\n","import { chains, assets } from 'chain-registry'\n\nimport { type ChainInfo } from '@chain-adapters/Cosmos/types'\n\nexport const fetchChainInfo = async (chainId: string): Promise<ChainInfo> => {\n const chainInfo = chains.find((chain) => chain.chain_id === chainId)\n if (!chainInfo) {\n throw new Error(`Chain info not found for chainId: ${chainId}`)\n }\n\n const { bech32_prefix: prefix, chain_id: expectedChainId } = chainInfo\n const denom = chainInfo.staking?.staking_tokens?.[0]?.denom\n const rpcUrl = chainInfo.apis?.rpc?.[0]?.address\n const restUrl = chainInfo.apis?.rest?.[0]?.address\n const gasPrice = chainInfo.fees?.fee_tokens?.[0]?.average_gas_price\n\n if (\n !prefix ||\n !denom ||\n !rpcUrl ||\n !restUrl ||\n !expectedChainId ||\n gasPrice === undefined\n ) {\n throw new Error(\n `Missing required chain information for ${chainInfo.chain_name}`\n )\n }\n\n const assetList = assets.find(\n (asset) => asset.chain_name === chainInfo.chain_name\n )\n const asset = assetList?.assets.find((asset) => asset.base === denom)\n const decimals = asset?.denom_units.find(\n (unit) => unit.denom === asset.display\n )?.exponent\n\n if (decimals === undefined) {\n throw new Error(\n `Could not find decimals for ${denom} on chain ${chainInfo.chain_name}`\n )\n }\n\n return { prefix, denom, rpcUrl, restUrl, expectedChainId, gasPrice, decimals }\n}\n","import { encodeSecp256k1Pubkey } from '@cosmjs/amino'\nimport { ripemd160, sha256 } from '@cosmjs/crypto'\nimport { toBase64, fromBase64, fromHex } from '@cosmjs/encoding'\nimport {\n Registry,\n makeSignBytes,\n encodePubkey,\n makeAuthInfoBytes,\n makeSignDoc,\n type TxBodyEncodeObject,\n} from '@cosmjs/proto-signing'\nimport { GasPrice, StargateClient, calculateFee } from '@cosmjs/stargate'\nimport { bech32 } from 'bech32'\nimport { SignMode } from 'cosmjs-types/cosmos/tx/signing/v1beta1/signing.js'\nimport { TxRaw } from 'cosmjs-types/cosmos/tx/v1beta1/tx.js'\n\nimport { ChainAdapter } from '@chain-adapters/ChainAdapter'\nimport type {\n CosmosNetworkIds,\n CosmosTransactionRequest,\n CosmosUnsignedTransaction,\n ChainInfo,\n BalanceResponse,\n} from '@chain-adapters/Cosmos/types'\nimport { fetchChainInfo } from '@chain-adapters/Cosmos/utils'\nimport type { BaseChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@types'\nimport { cryptography } from '@utils'\n\n/**\n * Implementation of the ChainAdapter interface for Cosmos-based networks.\n * Handles interactions with Cosmos SDK chains like Cosmos Hub, Osmosis, etc.\n */\nexport class Cosmos extends ChainAdapter<\n CosmosTransactionRequest,\n CosmosUnsignedTransaction\n> {\n private readonly registry: Registry\n private readonly chainId: CosmosNetworkIds\n private readonly contract: BaseChainSignatureContract\n private readonly endpoints?: {\n rpcUrl?: string\n restUrl?: string\n }\n\n /**\n * Creates a new Cosmos chain instance\n * @param params - Configuration parameters\n * @param params.chainId - Chain id for the Cosmos network\n * @param params.contract - Instance of the chain signature contract for MPC operations\n * @param params.endpoints - Optional RPC and REST endpoints\n * @param params.endpoints.rpcUrl - Optional RPC endpoint URL\n * @param params.endpoints.restUrl - Optional REST endpoint URL\n */\n constructor({\n chainId,\n contract,\n endpoints,\n }: {\n contract: BaseChainSignatureContract\n chainId: CosmosNetworkIds\n endpoints?: {\n rpcUrl?: string\n restUrl?: string\n }\n }) {\n super()\n\n this.contract = contract\n this.registry = new Registry()\n this.chainId = chainId\n this.endpoints = endpoints\n }\n\n private transformRSVSignature(rsvSignature: RSVSignature): Uint8Array {\n return new Uint8Array([\n ...fromHex(rsvSignature.r),\n ...fromHex(rsvSignature.s),\n ])\n }\n\n private async getChainInfo(): Promise<ChainInfo> {\n return {\n ...(await fetchChainInfo(this.chainId)),\n ...this.endpoints,\n }\n }\n\n async getBalance(\n address: string\n ): Promise<{ balance: bigint; decimals: number }> {\n try {\n const { restUrl, denom, decimals } = await this.getChainInfo()\n\n const response = await fetch(\n `${restUrl}/cosmos/bank/v1beta1/balances/${address}`\n )\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`)\n }\n\n const data = (await response.json()) as BalanceResponse\n const balance = data.balances.find((b) => b.denom === denom)\n const amount = balance?.amount ?? '0'\n\n return {\n balance: BigInt(amount),\n decimals,\n }\n } catch (error) {\n console.error('Failed to fetch Cosmos balance:', error)\n throw new Error('Failed to fetch Cosmos balance')\n }\n }\n\n async deriveAddressAndPublicKey(\n predecessor: string,\n path: KeyDerivationPath,\n keyVersion: number\n ): Promise<{\n address: string\n publicKey: string\n }> {\n const { prefix } = await this.getChainInfo()\n const uncompressedPubKey = await this.contract.getDerivedPublicKey({\n path,\n predecessor,\n keyVersion,\n })\n\n if (!uncompressedPubKey) {\n throw new Error('Failed to get derived public key')\n }\n\n const derivedKey = cryptography.compressPubKey(uncompressedPubKey)\n const pubKeySha256 = sha256(fromHex(derivedKey))\n const ripemd160Hash = ripemd160(pubKeySha256)\n const address = bech32.encode(prefix, bech32.toWords(ripemd160Hash))\n\n return { address, publicKey: derivedKey }\n }\n\n serializeTransaction(transaction: CosmosUnsignedTransaction): string {\n const serialized = TxRaw.encode(transaction).finish()\n return toBase64(serialized)\n }\n\n deserializeTransaction(serialized: string): CosmosUnsignedTransaction {\n return TxRaw.decode(fromBase64(serialized))\n }\n\n async prepareTransactionForSigning(\n transactionRequest: CosmosTransactionRequest\n ): Promise<{\n transaction: CosmosUnsignedTransaction\n hashesToSign: HashToSign[]\n }> {\n const { denom, rpcUrl, gasPrice } = await this.getChainInfo()\n const publicKeyBytes = fromHex(transactionRequest.publicKey)\n\n const gasLimit = transactionRequest.gas || 200_000\n\n const fee = calculateFee(\n gasLimit,\n GasPrice.fromString(`${gasPrice}${denom}`)\n )\n\n const client = await StargateClient.connect(rpcUrl)\n const accountOnChain = await client.getAccount(transactionRequest.address)\n if (!accountOnChain) {\n throw new Error(\n `Account ${transactionRequest.address} does not exist on chain`\n )\n }\n\n const { accountNumber, sequence } = accountOnChain\n\n const txBodyEncodeObject: TxBodyEncodeObject = {\n typeUrl: '/cosmos.tx.v1beta1.TxBody',\n value: {\n messages: transactionRequest.messages,\n memo: transactionRequest.memo || '',\n },\n }\n\n const txBodyBytes = this.registry.encode(txBodyEncodeObject)\n\n const pubkey = encodePubkey(encodeSecp256k1Pubkey(publicKeyBytes))\n\n // TODO: Allow caller to provide: multiple signers, fee payer, fee granter\n const authInfoBytes = makeAuthInfoBytes(\n [\n {\n pubkey,\n sequence,\n },\n ],\n fee.amount,\n Number(fee.gas),\n undefined,\n undefined,\n SignMode.SIGN_MODE_DIRECT\n )\n\n const signDoc = makeSignDoc(\n txBodyBytes,\n authInfoBytes,\n this.chainId,\n accountNumber\n )\n\n const signBytes = makeSignBytes(signDoc)\n const payload = Array.from(sha256(signBytes))\n\n return {\n transaction: TxRaw.fromPartial({\n bodyBytes: txBodyBytes,\n authInfoBytes,\n signatures: [],\n }),\n hashesToSign: [payload],\n }\n }\n\n finalizeTransactionSigning({\n transaction,\n rsvSignatures,\n }: {\n transaction: CosmosUnsignedTransaction\n rsvSignatures: RSVSignature[]\n }): string {\n // Allow support for multi-sig but the package only supports single-sig\n transaction.signatures = rsvSignatures.map((sig) =>\n this.transformRSVSignature(sig)\n )\n\n const txBytes = TxRaw.encode(transaction).finish()\n return Buffer.from(txBytes).toString('hex')\n }\n\n async broadcastTx(txSerialized: string): Promise<string> {\n try {\n const { rpcUrl } = await this.getChainInfo()\n const client = await StargateClient.connect(rpcUrl)\n\n const txBytes = fromHex(txSerialized)\n const broadcastResponse = await client.broadcastTx(txBytes)\n\n if (broadcastResponse.code !== 0) {\n throw new Error(`Broadcast error: ${broadcastResponse.rawLog}`)\n }\n\n return broadcastResponse.transactionHash\n } catch (error) {\n console.error('Transaction broadcast failed:', error)\n throw new Error('Failed to broadcast transaction.')\n }\n }\n}\n","export { ChainSignatureContract, type SignArgs } from './ChainSignatureContract'\n\nexport * as evm from './evm'\nexport * as solana from './solana'\n","import type BN from 'bn.js'\n\nimport type { RSVSignature, UncompressedPubKeySEC1 } from '@types'\n\nexport interface SignArgs {\n /** The payload to sign as an array of 32 bytes */\n payload: number[]\n /** The derivation path for key generation */\n path: string\n /** Version of the key to use */\n key_version: number\n}\n\n/**\n * Base contract interface required for compatibility with ChainAdapter instances like EVM and Bitcoin.\n *\n * See {@link EVM} and {@link Bitcoin} for example implementations.\n */\nexport abstract class BaseChainSignatureContract {\n /**\n * Gets the current signature deposit required by the contract.\n * This deposit amount helps manage network congestion.\n *\n * @returns Promise resolving to the required deposit amount as a BigNumber\n */\n abstract getCurrentSignatureDeposit(): Promise<BN>\n\n /**\n * Derives a child public key using a\\ derivation path and predecessor.\n *\n * @param args - Arguments for key derivation\n * @param args.path - The string path to use derive the key\n * @param args.predecessor - The id/address of the account requesting signature\n * @param args.keyVersion - Optional key version controlling the derivation prefix (defaults to 0)\n * @returns Promise resolving to the derived SEC1 uncompressed public key\n */\n abstract getDerivedPublicKey(\n args: {\n path: string\n predecessor: string\n keyVersion: number\n } & Record<string, unknown>\n ): Promise<UncompressedPubKeySEC1>\n}\n\n/**\n * Full contract interface that extends BaseChainSignatureContract to provide all Sig Network Smart Contract capabilities.\n */\nexport abstract class ChainSignatureContract extends BaseChainSignatureContract {\n /**\n * Signs a payload using Sig Network MPC.\n *\n * @param args - Arguments for the signing operation\n * @param args.payload - The data to sign as an array of 32 bytes\n * @param args.path - The string path to use derive the key\n * @param args.key_version - Version of the key to use\n * @returns Promise resolving to the RSV signature\n */\n abstract sign(args: SignArgs & Record<string, unknown>): Promise<RSVSignature>\n\n /**\n * Gets the public key associated with this contract instance.\n *\n * @returns Promise resolving to the SEC1 uncompressed public key\n */\n abstract getPublicKey(): Promise<UncompressedPubKeySEC1>\n}\n","import * as ChainSignaturesContractABI from './ChainSignaturesContractABI'\nimport * as errors from './errors'\nexport * from './ChainSignaturesContract'\n\nconst utils = {\n ChainSignaturesContractABI,\n errors,\n}\n\nexport { utils }\n","export const abi = [\n {\n inputs: [\n { internalType: 'address', name: '_mpc_network', type: 'address' },\n { internalType: 'uint256', name: '_signatureDeposit', type: 'uint256' },\n ],\n stateMutability: 'nonpayable',\n type: 'constructor',\n },\n { inputs: [], name: 'AccessControlBadConfirmation', type: 'error' },\n {\n inputs: [\n { internalType: 'address', name: 'account', type: 'address' },\n { internalType: 'bytes32', name: 'neededRole', type: 'bytes32' },\n ],\n name: 'AccessControlUnauthorizedAccount',\n type: 'error',\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: 'bytes32', name: 'role', type: 'bytes32' },\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'previousAdminRole',\n type: 'bytes32',\n },\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'newAdminRole',\n type: 'bytes32',\n },\n ],\n name: 'RoleAdminChanged',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: 'bytes32', name: 'role', type: 'bytes32' },\n {\n indexed: true,\n internalType: 'address',\n name: 'account',\n type: 'address',\n },\n {\n indexed: true,\n internalType: 'address',\n name: 'sender',\n type: 'address',\n },\n ],\n name: 'RoleGranted',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: 'bytes32', name: 'role', type: 'bytes32' },\n {\n indexed: true,\n internalType: 'address',\n name: 'account',\n type: 'address',\n },\n {\n indexed: true,\n internalType: 'address',\n name: 'sender',\n type: 'address',\n },\n ],\n name: 'RoleRevoked',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'requestId',\n type: 'bytes32',\n },\n {\n indexed: false,\n internalType: 'address',\n name: 'responder',\n type: 'address',\n },\n { indexed: false, internalType: 'string', name: 'error', type: 'string' },\n ],\n name: 'SignatureError',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: false,\n internalType: 'address',\n name: 'sender',\n type: 'address',\n },\n {\n indexed: false,\n internalType: 'bytes32',\n name: 'payload',\n type: 'bytes32',\n },\n {\n indexed: false,\n internalType: 'uint32',\n name: 'keyVersion',\n type: 'uint32',\n },\n {\n indexed: false,\n internalType: 'uint256',\n name: 'deposit',\n type: 'uint256',\n },\n {\n indexed: false,\n internalType: 'uint256',\n name: 'chainId',\n type: 'uint256',\n },\n { indexed: false, internalType: 'string', name: 'path', type: 'string' },\n { indexed: false, internalType: 'string', name: 'algo', type: 'string' },\n { indexed: false, internalType: 'string', name: 'dest', type: 'string' },\n {\n indexed: false,\n internalType: 'string',\n name: 'params',\n type: 'string',\n },\n ],\n name: 'SignatureRequested',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: true,\n internalType: 'bytes32',\n name: 'requestId',\n type: 'bytes32',\n },\n {\n indexed: false,\n internalType: 'address',\n name: 'responder',\n type: 'address',\n },\n {\n components: [\n {\n components: [\n { internalType: 'uint256', name: 'x', type: 'uint256' },\n { internalType: 'uint256', name: 'y', type: 'uint256' },\n ],\n internalType: 'struct ChainSignatures.AffinePoint',\n name: 'bigR',\n type: 'tuple',\n },\n { internalType: 'uint256', name: 's', type: 'uint256' },\n { internalType: 'uint8', name: 'recoveryId', type: 'uint8' },\n ],\n indexed: false,\n internalType: 'struct ChainSignatures.Signature',\n name: 'signature',\n type: 'tuple',\n },\n ],\n name: 'SignatureResponded',\n type: 'event',\n },\n {\n anonymous: false,\n inputs: [\n {\n indexed: true,\n internalType: 'address',\n name: 'owner',\n type: 'address',\n },\n {\n indexed: false,\n internalType: 'uint256',\n name: 'amount',\n type: 'uint256',\n },\n ],\n name: 'Withdraw',\n type: 'event',\n },\n {\n inputs: [],\n name: 'DEFAULT_ADMIN_ROLE',\n outputs: [{ internalType: 'bytes32', name: '', type: 'bytes32' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [{ internalType: 'bytes32', name: 'role', type: 'bytes32' }],\n name: 'getRoleAdmin',\n outputs: [{ internalType: 'bytes32', name: '', type: 'bytes32' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [],\n name: 'getSignatureDeposit',\n outputs: [{ internalType: 'uint256', name: '', type: 'uint256' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'account', type: 'address' },\n ],\n name: 'grantRole',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'account', type: 'address' },\n ],\n name: 'hasRole',\n outputs: [{ internalType: 'bool', name: '', type: 'bool' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'callerConfirmation', type: 'address' },\n ],\n name: 'renounceRole',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n {\n components: [\n { internalType: 'bytes32', name: 'requestId', type: 'bytes32' },\n {\n components: [\n {\n components: [\n { internalType: 'uint256', name: 'x', type: 'uint256' },\n { internalType: 'uint256', name: 'y', type: 'uint256' },\n ],\n internalType: 'struct ChainSignatures.AffinePoint',\n name: 'bigR',\n type: 'tuple',\n },\n { internalType: 'uint256', name: 's', type: 'uint256' },\n { internalType: 'uint8', name: 'recoveryId', type: 'uint8' },\n ],\n internalType: 'struct ChainSignatures.Signature',\n name: 'signature',\n type: 'tuple',\n },\n ],\n internalType: 'struct ChainSignatures.Response[]',\n name: '_responses',\n type: 'tuple[]',\n },\n ],\n name: 'respond',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n {\n components: [\n { internalType: 'bytes32', name: 'requestId', type: 'bytes32' },\n { internalType: 'string', name: 'errorMessage', type: 'string' },\n ],\n internalType: 'struct ChainSignatures.ErrorResponse[]',\n name: '_errors',\n type: 'tuple[]',\n },\n ],\n name: 'respondError',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'bytes32', name: 'role', type: 'bytes32' },\n { internalType: 'address', name: 'account', type: 'address' },\n ],\n name: 'revokeRole',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [{ internalType: 'uint256', name: '_amount', type: 'uint256' }],\n name: 'setSignatureDeposit',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n {\n inputs: [\n {\n components: [\n { internalType: 'bytes32', name: 'payload', type: 'bytes32' },\n { internalType: 'string', name: 'path', type: 'string' },\n { internalType: 'uint32', name: 'keyVersion', type: 'uint32' },\n { internalType: 'string', name: 'algo', type: 'string' },\n { internalType: 'string', name: 'dest', type: 'string' },\n { internalType: 'string', name: 'params', type: 'string' },\n ],\n internalType: 'struct ChainSignatures.SignRequest',\n name: '_request',\n type: 'tuple',\n },\n ],\n name: 'sign',\n outputs: [],\n stateMutability: 'payable',\n type: 'function',\n },\n {\n inputs: [{ internalType: 'bytes4', name: 'interfaceId', type: 'bytes4' }],\n name: 'supportsInterface',\n outputs: [{ internalType: 'bool', name: '', type: 'bool' }],\n stateMutability: 'view',\n type: 'function',\n },\n {\n inputs: [\n { internalType: 'uint256', name: '_amount', type: 'uint256' },\n { internalType: 'address', name: '_receiver', type: 'address' },\n ],\n name: 'withdraw',\n outputs: [],\n stateMutability: 'nonpayable',\n type: 'function',\n },\n]\n","import type { TransactionReceipt } from 'viem'\n\nexport class ChainSignatureError extends Error {\n requestId: `0x${string}`\n receipt: TransactionReceipt\n\n constructor(\n message: string,\n requestId: `0x${string}`,\n receipt: TransactionReceipt\n ) {\n super(message)\n this.name = 'ChainSignatureError'\n this.requestId = requestId\n this.receipt = receipt\n }\n}\n\nexport class SignatureNotFoundError extends ChainSignatureError {\n constructor(requestId: `0x${string}`, receipt: TransactionReceipt) {\n super('Signature not found after maximum retries', requestId, receipt)\n this.name = 'SignatureNotFoundError'\n }\n}\n\nexport class SignatureContractError extends ChainSignatureError {\n errorCode: string\n\n constructor(\n errorCode: string,\n requestId: `0x${string}`,\n receipt: TransactionReceipt\n ) {\n super(`Signature error: ${errorCode}`, requestId, receipt)\n this.name = 'SignatureContractError'\n this.errorCode = errorCode\n }\n}\n\nexport class SigningError extends ChainSignatureError {\n originalError?: Error\n\n constructor(\n requestId: `0x${string}`,\n receipt: TransactionReceipt,\n originalError?: Error\n ) {\n super('Error signing request', requestId, receipt)\n this.name = 'SigningError'\n this.originalError = originalError\n }\n}\n","import { CONTRACT_ADDRESSES, ROOT_PUBLIC_KEYS, type CHAINS } from '@constants'\nimport type { NajPublicKey } from '@types'\n\nexport const getRootPublicKey = (\n contractAddress: string,\n chain: keyof typeof CHAINS\n): NajPublicKey | undefined => {\n const environment = Object.entries(CONTRACT_ADDRESSES[chain]).find(\n ([_, address]) => address.toLowerCase() === contractAddress.toLowerCase()\n )?.[0] as keyof typeof ROOT_PUBLIC_KEYS | undefined\n\n if (environment) {\n return ROOT_PUBLIC_KEYS[environment]\n }\n\n return undefined\n}\n","import { encodeAbiParameters, keccak256 } from 'viem'\nimport * as chains from 'viem/chains'\nimport type { Chain } from 'viem/chains'\n\nimport { type RequestIdArgs } from './types'\n\nexport const getChain = (chainId: number): Chain => {\n for (const chain of Object.values(chains)) {\n if (chain.id === chainId) {\n return chain\n }\n }\n throw new Error('Chain not found')\n}\n\nexport const getRequestId = (request: RequestIdArgs): `0x${string}` => {\n const encoded = encodeAbiParameters(\n [\n { type: 'address' },\n { type: 'bytes' },\n { type: 'string' },\n { type: 'uint32' },\n { type: 'uint256' },\n { type: 'string' },\n { type: 'string' },\n { type: 'string' },\n ],\n [\n request.address,\n request.payload,\n request.path,\n Number(request.keyVersion),\n request.chainId,\n request.algo,\n request.dest,\n request.params,\n ]\n )\n\n return keccak256(encoded)\n}\n","import {\n najToUncompressedPubKeySEC1,\n verifyRecoveredAddress,\n} from '@utils/cryptography'\nimport { getRootPublicKey } from '@utils/publicKey'\nimport BN from 'bn.js'\nimport {\n withRetry,\n type PublicClient,\n type WalletClient,\n type Hex,\n encodeFunctionData,\n} from 'viem'\n\nimport { CHAINS, KDF_CHAIN_IDS } from '@constants'\nimport { ChainSignatureContract as AbstractChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { SignArgs } from '@contracts/ChainSignatureContract'\nimport type {\n NajPublicKey,\n RSVSignature,\n SigNetEvmMpcSignature,\n UncompressedPubKeySEC1,\n} from '@types'\nimport { cryptography } from '@utils'\n\nimport { abi } from './ChainSignaturesContractABI'\nimport {\n SignatureNotFoundError,\n SignatureContractError,\n SigningError,\n} from './errors'\nimport type {\n RetryOptions,\n SignOptions,\n SignRequest,\n SignatureErrorData,\n} from './types'\nimport { getRequestId } from './utils'\n\n/**\n * Implementation of the ChainSignatureContract for EVM chains.\n *\n * When signing data, the contract emits a SignatureRequested event with a requestId.\n * This requestId is used to track the signature request and retrieve the signature\n * once it's available. The sign method handles this process automatically by polling\n * for the signature using the requestId.\n */\nexport class ChainSignatureContract extends AbstractChainSignatureContract {\n private readonly publicClient: PublicClient\n private readonly walletClient: WalletClient\n private readonly contractAddress: Hex\n private readonly rootPublicKey: NajPublicKey\n\n /**\n * Creates a new instance of the ChainSignatureContract for EVM chains.\n *\n * @param args - Configuration options for the contract\n * @param args.publicClient - A Viem PublicClient instance for reading from the blockchain\n * @param args.walletClient - A Viem WalletClient instance for sending transactions\n * @param args.contractAddress - The address of the deployed ChainSignatures contract (e.g. `0x857ED3A242B59cC24144814a0DF41C397a3811E6`)\n * @param args.rootPublicKey - Optional root public key. If not provided, it will be derived from the contract address\n */\n constructor(args: {\n publicClient: PublicClient\n walletClient: WalletClient\n contractAddress: Hex\n rootPublicKey?: NajPublicKey\n }) {\n super()\n this.publicClient = args.publicClient\n this.walletClient = args.walletClient\n this.contractAddress = args.contractAddress\n\n const rootPublicKey =\n args.rootPublicKey ||\n getRootPublicKey(this.contractAddress, CHAINS.ETHEREUM)\n\n if (!rootPublicKey) {\n throw new Error(\n `Invalid public key, please provide a valid root public key or contract address`\n )\n }\n\n this.rootPublicKey = rootPublicKey\n }\n\n async getCurrentSignatureDeposit(): Promise<BN> {\n const deposit = (await this.publicClient.readContract({\n address: this.contractAddress,\n abi,\n functionName: 'getSignatureDeposit',\n })) as bigint\n\n return new BN(deposit.toString())\n }\n\n async getDerivedPublicKey(args: {\n path: string\n predecessor: string\n keyVersion: number\n }): Promise<UncompressedPubKeySEC1> {\n const pubKey = cryptography.deriveChildPublicKey(\n await this.getPublicKey(),\n args.predecessor.toLowerCase(),\n args.path,\n KDF_CHAIN_IDS.ETHEREUM,\n args.keyVersion\n )\n\n return pubKey\n }\n\n async getPublicKey(): Promise<UncompressedPubKeySEC1> {\n return najToUncompressedPubKeySEC1(this.rootPublicKey)\n }\n\n async getLatestKeyVersion(): Promise<number> {\n const version = (await this.publicClient.readContract({\n address: this.contractAddress,\n abi,\n functionName: 'latestKeyVersion',\n })) as bigint\n\n return Number(version)\n }\n\n /**\n * Sends a sign request transaction and return the transaction hash.\n *\n * @param args - The signature arguments\n * @param options - The signing options\n * @returns The transaction hash\n */\n async createSignatureRequest(\n args: SignArgs,\n options: Pick<SignOptions, 'sign' | 'transaction'> = {\n sign: {\n algo: '',\n dest: '',\n params: '',\n },\n }\n ): Promise<{\n txHash: Hex\n requestId: Hex\n }> {\n if (!this.walletClient?.account) {\n throw new Error('Wallet client required for signing operations')\n }\n\n const requestParams = await this.getSignRequestParams(args, options.sign)\n\n const requestId = this.getRequestId(args, options.sign)\n\n const hash = await this.walletClient.sendTransaction({\n ...options.transaction,\n account: this.walletClient.account,\n to: requestParams.target,\n data: requestParams.data,\n value: requestParams.value,\n chain: this.walletClient.chain,\n })\n\n return {\n txHash: hash,\n requestId,\n }\n }\n\n /**\n * Sends a transaction to the contract to request a signature, then\n * polls for the signature result. If the signature is not found within the retry\n * parameters, it will throw an error.\n */\n async sign(\n args: SignArgs,\n options: SignOptions = {\n sign: {\n algo: '',\n dest: '',\n params: '',\n },\n retry: {\n delay: 5000,\n retryCount: 12,\n },\n }\n ): Promise<RSVSignature> {\n const { txHash, requestId } = await this.createSignatureRequest(\n args,\n options\n )\n\n const receipt = await this.publicClient.waitForTransactionReceipt({\n hash: txHash,\n })\n\n try {\n const pollResult = await this.pollForRequestId({\n requestId,\n payload: args.payload,\n path: args.path,\n keyVersion: args.key_version,\n fromBlock: receipt.blockNumber,\n options: options.retry,\n })\n\n if (!pollResult) {\n throw new SignatureNotFoundError(requestId, receipt)\n }\n\n if ('error' in pollResult) {\n throw new SignatureContractError(pollResult.error, requestId, receipt)\n }\n\n return pollResult\n } catch (error) {\n if (\n error instanceof SignatureNotFoundError ||\n error instanceof SignatureContractError\n ) {\n throw error\n } else {\n throw new SigningError(\n requestId,\n receipt,\n error instanceof Error ? error : undefined\n )\n }\n }\n }\n\n async pollForRequestId({\n requestId,\n payload,\n path,\n keyVersion,\n fromBlock,\n options,\n }: {\n requestId: Hex\n payload: number[]\n path: string\n keyVersion: number\n fromBlock: bigint\n options?: RetryOptions\n }): Promise<RSVSignature | SignatureErrorData | undefined> {\n const delay = options?.delay ?? 5000\n const retryCount = options?.retryCount ?? 12\n\n const result = await withRetry(\n async () => {\n const result = await this.getSignatureFromEvents(requestId, fromBlock)\n\n if (result) {\n // Verify the signature\n const isValid = await verifyRecoveredAddress(\n result,\n payload,\n this.walletClient.account?.address as string,\n path,\n this,\n keyVersion\n )\n\n if (!isValid) {\n throw new Error('Signature not found yet')\n }\n return result\n } else {\n throw new Error('Signature not found yet')\n }\n },\n {\n delay,\n retryCount,\n shouldRetry: ({ count, error }) => {\n // TODO: Should be enabled only on debug mode\n console.log(`Retrying get signature: ${count}/${retryCount}`)\n return error.message === 'Signature not found yet'\n },\n }\n )\n\n if (result) {\n return result\n }\n\n return await this.getErrorFromEvents(requestId, fromBlock)\n }\n\n async getSignRequestParams(\n args: SignArgs,\n options: SignOptions['sign'] = {\n algo: '',\n dest: '',\n params: '',\n }\n ): Promise<{\n target: Hex\n data: Hex\n value: bigint\n }> {\n const request: SignRequest = {\n payload: `0x${Buffer.from(args.payload).toString('hex')}`,\n path: args.path,\n keyVersion: args.key_version,\n algo: options.algo ?? '',\n dest: options.dest ?? '',\n params: options.params ?? '',\n }\n\n return {\n target: this.contractAddress,\n data: encodeFunctionData({\n abi,\n functionName: 'sign',\n args: [request],\n }),\n value: BigInt((await this.getCurrentSignatureDeposit()).toString()),\n }\n }\n\n /**\n * Generates the request ID for a signature request allowing to track the response.\n *\n * @param args - The signature request object containing:\n * @param args.payload - The data payload to be signed as a hex string\n * @param args.path - The derivation path for the key\n * @param args.keyVersion - The version of the key to use\n * @param options - The signature request object containing:\n * @param options.algo - The signing algorithm to use\n * @param options.dest - The destination for the signature\n * @param options.params - Additional parameters for the signing process\n * @returns A hex string representing the unique request ID\n *\n * @example\n * ```typescript\n * const requestId = ChainSignatureContract.getRequestId({\n * payload: payload: `0x${Buffer.from(args.payload).toString('hex')}`,,\n * path: '',\n * keyVersion: 0\n * });\n * console.log(requestId); // 0x...\n * ```\n */\n getRequestId(\n args: SignArgs,\n options: SignOptions['sign'] = {\n algo: '',\n dest: '',\n params: '',\n }\n ): Hex {\n if (!this.walletClient.account) {\n throw new Error('Wallet client account required to compute requestId')\n }\n if (!this.publicClient.chain?.id) {\n throw new Error('Public client chain required to compute requestId')\n }\n return getRequestId({\n payload: `0x${Buffer.from(args.payload).toString('hex')}`,\n path: args.path,\n keyVersion: args.key_version,\n algo: options.algo ?? '',\n dest: options.dest ?? '',\n params: options.params ?? '',\n address: this.walletClient.account.address,\n chainId: BigInt(this.publicClient.chain.id),\n })\n }\n\n async getErrorFromEvents(\n requestId: Hex,\n fromBlock: bigint\n ): Promise<SignatureErrorData | undefined> {\n const errorLogs = await this.publicClient.getContractEvents({\n address: this.contractAddress,\n abi,\n eventName: 'SignatureError',\n args: {\n requestId,\n },\n fromBlock,\n toBlock: 'latest',\n })\n\n if (errorLogs.length > 0) {\n const { args: errorData } = errorLogs[\n errorLogs.length - 1\n ] as unknown as {\n args: SignatureErrorData\n }\n\n return errorData\n }\n\n return undefined\n }\n\n /**\n * Searches for SignatureResponded events that match the given requestId.\n * It works in conjunction with the getRequestId method which generates the unique\n * identifier for a signature request.\n *\n * @param requestId - The identifier for the signature request\n * @param fromBlock - The block number to start searching from\n * @returns The RSV signature if found, undefined otherwise\n */\n async getSignatureFromEvents(\n requestId: Hex,\n fromBlock: bigint\n ): Promise<RSVSignature | undefined> {\n const logs = await this.publicClient.getContractEvents({\n address: this.contractAddress,\n abi,\n eventName: 'SignatureResponded',\n args: {\n requestId,\n },\n fromBlock,\n toBlock: 'latest',\n })\n\n if (logs.length > 0) {\n const { args: signatureData } = logs[logs.length - 1] as unknown as {\n args: {\n signature: SigNetEvmMpcSignature\n }\n }\n\n return cryptography.toRSV(signatureData.signature)\n }\n\n return undefined\n }\n}\n","import * as errors from './errors'\nimport * as ChainSignaturesContractIdl from './types/chain_signatures_project.json'\nexport * from './ChainSignaturesContract'\nexport type { ChainSignaturesProject } from './types/chain_signatures_project'\n\nconst utils = {\n ChainSignaturesContractIdl,\n errors,\n}\n\nexport { utils }\n","export class SignatureNotFoundError extends Error {\n public readonly requestId?: string\n public readonly hash?: string\n\n constructor(requestId?: string, metadata?: { hash?: string }) {\n const message = requestId\n ? `Signature not found for request ID: ${requestId}`\n : 'Signature not found'\n\n super(message)\n this.name = 'SignatureNotFoundError'\n this.requestId = requestId\n this.hash = metadata?.hash\n }\n}\n\nexport class SignatureContractError extends Error {\n public readonly requestId?: string\n public readonly hash?: string\n public readonly originalError?: { hash: string }\n\n constructor(\n message: string,\n requestId?: string,\n metadata?: { hash?: string }\n ) {\n super(message)\n this.name = 'SignatureContractError'\n this.requestId = requestId\n this.hash = metadata?.hash\n }\n}\n\nexport class SigningError extends Error {\n public readonly requestId: string\n public readonly hash?: string\n public readonly originalError?: Error\n\n constructor(\n requestId: string,\n metadata?: { hash?: string },\n originalError?: Error\n ) {\n super(`Signing error for request ID: ${requestId}`)\n this.name = 'SigningError'\n this.requestId = requestId\n this.hash = metadata?.hash\n this.originalError = originalError\n }\n}\n\nexport class ResponseError extends Error {\n constructor(message: string) {\n super(message)\n this.name = 'ResponseError'\n }\n}\n","{\n \"address\": \"H5tHfpYoEnarrrzcV7sWBcZhiKMvL2aRpUYvb1ydWkwS\",\n \"metadata\": {\n \"name\": \"chain_signatures\",\n \"version\": \"0.4.0\",\n \"spec\": \"0.1.0\",\n \"description\": \"Chain signatures program for cross-chain signing on Solana\",\n \"repository\": \"https://github.com/sig-net/signet-solana-program\"\n },\n \"instructions\": [\n {\n \"name\": \"get_signature_deposit\",\n \"docs\": [\n \"* @dev Function to get the current signature deposit amount.\\n * @return The current signature deposit amount.\"\n ],\n \"discriminator\": [45, 243, 86, 86, 58, 57, 172, 253],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n }\n ],\n \"args\": [],\n \"returns\": \"u64\"\n },\n {\n \"name\": \"initialize\",\n \"docs\": [\n \"* @dev Function to initialize the program state.\\n * @param signature_deposit The deposit required for signature requests.\\n * @param chain_id The CAIP-2 chain identifier.\"\n ],\n \"discriminator\": [175, 175, 109, 31, 13, 152, 155, 237],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"admin\",\n \"writable\": true,\n \"signer\": true\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n }\n ],\n \"args\": [\n {\n \"name\": \"signature_deposit\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"chain_id\",\n \"type\": \"string\"\n }\n ]\n },\n {\n \"name\": \"respond\",\n \"docs\": [\n \"* @dev Function to respond to signature requests.\\n * @param request_ids The array of request IDs.\\n * @param signatures The array of signature responses.\\n * @notice When multiple entries reuse a request id, events emit in canonical signature order (PSBT-style).\"\n ],\n \"discriminator\": [72, 65, 227, 97, 42, 255, 147, 12],\n \"accounts\": [\n {\n \"name\": \"responder\",\n \"signer\": true\n },\n {\n \"name\": \"event_authority\",\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 95, 95, 101, 118, 101, 110, 116, 95, 97, 117, 116, 104, 111,\n 114, 105, 116, 121\n ]\n }\n ]\n }\n },\n {\n \"name\": \"program\"\n }\n ],\n \"args\": [\n {\n \"name\": \"request_ids\",\n \"type\": {\n \"vec\": {\n \"array\": [\"u8\", 32]\n }\n }\n },\n {\n \"name\": \"signatures\",\n \"type\": {\n \"vec\": {\n \"defined\": {\n \"name\": \"Signature\"\n }\n }\n }\n }\n ]\n },\n {\n \"name\": \"respond_bidirectional\",\n \"docs\": [\n \"* @dev Function to finalize bidirectional flow\\n * @param request_id The ID of the signature request to respond to\\n * @param serialized_output output of the previously executed transaction\\n * @param signature ECDSA signature of the serialized output and request_id (keccak256(request_id.concat(serialized_output)))\"\n ],\n \"discriminator\": [138, 0, 45, 246, 236, 211, 109, 81],\n \"accounts\": [\n {\n \"name\": \"responder\",\n \"signer\": true\n }\n ],\n \"args\": [\n {\n \"name\": \"request_id\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"serialized_output\",\n \"type\": \"bytes\"\n },\n {\n \"name\": \"signature\",\n \"type\": {\n \"defined\": {\n \"name\": \"Signature\"\n }\n }\n }\n ]\n },\n {\n \"name\": \"respond_error\",\n \"docs\": [\n \"* @dev Function to emit signature generation errors.\\n * @param errors The array of signature generation errors.\"\n ],\n \"discriminator\": [3, 170, 41, 132, 72, 184, 252, 69],\n \"accounts\": [\n {\n \"name\": \"responder\",\n \"signer\": true\n }\n ],\n \"args\": [\n {\n \"name\": \"errors\",\n \"type\": {\n \"vec\": {\n \"defined\": {\n \"name\": \"ErrorResponse\"\n }\n }\n }\n }\n ]\n },\n {\n \"name\": \"sign\",\n \"docs\": [\n \"* @dev Function to request a signature.\\n * @param payload The payload to be signed.\\n * @param key_version The version of the key used for signing.\\n * @param path The derivation path for the user account.\\n * @param algo The algorithm used for signing.\\n * @param dest The response destination.\\n * @param params Additional parameters.\"\n ],\n \"discriminator\": [5, 221, 155, 46, 237, 91, 28, 236],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"requester\",\n \"writable\": true,\n \"signer\": true\n },\n {\n \"name\": \"fee_payer\",\n \"writable\": true,\n \"signer\": true,\n \"optional\": true\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n },\n {\n \"name\": \"event_authority\",\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 95, 95, 101, 118, 101, 110, 116, 95, 97, 117, 116, 104, 111,\n 114, 105, 116, 121\n ]\n }\n ]\n }\n },\n {\n \"name\": \"program\"\n }\n ],\n \"args\": [\n {\n \"name\": \"payload\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"key_version\",\n \"type\": \"u32\"\n },\n {\n \"name\": \"path\",\n \"type\": \"string\"\n },\n {\n \"name\": \"algo\",\n \"type\": \"string\"\n },\n {\n \"name\": \"dest\",\n \"type\": \"string\"\n },\n {\n \"name\": \"params\",\n \"type\": \"string\"\n }\n ]\n },\n {\n \"name\": \"sign_bidirectional\",\n \"docs\": [\n \"* @dev Function to initiate bidirectional flow\\n * @param serialized_transaction transaction to be signed\\n * @param caip2_id chain identifier\\n * @param key_version The version of the key used for signing.\\n * @param path The derivation path for the user account.\\n * @param algo The algorithm used for signing.\\n * @param dest The response destination.\\n * @param params Additional parameters.\\n * @param program_id Program ID to callback after execution (not yet enabled).\\n * @param output_deserialization_schema schema for transaction output deserialization\\n * @param respond_serialization_schema serialization schema for respond_bidirectional payload\"\n ],\n \"discriminator\": [21, 104, 182, 213, 189, 143, 219, 48],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"requester\",\n \"writable\": true,\n \"signer\": true\n },\n {\n \"name\": \"fee_payer\",\n \"writable\": true,\n \"signer\": true,\n \"optional\": true\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n },\n {\n \"name\": \"instructions\",\n \"optional\": true\n },\n {\n \"name\": \"event_authority\",\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 95, 95, 101, 118, 101, 110, 116, 95, 97, 117, 116, 104, 111,\n 114, 105, 116, 121\n ]\n }\n ]\n }\n },\n {\n \"name\": \"program\"\n }\n ],\n \"args\": [\n {\n \"name\": \"serialized_transaction\",\n \"type\": \"bytes\"\n },\n {\n \"name\": \"caip2_id\",\n \"type\": \"string\"\n },\n {\n \"name\": \"key_version\",\n \"type\": \"u32\"\n },\n {\n \"name\": \"path\",\n \"type\": \"string\"\n },\n {\n \"name\": \"algo\",\n \"type\": \"string\"\n },\n {\n \"name\": \"dest\",\n \"type\": \"string\"\n },\n {\n \"name\": \"params\",\n \"type\": \"string\"\n },\n {\n \"name\": \"program_id\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"output_deserialization_schema\",\n \"type\": \"bytes\"\n },\n {\n \"name\": \"respond_serialization_schema\",\n \"type\": \"bytes\"\n }\n ]\n },\n {\n \"name\": \"update_deposit\",\n \"docs\": [\n \"* @dev Function to set the signature deposit amount.\\n * @param new_deposit The new deposit amount.\"\n ],\n \"discriminator\": [126, 116, 15, 164, 238, 179, 155, 59],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"admin\",\n \"writable\": true,\n \"signer\": true,\n \"relations\": [\"program_state\"]\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n }\n ],\n \"args\": [\n {\n \"name\": \"new_deposit\",\n \"type\": \"u64\"\n }\n ]\n },\n {\n \"name\": \"withdraw_funds\",\n \"docs\": [\n \"* @dev Function to withdraw funds from the program.\\n * @param amount The amount to withdraw.\"\n ],\n \"discriminator\": [241, 36, 29, 111, 208, 31, 104, 217],\n \"accounts\": [\n {\n \"name\": \"program_state\",\n \"writable\": true,\n \"pda\": {\n \"seeds\": [\n {\n \"kind\": \"const\",\n \"value\": [\n 112, 114, 111, 103, 114, 97, 109, 45, 115, 116, 97, 116, 101\n ]\n }\n ]\n }\n },\n {\n \"name\": \"admin\",\n \"writable\": true,\n \"signer\": true,\n \"relations\": [\"program_state\"]\n },\n {\n \"name\": \"recipient\",\n \"docs\": [\"function by checking it is not the zero address.\"],\n \"writable\": true\n },\n {\n \"name\": \"system_program\",\n \"address\": \"11111111111111111111111111111111\"\n }\n ],\n \"args\": [\n {\n \"name\": \"amount\",\n \"type\": \"u64\"\n }\n ]\n }\n ],\n \"accounts\": [\n {\n \"name\": \"ProgramState\",\n \"discriminator\": [77, 209, 137, 229, 149, 67, 167, 230]\n }\n ],\n \"events\": [\n {\n \"name\": \"DepositUpdatedEvent\",\n \"discriminator\": [215, 193, 53, 27, 221, 101, 249, 108]\n },\n {\n \"name\": \"FundsWithdrawnEvent\",\n \"discriminator\": [86, 232, 194, 4, 211, 69, 172, 202]\n },\n {\n \"name\": \"RespondBidirectionalEvent\",\n \"discriminator\": [195, 195, 28, 1, 102, 100, 189, 234]\n },\n {\n \"name\": \"SignBidirectionalEvent\",\n \"discriminator\": [135, 205, 217, 152, 96, 187, 11, 124]\n },\n {\n \"name\": \"SignatureErrorEvent\",\n \"discriminator\": [42, 28, 210, 105, 9, 196, 189, 51]\n },\n {\n \"name\": \"SignatureRequestedEvent\",\n \"discriminator\": [171, 129, 105, 91, 154, 49, 160, 34]\n },\n {\n \"name\": \"SignatureRespondedEvent\",\n \"discriminator\": [118, 146, 248, 151, 194, 93, 18, 86]\n }\n ],\n \"errors\": [\n {\n \"code\": 6000,\n \"name\": \"InsufficientDeposit\",\n \"msg\": \"Insufficient deposit amount\"\n },\n {\n \"code\": 6001,\n \"name\": \"InvalidInputLength\",\n \"msg\": \"Arrays must have the same length\"\n },\n {\n \"code\": 6002,\n \"name\": \"Unauthorized\",\n \"msg\": \"Unauthorized access\"\n },\n {\n \"code\": 6003,\n \"name\": \"InsufficientFunds\",\n \"msg\": \"Insufficient funds for withdrawal\"\n },\n {\n \"code\": 6004,\n \"name\": \"InvalidRecipient\",\n \"msg\": \"Invalid recipient address\"\n },\n {\n \"code\": 6005,\n \"name\": \"InvalidTransaction\",\n \"msg\": \"Invalid transaction data\"\n },\n {\n \"code\": 6006,\n \"name\": \"MissingInstructionSysvar\",\n \"msg\": \"Missing instruction sysvar\"\n }\n ],\n \"types\": [\n {\n \"name\": \"AffinePoint\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"x\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"y\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n }\n ]\n }\n },\n {\n \"name\": \"DepositUpdatedEvent\",\n \"docs\": [\n \"* @dev Emitted when the deposit amount is updated.\\n * @param old_deposit The previous deposit amount.\\n * @param new_deposit The new deposit amount.\"\n ],\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"old_deposit\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"new_deposit\",\n \"type\": \"u64\"\n }\n ]\n }\n },\n {\n \"name\": \"ErrorResponse\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"request_id\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"error_message\",\n \"type\": \"string\"\n }\n ]\n }\n },\n {\n \"name\": \"FundsWithdrawnEvent\",\n \"docs\": [\n \"* @dev Emitted when a withdrawal is made.\\n * @param amount The amount withdrawn.\\n * @param recipient The address of the recipient.\"\n ],\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"amount\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"recipient\",\n \"type\": \"pubkey\"\n }\n ]\n }\n },\n {\n \"name\": \"ProgramState\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"admin\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"signature_deposit\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"chain_id\",\n \"type\": \"string\"\n }\n ]\n }\n },\n {\n \"name\": \"RespondBidirectionalEvent\",\n \"docs\": [\n \"* @dev Emitted when a read response is received.\\n * @param request_id The ID of the request. Must be calculated off-chain.\\n * @param responder The address of the responder.\\n * @param serialized_output The serialized output.\\n * @param signature The signature.\"\n ],\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"request_id\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"responder\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"serialized_output\",\n \"type\": \"bytes\"\n },\n {\n \"name\": \"signature\",\n \"type\": {\n \"defined\": {\n \"name\": \"Signature\"\n }\n }\n }\n ]\n }\n },\n {\n \"name\": \"SignBidirectionalEvent\",\n \"docs\": [\n \"* @dev Emitted when a sign_bidirectional request is made.\\n * @param sender The address of the sender.\\n * @param serialized_transaction The serialized transaction to be signed.\\n * @param caip2_id The SLIP-44 chain ID.\\n * @param key_version The version of the key used for signing.\\n * @param deposit The deposit amount.\\n * @param path The derivation path for the user account.\\n * @param algo The algorithm used for signing.\\n * @param dest The response destination.\\n * @param params Additional parameters.\\n * @param program_id Program ID to callback after execution (not yet enabled).\\n * @param output_deserialization_schema Schema for transaction output deserialization.\\n * @param respond_serialization_schema Serialization schema for respond_bidirectional payload.\"\n ],\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"sender\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"serialized_transaction\",\n \"type\": \"bytes\"\n },\n {\n \"name\": \"caip2_id\",\n \"type\": \"string\"\n },\n {\n \"name\": \"key_version\",\n \"type\": \"u32\"\n },\n {\n \"name\": \"deposit\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"path\",\n \"type\": \"string\"\n },\n {\n \"name\": \"algo\",\n \"type\": \"string\"\n },\n {\n \"name\": \"dest\",\n \"type\": \"string\"\n },\n {\n \"name\": \"params\",\n \"type\": \"string\"\n },\n {\n \"name\": \"program_id\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"output_deserialization_schema\",\n \"type\": \"bytes\"\n },\n {\n \"name\": \"respond_serialization_schema\",\n \"type\": \"bytes\"\n }\n ]\n }\n },\n {\n \"name\": \"Signature\",\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"big_r\",\n \"type\": {\n \"defined\": {\n \"name\": \"AffinePoint\"\n }\n }\n },\n {\n \"name\": \"s\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"recovery_id\",\n \"type\": \"u8\"\n }\n ]\n }\n },\n {\n \"name\": \"SignatureErrorEvent\",\n \"docs\": [\n \"* @dev Emitted when a signature error is received.\\n * @notice Any address can emit this event. Do not rely on it for business logic.\\n * @param request_id The ID of the request. Must be calculated off-chain.\\n * @param responder The address of the responder.\\n * @param error The error message.\"\n ],\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"request_id\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"responder\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"error\",\n \"type\": \"string\"\n }\n ]\n }\n },\n {\n \"name\": \"SignatureRequestedEvent\",\n \"docs\": [\n \"* @dev Emitted when a signature is requested.\\n * @param sender The address of the sender.\\n * @param payload The payload to be signed.\\n * @param key_version The version of the key used for signing.\\n * @param deposit The deposit amount.\\n * @param chain_id The CAIP-2 ID of the blockchain.\\n * @param path The derivation path for the user account.\\n * @param algo The algorithm used for signing.\\n * @param dest The response destination.\\n * @param params Additional parameters.\\n * @param fee_payer Optional fee payer account.\"\n ],\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"sender\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"payload\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"key_version\",\n \"type\": \"u32\"\n },\n {\n \"name\": \"deposit\",\n \"type\": \"u64\"\n },\n {\n \"name\": \"chain_id\",\n \"type\": \"string\"\n },\n {\n \"name\": \"path\",\n \"type\": \"string\"\n },\n {\n \"name\": \"algo\",\n \"type\": \"string\"\n },\n {\n \"name\": \"dest\",\n \"type\": \"string\"\n },\n {\n \"name\": \"params\",\n \"type\": \"string\"\n },\n {\n \"name\": \"fee_payer\",\n \"type\": {\n \"option\": \"pubkey\"\n }\n }\n ]\n }\n },\n {\n \"name\": \"SignatureRespondedEvent\",\n \"docs\": [\n \"* @dev Emitted when a signature response is received.\\n * @notice Any address can emit this event. Clients should always verify the validity of the signature.\\n * @param request_id The ID of the request. Must be calculated off-chain.\\n * @param responder The address of the responder.\\n * @param signature The signature response.\"\n ],\n \"type\": {\n \"kind\": \"struct\",\n \"fields\": [\n {\n \"name\": \"request_id\",\n \"type\": {\n \"array\": [\"u8\", 32]\n }\n },\n {\n \"name\": \"responder\",\n \"type\": \"pubkey\"\n },\n {\n \"name\": \"signature\",\n \"type\": {\n \"defined\": {\n \"name\": \"Signature\"\n }\n }\n }\n ]\n }\n }\n ]\n}\n","import * as anchor from '@coral-xyz/anchor'\nimport { type Connection } from '@solana/web3.js'\n\nimport type { ChainSignaturesEvent } from './types/events'\n\n// Anchor's emit_cpi! instruction discriminator: Sha256(\"anchor:event\")[..8]\nconst EMIT_CPI_INSTRUCTION_DISCRIMINATOR = Buffer.from([\n 0xe4, 0x45, 0xa5, 0x2e, 0x51, 0xcb, 0x9a, 0x1d,\n])\n\n// eslint-disable-next-line @typescript-eslint/no-extraneous-class\nexport class CpiEventParser {\n /**\n * Parse CPI events from a transaction (emit_cpi! pattern)\n */\n static async parseCpiEvents<T extends anchor.Idl>(\n connection: Connection,\n signature: string,\n targetProgramId: string,\n program: anchor.Program<T>\n ): Promise<ChainSignaturesEvent[]> {\n const events: ChainSignaturesEvent[] = []\n\n try {\n const tx = await connection.getParsedTransaction(signature, {\n commitment: 'confirmed',\n maxSupportedTransactionVersion: 0,\n })\n\n if (!tx?.meta?.innerInstructions) return events\n\n for (const innerIxSet of tx.meta.innerInstructions) {\n for (const instruction of innerIxSet.instructions) {\n if (!('programId' in instruction) || !('data' in instruction)) {\n continue\n }\n\n if (instruction.programId.toString() !== targetProgramId) {\n continue\n }\n\n const parsedEvent = this.parseInstruction(instruction.data, program)\n if (parsedEvent) {\n events.push(parsedEvent)\n }\n }\n }\n } catch {}\n\n return events\n }\n\n /**\n * Parse CPI event from instruction data\n * Structure: [8 bytes: anchor discriminator][8 bytes: event discriminator][event data]\n */\n private static parseInstruction<T extends anchor.Idl>(\n instructionData: string,\n program: anchor.Program<T>\n ): ChainSignaturesEvent | null {\n try {\n const ixData = anchor.utils.bytes.bs58.decode(instructionData)\n\n if (ixData.length < 16) {\n return null\n }\n\n const ixDiscriminator = ixData.subarray(0, 8)\n if (\n Buffer.compare(ixDiscriminator, EMIT_CPI_INSTRUCTION_DISCRIMINATOR) !==\n 0\n ) {\n return null\n }\n\n const eventDiscriminator = ixData.subarray(8, 16)\n\n const matchedEvent = program.idl.events?.find((event) => {\n const idlDiscriminator = Buffer.from(event.discriminator)\n return Buffer.compare(eventDiscriminator, idlDiscriminator) === 0\n })\n\n if (!matchedEvent) {\n return null\n }\n\n const fullEventData = ixData.subarray(8)\n\n const decodedEvent = program.coder.events.decode(\n anchor.utils.bytes.base64.encode(fullEventData)\n )\n\n return decodedEvent as ChainSignaturesEvent | null\n } catch {\n return null\n }\n }\n\n /**\n * Subscribe to CPI events for a program\n */\n static subscribeToCpiEvents<T extends anchor.Idl>(\n connection: Connection,\n program: anchor.Program<T>,\n eventHandlers: Map<\n ChainSignaturesEvent['name'],\n (event: ChainSignaturesEvent['data'], slot: number) => Promise<void>\n >\n ): number {\n return connection.onLogs(\n program.programId,\n (logs, context) => {\n if (logs.err) return\n\n void (async () => {\n const events = await this.parseCpiEvents(\n connection,\n logs.signature,\n program.programId.toString(),\n program\n )\n\n for (const event of events) {\n const handler = eventHandlers.get(event.name)\n if (handler) {\n try {\n await handler(event.data, context.slot)\n } catch {}\n }\n }\n })()\n },\n 'confirmed'\n )\n }\n}\n","import { encodeAbiParameters, parseAbiParameters, keccak256 } from 'viem'\n\nexport function generateRequestIdSolana({\n address,\n payload,\n path,\n keyVersion,\n chainId,\n algo,\n dest,\n params,\n}: {\n address: string\n payload: Uint8Array | number[]\n path: string\n keyVersion: number\n chainId: string\n algo: string\n dest: string\n params: string\n}): string {\n const payloadHex: `0x${string}` = ('0x' +\n Buffer.from(payload as any).toString('hex')) as `0x${string}`\n\n const encoded = encodeAbiParameters(\n parseAbiParameters(\n 'string, bytes, string, uint32, string, string, string, string'\n ),\n [address, payloadHex, path, keyVersion, chainId, algo, dest, params]\n )\n\n return keccak256(encoded)\n}\n","import {\n type AnchorProvider,\n Program,\n EventParser,\n type Idl,\n} from '@coral-xyz/anchor'\nimport {\n type AccountMeta,\n PublicKey,\n type Signer,\n Transaction,\n type TransactionInstruction,\n TransactionExpiredTimeoutError,\n type Connection,\n} from '@solana/web3.js'\nimport {\n najToUncompressedPubKeySEC1,\n verifyRecoveredAddress,\n} from '@utils/cryptography'\nimport { getRootPublicKey } from '@utils/publicKey'\nimport BN from 'bn.js'\n\nimport { CHAINS, KDF_CHAIN_IDS } from '@constants'\nimport { ChainSignatureContract as AbstractChainSignatureContract } from '@contracts/ChainSignatureContract'\nimport type { SignArgs } from '@contracts/ChainSignatureContract'\nimport type { NajPublicKey, RSVSignature, UncompressedPubKeySEC1 } from '@types'\nimport { cryptography } from '@utils'\n\nimport type {\n RetryOptions,\n SignOptions,\n SignatureErrorData,\n} from '../evm/types'\n\nimport { CpiEventParser } from './CpiEventParser'\nimport {\n SignatureNotFoundError,\n SignatureContractError,\n SigningError,\n} from './errors'\nimport { type ChainSignaturesProject } from './types/chain_signatures_project'\nimport IDL from './types/chain_signatures_project.json'\nimport type {\n SignatureErrorEvent,\n SignatureRespondedEvent,\n ChainSignaturesEventName,\n} from './types/events'\nimport { generateRequestIdSolana } from './utils'\n\nexport class ChainSignatureContract extends AbstractChainSignatureContract {\n private readonly provider: AnchorProvider\n private readonly program: Program<ChainSignaturesProject>\n private readonly programId: PublicKey\n private readonly rootPublicKey: NajPublicKey\n private readonly requesterAddress: string\n\n /**\n * Creates a new instance of the ChainSignatureContract for Solana chains.\n *\n * @param args - Configuration options for the contract\n * @param args.provider - An Anchor Provider for interacting with Solana\n * @param args.programId - The program ID as a string or PublicKey\n * @param args.config - Optional configuration\n * @param args.config.rootPublicKey - Optional root public key. If not provided, it will be derived from the program ID\n * @param args.config.requesterAddress - Provider wallet address is always the fee payer but requester can be overridden\n * @param args.config.idl - Optional custom IDL. If not provided, the default ChainSignatures IDL will be used\n */\n constructor(args: {\n provider: AnchorProvider\n programId: string | PublicKey\n config?: {\n rootPublicKey?: NajPublicKey\n requesterAddress?: string\n idl?: ChainSignaturesProject & Idl\n }\n }) {\n super()\n this.provider = args.provider\n this.requesterAddress =\n args.config?.requesterAddress ?? this.provider.wallet.publicKey.toString()\n\n this.programId =\n typeof args.programId === 'string'\n ? new PublicKey(args.programId)\n : args.programId\n\n const idl = args.config?.idl || (IDL as ChainSignaturesProject & Idl)\n this.program = new Program<ChainSignaturesProject>(\n { ...idl, address: this.programId.toString() },\n this.provider\n )\n\n const rootPublicKey =\n args.config?.rootPublicKey ||\n getRootPublicKey(this.programId.toString(), CHAINS.SOLANA)\n\n if (!rootPublicKey) {\n throw new Error(\n `Invalid public key, please provide a valid root public key or program ID`\n )\n }\n\n this.rootPublicKey = rootPublicKey\n }\n\n /**\n * Gets the connection from the provider\n */\n get connection(): Connection {\n return this.provider.connection\n }\n\n async getCurrentSignatureDeposit(): Promise<BN> {\n try {\n const programStatePDA = await this.getProgramStatePDA()\n\n const programState =\n await this.program.account.programState.fetch(programStatePDA)\n\n return new BN(programState.signatureDeposit.toString())\n } catch (error) {\n throw new Error(\n `Failed to get signature deposit: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n }\n }\n\n /**\n * Get the Program State PDA\n */\n async getProgramStatePDA(): Promise<PublicKey> {\n const [pda] = PublicKey.findProgramAddressSync(\n [Buffer.from('program-state')],\n this.programId\n )\n return pda\n }\n\n async getDerivedPublicKey(args: {\n path: string\n predecessor: string\n keyVersion: number\n }): Promise<UncompressedPubKeySEC1> {\n const pubKey = cryptography.deriveChildPublicKey(\n await this.getPublicKey(),\n args.predecessor,\n args.path,\n KDF_CHAIN_IDS.SOLANA,\n args.keyVersion\n )\n\n return pubKey\n }\n\n async getPublicKey(): Promise<UncompressedPubKeySEC1> {\n return najToUncompressedPubKeySEC1(this.rootPublicKey)\n }\n\n async getSignRequestInstruction(\n args: SignArgs,\n options?: Pick<SignOptions, 'sign'> & {\n remainingAccounts?: AccountMeta[]\n }\n ): Promise<TransactionInstruction> {\n const fixedRemainingAccounts: AccountMeta[] = [\n {\n pubkey: PublicKey.findProgramAddressSync(\n [Buffer.from('__event_authority')],\n this.program.programId\n )[0],\n isWritable: false,\n isSigner: false,\n },\n {\n pubkey: this.program.programId,\n isWritable: false,\n isSigner: false,\n },\n ]\n\n return await this.program.methods\n .sign(\n Array.from(args.payload),\n args.key_version,\n args.path,\n options?.sign?.algo || '',\n options?.sign?.dest || '',\n options?.sign?.params || ''\n )\n .accounts({\n requester: this.requesterAddress,\n feePayer: this.provider.wallet.publicKey,\n program: this.programId,\n })\n .remainingAccounts([\n ...fixedRemainingAccounts,\n ...(options?.remainingAccounts ?? []),\n ])\n .instruction()\n }\n\n /**\n * Sends a transaction to the program to request a signature, then\n * polls for the signature result. If the signature is not found within the retry\n * parameters, it will throw an error.\n */\n async sign(\n args: SignArgs,\n options?: Partial<SignOptions> & {\n remainingAccounts?: AccountMeta[]\n remainingSigners?: Signer[]\n }\n ): Promise<RSVSignature> {\n const algo = options?.sign?.algo ?? ''\n const dest = options?.sign?.dest ?? ''\n const params = options?.sign?.params ?? ''\n const delay = options?.retry?.delay ?? 5000\n const retryCount = options?.retry?.retryCount ?? 12\n\n const missingSigners = options?.remainingAccounts\n ?.filter((acc) => acc.isSigner)\n ?.some(\n (acc) =>\n !options?.remainingSigners?.some((signer) =>\n signer.publicKey.equals(acc.pubkey)\n )\n )\n\n if (missingSigners) {\n throw new Error(\n 'All accounts marked as signers must have a corresponding signer'\n )\n }\n\n const requestId = this.getRequestId(args, {\n algo,\n dest,\n params,\n })\n\n const instruction = await this.getSignRequestInstruction(args, {\n sign: {\n algo,\n dest,\n params,\n },\n remainingAccounts: options?.remainingAccounts,\n })\n const transaction = new Transaction().add(instruction)\n transaction.feePayer = this.provider.wallet.publicKey\n const hash = await this.sendAndConfirmWithoutWebSocket(\n transaction,\n options?.remainingSigners\n )\n\n try {\n const pollResult = await this.pollForRequestId({\n requestId,\n payload: args.payload,\n path: args.path,\n afterSignature: hash,\n options: {\n delay,\n retryCount,\n },\n })\n\n if (!pollResult) {\n throw new SignatureNotFoundError(requestId, { hash })\n }\n\n if ('error' in pollResult) {\n throw new SignatureContractError(pollResult.error, requestId, { hash })\n }\n\n const isValid = await verifyRecoveredAddress(\n pollResult,\n args.payload,\n this.requesterAddress,\n args.path,\n this,\n args.key_version\n )\n\n if (!isValid) {\n throw new SigningError(\n requestId,\n { hash },\n new Error(\n 'Signature verification failed: recovered address does not match expected address'\n )\n )\n }\n\n return pollResult\n } catch (error) {\n if (\n error instanceof SignatureNotFoundError ||\n error instanceof SignatureContractError\n ) {\n throw error\n } else {\n throw new SigningError(\n requestId,\n { hash },\n error instanceof Error ? error : undefined\n )\n }\n }\n }\n\n private async sendAndConfirmWithoutWebSocket(\n transaction: Transaction,\n signers?: Signer[]\n ): Promise<string> {\n const { blockhash } =\n await this.provider.connection.getLatestBlockhash('confirmed')\n transaction.recentBlockhash = blockhash\n\n transaction = await this.provider.wallet.signTransaction(transaction)\n\n if (signers && signers.length > 0) {\n transaction.partialSign(...signers)\n }\n\n const signature = await this.provider.connection.sendRawTransaction(\n transaction.serialize(),\n {\n skipPreflight: false,\n preflightCommitment: 'processed',\n maxRetries: 3,\n }\n )\n\n const startTime = Date.now()\n const timeout = 30000 // 30 seconds, same as default sendAndConfirm\n\n while (Date.now() - startTime < timeout) {\n const status =\n await this.provider.connection.getSignatureStatus(signature)\n\n if (status.value?.err) {\n throw new Error(\n `Transaction failed: ${JSON.stringify(status.value.err)}`\n )\n }\n\n if (\n status.value?.confirmationStatus === 'confirmed' ||\n status.value?.confirmationStatus === 'finalized'\n ) {\n return signature\n }\n\n await new Promise((resolve) => setTimeout(resolve, 2000))\n }\n\n throw new TransactionExpiredTimeoutError(signature, timeout / 1000)\n }\n\n /**\n * Polls for signature or error events matching the given requestId starting from the solana transaction with signature afterSignature.\n * Returns a signature, error data, or undefined if nothing is found.\n */\n async pollForRequestId({\n requestId,\n payload: _payload,\n path: _path,\n afterSignature,\n options,\n }: {\n requestId: string\n payload: number[]\n path: string\n afterSignature: string\n options?: RetryOptions\n }): Promise<RSVSignature | SignatureErrorData | undefined> {\n const delay = options?.delay ?? 5000\n const retryCount = options?.retryCount ?? 12\n\n let lastCheckedSignature = afterSignature\n\n for (let i = 0; i < retryCount; i++) {\n try {\n // Get all transactions since last check\n const signatures = await this.connection.getSignaturesForAddress(\n this.programId,\n {\n until: lastCheckedSignature,\n limit: 50,\n },\n 'confirmed'\n )\n\n if (signatures.length > 0) {\n lastCheckedSignature = signatures[signatures.length - 1].signature\n }\n\n for (const sig of signatures) {\n const tx = await this.connection.getParsedTransaction(sig.signature, {\n commitment: 'confirmed',\n maxSupportedTransactionVersion: 0,\n })\n\n if (tx?.meta?.logMessages) {\n const result = await this.parseLogsForEvents(\n tx.meta.logMessages,\n requestId,\n sig.signature\n )\n\n if (result) {\n return result\n }\n }\n }\n } catch (error) {\n console.error('Error checking for events:', error)\n }\n\n if (i < retryCount - 1) {\n console.log(`Retrying get signature: ${i + 1}/${retryCount}`)\n await new Promise((resolve) => setTimeout(resolve, delay))\n }\n }\n\n return undefined\n }\n\n /**\n * Parses transaction logs for signature or error events.\n */\n private async parseLogsForEvents(\n logs: string[],\n requestId: string,\n signature: string\n ): Promise<RSVSignature | SignatureErrorData | undefined> {\n const cpiEvents = await CpiEventParser.parseCpiEvents(\n this.connection,\n signature,\n this.programId.toString(),\n this.program\n )\n for (const event of cpiEvents) {\n const mapped = this.mapEventToResult(\n event.name,\n event.name === 'signatureRespondedEvent' ? event.data : event.data,\n requestId\n )\n if (mapped) return mapped\n }\n\n // 2) Parse regular Anchor events from logs (emit!)\n const parser = new EventParser(this.program.programId, this.program.coder)\n for (const evt of parser.parseLogs(logs)) {\n if (!evt) continue\n const mapped = this.mapEventToResult(\n evt.name as ChainSignaturesEventName,\n evt.name === 'signatureRespondedEvent'\n ? (evt.data as SignatureRespondedEvent)\n : (evt.data as SignatureErrorEvent),\n requestId\n )\n if (mapped) return mapped\n }\n\n return undefined\n }\n\n private mapEventToResult(\n name: ChainSignaturesEventName,\n data: SignatureRespondedEvent | SignatureErrorEvent,\n requestId: string\n ): RSVSignature | SignatureErrorData | undefined {\n const eventRequestIdHex = '0x' + Buffer.from(data.requestId).toString('hex')\n if (name === 'signatureRespondedEvent' && eventRequestIdHex === requestId) {\n const d = data as SignatureRespondedEvent\n return {\n r: Buffer.from(d.signature.bigR.x).toString('hex'),\n s: Buffer.from(d.signature.s).toString('hex'),\n v: d.signature.recoveryId + 27,\n }\n }\n if (name === 'signatureErrorEvent' && eventRequestIdHex === requestId) {\n const d = data as SignatureErrorEvent\n return {\n requestId: eventRequestIdHex,\n error: d.error,\n }\n }\n return undefined\n }\n\n /**\n * Generates the request ID for a signature request allowing to track the response.\n */\n getRequestId(\n args: SignArgs,\n options: SignOptions['sign'] = {\n algo: '',\n dest: '',\n params: '',\n }\n ): string {\n return generateRequestIdSolana({\n payload: args.payload,\n path: args.path,\n keyVersion: args.key_version,\n algo: options.algo || '',\n dest: options.dest || '',\n params: options.params || '',\n address: this.requesterAddress,\n chainId: KDF_CHAIN_IDS.SOLANA,\n })\n }\n\n /**\n * Subscribes to program events using Anchor's EventParser for regular events,\n * and CPI parsing for emit_cpi!-emitted events. Returns an unsubscribe fn.\n */\n async subscribeToEvents(handlers: {\n onSignatureResponded?: (\n event: SignatureRespondedEvent,\n slot: number\n ) => Promise<void> | void\n onSignatureError?: (\n event: SignatureErrorEvent,\n slot: number\n ) => Promise<void> | void\n }): Promise<() => Promise<void>> {\n const commitment: 'processed' | 'confirmed' | 'finalized' = 'confirmed'\n // Subscribe to CPI events (emit_cpi!)\n const cpiHandlers = new Map<\n ChainSignaturesEventName,\n (\n event: SignatureRespondedEvent | SignatureErrorEvent,\n slot: number\n ) => Promise<void>\n >()\n if (handlers.onSignatureResponded) {\n const onSignatureResponded = handlers.onSignatureResponded\n cpiHandlers.set('signatureRespondedEvent', async (e, s) => {\n await onSignatureResponded(e as SignatureRespondedEvent, s)\n })\n }\n if (handlers.onSignatureError) {\n const onSignatureError = handlers.onSignatureError\n cpiHandlers.set('signatureErrorEvent', async (e, s) => {\n await onSignatureError(e as SignatureErrorEvent, s)\n })\n }\n const cpiSubId = CpiEventParser.subscribeToCpiEvents(\n this.connection,\n this.program,\n cpiHandlers\n )\n\n const parser = new EventParser(this.program.programId, this.program.coder)\n const subId = this.connection.onLogs(\n this.program.programId,\n (logs, context) => {\n if (logs.err) return\n for (const evt of parser.parseLogs(logs.logs)) {\n if (!evt) continue\n if (evt.name === 'signatureRespondedEvent') {\n const onSignatureResponded = handlers.onSignatureResponded\n if (onSignatureResponded) {\n void onSignatureResponded(\n evt.data as SignatureRespondedEvent,\n context.slot\n )\n }\n }\n if (evt.name === 'signatureErrorEvent') {\n const onSignatureError = handlers.onSignatureError\n if (onSignatureError) {\n void onSignatureError(\n evt.data as SignatureErrorEvent,\n context.slot\n )\n }\n }\n }\n },\n commitment\n )\n\n return async () => {\n await this.connection.removeOnLogsListener(subId)\n await this.connection.removeOnLogsListener(cpiSubId)\n }\n }\n}\n"]}