signet.js 0.0.3 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/README.md +1 -1
  2. package/browser/index.browser.cjs +3 -0
  3. package/browser/index.browser.cjs.map +1 -0
  4. package/browser/index.browser.js +3 -0
  5. package/browser/index.browser.js.map +1 -0
  6. package/node/index.node.cjs +3 -0
  7. package/node/index.node.cjs.map +1 -0
  8. package/node/index.node.js +3 -0
  9. package/node/index.node.js.map +1 -0
  10. package/package.json +2 -2
  11. package/types/index.d.cts +919 -0
  12. package/types/index.d.ts +919 -0
  13. package/.eslintrc.json +0 -55
  14. package/.prettierrc +0 -1
  15. package/babel.config.js +0 -6
  16. package/docs/pages/index.mdx +0 -36
  17. package/docs/pages/signetjs/advanced/chain-signatures-contract.mdx +0 -52
  18. package/docs/pages/signetjs/advanced/chain.mdx +0 -45
  19. package/docs/pages/signetjs/chains/bitcoin/bitcoin.mdx +0 -171
  20. package/docs/pages/signetjs/chains/bitcoin/btc-rpc-adapter.mdx +0 -26
  21. package/docs/pages/signetjs/chains/cosmos.mdx +0 -171
  22. package/docs/pages/signetjs/chains/evm.mdx +0 -319
  23. package/docs/pages/signetjs/contract-addresses.mdx +0 -27
  24. package/docs/pages/signetjs/index.mdx +0 -88
  25. package/docs/snippets/code/contract.ts +0 -21
  26. package/docs/snippets/code/evm/env.ts +0 -16
  27. package/docs/snippets/code/near/env.ts +0 -13
  28. package/hardhat.config.mts +0 -19
  29. package/src/chains/Bitcoin/BTCRpcAdapter/BTCRpcAdapter.ts +0 -11
  30. package/src/chains/Bitcoin/BTCRpcAdapter/Mempool/Mempool.ts +0 -96
  31. package/src/chains/Bitcoin/BTCRpcAdapter/Mempool/index.ts +0 -1
  32. package/src/chains/Bitcoin/BTCRpcAdapter/Mempool/types.ts +0 -72
  33. package/src/chains/Bitcoin/BTCRpcAdapter/index.ts +0 -6
  34. package/src/chains/Bitcoin/Bitcoin.ts +0 -287
  35. package/src/chains/Bitcoin/types.ts +0 -48
  36. package/src/chains/Bitcoin/utils.ts +0 -14
  37. package/src/chains/Chain.ts +0 -92
  38. package/src/chains/ChainSignatureContract.ts +0 -65
  39. package/src/chains/Cosmos/Cosmos.ts +0 -258
  40. package/src/chains/Cosmos/types.ts +0 -35
  41. package/src/chains/Cosmos/utils.ts +0 -45
  42. package/src/chains/EVM/EVM.test.ts +0 -238
  43. package/src/chains/EVM/EVM.ts +0 -334
  44. package/src/chains/EVM/types.ts +0 -53
  45. package/src/chains/EVM/utils.ts +0 -27
  46. package/src/chains/index.ts +0 -38
  47. package/src/chains/types.ts +0 -46
  48. package/src/index.ts +0 -2
  49. package/src/utils/chains/evm/ChainSignaturesContract.ts +0 -286
  50. package/src/utils/chains/evm/ChainSignaturesContractABI.ts +0 -359
  51. package/src/utils/chains/evm/errors.ts +0 -52
  52. package/src/utils/chains/evm/index.ts +0 -3
  53. package/src/utils/chains/evm/types.ts +0 -28
  54. package/src/utils/chains/evm/utils.ts +0 -11
  55. package/src/utils/chains/index.ts +0 -2
  56. package/src/utils/chains/near/ChainSignatureContract.ts +0 -155
  57. package/src/utils/chains/near/account.ts +0 -42
  58. package/src/utils/chains/near/constants.ts +0 -4
  59. package/src/utils/chains/near/index.ts +0 -3
  60. package/src/utils/chains/near/signAndSend/index.ts +0 -1
  61. package/src/utils/chains/near/signAndSend/keypair.ts +0 -178
  62. package/src/utils/chains/near/transactionBuilder.ts +0 -73
  63. package/src/utils/chains/near/types.ts +0 -77
  64. package/src/utils/constants.ts +0 -62
  65. package/src/utils/cryptography.ts +0 -131
  66. package/src/utils/index.ts +0 -3
  67. package/src/utils/publicKey.ts +0 -23
  68. package/tsconfig.eslint.json +0 -8
  69. package/tsconfig.json +0 -122
  70. package/tsup.config.ts +0 -55
  71. package/vitest.config.ts +0 -16
  72. package/vocs.config.ts +0 -73
package/README.md CHANGED
@@ -80,7 +80,7 @@ const signature = await contract.sign({
80
80
  })
81
81
 
82
82
  // Add signature
83
- const signedTx = evmChain.attachTransactionSignature({
83
+ const signedTx = evmChain.finalizeTransactionSigning({
84
84
  transaction,
85
85
  rsvSignatures: [signature],
86
86
  })
@@ -0,0 +1,3 @@
1
+ 'use strict';var xt=require('bn.js'),providers=require('near-api-js/lib/providers'),accounts=require('@near-js/accounts'),crypto=require('@near-js/crypto'),keystores=require('@near-js/keystores'),base=require('@scure/base'),elliptic=require('elliptic'),viem=require('viem'),h=require('bitcoinjs-lib'),qt=require('coinselect'),amino=require('@cosmjs/amino'),crypto$1=require('@cosmjs/crypto'),encoding=require('@cosmjs/encoding'),protoSigning=require('@cosmjs/proto-signing'),stargate=require('@cosmjs/stargate'),bech32=require('bech32'),signing=require('cosmjs-types/cosmos/tx/signing/v1beta1/signing'),tx=require('cosmjs-types/cosmos/tx/v1beta1/tx'),chainRegistry=require('chain-registry');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var xt__default=/*#__PURE__*/_interopDefault(xt);var h__namespace=/*#__PURE__*/_interopNamespace(h);var qt__default=/*#__PURE__*/_interopDefault(qt);var wt=Object.defineProperty;var m=(r,t)=>{for(var e in t)wt(r,e,{get:t[e],enumerable:true});};var bt={};m(bt,{chains:()=>st,constants:()=>nt,cryptography:()=>u});var st={};m(st,{evm:()=>it,near:()=>Q});var Q={};m(Q,{ChainSignatureContract:()=>l,signAndSend:()=>J,transactionBuilder:()=>G});var G={};m(G,{mpcPayloadsToChainSigTransaction:()=>Ft,responseToMpcSignature:()=>Ot});var j=class{},b=class extends j{};var D=new xt__default.default("300000000000000"),A="dontcare";var w=async({networkId:r,accountId:t=A,keypair:e=crypto.KeyPair.fromRandom("ed25519")})=>{let n=new keystores.InMemoryKeyStore;await n.setKey(r,t,e);let a=accounts.Connection.fromConfig({networkId:r,provider:{type:"JsonRpcProvider",args:{url:{testnet:"https://rpc.testnet.near.org",mainnet:"https://rpc.mainnet.near.org"}[r]}},signer:{type:"InMemorySigner",keyStore:n}});return new accounts.Account(a,t)};var u={};m(u,{compressPubKey:()=>Kt,deriveChildPublicKey:()=>Nt,najToUncompressedPubKeySEC1:()=>x,toRSV:()=>kt});var kt=r=>{if("big_r"in r&&typeof r.big_r=="object"&&"affine_point"in r.big_r&&"s"in r&&typeof r.s=="object"&&"scalar"in r.s)return {r:r.big_r.affine_point.substring(2),s:r.s.scalar,v:r.recovery_id+27};if("big_r"in r&&typeof r.big_r=="string"&&"s"in r&&typeof r.s=="string")return {r:r.big_r.substring(2),s:r.s,v:r.recovery_id+27};if("bigR"in r&&"x"in r.bigR&&"s"in r&&typeof r.s=="bigint")return {r:r.bigR.x.toString(16).padStart(64,"0"),s:r.s.toString(16).padStart(64,"0"),v:r.recoveryId+27};throw new Error("Invalid signature format")},Kt=r=>{let t=r.slice(2);if(t.length!==128)throw new Error("Invalid uncompressed public key length");let e=t.slice(0,64),n=t.slice(64);return (parseInt(n.slice(-1),16)%2===0?"02":"03")+e},x=r=>{let t=base.base58.decode(r.split(":")[1]);return `04${Buffer.from(t).toString("hex")}`};function Nt(r,t,e="",n){let a=new elliptic.ec("secp256k1"),s=`sig.network v1.0.0 epsilon derivation,${n},${t},${e}`,o=viem.keccak256(Buffer.from(s)).slice(2),c=r.substring(2,66),p=r.substring(66),y=a.curve.point(c,p),d=a.g.mul(o),V=y.add(d),M=V.getX().toString("hex").padStart(64,"0"),z=V.getY().toString("hex").padStart(64,"0");return `04${M}${z}`}var Mt=r=>{if(r===A)throw new Error("A valid account ID and keypair are required for change methods. Please instantiate a new contract with valid credentials.")},l=class extends b{constructor({networkId:t,contractId:e,accountId:n=A,keypair:a=crypto.KeyPair.fromRandom("ed25519")}){super(),this.networkId=t,this.contractId=e,this.accountId=n,this.keypair=a;}async getContract(){let t=await w({networkId:this.networkId,accountId:this.accountId,keypair:this.keypair});return new accounts.Contract(t,this.contractId,{viewMethods:["public_key","experimental_signature_deposit","derived_public_key"],changeMethods:["sign"],useLocalViewExecution:false})}async getCurrentSignatureDeposit(){let t=await this.getContract();return new xt__default.default((await t.experimental_signature_deposit()).toLocaleString("fullwide",{useGrouping:false}))}async getDerivedPublicKey(t){let n=await(await this.getContract()).derived_public_key(t);return x(n)}async getPublicKey(){let e=await(await this.getContract()).public_key();return x(e)}async sign(t){Mt(this.accountId);let e=await this.getContract(),n=await this.getCurrentSignatureDeposit(),a=await e.sign({args:{request:t},gas:D,amount:n});return u.toRSV(a)}};var Ft=async({networkId:r,contractId:t,hashesToSign:e,path:n})=>{let i=await new l({networkId:r,contractId:t}).getCurrentSignatureDeposit();return {receiverId:t,actions:e.map(s=>({type:"FunctionCall",params:{methodName:"sign",args:{request:{payload:Array.from(s),path:n,key_version:0}},gas:D.div(new xt__default.default(e.length)).toString(),deposit:i?.toString()||"1"}}))}},Ot=({response:r})=>{let t=providers.getTransactionLastResult(r);if(t)return u.toRSV(t)};var J={};m(J,{keypair:()=>Y});var Y={};m(Y,{BTCTransaction:()=>ue,CosmosTransaction:()=>de,EVMTransaction:()=>pe});var f=class{};async function L(r,t){let[e,n]=await Promise.all([r.estimateGas(t),r.estimateFeesPerGas()]),a=n.maxFeePerGas??BigInt(1e10),i=n.maxPriorityFeePerGas??BigInt(1e10);return {gas:e,maxFeePerGas:a,maxPriorityFeePerGas:i}}var B=class extends f{constructor({rpcUrl:t,contract:e}){super(),this.contract=e,this.client=viem.createPublicClient({transport:viem.http(t)});}async attachGasAndNonce(t){let e=await L(this.client,t),n=await this.client.getTransactionCount({address:t.from}),{from:a,...i}=t;return {...e,nonce:n,chainId:Number(await this.client.getChainId()),type:"eip1559",...i}}transformRSVSignature(t){return {r:`0x${t.r}`,s:`0x${t.s}`,yParity:t.v-27}}assembleSignature(t){let{r:e,s:n,yParity:a}=this.transformRSVSignature(t);if(a===void 0)throw new Error("Missing yParity");return viem.concatHex([e,n,viem.numberToHex(a+27,{size:1})])}async deriveAddressAndPublicKey(t,e){let n=await this.contract.getDerivedPublicKey({path:e,predecessor:t});if(!n)throw new Error("Failed to get derived public key");let a=n.startsWith("04")?n.slice(2):n,i=viem.keccak256(Buffer.from(a,"hex"));return {address:viem.getAddress(`0x${i.slice(-40)}`),publicKey:n}}async getBalance(t){return {balance:await this.client.getBalance({address:t}),decimals:18}}serializeTransaction(t){return viem.serializeTransaction(t)}deserializeTransaction(t){return viem.parseTransaction(t)}async prepareTransactionForSigning(t){let e=await this.attachGasAndNonce(t),n=viem.serializeTransaction(e),a=viem.toBytes(viem.keccak256(n));return {transaction:e,hashesToSign:[Array.from(a)]}}async prepareMessageForSigning(t){return {hashToSign:Array.from(viem.toBytes(viem.hashMessage(t)))}}async prepareTypedDataForSigning(t){return {hashToSign:Array.from(viem.toBytes(viem.hashTypedData(t)))}}async prepareUserOpForSigning(t,e,n){let a=n??await this.client.getChainId(),i=e||"0x0000000071727De22E5E9d8BAf0edAc6f37da032",s=viem.encodeAbiParameters([{type:"bytes32"},{type:"address"},{type:"uint256"}],[viem.keccak256(viem.encodeAbiParameters([{type:"address"},{type:"uint256"},{type:"bytes32"},{type:"bytes32"},{type:"bytes32"},{type:"uint256"},{type:"bytes32"},{type:"bytes32"}],[t.sender,viem.hexToBigInt(t.nonce),viem.keccak256("factory"in t&&"factoryData"in t&&t.factory&&t.factoryData?viem.concat([t.factory,t.factoryData]):"initCode"in t?t.initCode:"0x"),viem.keccak256(t.callData),viem.concat([viem.pad(t.verificationGasLimit,{size:16}),viem.pad(t.callGasLimit,{size:16})]),viem.hexToBigInt(t.preVerificationGas),viem.concat([viem.pad(t.maxPriorityFeePerGas,{size:16}),viem.pad(t.maxFeePerGas,{size:16})]),viem.keccak256("paymaster"in t&&t.paymaster&&viem.isAddress(t.paymaster)?viem.concat([t.paymaster,viem.pad(t.paymasterVerificationGasLimit,{size:16}),viem.pad(t.paymasterPostOpGasLimit,{size:16}),t.paymasterData]):"paymasterAndData"in t?t.paymasterAndData:"0x")])),i,BigInt(a)]),o=viem.keccak256(s);return {userOp:t,hashToSign:Array.from(viem.toBytes(viem.hashMessage({raw:o})))}}finalizeTransactionSigning({transaction:t,rsvSignatures:e}){let n=this.transformRSVSignature(e[0]);return viem.serializeTransaction(t,n)}finalizeMessageSigning({rsvSignature:t}){return this.assembleSignature(t)}finalizeTypedDataSigning({rsvSignature:t}){return this.assembleSignature(t)}finalizeUserOpSigning({userOp:t,rsvSignature:e}){let{r:n,s:a,yParity:i}=this.transformRSVSignature(e);if(i===void 0)throw new Error("Missing yParity");return {...t,signature:viem.concatHex(["0x00",n,a,viem.numberToHex(Number(i+27),{size:1})])}}async broadcastTx(t){try{return await this.client.sendRawTransaction({serializedTransaction:t})}catch(e){throw console.error("Transaction broadcast failed:",e),new Error("Failed to broadcast transaction.")}}};function q(r){switch(r.toLowerCase()){case "mainnet":return h__namespace.networks.bitcoin;case "testnet":return h__namespace.networks.testnet;case "regtest":return h__namespace.networks.regtest;default:throw new Error(`Unknown Bitcoin network: ${r}`)}}var k=class r extends f{static{this.SATOSHIS_PER_BTC=1e8;}constructor({network:t,contract:e,btcRpcAdapter:n}){super(),this.network=t,this.btcRpcAdapter=n,this.contract=e;}static toBTC(t){return t/r.SATOSHIS_PER_BTC}static toSatoshi(t){return Math.round(t*r.SATOSHIS_PER_BTC)}async fetchTransaction(t){let e=await this.btcRpcAdapter.getTransaction(t),n=new h__namespace.Transaction;return e.vout.forEach(a=>{let i=Buffer.from(a.scriptpubkey,"hex");n.addOutput(i,Number(a.value));}),n}static transformRSVSignature(t){let e=t.r.padStart(64,"0"),n=t.s.padStart(64,"0"),a=Buffer.from(e+n,"hex");if(a.length!==64)throw new Error("Invalid signature length.");return a}async createPSBT({transactionRequest:t}){let{inputs:e,outputs:n}=t.inputs&&t.outputs?t:await this.btcRpcAdapter.selectUTXOs(t.from,[{address:t.to,value:parseFloat(t.value)}]),a=new h__namespace.Psbt({network:q(this.network)});return await Promise.all(e.map(async i=>{if(!i.scriptPubKey){let o=(await this.fetchTransaction(i.txid)).outs[i.vout];i.scriptPubKey=o.script;}a.addInput({hash:i.txid,index:i.vout,witnessUtxo:{script:i.scriptPubKey,value:i.value}});})),n.forEach(i=>{"address"in i?a.addOutput({address:i.address,value:i.value}):"script"in i?a.addOutput({script:i.script,value:i.value}):t.from!==void 0&&a.addOutput({value:Number(i.value),address:t.from});}),a}async getBalance(t){return {balance:BigInt(await this.btcRpcAdapter.getBalance(t)),decimals:8}}async deriveAddressAndPublicKey(t,e){let n=await this.contract.getDerivedPublicKey({path:e,predecessor:t});if(!n)throw new Error("Failed to get derived public key");let a=u.compressPubKey(n),i=Buffer.from(a,"hex"),s=q(this.network),o=h__namespace.payments.p2wpkh({pubkey:i,network:s}),{address:c}=o;if(!c)throw new Error("Failed to generate Bitcoin address");return {address:c,publicKey:a}}serializeTransaction(t){return JSON.stringify({psbt:t.psbt.toHex(),publicKey:t.publicKey})}deserializeTransaction(t){let e=JSON.parse(t);return {psbt:h__namespace.Psbt.fromHex(e.psbt),publicKey:e.publicKey}}async prepareTransactionForSigning(t){let e=Buffer.from(t.publicKey,"hex"),n=await this.createPSBT({transactionRequest:t}),a=n.toHex(),i=[],s=o=>({publicKey:e,sign:c=>(i[o]=Array.from(c),Buffer.alloc(64))});for(let o=0;o<n.inputCount;o++)n.signInput(o,s(o));return {transaction:{psbt:h__namespace.Psbt.fromHex(a),publicKey:t.publicKey},hashesToSign:i}}finalizeTransactionSigning({transaction:{psbt:t,publicKey:e},rsvSignatures:n}){let a=Buffer.from(e,"hex"),i=s=>({publicKey:a,sign:()=>{let o=n[s];return r.transformRSVSignature(o)}});for(let s=0;s<t.inputCount;s++)t.signInput(s,i(s));return t.finalizeAllInputs(),t.extractTransaction().toHex()}async broadcastTx(t){return await this.btcRpcAdapter.broadcastTransaction(t)}};var E=class{};var K=class extends E{constructor(t){super(),this.providerUrl=t;}async fetchFeeRate(t=6){let n=await(await fetch(`${this.providerUrl}/v1/fees/recommended`)).json();return t<=1?n.fastestFee:t<=3?n.halfHourFee:t<=6?n.hourFee:n.economyFee}async fetchUTXOs(t){try{return await(await fetch(`${this.providerUrl}/address/${t}/utxo`)).json()}catch(e){return console.error("Failed to fetch UTXOs:",e),[]}}async selectUTXOs(t,e,n=6){let a=await this.fetchUTXOs(t),i=await this.fetchFeeRate(n),s=qt__default.default(a,e,Math.ceil(i+1));if(!s.inputs||!s.outputs)throw new Error("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.");return {inputs:s.inputs,outputs:s.outputs}}async broadcastTransaction(t){let e=await fetch(`${this.providerUrl}/tx`,{method:"POST",body:t});if(e.ok)return await e.text();throw new Error(`Failed to broadcast transaction: ${await e.text()}`)}async getBalance(t){let n=await(await fetch(`${this.providerUrl}/address/${t}`)).json();return n.chain_stats.funded_txo_sum-n.chain_stats.spent_txo_sum}async getTransaction(t){return await(await fetch(`${this.providerUrl}/tx/${t}`)).json()}};var W={Mempool:K};var mt=async r=>{let t=chainRegistry.chains.find(d=>d.chain_id===r);if(!t)throw new Error(`Chain info not found for chainId: ${r}`);let{bech32_prefix:e,chain_id:n}=t,a=t.staking?.staking_tokens?.[0]?.denom,i=t.apis?.rpc?.[0]?.address,s=t.apis?.rest?.[0]?.address,o=t.fees?.fee_tokens?.[0]?.average_gas_price;if(!e||!a||!i||!s||!n||o===void 0)throw new Error(`Missing required chain information for ${t.chain_name}`);let p=chainRegistry.assets.find(d=>d.chain_name===t.chain_name)?.assets.find(d=>d.base===a),y=p?.denom_units.find(d=>d.denom===p.display)?.exponent;if(y===void 0)throw new Error(`Could not find decimals for ${a} on chain ${t.chain_name}`);return {prefix:e,denom:a,rpcUrl:i,restUrl:s,expectedChainId:n,gasPrice:o,decimals:y}};var _=class extends f{constructor({chainId:t,contract:e,endpoints:n}){super(),this.contract=e,this.registry=new protoSigning.Registry,this.chainId=t,this.endpoints=n;}transformRSVSignature(t){return new Uint8Array([...encoding.fromHex(t.r),...encoding.fromHex(t.s)])}async getChainInfo(){return {...await mt(this.chainId),...this.endpoints}}async getBalance(t){try{let{restUrl:e,denom:n,decimals:a}=await this.getChainInfo(),i=await fetch(`${e}/cosmos/bank/v1beta1/balances/${t}`);if(!i.ok)throw new Error(`HTTP error! status: ${i.status}`);let c=(await i.json()).balances.find(p=>p.denom===n)?.amount??"0";return {balance:BigInt(c),decimals:a}}catch(e){throw console.error("Failed to fetch Cosmos balance:",e),new Error("Failed to fetch Cosmos balance")}}async deriveAddressAndPublicKey(t,e){let{prefix:n}=await this.getChainInfo(),a=await this.contract.getDerivedPublicKey({path:e,predecessor:t});if(!a)throw new Error("Failed to get derived public key");let i=u.compressPubKey(a),s=crypto$1.sha256(encoding.fromHex(i)),o=crypto$1.ripemd160(s);return {address:bech32.bech32.encode(n,bech32.bech32.toWords(o)),publicKey:i}}serializeTransaction(t){let e=tx.TxRaw.encode(t).finish();return encoding.toBase64(e)}deserializeTransaction(t){return tx.TxRaw.decode(encoding.fromBase64(t))}async prepareTransactionForSigning(t){let{denom:e,rpcUrl:n,gasPrice:a}=await this.getChainInfo(),i=encoding.fromHex(t.publicKey),s=t.gas||2e5,o=stargate.calculateFee(s,stargate.GasPrice.fromString(`${a}${e}`)),p=await(await stargate.StargateClient.connect(n)).getAccount(t.address);if(!p)throw new Error(`Account ${t.address} does not exist on chain`);let{accountNumber:y,sequence:d}=p,V={typeUrl:"/cosmos.tx.v1beta1.TxBody",value:{messages:t.messages,memo:t.memo||""}},M=this.registry.encode(V),z=protoSigning.encodePubkey(amino.encodeSecp256k1Pubkey(i)),ot=protoSigning.makeAuthInfoBytes([{pubkey:z,sequence:d}],o.amount,Number(o.gas),void 0,void 0,signing.SignMode.SIGN_MODE_DIRECT),Tt=protoSigning.makeSignDoc(M,ot,this.chainId,y),St=protoSigning.makeSignBytes(Tt),Ct=Array.from(crypto$1.sha256(St));return {transaction:tx.TxRaw.fromPartial({bodyBytes:M,authInfoBytes:ot,signatures:[]}),hashesToSign:[Ct]}}finalizeTransactionSigning({transaction:t,rsvSignatures:e}){t.signatures=e.map(a=>this.transformRSVSignature(a));let n=tx.TxRaw.encode(t).finish();return Buffer.from(n).toString("hex")}async broadcastTx(t){try{let{rpcUrl:e}=await this.getChainInfo(),n=await stargate.StargateClient.connect(e),a=encoding.fromHex(t),i=await n.broadcastTx(a);if(i.code!==0)throw new Error(`Broadcast error: ${i.rawLog}`);return i.transactionHash}catch(e){throw console.error("Transaction broadcast failed:",e),new Error("Failed to broadcast transaction.")}}};var pe=async(r,t)=>{try{let e=await w({networkId:r.nearAuthentication.networkId,accountId:r.nearAuthentication.accountId,keypair:t}),n=new l({networkId:r.nearAuthentication.networkId,contractId:r.chainConfig.contract,accountId:e.accountId,keypair:t}),a=new B({rpcUrl:r.chainConfig.providerUrl,contract:n}),{transaction:i,hashesToSign:s}=await a.prepareTransactionForSigning(r.transaction),o=await n.sign({payload:s[0],path:r.derivationPath,key_version:0}),c=a.finalizeTransactionSigning({transaction:i,rsvSignatures:[o]});return {transactionHash:await a.broadcastTx(c),success:!0}}catch(e){return console.error(e),{success:false,errorMessage:e instanceof Error?e.message:String(e)}}},ue=async(r,t)=>{try{let e=await w({networkId:r.nearAuthentication.networkId,accountId:r.nearAuthentication.accountId,keypair:t}),n=new l({networkId:r.nearAuthentication.networkId,contractId:r.chainConfig.contract,accountId:e.accountId,keypair:t}),a=new k({btcRpcAdapter:new W.Mempool(r.chainConfig.providerUrl),contract:n,network:r.chainConfig.network}),{transaction:i,hashesToSign:s}=await a.prepareTransactionForSigning(r.transaction),o=await Promise.all(s.map(async y=>await n.sign({payload:y,path:r.derivationPath,key_version:0}))),c=a.finalizeTransactionSigning({transaction:i,rsvSignatures:o});return {transactionHash:await a.broadcastTx(c),success:!0}}catch(e){return {success:false,errorMessage:e instanceof Error?e.message:String(e)}}},de=async(r,t)=>{try{let e=await w({networkId:r.nearAuthentication.networkId,accountId:r.nearAuthentication.accountId,keypair:t}),n=new l({networkId:r.nearAuthentication.networkId,contractId:r.chainConfig.contract,accountId:e.accountId,keypair:t}),a=new _({contract:n,chainId:r.chainConfig.chainId}),{transaction:i,hashesToSign:s}=await a.prepareTransactionForSigning(r.transaction),o=await Promise.all(s.map(async y=>await n.sign({payload:y,path:r.derivationPath,key_version:0}))),c=a.finalizeTransactionSigning({transaction:i,rsvSignatures:o});return {transactionHash:await a.broadcastTx(c),success:!0}}catch(e){return console.error(e),{success:false,errorMessage:e instanceof Error?e.message:String(e)}}};var it={};m(it,{ChainSignatureContract:()=>at,abi:()=>C,errors:()=>rt});var nt={};m(nt,{CHAINS:()=>S,CONTRACT_ADDRESSES:()=>et,ENVS:()=>g,KDF_CHAIN_IDS:()=>tt,ROOT_PUBLIC_KEYS:()=>Z});var g={TESTNET_DEV:"TESTNET_DEV",TESTNET:"TESTNET",MAINNET:"MAINNET"},S={ETHEREUM:"ETHEREUM",NEAR:"NEAR"},Z={[g.TESTNET_DEV]:"secp256k1:54hU5wcCmVUPFWLDALXMh1fFToZsVXrx9BbTbHzSfQq1Kd1rJZi52iPa4QQxo6s5TgjWqgpY8HamYuUDzG6fAaUq",[g.TESTNET]:"secp256k1:3Ww8iFjqTHufye5aRGUvrQqETegR4gVUcW8FX5xzscaN9ENhpkffojsxJwi6N1RbbHMTxYa9UyKeqK3fsMuwxjR5",[g.MAINNET]:"secp256k1:4tY4qMzusmgX5wYdG35663Y3Qar3CTbpApotwk9ZKLoF79XA4DjG8XoByaKdNHKQX9Lz5hd7iJqsWdTKyA7dKa6Z"},tt={[S.ETHEREUM]:"0x1",[S.NEAR]:"0x18d"},et={[S.NEAR]:{[g.TESTNET_DEV]:"dev.sig-net.testnet",[g.TESTNET]:"v1.sig-net.testnet",[g.MAINNET]:"v1.sig-net.near"},[S.ETHEREUM]:{[g.TESTNET_DEV]:"0x69C6b28Fdc74618817fa380De29a653060e14009",[g.TESTNET]:"0x83458E8Bf8206131Fe5c05127007FA164c0948A2",[g.MAINNET]:"0xf8bdC0612361a1E49a8E01423d4C0cFc5dF4791A"}};var ht=(r,t)=>{let e=Object.entries(et[t]).find(([n,a])=>a.toLowerCase()===r.toLowerCase())?.[0];if(e)return Z[e];throw new Error(`Contract address ${r} not supported for chain ${t}`)};var C=[{inputs:[{internalType:"address",name:"_mpc_network",type:"address"},{internalType:"uint256",name:"_signatureDeposit",type:"uint256"}],stateMutability:"nonpayable",type:"constructor"},{inputs:[],name:"AccessControlBadConfirmation",type:"error"},{inputs:[{internalType:"address",name:"account",type:"address"},{internalType:"bytes32",name:"neededRole",type:"bytes32"}],name:"AccessControlUnauthorizedAccount",type:"error"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"role",type:"bytes32"},{indexed:true,internalType:"bytes32",name:"previousAdminRole",type:"bytes32"},{indexed:true,internalType:"bytes32",name:"newAdminRole",type:"bytes32"}],name:"RoleAdminChanged",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"role",type:"bytes32"},{indexed:true,internalType:"address",name:"account",type:"address"},{indexed:true,internalType:"address",name:"sender",type:"address"}],name:"RoleGranted",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"role",type:"bytes32"},{indexed:true,internalType:"address",name:"account",type:"address"},{indexed:true,internalType:"address",name:"sender",type:"address"}],name:"RoleRevoked",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"requestId",type:"bytes32"},{indexed:false,internalType:"address",name:"responder",type:"address"},{indexed:false,internalType:"string",name:"error",type:"string"}],name:"SignatureError",type:"event"},{anonymous:false,inputs:[{indexed:false,internalType:"address",name:"sender",type:"address"},{indexed:false,internalType:"bytes32",name:"payload",type:"bytes32"},{indexed:false,internalType:"uint32",name:"keyVersion",type:"uint32"},{indexed:false,internalType:"uint256",name:"deposit",type:"uint256"},{indexed:false,internalType:"uint256",name:"chainId",type:"uint256"},{indexed:false,internalType:"string",name:"path",type:"string"},{indexed:false,internalType:"string",name:"algo",type:"string"},{indexed:false,internalType:"string",name:"dest",type:"string"},{indexed:false,internalType:"string",name:"params",type:"string"}],name:"SignatureRequested",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"requestId",type:"bytes32"},{indexed:false,internalType:"address",name:"responder",type:"address"},{components:[{components:[{internalType:"uint256",name:"x",type:"uint256"},{internalType:"uint256",name:"y",type:"uint256"}],internalType:"struct ChainSignatures.AffinePoint",name:"bigR",type:"tuple"},{internalType:"uint256",name:"s",type:"uint256"},{internalType:"uint8",name:"recoveryId",type:"uint8"}],indexed:false,internalType:"struct ChainSignatures.Signature",name:"signature",type:"tuple"}],name:"SignatureResponded",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"address",name:"owner",type:"address"},{indexed:false,internalType:"uint256",name:"amount",type:"uint256"}],name:"Withdraw",type:"event"},{inputs:[],name:"DEFAULT_ADMIN_ROLE",outputs:[{internalType:"bytes32",name:"",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"}],name:"getRoleAdmin",outputs:[{internalType:"bytes32",name:"",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[],name:"getSignatureDeposit",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"account",type:"address"}],name:"grantRole",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"account",type:"address"}],name:"hasRole",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"callerConfirmation",type:"address"}],name:"renounceRole",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"bytes32",name:"requestId",type:"bytes32"},{components:[{components:[{internalType:"uint256",name:"x",type:"uint256"},{internalType:"uint256",name:"y",type:"uint256"}],internalType:"struct ChainSignatures.AffinePoint",name:"bigR",type:"tuple"},{internalType:"uint256",name:"s",type:"uint256"},{internalType:"uint8",name:"recoveryId",type:"uint8"}],internalType:"struct ChainSignatures.Signature",name:"signature",type:"tuple"}],internalType:"struct ChainSignatures.Response[]",name:"_responses",type:"tuple[]"}],name:"respond",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"bytes32",name:"requestId",type:"bytes32"},{internalType:"string",name:"errorMessage",type:"string"}],internalType:"struct ChainSignatures.ErrorResponse[]",name:"_errors",type:"tuple[]"}],name:"respondError",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"account",type:"address"}],name:"revokeRole",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_amount",type:"uint256"}],name:"setSignatureDeposit",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"bytes32",name:"payload",type:"bytes32"},{internalType:"string",name:"path",type:"string"},{internalType:"uint32",name:"keyVersion",type:"uint32"},{internalType:"string",name:"algo",type:"string"},{internalType:"string",name:"dest",type:"string"},{internalType:"string",name:"params",type:"string"}],internalType:"struct ChainSignatures.SignRequest",name:"_request",type:"tuple"}],name:"sign",outputs:[],stateMutability:"payable",type:"function"},{inputs:[{internalType:"bytes4",name:"interfaceId",type:"bytes4"}],name:"supportsInterface",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"uint256",name:"_amount",type:"uint256"},{internalType:"address",name:"_receiver",type:"address"}],name:"withdraw",outputs:[],stateMutability:"nonpayable",type:"function"}];var rt={};m(rt,{ChainSignatureError:()=>v,SignatureContractError:()=>I,SignatureNotFoundError:()=>R,SigningError:()=>U});var v=class extends Error{constructor(t,e,n){super(t),this.name="ChainSignatureError",this.requestId=e,this.receipt=n;}},R=class extends v{constructor(t,e){super("Signature not found after maximum retries",t,e),this.name="SignatureNotFoundError";}},I=class extends v{constructor(t,e,n){super(`Signature error: ${t}`,e,n),this.name="SignatureContractError",this.errorCode=t;}},U=class extends v{constructor(t,e,n){super("Error signing request",t,e),this.name="SigningError",this.originalError=n;}};var at=class extends b{constructor(t){super(),this.publicClient=t.publicClient,this.walletClient=t.walletClient,this.contractAddress=t.contractAddress,this.rootPublicKey=t.rootPublicKey||ht(this.contractAddress,S.ETHEREUM);}async getCurrentSignatureDeposit(){let t=await this.publicClient.readContract({address:this.contractAddress,abi:C,functionName:"getSignatureDeposit"});return new xt__default.default(t.toString())}async getDerivedPublicKey(t){return u.deriveChildPublicKey(await this.getPublicKey(),t.predecessor.toLowerCase(),t.path,tt.ETHEREUM)}async getPublicKey(){return x(this.rootPublicKey)}async getLatestKeyVersion(){let t=await this.publicClient.readContract({address:this.contractAddress,abi:C,functionName:"latestKeyVersion"});return Number(t)}async sign(t,e={sign:{algo:"",dest:"",params:""},retry:{delay:5e3,retryCount:12}}){if(!this.walletClient?.account)throw new Error("Wallet client required for signing operations");let n={payload:`0x${Buffer.from(t.payload).toString("hex")}`,path:t.path,keyVersion:t.key_version,algo:e.sign.algo??"",dest:e.sign.dest??"",params:e.sign.params??""},a=this.getRequestId(n),i=await this.walletClient.writeContract({address:this.contractAddress,abi:C,chain:this.publicClient.chain,account:this.walletClient.account,functionName:"sign",args:[n],value:BigInt((await this.getCurrentSignatureDeposit()).toString())}),s=await this.publicClient.waitForTransactionReceipt({hash:i});try{let o=await viem.withRetry(async()=>{let c=await this.getSignatureFromEvents(a,s);if(c)return c;throw new Error("Signature not found yet")},{delay:e.retry.delay,retryCount:e.retry.retryCount,shouldRetry:({count:c,error:p})=>(console.log(`Retrying get signature: ${c}/${e.retry.retryCount}`),p.message==="Signature not found yet")});if(o)return o;{let c=await this.getErrorFromEvents(a,s);throw c?new I(c.error,a,s):new R(a,s)}}catch(o){throw o instanceof R||o instanceof I?o:new U(a,s,o instanceof Error?o:void 0)}}getRequestId(t){if(!this.walletClient?.account)throw new Error("Wallet client required for signing operations");let e=viem.encodeAbiParameters([{type:"address"},{type:"bytes"},{type:"string"},{type:"uint32"},{type:"uint256"},{type:"string"},{type:"string"},{type:"string"}],[this.walletClient.account.address,t.payload,t.path,Number(t.keyVersion),this.publicClient.chain?.id?BigInt(this.publicClient.chain.id):0n,t.algo,t.dest,t.params]);return viem.keccak256(e)}async getErrorFromEvents(t,e){let n=await this.publicClient.getContractEvents({address:this.contractAddress,abi:C,eventName:"SignatureError",args:{requestId:t},fromBlock:e.blockNumber,toBlock:"latest"});if(n.length>0){let{args:a}=n[n.length-1];return a}}async getSignatureFromEvents(t,e){let n=await this.publicClient.getContractEvents({address:this.contractAddress,abi:C,eventName:"SignatureResponded",args:{requestId:t},fromBlock:e.blockNumber,toBlock:"latest"});if(n.length>0){let{args:a}=n[n.length-1];return u.toRSV(a.signature)}}};
2
+ exports.BTCRpcAdapter=E;exports.BTCRpcAdapters=W;exports.Bitcoin=k;exports.Chain=f;exports.ChainSignatureContract=b;exports.Cosmos=_;exports.EVM=B;exports.fetchEVMFeeProperties=L;exports.utils=bt;//# sourceMappingURL=index.browser.cjs.map
3
+ //# sourceMappingURL=index.browser.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/chains/index.ts","../../src/utils/chains/near/index.ts","../../src/utils/chains/near/transactionBuilder.ts","../../src/chains/ChainSignatureContract.ts","../../src/utils/chains/near/constants.ts","../../src/utils/chains/near/account.ts","../../src/utils/cryptography.ts","../../src/utils/chains/near/ChainSignatureContract.ts","../../src/utils/chains/near/signAndSend/index.ts","../../src/utils/chains/near/signAndSend/keypair.ts","../../src/chains/Chain.ts","../../src/chains/EVM/utils.ts","../../src/chains/EVM/EVM.ts","../../src/chains/Bitcoin/utils.ts","../../src/chains/Bitcoin/Bitcoin.ts","../../src/chains/Bitcoin/BTCRpcAdapter/BTCRpcAdapter.ts","../../src/chains/Bitcoin/BTCRpcAdapter/Mempool/Mempool.ts","../../src/chains/Bitcoin/BTCRpcAdapter/index.ts","../../src/chains/Cosmos/utils.ts","../../src/chains/Cosmos/Cosmos.ts","../../src/utils/chains/evm/index.ts","../../src/utils/chains/evm/ChainSignaturesContract.ts","../../src/utils/constants.ts","../../src/utils/publicKey.ts","../../src/utils/chains/evm/ChainSignaturesContractABI.ts","../../src/utils/chains/evm/errors.ts"],"names":["utils_exports","__export","chains_exports","constants_exports","cryptography_exports","evm_exports","near_exports","ChainSignatureContract","signAndSend_exports","transactionBuilder_exports","mpcPayloadsToChainSigTransaction","responseToMpcSignature","BaseChainSignatureContract","NEAR_MAX_GAS","BN","DONT_CARE_ACCOUNT_ID","getNearAccount","networkId","accountId","keypair","KeyPair","keyStore","InMemoryKeyStore","connection","Connection","Account","compressPubKey","deriveChildPublicKey","najToUncompressedPubKeySEC1","toRSV","signature","uncompressedPubKeySEC1","slicedPubKey","x","y","najPublicKey","decodedKey","base58","rootUncompressedPubKeySEC1","predecessorId","path","chainId","ec","EC","derivationPath","scalarHex","keccak256","oldPublicKeyPoint","scalarTimesG","newPublicKeyPoint","newX","newY","requireAccount","contractId","account","Contract","contract","args","najPubKey","deposit","hashesToSign","currentContractFee","payload","response","getTransactionLastResult","keypair_exports","BTCTransaction","CosmosTransaction","EVMTransaction","Chain","fetchEVMFeeProperties","client","transaction","gas","feeData","maxFeePerGas","maxPriorityFeePerGas","EVM","rpcUrl","createPublicClient","http","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","error","parseBTCNetwork","network","O","Bitcoin","_Bitcoin","btcRpcAdapter","satoshis","btc","transactionId","data","tx","h","vout","scriptPubKey","rawSignature","inputs","outputs","psbt","input","prevOut","out","derivedKey","publicKeyBuffer","payment","transactionJSON","psbtHex","mockKeyPair","index","publicKey","keyPair","mpcSignature","BTCRpcAdapter","Mempool","providerUrl","confirmationTarget","targets","utxos","feeRate","ret","coinselect","transactionHex","txid","BTCRpcAdapters","fetchChainInfo","chainInfo","chains","chain","prefix","expectedChainId","denom","restUrl","gasPrice","asset","assets","decimals","unit","Cosmos","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","req","evm","signatures","cosmos","abi","errors_exports","CHAINS","CONTRACT_ADDRESSES","ENVS","KDF_CHAIN_IDS","ROOT_PUBLIC_KEYS","getRootPublicKey","contractAddress","environment","_","ChainSignatureError","SignatureContractError","SignatureNotFoundError","SigningError","requestId","receipt","errorCode","originalError","version","options","request","result","withRetry","count","errorData","errorLogs","logs","signatureData"],"mappings":"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","file":"index.browser.cjs","sourcesContent":["export * as chains from './chains'\nexport * as cryptography from './cryptography'\nexport * as constants from './constants'\n","export * as near from './near'\nexport * as evm from './evm'\n","export * as transactionBuilder from './transactionBuilder'\nexport * as signAndSend from './signAndSend'\nexport * from './ChainSignatureContract'\n","import type {\n Action,\n FinalExecutionOutcome,\n NetworkId,\n} from '@near-wallet-selector/core'\nimport BN from 'bn.js'\nimport { getTransactionLastResult } from 'near-api-js/lib/providers'\n\nimport {\n type RSVSignature,\n type KeyDerivationPath,\n type MPCSignature,\n type HashToSign,\n} from '@chains/types'\nimport { cryptography } from '@utils'\nimport { ChainSignatureContract } from '@utils/chains/near/ChainSignatureContract'\nimport { NEAR_MAX_GAS } from '@utils/chains/near/constants'\nimport { type ChainSignatureContractIds } from '@utils/chains/near/types'\n\nexport const mpcPayloadsToChainSigTransaction = async ({\n networkId,\n contractId,\n hashesToSign,\n path,\n}: {\n networkId: NetworkId\n contractId: ChainSignatureContractIds\n hashesToSign: HashToSign[]\n path: KeyDerivationPath\n}): Promise<{\n receiverId: string\n actions: Action[]\n}> => {\n const contract = new ChainSignatureContract({\n networkId,\n contractId,\n })\n\n const currentContractFee = await contract.getCurrentSignatureDeposit()\n\n return {\n receiverId: contractId,\n actions: hashesToSign.map((payload) => ({\n type: 'FunctionCall',\n params: {\n methodName: 'sign',\n args: {\n request: {\n payload: Array.from(payload),\n path,\n key_version: 0,\n },\n },\n gas: NEAR_MAX_GAS.div(new BN(hashesToSign.length)).toString(),\n deposit: currentContractFee?.toString() || '1',\n },\n })),\n }\n}\n\nexport const responseToMpcSignature = ({\n response,\n}: {\n response: FinalExecutionOutcome\n}): RSVSignature | undefined => {\n const signature: MPCSignature = getTransactionLastResult(response)\n\n if (signature) {\n return cryptography.toRSV(signature)\n } else {\n return undefined\n }\n}\n","import type BN from 'bn.js'\n\nimport type { RSVSignature, UncompressedPubKeySEC1 } from '@chains/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 Chain 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 BN from 'bn.js'\n\nexport const NEAR_MAX_GAS = new BN('300000000000000')\nexport const DONT_CARE_ACCOUNT_ID = 'dontcare'\n","import { Account, Connection } from '@near-js/accounts'\nimport { KeyPair } from '@near-js/crypto'\nimport { InMemoryKeyStore } from '@near-js/keystores'\n\nimport { DONT_CARE_ACCOUNT_ID } from '@utils/chains/near/constants'\n\ntype SetConnectionArgs =\n | {\n networkId: string\n accountId: string\n keypair: KeyPair\n }\n | {\n networkId: string\n accountId?: never\n keypair?: never\n }\n\nexport const getNearAccount = async ({\n networkId,\n accountId = DONT_CARE_ACCOUNT_ID,\n keypair = KeyPair.fromRandom('ed25519'),\n}: SetConnectionArgs): Promise<Account> => {\n const keyStore = new InMemoryKeyStore()\n await keyStore.setKey(networkId, accountId, keypair)\n\n const connection = Connection.fromConfig({\n networkId,\n provider: {\n type: 'JsonRpcProvider',\n args: {\n url: {\n testnet: 'https://rpc.testnet.near.org',\n mainnet: 'https://rpc.mainnet.near.org',\n }[networkId],\n },\n },\n signer: { type: 'InMemorySigner', keyStore },\n })\n\n return new Account(connection, accountId)\n}\n","import { base58 } from '@scure/base'\nimport { ec as EC } from 'elliptic'\nimport { keccak256 } from 'viem'\n\nimport {\n type NajPublicKey,\n type MPCSignature,\n type RSVSignature,\n type UncompressedPubKeySEC1,\n} from '@chains/types'\n\nexport const toRSV = (signature: MPCSignature): RSVSignature => {\n // Handle NearNearMpcSignature\n if (\n 'big_r' in signature &&\n typeof signature.big_r === 'object' &&\n 'affine_point' in signature.big_r &&\n 's' in signature &&\n typeof signature.s === 'object' &&\n 'scalar' in signature.s\n ) {\n return {\n r: signature.big_r.affine_point.substring(2),\n s: signature.s.scalar,\n v: signature.recovery_id + 27,\n }\n }\n // Handle SigNetNearMpcSignature\n else if (\n 'big_r' in signature &&\n typeof signature.big_r === 'string' &&\n 's' in signature &&\n typeof signature.s === 'string'\n ) {\n return {\n r: signature.big_r.substring(2),\n s: signature.s,\n v: signature.recovery_id + 27,\n }\n }\n // Handle SigNetEvmMpcSignature\n else 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. secp256k1: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 const scalarHex = keccak256(Buffer.from(derivationPath)).slice(2)\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","import { Contract } from '@near-js/accounts'\nimport { KeyPair } from '@near-js/crypto'\nimport BN from 'bn.js'\n\nimport { ChainSignatureContract as AbstractChainSignatureContract } from '@chains/ChainSignatureContract'\nimport type { SignArgs } from '@chains/ChainSignatureContract'\nimport type {\n RSVSignature,\n MPCSignature,\n UncompressedPubKeySEC1,\n NajPublicKey,\n} from '@chains/types'\nimport { cryptography } from '@utils'\nimport { getNearAccount } from '@utils/chains/near/account'\nimport {\n DONT_CARE_ACCOUNT_ID,\n NEAR_MAX_GAS,\n} from '@utils/chains/near/constants'\nimport {\n type NearNetworkIds,\n type ChainSignatureContractIds,\n} from '@utils/chains/near/types'\nimport { najToUncompressedPubKeySEC1 } from '@utils/cryptography'\n\nconst requireAccount = (accountId: string): void => {\n if (accountId === DONT_CARE_ACCOUNT_ID) {\n throw new Error(\n 'A valid account ID and keypair are required for change methods. Please instantiate a new contract with valid credentials.'\n )\n }\n}\n\ntype NearContract = Contract & {\n public_key: () => Promise<NajPublicKey>\n sign: (args: {\n args: { request: SignArgs }\n gas: BN\n amount: BN\n }) => Promise<MPCSignature>\n experimental_signature_deposit: () => Promise<number>\n derived_public_key: (args: {\n path: string\n predecessor: string\n }) => Promise<NajPublicKey>\n}\n\ninterface ChainSignatureContractArgs {\n networkId: NearNetworkIds\n contractId: ChainSignatureContractIds\n accountId?: string\n keypair?: KeyPair\n}\n\n/**\n * Implementation of the ChainSignatureContract for NEAR chains.\n *\n * This class provides an interface to interact with the ChainSignatures contract\n * deployed on NEAR. It supports both view methods (which don't require authentication)\n * and change methods (which require a valid NEAR account and keypair).\n *\n * @extends AbstractChainSignatureContract\n */\nexport class ChainSignatureContract extends AbstractChainSignatureContract {\n private readonly networkId: NearNetworkIds\n private readonly contractId: ChainSignatureContractIds\n private readonly accountId: string\n private readonly keypair: KeyPair\n\n /**\n * Creates a new instance of the ChainSignatureContract for NEAR chains.\n *\n * @param args - Configuration options for the contract\n * @param args.networkId - The NEAR network ID (e.g. 'testnet', 'mainnet')\n * @param args.contractId - The contract ID of the deployed ChainSignatures contract\n * @param args.accountId - Optional NEAR account ID for signing transactions. Required for change methods.\n * @param args.keypair - Optional NEAR KeyPair for signing transactions. Required for change methods.\n */\n constructor({\n networkId,\n contractId,\n accountId = DONT_CARE_ACCOUNT_ID,\n keypair = KeyPair.fromRandom('ed25519'),\n }: ChainSignatureContractArgs) {\n // TODO: Should use the hardcoded ROOT_PUBLIC_KEY as in the EVM ChainSignatureContract\n super()\n\n this.networkId = networkId\n this.contractId = contractId\n this.accountId = accountId\n this.keypair = keypair\n }\n\n private async getContract(): Promise<NearContract> {\n const account = await getNearAccount({\n networkId: this.networkId,\n accountId: this.accountId,\n keypair: this.keypair,\n })\n\n return new Contract(account, this.contractId, {\n viewMethods: [\n 'public_key',\n 'experimental_signature_deposit',\n 'derived_public_key',\n ],\n changeMethods: ['sign'],\n useLocalViewExecution: false,\n }) as unknown as NearContract\n }\n\n async getCurrentSignatureDeposit(): Promise<BN> {\n const contract = await this.getContract()\n return new BN(\n (await contract.experimental_signature_deposit()).toLocaleString(\n 'fullwide',\n {\n useGrouping: false,\n }\n )\n )\n }\n\n async getDerivedPublicKey(args: {\n path: string\n predecessor: string\n }): Promise<UncompressedPubKeySEC1> {\n const contract = await this.getContract()\n\n const najPubKey = await contract.derived_public_key(args)\n return najToUncompressedPubKeySEC1(najPubKey)\n }\n\n async getPublicKey(): Promise<UncompressedPubKeySEC1> {\n const contract = await this.getContract()\n\n const najPubKey = await contract.public_key()\n return najToUncompressedPubKeySEC1(najPubKey)\n }\n\n // TODO: Should call the contract without the Contract instance as it doesn't allow for proper timeout handling on the BE\n async sign(args: SignArgs): Promise<RSVSignature> {\n requireAccount(this.accountId)\n\n const contract = await this.getContract()\n const deposit = await this.getCurrentSignatureDeposit()\n\n const signature = await contract.sign({\n args: { request: args },\n gas: NEAR_MAX_GAS,\n amount: deposit,\n })\n\n return cryptography.toRSV(signature)\n }\n}\n","export * as keypair from './keypair'\n","import { type KeyPair } from '@near-js/crypto'\n\nimport { Bitcoin, Cosmos, EVM } from '@chains'\nimport { BTCRpcAdapters } from '@chains/Bitcoin/BTCRpcAdapter'\nimport { getNearAccount } from '@utils/chains/near/account'\nimport { ChainSignatureContract } from '@utils/chains/near/ChainSignatureContract'\nimport {\n type Response,\n type BitcoinRequest,\n type CosmosRequest,\n type EVMRequest,\n} from '@utils/chains/near/types'\n\nexport const EVMTransaction = async (\n req: EVMRequest,\n keyPair: KeyPair\n): Promise<Response> => {\n try {\n const account = await getNearAccount({\n networkId: req.nearAuthentication.networkId,\n accountId: req.nearAuthentication.accountId,\n keypair: keyPair,\n })\n\n const contract = new ChainSignatureContract({\n networkId: req.nearAuthentication.networkId,\n contractId: req.chainConfig.contract,\n accountId: account.accountId,\n keypair: keyPair,\n })\n\n const evm = new EVM({\n rpcUrl: req.chainConfig.providerUrl,\n contract,\n })\n\n const { transaction, hashesToSign } =\n await evm.prepareTransactionForSigning(req.transaction)\n\n const signature = await contract.sign({\n payload: hashesToSign[0],\n path: req.derivationPath,\n key_version: 0,\n })\n\n const txSerialized = evm.finalizeTransactionSigning({\n transaction,\n rsvSignatures: [signature],\n })\n\n const txHash = await evm.broadcastTx(txSerialized)\n\n return {\n transactionHash: txHash,\n success: true,\n }\n } catch (e: unknown) {\n console.error(e)\n return {\n success: false,\n errorMessage: e instanceof Error ? e.message : String(e),\n }\n }\n}\n\nexport const BTCTransaction = async (\n req: BitcoinRequest,\n keyPair: KeyPair\n): Promise<Response> => {\n try {\n const account = await getNearAccount({\n networkId: req.nearAuthentication.networkId,\n accountId: req.nearAuthentication.accountId,\n keypair: keyPair,\n })\n\n const contract = new ChainSignatureContract({\n networkId: req.nearAuthentication.networkId,\n contractId: req.chainConfig.contract,\n accountId: account.accountId,\n keypair: keyPair,\n })\n\n const btc = new Bitcoin({\n btcRpcAdapter: new BTCRpcAdapters.Mempool(req.chainConfig.providerUrl),\n contract,\n network: req.chainConfig.network,\n })\n\n const { transaction, hashesToSign } =\n await btc.prepareTransactionForSigning(req.transaction)\n\n const signatures = await Promise.all(\n hashesToSign.map(\n async (payload) =>\n await contract.sign({\n payload,\n path: req.derivationPath,\n key_version: 0,\n })\n )\n )\n\n const txSerialized = btc.finalizeTransactionSigning({\n transaction,\n rsvSignatures: signatures,\n })\n\n const txHash = await btc.broadcastTx(txSerialized)\n\n return {\n transactionHash: txHash,\n success: true,\n }\n } catch (e: unknown) {\n return {\n success: false,\n errorMessage: e instanceof Error ? e.message : String(e),\n }\n }\n}\n\nexport const CosmosTransaction = async (\n req: CosmosRequest,\n keyPair: KeyPair\n): Promise<Response> => {\n try {\n const account = await getNearAccount({\n networkId: req.nearAuthentication.networkId,\n accountId: req.nearAuthentication.accountId,\n keypair: keyPair,\n })\n\n const contract = new ChainSignatureContract({\n networkId: req.nearAuthentication.networkId,\n contractId: req.chainConfig.contract,\n accountId: account.accountId,\n keypair: keyPair,\n })\n\n const cosmos = new Cosmos({\n contract,\n chainId: req.chainConfig.chainId,\n })\n\n const { transaction, hashesToSign } =\n await cosmos.prepareTransactionForSigning(req.transaction)\n\n const signatures = await Promise.all(\n hashesToSign.map(\n async (payload) =>\n await contract.sign({\n payload,\n path: req.derivationPath,\n key_version: 0,\n })\n )\n )\n\n const txSerialized = cosmos.finalizeTransactionSigning({\n transaction,\n rsvSignatures: signatures,\n })\n\n const txHash = await cosmos.broadcastTx(txSerialized)\n\n return {\n transactionHash: txHash,\n success: true,\n }\n } catch (e: unknown) {\n console.error(e)\n return {\n success: false,\n errorMessage: e instanceof Error ? e.message : String(e),\n }\n }\n}\n","import type { KeyDerivationPath, HashToSign, RSVSignature } from '@chains/types'\n\nexport abstract class Chain<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","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 createPublicClient,\n http,\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 { Chain } from '@chains/Chain'\nimport type { BaseChainSignatureContract } from '@chains/ChainSignatureContract'\nimport type {\n EVMTransactionRequest,\n EVMUnsignedTransaction,\n EVMMessage,\n EVMTypedData,\n UserOperationV6,\n UserOperationV7,\n} from '@chains/EVM/types'\nimport { fetchEVMFeeProperties } from '@chains/EVM/utils'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@chains/types'\n\n/**\n * Implementation of the Chain interface for EVM-compatible networks.\n * Handles interactions with Ethereum Virtual Machine based blockchains like Ethereum, BSC, Polygon, etc.\n */\nexport class EVM extends Chain<EVMTransactionRequest, EVMUnsignedTransaction> {\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.rpcUrl - URL of the EVM JSON-RPC provider (e.g., Infura endpoint)\n * @param params.contract - Instance of the chain signature contract for MPC operations\n */\n constructor({\n rpcUrl,\n contract,\n }: {\n rpcUrl: string\n contract: BaseChainSignatureContract\n }) {\n super()\n\n this.contract = contract\n this.client = createPublicClient({\n transport: http(rpcUrl),\n })\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","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 '@chains/Bitcoin/BTCRpcAdapter'\nimport type {\n BTCInput,\n BTCNetworkIds,\n BTCOutput,\n BTCTransactionRequest,\n BTCUnsignedTransaction,\n} from '@chains/Bitcoin/types'\nimport { parseBTCNetwork } from '@chains/Bitcoin/utils'\nimport { Chain } from '@chains/Chain'\nimport type { BaseChainSignatureContract } from '@chains/ChainSignatureContract'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@chains/types'\nimport { cryptography } from '@utils'\n\n/**\n * Implementation of the Chain interface for Bitcoin network.\n * Handles interactions with both Bitcoin mainnet and testnet, supporting P2WPKH transactions.\n */\nexport class Bitcoin extends Chain<\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 { BTCTransaction, BTCInput, BTCOutput } from '@chains/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\nimport coinselect from 'coinselect'\n\nimport { BTCRpcAdapter } from '@chains/Bitcoin/BTCRpcAdapter/BTCRpcAdapter'\nimport {\n type BTCFeeRecommendation,\n type UTXO,\n} from '@chains/Bitcoin/BTCRpcAdapter/Mempool/types'\nimport type { BTCTransaction, BTCInput, BTCOutput } from '@chains/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","import { chains, assets } from 'chain-registry'\n\nimport { type ChainInfo } from '@chains/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'\nimport { TxRaw } from 'cosmjs-types/cosmos/tx/v1beta1/tx'\n\nimport { Chain } from '@chains/Chain'\nimport type { BaseChainSignatureContract } from '@chains/ChainSignatureContract'\nimport type {\n CosmosNetworkIds,\n CosmosTransactionRequest,\n CosmosUnsignedTransaction,\n ChainInfo,\n BalanceResponse,\n} from '@chains/Cosmos/types'\nimport { fetchChainInfo } from '@chains/Cosmos/utils'\nimport type { HashToSign, RSVSignature, KeyDerivationPath } from '@chains/types'\nimport { cryptography } from '@utils'\n\n/**\n * Implementation of the Chain interface for Cosmos-based networks.\n * Handles interactions with Cosmos SDK chains like Cosmos Hub, Osmosis, etc.\n */\nexport class Cosmos extends Chain<\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 * from './ChainSignaturesContract'\nexport * from './ChainSignaturesContractABI'\nexport * as errors from './errors'\n","import BN from 'bn.js'\nimport {\n encodeAbiParameters,\n keccak256,\n type TransactionReceipt,\n withRetry,\n type PublicClient,\n type WalletClient,\n type Hex,\n} from 'viem'\n\nimport { ChainSignatureContract as AbstractChainSignatureContract } from '@chains/ChainSignatureContract'\nimport type { SignArgs } from '@chains/ChainSignatureContract'\nimport type {\n NajPublicKey,\n RSVSignature,\n SigNetEvmMpcSignature,\n UncompressedPubKeySEC1,\n} from '@chains/types'\nimport { cryptography } from '@utils'\nimport { CHAINS, KDF_CHAIN_IDS } from '@utils/constants'\nimport { najToUncompressedPubKeySEC1 } from '@utils/cryptography'\nimport { getRootPublicKey } from '@utils/publicKey'\n\nimport { abi } from './ChainSignaturesContractABI'\nimport {\n SignatureNotFoundError,\n SignatureContractError,\n SigningError,\n} from './errors'\nimport type { SignOptions, SignRequest, SignatureErrorData } from './types'\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 this.rootPublicKey =\n args.rootPublicKey ||\n getRootPublicKey(this.contractAddress, CHAINS.ETHEREUM)\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 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 if (!this.walletClient?.account) {\n throw new Error('Wallet client required for signing operations')\n }\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.sign.algo ?? '',\n dest: options.sign.dest ?? '',\n params: options.sign.params ?? '',\n }\n\n const requestId = this.getRequestId(request)\n\n const hash = await this.walletClient.writeContract({\n address: this.contractAddress,\n abi,\n chain: this.publicClient.chain,\n account: this.walletClient.account,\n functionName: 'sign',\n args: [request],\n value: BigInt((await this.getCurrentSignatureDeposit()).toString()),\n })\n\n const receipt = await this.publicClient.waitForTransactionReceipt({ hash })\n\n try {\n const result = await withRetry(\n async () => {\n const result = await this.getSignatureFromEvents(requestId, receipt)\n if (result) {\n return result\n } else {\n throw new Error('Signature not found yet')\n }\n },\n {\n delay: options.retry.delay,\n retryCount: options.retry.retryCount,\n shouldRetry: ({ count, error }) => {\n // TODO: Should be enabled only on debug mode\n console.log(\n `Retrying get signature: ${count}/${options.retry.retryCount}`\n )\n return error.message === 'Signature not found yet'\n },\n }\n )\n\n if (result) {\n return result\n } else {\n const errorData = await this.getErrorFromEvents(requestId, receipt)\n if (errorData) {\n throw new SignatureContractError(errorData.error, requestId, receipt)\n } else {\n throw new SignatureNotFoundError(requestId, receipt)\n }\n }\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 private getRequestId(request: SignRequest): `0x${string}` {\n if (!this.walletClient?.account) {\n throw new Error('Wallet client required for signing operations')\n }\n\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 this.walletClient.account.address,\n request.payload,\n request.path,\n Number(request.keyVersion),\n this.publicClient.chain?.id ? BigInt(this.publicClient.chain.id) : 0n,\n request.algo,\n request.dest,\n request.params,\n ]\n )\n\n return keccak256(encoded)\n }\n\n async getErrorFromEvents(\n requestId: `0x${string}`,\n receipt: TransactionReceipt\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: receipt.blockNumber,\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 async getSignatureFromEvents(\n requestId: `0x${string}`,\n receipt: TransactionReceipt\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: receipt.blockNumber,\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 { type NajPublicKey } from '@chains'\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 NEAR: 'NEAR',\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.NEAR]: '0x18d',\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.NEAR]: {\n [ENVS.TESTNET_DEV]: 'dev.sig-net.testnet',\n [ENVS.TESTNET]: 'v1.sig-net.testnet',\n [ENVS.MAINNET]: 'v1.sig-net.near',\n },\n [CHAINS.ETHEREUM]: {\n [ENVS.TESTNET_DEV]: '0x69C6b28Fdc74618817fa380De29a653060e14009',\n [ENVS.TESTNET]: '0x83458E8Bf8206131Fe5c05127007FA164c0948A2',\n [ENVS.MAINNET]: '0xf8bdC0612361a1E49a8E01423d4C0cFc5dF4791A',\n },\n}\n","import type { NajPublicKey } from '@chains/types'\nimport {\n CONTRACT_ADDRESSES,\n ROOT_PUBLIC_KEYS,\n type CHAINS,\n} from '@utils/constants'\n\nexport const getRootPublicKey = (\n contractAddress: string,\n chain: keyof typeof CHAINS\n): NajPublicKey => {\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 throw new Error(\n `Contract address ${contractAddress} not supported for chain ${chain}`\n )\n}\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"]}
@@ -0,0 +1,3 @@
1
+ import xt from'bn.js';import {getTransactionLastResult}from'near-api-js/lib/providers';import {Contract,Connection,Account}from'@near-js/accounts';import {KeyPair}from'@near-js/crypto';import {InMemoryKeyStore}from'@near-js/keystores';import {base58}from'@scure/base';import {ec}from'elliptic';import {keccak256,createPublicClient,http,concatHex,numberToHex,getAddress,serializeTransaction,parseTransaction,toBytes,hashMessage,hashTypedData,encodeAbiParameters,hexToBigInt,concat,pad,isAddress,withRetry}from'viem';import*as h from'bitcoinjs-lib';import qt from'coinselect';import {encodeSecp256k1Pubkey}from'@cosmjs/amino';import {sha256,ripemd160}from'@cosmjs/crypto';import {fromHex,toBase64,fromBase64}from'@cosmjs/encoding';import {Registry,encodePubkey,makeAuthInfoBytes,makeSignDoc,makeSignBytes}from'@cosmjs/proto-signing';import {calculateFee,GasPrice,StargateClient}from'@cosmjs/stargate';import {bech32}from'bech32';import {SignMode}from'cosmjs-types/cosmos/tx/signing/v1beta1/signing';import {TxRaw}from'cosmjs-types/cosmos/tx/v1beta1/tx';import {chains,assets}from'chain-registry';var wt=Object.defineProperty;var m=(r,t)=>{for(var e in t)wt(r,e,{get:t[e],enumerable:true});};var bt={};m(bt,{chains:()=>st,constants:()=>nt,cryptography:()=>u});var st={};m(st,{evm:()=>it,near:()=>Q});var Q={};m(Q,{ChainSignatureContract:()=>l,signAndSend:()=>J,transactionBuilder:()=>G});var G={};m(G,{mpcPayloadsToChainSigTransaction:()=>Ft,responseToMpcSignature:()=>Ot});var j=class{},b=class extends j{};var D=new xt("300000000000000"),A="dontcare";var w=async({networkId:r,accountId:t=A,keypair:e=KeyPair.fromRandom("ed25519")})=>{let n=new InMemoryKeyStore;await n.setKey(r,t,e);let a=Connection.fromConfig({networkId:r,provider:{type:"JsonRpcProvider",args:{url:{testnet:"https://rpc.testnet.near.org",mainnet:"https://rpc.mainnet.near.org"}[r]}},signer:{type:"InMemorySigner",keyStore:n}});return new Account(a,t)};var u={};m(u,{compressPubKey:()=>Kt,deriveChildPublicKey:()=>Nt,najToUncompressedPubKeySEC1:()=>x,toRSV:()=>kt});var kt=r=>{if("big_r"in r&&typeof r.big_r=="object"&&"affine_point"in r.big_r&&"s"in r&&typeof r.s=="object"&&"scalar"in r.s)return {r:r.big_r.affine_point.substring(2),s:r.s.scalar,v:r.recovery_id+27};if("big_r"in r&&typeof r.big_r=="string"&&"s"in r&&typeof r.s=="string")return {r:r.big_r.substring(2),s:r.s,v:r.recovery_id+27};if("bigR"in r&&"x"in r.bigR&&"s"in r&&typeof r.s=="bigint")return {r:r.bigR.x.toString(16).padStart(64,"0"),s:r.s.toString(16).padStart(64,"0"),v:r.recoveryId+27};throw new Error("Invalid signature format")},Kt=r=>{let t=r.slice(2);if(t.length!==128)throw new Error("Invalid uncompressed public key length");let e=t.slice(0,64),n=t.slice(64);return (parseInt(n.slice(-1),16)%2===0?"02":"03")+e},x=r=>{let t=base58.decode(r.split(":")[1]);return `04${Buffer.from(t).toString("hex")}`};function Nt(r,t,e="",n){let a=new ec("secp256k1"),s=`sig.network v1.0.0 epsilon derivation,${n},${t},${e}`,o=keccak256(Buffer.from(s)).slice(2),c=r.substring(2,66),p=r.substring(66),y=a.curve.point(c,p),d=a.g.mul(o),V=y.add(d),M=V.getX().toString("hex").padStart(64,"0"),z=V.getY().toString("hex").padStart(64,"0");return `04${M}${z}`}var Mt=r=>{if(r===A)throw new Error("A valid account ID and keypair are required for change methods. Please instantiate a new contract with valid credentials.")},l=class extends b{constructor({networkId:t,contractId:e,accountId:n=A,keypair:a=KeyPair.fromRandom("ed25519")}){super(),this.networkId=t,this.contractId=e,this.accountId=n,this.keypair=a;}async getContract(){let t=await w({networkId:this.networkId,accountId:this.accountId,keypair:this.keypair});return new Contract(t,this.contractId,{viewMethods:["public_key","experimental_signature_deposit","derived_public_key"],changeMethods:["sign"],useLocalViewExecution:false})}async getCurrentSignatureDeposit(){let t=await this.getContract();return new xt((await t.experimental_signature_deposit()).toLocaleString("fullwide",{useGrouping:false}))}async getDerivedPublicKey(t){let n=await(await this.getContract()).derived_public_key(t);return x(n)}async getPublicKey(){let e=await(await this.getContract()).public_key();return x(e)}async sign(t){Mt(this.accountId);let e=await this.getContract(),n=await this.getCurrentSignatureDeposit(),a=await e.sign({args:{request:t},gas:D,amount:n});return u.toRSV(a)}};var Ft=async({networkId:r,contractId:t,hashesToSign:e,path:n})=>{let i=await new l({networkId:r,contractId:t}).getCurrentSignatureDeposit();return {receiverId:t,actions:e.map(s=>({type:"FunctionCall",params:{methodName:"sign",args:{request:{payload:Array.from(s),path:n,key_version:0}},gas:D.div(new xt(e.length)).toString(),deposit:i?.toString()||"1"}}))}},Ot=({response:r})=>{let t=getTransactionLastResult(r);if(t)return u.toRSV(t)};var J={};m(J,{keypair:()=>Y});var Y={};m(Y,{BTCTransaction:()=>ue,CosmosTransaction:()=>de,EVMTransaction:()=>pe});var f=class{};async function L(r,t){let[e,n]=await Promise.all([r.estimateGas(t),r.estimateFeesPerGas()]),a=n.maxFeePerGas??BigInt(1e10),i=n.maxPriorityFeePerGas??BigInt(1e10);return {gas:e,maxFeePerGas:a,maxPriorityFeePerGas:i}}var B=class extends f{constructor({rpcUrl:t,contract:e}){super(),this.contract=e,this.client=createPublicClient({transport:http(t)});}async attachGasAndNonce(t){let e=await L(this.client,t),n=await this.client.getTransactionCount({address:t.from}),{from:a,...i}=t;return {...e,nonce:n,chainId:Number(await this.client.getChainId()),type:"eip1559",...i}}transformRSVSignature(t){return {r:`0x${t.r}`,s:`0x${t.s}`,yParity:t.v-27}}assembleSignature(t){let{r:e,s:n,yParity:a}=this.transformRSVSignature(t);if(a===void 0)throw new Error("Missing yParity");return concatHex([e,n,numberToHex(a+27,{size:1})])}async deriveAddressAndPublicKey(t,e){let n=await this.contract.getDerivedPublicKey({path:e,predecessor:t});if(!n)throw new Error("Failed to get derived public key");let a=n.startsWith("04")?n.slice(2):n,i=keccak256(Buffer.from(a,"hex"));return {address:getAddress(`0x${i.slice(-40)}`),publicKey:n}}async getBalance(t){return {balance:await this.client.getBalance({address:t}),decimals:18}}serializeTransaction(t){return serializeTransaction(t)}deserializeTransaction(t){return parseTransaction(t)}async prepareTransactionForSigning(t){let e=await this.attachGasAndNonce(t),n=serializeTransaction(e),a=toBytes(keccak256(n));return {transaction:e,hashesToSign:[Array.from(a)]}}async prepareMessageForSigning(t){return {hashToSign:Array.from(toBytes(hashMessage(t)))}}async prepareTypedDataForSigning(t){return {hashToSign:Array.from(toBytes(hashTypedData(t)))}}async prepareUserOpForSigning(t,e,n){let a=n??await this.client.getChainId(),i=e||"0x0000000071727De22E5E9d8BAf0edAc6f37da032",s=encodeAbiParameters([{type:"bytes32"},{type:"address"},{type:"uint256"}],[keccak256(encodeAbiParameters([{type:"address"},{type:"uint256"},{type:"bytes32"},{type:"bytes32"},{type:"bytes32"},{type:"uint256"},{type:"bytes32"},{type:"bytes32"}],[t.sender,hexToBigInt(t.nonce),keccak256("factory"in t&&"factoryData"in t&&t.factory&&t.factoryData?concat([t.factory,t.factoryData]):"initCode"in t?t.initCode:"0x"),keccak256(t.callData),concat([pad(t.verificationGasLimit,{size:16}),pad(t.callGasLimit,{size:16})]),hexToBigInt(t.preVerificationGas),concat([pad(t.maxPriorityFeePerGas,{size:16}),pad(t.maxFeePerGas,{size:16})]),keccak256("paymaster"in t&&t.paymaster&&isAddress(t.paymaster)?concat([t.paymaster,pad(t.paymasterVerificationGasLimit,{size:16}),pad(t.paymasterPostOpGasLimit,{size:16}),t.paymasterData]):"paymasterAndData"in t?t.paymasterAndData:"0x")])),i,BigInt(a)]),o=keccak256(s);return {userOp:t,hashToSign:Array.from(toBytes(hashMessage({raw:o})))}}finalizeTransactionSigning({transaction:t,rsvSignatures:e}){let n=this.transformRSVSignature(e[0]);return serializeTransaction(t,n)}finalizeMessageSigning({rsvSignature:t}){return this.assembleSignature(t)}finalizeTypedDataSigning({rsvSignature:t}){return this.assembleSignature(t)}finalizeUserOpSigning({userOp:t,rsvSignature:e}){let{r:n,s:a,yParity:i}=this.transformRSVSignature(e);if(i===void 0)throw new Error("Missing yParity");return {...t,signature:concatHex(["0x00",n,a,numberToHex(Number(i+27),{size:1})])}}async broadcastTx(t){try{return await this.client.sendRawTransaction({serializedTransaction:t})}catch(e){throw console.error("Transaction broadcast failed:",e),new Error("Failed to broadcast transaction.")}}};function q(r){switch(r.toLowerCase()){case "mainnet":return h.networks.bitcoin;case "testnet":return h.networks.testnet;case "regtest":return h.networks.regtest;default:throw new Error(`Unknown Bitcoin network: ${r}`)}}var k=class r extends f{static{this.SATOSHIS_PER_BTC=1e8;}constructor({network:t,contract:e,btcRpcAdapter:n}){super(),this.network=t,this.btcRpcAdapter=n,this.contract=e;}static toBTC(t){return t/r.SATOSHIS_PER_BTC}static toSatoshi(t){return Math.round(t*r.SATOSHIS_PER_BTC)}async fetchTransaction(t){let e=await this.btcRpcAdapter.getTransaction(t),n=new h.Transaction;return e.vout.forEach(a=>{let i=Buffer.from(a.scriptpubkey,"hex");n.addOutput(i,Number(a.value));}),n}static transformRSVSignature(t){let e=t.r.padStart(64,"0"),n=t.s.padStart(64,"0"),a=Buffer.from(e+n,"hex");if(a.length!==64)throw new Error("Invalid signature length.");return a}async createPSBT({transactionRequest:t}){let{inputs:e,outputs:n}=t.inputs&&t.outputs?t:await this.btcRpcAdapter.selectUTXOs(t.from,[{address:t.to,value:parseFloat(t.value)}]),a=new h.Psbt({network:q(this.network)});return await Promise.all(e.map(async i=>{if(!i.scriptPubKey){let o=(await this.fetchTransaction(i.txid)).outs[i.vout];i.scriptPubKey=o.script;}a.addInput({hash:i.txid,index:i.vout,witnessUtxo:{script:i.scriptPubKey,value:i.value}});})),n.forEach(i=>{"address"in i?a.addOutput({address:i.address,value:i.value}):"script"in i?a.addOutput({script:i.script,value:i.value}):t.from!==void 0&&a.addOutput({value:Number(i.value),address:t.from});}),a}async getBalance(t){return {balance:BigInt(await this.btcRpcAdapter.getBalance(t)),decimals:8}}async deriveAddressAndPublicKey(t,e){let n=await this.contract.getDerivedPublicKey({path:e,predecessor:t});if(!n)throw new Error("Failed to get derived public key");let a=u.compressPubKey(n),i=Buffer.from(a,"hex"),s=q(this.network),o=h.payments.p2wpkh({pubkey:i,network:s}),{address:c}=o;if(!c)throw new Error("Failed to generate Bitcoin address");return {address:c,publicKey:a}}serializeTransaction(t){return JSON.stringify({psbt:t.psbt.toHex(),publicKey:t.publicKey})}deserializeTransaction(t){let e=JSON.parse(t);return {psbt:h.Psbt.fromHex(e.psbt),publicKey:e.publicKey}}async prepareTransactionForSigning(t){let e=Buffer.from(t.publicKey,"hex"),n=await this.createPSBT({transactionRequest:t}),a=n.toHex(),i=[],s=o=>({publicKey:e,sign:c=>(i[o]=Array.from(c),Buffer.alloc(64))});for(let o=0;o<n.inputCount;o++)n.signInput(o,s(o));return {transaction:{psbt:h.Psbt.fromHex(a),publicKey:t.publicKey},hashesToSign:i}}finalizeTransactionSigning({transaction:{psbt:t,publicKey:e},rsvSignatures:n}){let a=Buffer.from(e,"hex"),i=s=>({publicKey:a,sign:()=>{let o=n[s];return r.transformRSVSignature(o)}});for(let s=0;s<t.inputCount;s++)t.signInput(s,i(s));return t.finalizeAllInputs(),t.extractTransaction().toHex()}async broadcastTx(t){return await this.btcRpcAdapter.broadcastTransaction(t)}};var E=class{};var K=class extends E{constructor(t){super(),this.providerUrl=t;}async fetchFeeRate(t=6){let n=await(await fetch(`${this.providerUrl}/v1/fees/recommended`)).json();return t<=1?n.fastestFee:t<=3?n.halfHourFee:t<=6?n.hourFee:n.economyFee}async fetchUTXOs(t){try{return await(await fetch(`${this.providerUrl}/address/${t}/utxo`)).json()}catch(e){return console.error("Failed to fetch UTXOs:",e),[]}}async selectUTXOs(t,e,n=6){let a=await this.fetchUTXOs(t),i=await this.fetchFeeRate(n),s=qt(a,e,Math.ceil(i+1));if(!s.inputs||!s.outputs)throw new Error("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.");return {inputs:s.inputs,outputs:s.outputs}}async broadcastTransaction(t){let e=await fetch(`${this.providerUrl}/tx`,{method:"POST",body:t});if(e.ok)return await e.text();throw new Error(`Failed to broadcast transaction: ${await e.text()}`)}async getBalance(t){let n=await(await fetch(`${this.providerUrl}/address/${t}`)).json();return n.chain_stats.funded_txo_sum-n.chain_stats.spent_txo_sum}async getTransaction(t){return await(await fetch(`${this.providerUrl}/tx/${t}`)).json()}};var W={Mempool:K};var mt=async r=>{let t=chains.find(d=>d.chain_id===r);if(!t)throw new Error(`Chain info not found for chainId: ${r}`);let{bech32_prefix:e,chain_id:n}=t,a=t.staking?.staking_tokens?.[0]?.denom,i=t.apis?.rpc?.[0]?.address,s=t.apis?.rest?.[0]?.address,o=t.fees?.fee_tokens?.[0]?.average_gas_price;if(!e||!a||!i||!s||!n||o===void 0)throw new Error(`Missing required chain information for ${t.chain_name}`);let p=assets.find(d=>d.chain_name===t.chain_name)?.assets.find(d=>d.base===a),y=p?.denom_units.find(d=>d.denom===p.display)?.exponent;if(y===void 0)throw new Error(`Could not find decimals for ${a} on chain ${t.chain_name}`);return {prefix:e,denom:a,rpcUrl:i,restUrl:s,expectedChainId:n,gasPrice:o,decimals:y}};var _=class extends f{constructor({chainId:t,contract:e,endpoints:n}){super(),this.contract=e,this.registry=new Registry,this.chainId=t,this.endpoints=n;}transformRSVSignature(t){return new Uint8Array([...fromHex(t.r),...fromHex(t.s)])}async getChainInfo(){return {...await mt(this.chainId),...this.endpoints}}async getBalance(t){try{let{restUrl:e,denom:n,decimals:a}=await this.getChainInfo(),i=await fetch(`${e}/cosmos/bank/v1beta1/balances/${t}`);if(!i.ok)throw new Error(`HTTP error! status: ${i.status}`);let c=(await i.json()).balances.find(p=>p.denom===n)?.amount??"0";return {balance:BigInt(c),decimals:a}}catch(e){throw console.error("Failed to fetch Cosmos balance:",e),new Error("Failed to fetch Cosmos balance")}}async deriveAddressAndPublicKey(t,e){let{prefix:n}=await this.getChainInfo(),a=await this.contract.getDerivedPublicKey({path:e,predecessor:t});if(!a)throw new Error("Failed to get derived public key");let i=u.compressPubKey(a),s=sha256(fromHex(i)),o=ripemd160(s);return {address:bech32.encode(n,bech32.toWords(o)),publicKey:i}}serializeTransaction(t){let e=TxRaw.encode(t).finish();return toBase64(e)}deserializeTransaction(t){return TxRaw.decode(fromBase64(t))}async prepareTransactionForSigning(t){let{denom:e,rpcUrl:n,gasPrice:a}=await this.getChainInfo(),i=fromHex(t.publicKey),s=t.gas||2e5,o=calculateFee(s,GasPrice.fromString(`${a}${e}`)),p=await(await StargateClient.connect(n)).getAccount(t.address);if(!p)throw new Error(`Account ${t.address} does not exist on chain`);let{accountNumber:y,sequence:d}=p,V={typeUrl:"/cosmos.tx.v1beta1.TxBody",value:{messages:t.messages,memo:t.memo||""}},M=this.registry.encode(V),z=encodePubkey(encodeSecp256k1Pubkey(i)),ot=makeAuthInfoBytes([{pubkey:z,sequence:d}],o.amount,Number(o.gas),void 0,void 0,SignMode.SIGN_MODE_DIRECT),Tt=makeSignDoc(M,ot,this.chainId,y),St=makeSignBytes(Tt),Ct=Array.from(sha256(St));return {transaction:TxRaw.fromPartial({bodyBytes:M,authInfoBytes:ot,signatures:[]}),hashesToSign:[Ct]}}finalizeTransactionSigning({transaction:t,rsvSignatures:e}){t.signatures=e.map(a=>this.transformRSVSignature(a));let n=TxRaw.encode(t).finish();return Buffer.from(n).toString("hex")}async broadcastTx(t){try{let{rpcUrl:e}=await this.getChainInfo(),n=await StargateClient.connect(e),a=fromHex(t),i=await n.broadcastTx(a);if(i.code!==0)throw new Error(`Broadcast error: ${i.rawLog}`);return i.transactionHash}catch(e){throw console.error("Transaction broadcast failed:",e),new Error("Failed to broadcast transaction.")}}};var pe=async(r,t)=>{try{let e=await w({networkId:r.nearAuthentication.networkId,accountId:r.nearAuthentication.accountId,keypair:t}),n=new l({networkId:r.nearAuthentication.networkId,contractId:r.chainConfig.contract,accountId:e.accountId,keypair:t}),a=new B({rpcUrl:r.chainConfig.providerUrl,contract:n}),{transaction:i,hashesToSign:s}=await a.prepareTransactionForSigning(r.transaction),o=await n.sign({payload:s[0],path:r.derivationPath,key_version:0}),c=a.finalizeTransactionSigning({transaction:i,rsvSignatures:[o]});return {transactionHash:await a.broadcastTx(c),success:!0}}catch(e){return console.error(e),{success:false,errorMessage:e instanceof Error?e.message:String(e)}}},ue=async(r,t)=>{try{let e=await w({networkId:r.nearAuthentication.networkId,accountId:r.nearAuthentication.accountId,keypair:t}),n=new l({networkId:r.nearAuthentication.networkId,contractId:r.chainConfig.contract,accountId:e.accountId,keypair:t}),a=new k({btcRpcAdapter:new W.Mempool(r.chainConfig.providerUrl),contract:n,network:r.chainConfig.network}),{transaction:i,hashesToSign:s}=await a.prepareTransactionForSigning(r.transaction),o=await Promise.all(s.map(async y=>await n.sign({payload:y,path:r.derivationPath,key_version:0}))),c=a.finalizeTransactionSigning({transaction:i,rsvSignatures:o});return {transactionHash:await a.broadcastTx(c),success:!0}}catch(e){return {success:false,errorMessage:e instanceof Error?e.message:String(e)}}},de=async(r,t)=>{try{let e=await w({networkId:r.nearAuthentication.networkId,accountId:r.nearAuthentication.accountId,keypair:t}),n=new l({networkId:r.nearAuthentication.networkId,contractId:r.chainConfig.contract,accountId:e.accountId,keypair:t}),a=new _({contract:n,chainId:r.chainConfig.chainId}),{transaction:i,hashesToSign:s}=await a.prepareTransactionForSigning(r.transaction),o=await Promise.all(s.map(async y=>await n.sign({payload:y,path:r.derivationPath,key_version:0}))),c=a.finalizeTransactionSigning({transaction:i,rsvSignatures:o});return {transactionHash:await a.broadcastTx(c),success:!0}}catch(e){return console.error(e),{success:false,errorMessage:e instanceof Error?e.message:String(e)}}};var it={};m(it,{ChainSignatureContract:()=>at,abi:()=>C,errors:()=>rt});var nt={};m(nt,{CHAINS:()=>S,CONTRACT_ADDRESSES:()=>et,ENVS:()=>g,KDF_CHAIN_IDS:()=>tt,ROOT_PUBLIC_KEYS:()=>Z});var g={TESTNET_DEV:"TESTNET_DEV",TESTNET:"TESTNET",MAINNET:"MAINNET"},S={ETHEREUM:"ETHEREUM",NEAR:"NEAR"},Z={[g.TESTNET_DEV]:"secp256k1:54hU5wcCmVUPFWLDALXMh1fFToZsVXrx9BbTbHzSfQq1Kd1rJZi52iPa4QQxo6s5TgjWqgpY8HamYuUDzG6fAaUq",[g.TESTNET]:"secp256k1:3Ww8iFjqTHufye5aRGUvrQqETegR4gVUcW8FX5xzscaN9ENhpkffojsxJwi6N1RbbHMTxYa9UyKeqK3fsMuwxjR5",[g.MAINNET]:"secp256k1:4tY4qMzusmgX5wYdG35663Y3Qar3CTbpApotwk9ZKLoF79XA4DjG8XoByaKdNHKQX9Lz5hd7iJqsWdTKyA7dKa6Z"},tt={[S.ETHEREUM]:"0x1",[S.NEAR]:"0x18d"},et={[S.NEAR]:{[g.TESTNET_DEV]:"dev.sig-net.testnet",[g.TESTNET]:"v1.sig-net.testnet",[g.MAINNET]:"v1.sig-net.near"},[S.ETHEREUM]:{[g.TESTNET_DEV]:"0x69C6b28Fdc74618817fa380De29a653060e14009",[g.TESTNET]:"0x83458E8Bf8206131Fe5c05127007FA164c0948A2",[g.MAINNET]:"0xf8bdC0612361a1E49a8E01423d4C0cFc5dF4791A"}};var ht=(r,t)=>{let e=Object.entries(et[t]).find(([n,a])=>a.toLowerCase()===r.toLowerCase())?.[0];if(e)return Z[e];throw new Error(`Contract address ${r} not supported for chain ${t}`)};var C=[{inputs:[{internalType:"address",name:"_mpc_network",type:"address"},{internalType:"uint256",name:"_signatureDeposit",type:"uint256"}],stateMutability:"nonpayable",type:"constructor"},{inputs:[],name:"AccessControlBadConfirmation",type:"error"},{inputs:[{internalType:"address",name:"account",type:"address"},{internalType:"bytes32",name:"neededRole",type:"bytes32"}],name:"AccessControlUnauthorizedAccount",type:"error"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"role",type:"bytes32"},{indexed:true,internalType:"bytes32",name:"previousAdminRole",type:"bytes32"},{indexed:true,internalType:"bytes32",name:"newAdminRole",type:"bytes32"}],name:"RoleAdminChanged",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"role",type:"bytes32"},{indexed:true,internalType:"address",name:"account",type:"address"},{indexed:true,internalType:"address",name:"sender",type:"address"}],name:"RoleGranted",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"role",type:"bytes32"},{indexed:true,internalType:"address",name:"account",type:"address"},{indexed:true,internalType:"address",name:"sender",type:"address"}],name:"RoleRevoked",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"requestId",type:"bytes32"},{indexed:false,internalType:"address",name:"responder",type:"address"},{indexed:false,internalType:"string",name:"error",type:"string"}],name:"SignatureError",type:"event"},{anonymous:false,inputs:[{indexed:false,internalType:"address",name:"sender",type:"address"},{indexed:false,internalType:"bytes32",name:"payload",type:"bytes32"},{indexed:false,internalType:"uint32",name:"keyVersion",type:"uint32"},{indexed:false,internalType:"uint256",name:"deposit",type:"uint256"},{indexed:false,internalType:"uint256",name:"chainId",type:"uint256"},{indexed:false,internalType:"string",name:"path",type:"string"},{indexed:false,internalType:"string",name:"algo",type:"string"},{indexed:false,internalType:"string",name:"dest",type:"string"},{indexed:false,internalType:"string",name:"params",type:"string"}],name:"SignatureRequested",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"bytes32",name:"requestId",type:"bytes32"},{indexed:false,internalType:"address",name:"responder",type:"address"},{components:[{components:[{internalType:"uint256",name:"x",type:"uint256"},{internalType:"uint256",name:"y",type:"uint256"}],internalType:"struct ChainSignatures.AffinePoint",name:"bigR",type:"tuple"},{internalType:"uint256",name:"s",type:"uint256"},{internalType:"uint8",name:"recoveryId",type:"uint8"}],indexed:false,internalType:"struct ChainSignatures.Signature",name:"signature",type:"tuple"}],name:"SignatureResponded",type:"event"},{anonymous:false,inputs:[{indexed:true,internalType:"address",name:"owner",type:"address"},{indexed:false,internalType:"uint256",name:"amount",type:"uint256"}],name:"Withdraw",type:"event"},{inputs:[],name:"DEFAULT_ADMIN_ROLE",outputs:[{internalType:"bytes32",name:"",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"}],name:"getRoleAdmin",outputs:[{internalType:"bytes32",name:"",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[],name:"getSignatureDeposit",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"account",type:"address"}],name:"grantRole",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"account",type:"address"}],name:"hasRole",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"callerConfirmation",type:"address"}],name:"renounceRole",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"bytes32",name:"requestId",type:"bytes32"},{components:[{components:[{internalType:"uint256",name:"x",type:"uint256"},{internalType:"uint256",name:"y",type:"uint256"}],internalType:"struct ChainSignatures.AffinePoint",name:"bigR",type:"tuple"},{internalType:"uint256",name:"s",type:"uint256"},{internalType:"uint8",name:"recoveryId",type:"uint8"}],internalType:"struct ChainSignatures.Signature",name:"signature",type:"tuple"}],internalType:"struct ChainSignatures.Response[]",name:"_responses",type:"tuple[]"}],name:"respond",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"bytes32",name:"requestId",type:"bytes32"},{internalType:"string",name:"errorMessage",type:"string"}],internalType:"struct ChainSignatures.ErrorResponse[]",name:"_errors",type:"tuple[]"}],name:"respondError",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bytes32",name:"role",type:"bytes32"},{internalType:"address",name:"account",type:"address"}],name:"revokeRole",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_amount",type:"uint256"}],name:"setSignatureDeposit",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"bytes32",name:"payload",type:"bytes32"},{internalType:"string",name:"path",type:"string"},{internalType:"uint32",name:"keyVersion",type:"uint32"},{internalType:"string",name:"algo",type:"string"},{internalType:"string",name:"dest",type:"string"},{internalType:"string",name:"params",type:"string"}],internalType:"struct ChainSignatures.SignRequest",name:"_request",type:"tuple"}],name:"sign",outputs:[],stateMutability:"payable",type:"function"},{inputs:[{internalType:"bytes4",name:"interfaceId",type:"bytes4"}],name:"supportsInterface",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"uint256",name:"_amount",type:"uint256"},{internalType:"address",name:"_receiver",type:"address"}],name:"withdraw",outputs:[],stateMutability:"nonpayable",type:"function"}];var rt={};m(rt,{ChainSignatureError:()=>v,SignatureContractError:()=>I,SignatureNotFoundError:()=>R,SigningError:()=>U});var v=class extends Error{constructor(t,e,n){super(t),this.name="ChainSignatureError",this.requestId=e,this.receipt=n;}},R=class extends v{constructor(t,e){super("Signature not found after maximum retries",t,e),this.name="SignatureNotFoundError";}},I=class extends v{constructor(t,e,n){super(`Signature error: ${t}`,e,n),this.name="SignatureContractError",this.errorCode=t;}},U=class extends v{constructor(t,e,n){super("Error signing request",t,e),this.name="SigningError",this.originalError=n;}};var at=class extends b{constructor(t){super(),this.publicClient=t.publicClient,this.walletClient=t.walletClient,this.contractAddress=t.contractAddress,this.rootPublicKey=t.rootPublicKey||ht(this.contractAddress,S.ETHEREUM);}async getCurrentSignatureDeposit(){let t=await this.publicClient.readContract({address:this.contractAddress,abi:C,functionName:"getSignatureDeposit"});return new xt(t.toString())}async getDerivedPublicKey(t){return u.deriveChildPublicKey(await this.getPublicKey(),t.predecessor.toLowerCase(),t.path,tt.ETHEREUM)}async getPublicKey(){return x(this.rootPublicKey)}async getLatestKeyVersion(){let t=await this.publicClient.readContract({address:this.contractAddress,abi:C,functionName:"latestKeyVersion"});return Number(t)}async sign(t,e={sign:{algo:"",dest:"",params:""},retry:{delay:5e3,retryCount:12}}){if(!this.walletClient?.account)throw new Error("Wallet client required for signing operations");let n={payload:`0x${Buffer.from(t.payload).toString("hex")}`,path:t.path,keyVersion:t.key_version,algo:e.sign.algo??"",dest:e.sign.dest??"",params:e.sign.params??""},a=this.getRequestId(n),i=await this.walletClient.writeContract({address:this.contractAddress,abi:C,chain:this.publicClient.chain,account:this.walletClient.account,functionName:"sign",args:[n],value:BigInt((await this.getCurrentSignatureDeposit()).toString())}),s=await this.publicClient.waitForTransactionReceipt({hash:i});try{let o=await withRetry(async()=>{let c=await this.getSignatureFromEvents(a,s);if(c)return c;throw new Error("Signature not found yet")},{delay:e.retry.delay,retryCount:e.retry.retryCount,shouldRetry:({count:c,error:p})=>(console.log(`Retrying get signature: ${c}/${e.retry.retryCount}`),p.message==="Signature not found yet")});if(o)return o;{let c=await this.getErrorFromEvents(a,s);throw c?new I(c.error,a,s):new R(a,s)}}catch(o){throw o instanceof R||o instanceof I?o:new U(a,s,o instanceof Error?o:void 0)}}getRequestId(t){if(!this.walletClient?.account)throw new Error("Wallet client required for signing operations");let e=encodeAbiParameters([{type:"address"},{type:"bytes"},{type:"string"},{type:"uint32"},{type:"uint256"},{type:"string"},{type:"string"},{type:"string"}],[this.walletClient.account.address,t.payload,t.path,Number(t.keyVersion),this.publicClient.chain?.id?BigInt(this.publicClient.chain.id):0n,t.algo,t.dest,t.params]);return keccak256(e)}async getErrorFromEvents(t,e){let n=await this.publicClient.getContractEvents({address:this.contractAddress,abi:C,eventName:"SignatureError",args:{requestId:t},fromBlock:e.blockNumber,toBlock:"latest"});if(n.length>0){let{args:a}=n[n.length-1];return a}}async getSignatureFromEvents(t,e){let n=await this.publicClient.getContractEvents({address:this.contractAddress,abi:C,eventName:"SignatureResponded",args:{requestId:t},fromBlock:e.blockNumber,toBlock:"latest"});if(n.length>0){let{args:a}=n[n.length-1];return u.toRSV(a.signature)}}};
2
+ export{E as BTCRpcAdapter,W as BTCRpcAdapters,k as Bitcoin,f as Chain,b as ChainSignatureContract,_ as Cosmos,B as EVM,L as fetchEVMFeeProperties,bt as utils};//# sourceMappingURL=index.browser.js.map
3
+ //# sourceMappingURL=index.browser.js.map