@swapkit/wallets 3.0.0-beta.2 → 3.0.0-beta.20

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 (92) hide show
  1. package/dist/{chunk-p1kdg37m.js → chunk-38ztynv0.js} +1 -1
  2. package/dist/{chunk-p1kdg37m.js.map → chunk-38ztynv0.js.map} +1 -1
  3. package/dist/chunk-4ef2xs46.js +3 -0
  4. package/dist/chunk-4ef2xs46.js.map +10 -0
  5. package/dist/chunk-qgv1myym.js +3 -0
  6. package/dist/chunk-qgv1myym.js.map +10 -0
  7. package/dist/chunk-s6xqbsy0.js +4 -0
  8. package/dist/{chunk-czhtd6cy.js.map → chunk-s6xqbsy0.js.map} +3 -3
  9. package/dist/{chunk-qadd75nn.js → chunk-sygzrjje.js} +2 -2
  10. package/dist/{chunk-qadd75nn.js.map → chunk-sygzrjje.js.map} +3 -3
  11. package/dist/chunk-w07sv0jv.js +3 -0
  12. package/dist/chunk-w07sv0jv.js.map +10 -0
  13. package/dist/chunk-y0g3prs9.js +3 -0
  14. package/dist/chunk-y0g3prs9.js.map +10 -0
  15. package/dist/src/bitget/index.cjs +2 -2
  16. package/dist/src/bitget/index.cjs.map +3 -3
  17. package/dist/src/bitget/index.js +2 -2
  18. package/dist/src/bitget/index.js.map +3 -3
  19. package/dist/src/coinbase/index.js +1 -1
  20. package/dist/src/ctrl/index.cjs +2 -2
  21. package/dist/src/ctrl/index.cjs.map +3 -3
  22. package/dist/src/ctrl/index.js +2 -2
  23. package/dist/src/ctrl/index.js.map +3 -3
  24. package/dist/src/evm-extensions/index.js +1 -1
  25. package/dist/src/exodus/index.cjs +2 -2
  26. package/dist/src/exodus/index.cjs.map +3 -3
  27. package/dist/src/exodus/index.js +2 -2
  28. package/dist/src/exodus/index.js.map +3 -3
  29. package/dist/src/index.js +1 -1
  30. package/dist/src/keepkey/index.cjs +2 -2
  31. package/dist/src/keepkey/index.cjs.map +4 -4
  32. package/dist/src/keepkey/index.js +2 -2
  33. package/dist/src/keepkey/index.js.map +4 -4
  34. package/dist/src/keepkey-bex/index.js +1 -1
  35. package/dist/src/keplr/index.js +1 -1
  36. package/dist/src/keystore/index.cjs +2 -2
  37. package/dist/src/keystore/index.cjs.map +3 -3
  38. package/dist/src/keystore/index.js +2 -2
  39. package/dist/src/keystore/index.js.map +3 -3
  40. package/dist/src/ledger/index.cjs +3 -3
  41. package/dist/src/ledger/index.cjs.map +12 -11
  42. package/dist/src/ledger/index.js +3 -3
  43. package/dist/src/ledger/index.js.map +12 -11
  44. package/dist/src/okx/index.cjs +2 -2
  45. package/dist/src/okx/index.cjs.map +3 -3
  46. package/dist/src/okx/index.js +2 -2
  47. package/dist/src/okx/index.js.map +3 -3
  48. package/dist/src/onekey/index.cjs +2 -2
  49. package/dist/src/onekey/index.cjs.map +3 -3
  50. package/dist/src/onekey/index.js +2 -2
  51. package/dist/src/onekey/index.js.map +3 -3
  52. package/dist/src/phantom/index.js +1 -1
  53. package/dist/src/polkadotjs/index.js +1 -1
  54. package/dist/src/radix/index.js +1 -1
  55. package/dist/src/talisman/index.js +1 -1
  56. package/dist/src/trezor/index.cjs +2 -2
  57. package/dist/src/trezor/index.cjs.map +3 -3
  58. package/dist/src/trezor/index.js +2 -2
  59. package/dist/src/trezor/index.js.map +3 -3
  60. package/dist/src/walletconnect/index.cjs +2 -2
  61. package/dist/src/walletconnect/index.cjs.map +3 -3
  62. package/dist/src/walletconnect/index.js +2 -2
  63. package/dist/src/walletconnect/index.js.map +3 -3
  64. package/package.json +22 -22
  65. package/src/bitget/helpers.ts +1 -2
  66. package/src/cosmostation/index.ts +141 -0
  67. package/src/ctrl/walletHelpers.ts +82 -70
  68. package/src/exodus/index.ts +1 -2
  69. package/src/keepkey/chains/mayachain.ts +1 -1
  70. package/src/keepkey/chains/thorchain.ts +1 -1
  71. package/src/keystore/helpers.ts +2 -4
  72. package/src/ledger/clients/cosmos.ts +2 -2
  73. package/src/ledger/clients/evm.ts +1 -1
  74. package/src/ledger/clients/utxo.ts +3 -5
  75. package/src/ledger/clients/xrp.ts +66 -0
  76. package/src/ledger/helpers/getLedgerAddress.ts +12 -3
  77. package/src/ledger/helpers/getLedgerClient.ts +4 -0
  78. package/src/ledger/helpers/getLedgerTransport.ts +4 -2
  79. package/src/ledger/index.ts +11 -1
  80. package/src/ledger/interfaces/CosmosLedgerInterface.ts +1 -1
  81. package/src/okx/helpers.ts +2 -1
  82. package/src/onekey/index.ts +1 -1
  83. package/src/trezor/evmSigner.ts +3 -3
  84. package/src/trezor/index.ts +14 -4
  85. package/src/types.ts +3 -0
  86. package/src/utils.ts +4 -0
  87. package/src/walletconnect/index.ts +2 -2
  88. package/dist/chunk-bhfpfqc3.js +0 -3
  89. package/dist/chunk-bhfpfqc3.js.map +0 -10
  90. package/dist/chunk-czhtd6cy.js +0 -4
  91. package/dist/chunk-q81hzyra.js +0 -3
  92. package/dist/chunk-q81hzyra.js.map +0 -10
@@ -6,11 +6,11 @@
6
6
  "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { GenericTransferParams } from \"@swapkit/helpers\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\nexport const cosmosWalletMethods = async ({\n sdk,\n derivationPath,\n}: { sdk: KeepKeySdk; derivationPath?: DerivationPathArray }) => {\n const {\n DEFAULT_COSMOS_FEE_MAINNET,\n getCosmosToolbox,\n getFeeRateFromThorswap,\n createStargateClient,\n } = await import(\"@swapkit/toolboxes/cosmos\");\n\n try {\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.GAIA}/0`;\n\n const { address: fromAddress } = (await sdk.address.cosmosGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const toolbox = await getCosmosToolbox(Chain.Cosmos);\n\n if (DEFAULT_COSMOS_FEE_MAINNET.amount[0]) {\n DEFAULT_COSMOS_FEE_MAINNET.amount[0].amount = String(\n await getFeeRateFromThorswap(ChainId.Cosmos, 500),\n );\n }\n\n // TODO support other cosmos assets\n const transfer = async ({ assetValue, recipient, memo }: GenericTransferParams) => {\n const amount = assetValue.getBaseValue(\"string\");\n const accountInfo = await toolbox.getAccount(fromAddress);\n\n const keepKeySignedTx = await sdk.cosmos.cosmosSignAmino({\n signerAddress: fromAddress,\n signDoc: {\n fee: DEFAULT_COSMOS_FEE_MAINNET,\n memo: memo || \"\",\n sequence: accountInfo?.sequence.toString() ?? \"\",\n chain_id: ChainId.Cosmos,\n account_number: accountInfo?.accountNumber.toString() ?? \"\",\n msgs: [\n {\n value: {\n amount: [{ denom: \"uatom\", amount }],\n to_address: recipient,\n from_address: fromAddress,\n },\n type: \"cosmos-sdk/MsgSend\",\n },\n ],\n },\n });\n\n const decodedBytes = atob(keepKeySignedTx.serialized);\n const uint8Array = new Uint8Array(decodedBytes.length).map((_, i) =>\n decodedBytes.charCodeAt(i),\n );\n\n const client = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Cosmos]);\n const response = await client.broadcastTx(uint8Array);\n\n return response.transactionHash;\n };\n\n return { ...toolbox, transfer, address: fromAddress };\n } catch (e) {\n console.error(e);\n throw e;\n }\n};\n",
7
7
  "/*\n KeepKey Specific bip32 path conventions\n*/\n\nconst HARDENED = 0x80000000;\n\nexport enum ChainToKeepKeyName {\n BTC = \"Bitcoin\",\n BCH = \"BitcoinCash\",\n DOGE = \"Dogecoin\",\n LTC = \"Litecoin\",\n DASH = \"Dash\",\n}\n\nexport function addressNListToBIP32(address: number[]) {\n return `m/${address.map((num) => (num >= HARDENED ? `${num - HARDENED}'` : num)).join(\"/\")}`;\n}\n\nexport function bip32Like(path: string) {\n if (path === \"m/\") return true;\n\n return /^m(((\\/[0-9]+h)+|(\\/[0-9]+H)+|(\\/[0-9]+')*)((\\/[0-9]+)*))$/.test(path);\n}\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: TODO: Refactor\nexport function bip32ToAddressNList(initPath: string): number[] {\n let path = initPath;\n\n if (!bip32Like(path)) {\n throw new Error(`Not a bip32 path: '${path}'`);\n }\n\n if (/^m\\//i.test(path)) {\n path = path.slice(2);\n }\n const segments = path.split(\"/\");\n\n if (segments.length === 1 && segments[0] === \"\") return [];\n\n const ret = new Array(segments.length);\n\n for (let i = 0; i < segments.length; i++) {\n // TODO: Check for better way instead of exec\n const segment = segments[i];\n if (segment) {\n const tmp = /(\\d+)([hH']?)/.exec(segment);\n if (tmp === null) throw new Error(\"Invalid input\");\n\n const [, num = \"\", modifier = \"\"] = tmp;\n\n ret[i] = Number.parseInt(num, 10);\n\n if (ret[i] >= HARDENED) throw new Error(\"Invalid child index\");\n\n if (modifier === \"h\" || modifier === \"H\" || modifier === \"'\") {\n ret[i] += HARDENED;\n } else if (modifier.length > 0) {\n throw new Error(\"Invalid modifier\");\n }\n }\n }\n\n return ret;\n}\n",
8
8
  "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n type Chain,\n ChainToChainId,\n type DerivationPathArray,\n NetworkDerivationPath,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { JsonRpcProvider, Provider, TransactionRequest } from \"ethers\";\nimport { AbstractSigner } from \"ethers\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ninterface KeepKeyEVMSignerParams {\n sdk: KeepKeySdk;\n chain: Chain;\n derivationPath?: DerivationPathArray;\n provider: Provider | JsonRpcProvider;\n}\n\nexport class KeepKeySigner extends AbstractSigner {\n private sdk: KeepKeySdk;\n private chain: Chain;\n private derivationPath: DerivationPathArray;\n private address: string;\n readonly provider: Provider | JsonRpcProvider;\n\n constructor({ sdk, chain, derivationPath, provider }: KeepKeyEVMSignerParams) {\n super();\n this.sdk = sdk;\n this.chain = chain;\n this.derivationPath = derivationPath || NetworkDerivationPath.ETH;\n this.address = \"\";\n this.provider = provider;\n }\n\n signTypedData(): Promise<string> {\n throw new Error(\"this method is not implemented\");\n }\n\n getAddress = async () => {\n if (this.address) return this.address;\n const { address } = await this.sdk.address.ethereumGetAddress({\n address_n: bip32ToAddressNList(derivationPathToString(this.derivationPath)),\n });\n\n this.address = address;\n return address;\n };\n\n signMessage = (message: string) =>\n this.sdk.eth.ethSign({ address: this.address, message }) as Promise<string>;\n\n signTransaction = async ({\n to,\n value,\n gasLimit,\n nonce,\n data,\n maxFeePerGas,\n maxPriorityFeePerGas,\n gasPrice,\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\n }: TransactionRequest) => {\n if (!to) throw new Error(\"Missing to address\");\n if (!gasLimit) throw new Error(\"Missing gasLimit\");\n if (!data) throw new Error(\"Missing data\");\n\n const isEIP1559 = !!((maxFeePerGas || maxPriorityFeePerGas) && !gasPrice);\n if (isEIP1559 && !maxFeePerGas) throw new Error(\"Missing maxFeePerGas\");\n if (isEIP1559 && !maxPriorityFeePerGas) throw new Error(\"Missing maxFeePerGas\");\n if (!(isEIP1559 || gasPrice)) throw new Error(\"Missing gasPrice\");\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n const nonceValue = nonce\n ? BigInt(nonce)\n : BigInt(await this.provider.getTransactionCount(await this.getAddress(), \"pending\"));\n\n const input = {\n gas: toHexString(BigInt(gasLimit)),\n addressNList: [2147483692, 2147483708, 2147483648, 0, 0],\n from: this.address,\n chainId: toHexString(BigInt(ChainToChainId[this.chain])),\n to: to.toString(),\n value: toHexString(BigInt(value || 0)),\n nonce: toHexString(nonceValue),\n data,\n ...(isEIP1559 && {\n maxFeePerGas: toHexString(BigInt(maxFeePerGas?.toString() || \"0\")),\n maxPriorityFeePerGas: toHexString(BigInt(maxPriorityFeePerGas?.toString() || \"0\")),\n }),\n ...(!isEIP1559 && {\n // Fixed syntax error and structure here\n gasPrice: toHexString(BigInt(gasPrice?.toString() || \"0\")),\n }),\n };\n const responseSign = await this.sdk.eth.ethSignTransaction(input);\n return responseSign.serialized;\n };\n\n sendTransaction = async (tx: TransactionRequest): Promise<any> => {\n if (!this.provider) throw new Error(\"No provider set\");\n\n const signedTxHex = await this.signTransaction(tx);\n\n return await this.provider.broadcastTransaction(signedTxHex);\n };\n\n connect = (provider: Provider) =>\n new KeepKeySigner({\n sdk: this.sdk,\n chain: this.chain,\n derivationPath: this.derivationPath,\n provider,\n });\n}\n",
9
- "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n type AssetValue,\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n type GenericTransferParams,\n SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const mayachainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { createStargateClient, getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.Maya);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.MAYA}/0`;\n\n const { address: fromAddress } = (await sdk.address.mayachainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const { makeSignDoc } = await import(\"@cosmjs/amino\");\n const { getDenomWithChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const account = await toolbox.getAccount(sender);\n if (!account) throw new Error(\"Account not found\");\n const { accountNumber, sequence = 0 } = account;\n const amount = assetValue.getBaseValue(\"string\");\n\n const isTransfer = recipient && recipient !== \"\";\n\n // TODO check if we can move to toolbox created msg\n const msg = isTransfer\n ? {\n type: \"mayachain/MsgSend\",\n value: {\n amount: [{ amount, denom: assetValue.symbol.toLowerCase() }],\n from_address: sender,\n to_address: recipient,\n },\n }\n : {\n type: \"mayachain/MsgDeposit\",\n value: {\n coins: [{ amount, asset: getDenomWithChain(assetValue) }],\n memo,\n signer: sender,\n },\n };\n\n const signDoc = makeSignDoc(\n [msg],\n { gas: \"500000000\", amount: [] },\n ChainId.Maya,\n memo,\n accountNumber?.toString(),\n sequence,\n );\n\n const sdkMethod = isTransfer\n ? sdk.mayachain.mayachainSignAminoTransfer\n : sdk.mayachain.mayachainSignAminoDeposit;\n\n // @ts-expect-error TC\n const signedTx = await sdkMethod({ signDoc, signerAddress: sender });\n const decodedBytes = atob(signedTx.serialized);\n return new Uint8Array(decodedBytes.length).map((_, i) => decodedBytes.charCodeAt(i));\n };\n\n const transfer = async ({ assetValue, recipient, memo }: GenericTransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: ThorchainDepositParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n return { ...toolbox, transfer, deposit, address: fromAddress };\n};\n",
10
- "import type {\n KeepKeySdk,\n TypesThorchainSignDocDeposit,\n TypesThorchainSignDocTransfer,\n} from \"@keepkey/keepkey-sdk\";\nimport {\n type AssetValue,\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n type GenericTransferParams,\n SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const thorchainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { makeSignDoc } = await import(\"@cosmjs/amino\");\n const { buildAminoMsg, getDefaultChainFee, createStargateClient, getCosmosToolbox } =\n await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.THOR}/0`;\n\n const { address: fromAddress } = (await sdk.address.thorchainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const account = await toolbox.getAccount(sender);\n if (!account) throw new Error(\"Account not found\");\n const { accountNumber, sequence = 0 } = account;\n\n const isTransfer = recipient && recipient !== \"\";\n\n const msg = buildAminoMsg({ sender, recipient, assetValue, memo });\n\n const chainId = ChainId.THORChain;\n\n const signDoc = makeSignDoc(\n [msg],\n getDefaultChainFee(Chain.THORChain),\n chainId,\n memo,\n accountNumber?.toString(),\n sequence,\n );\n\n const signedTx = isTransfer\n ? await sdk.thorchain.thorchainSignAminoTransfer({\n signDoc: signDoc as TypesThorchainSignDocTransfer,\n signerAddress: sender,\n })\n : await sdk.thorchain.thorchainSignAminoDeposit({\n signDoc: signDoc as TypesThorchainSignDocDeposit,\n signerAddress: sender,\n });\n const decodedBytes = atob(signedTx.serialized);\n return new Uint8Array(decodedBytes.length).map((_, i) => decodedBytes.charCodeAt(i));\n };\n\n const transfer = async ({ assetValue, recipient, memo }: GenericTransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: ThorchainDepositParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n // const signMessage = async (message: string) => {\n // const stargateClient = await createStargateClient(RPCUrl.THORChain);\n // // return signedTx;\n // };\n\n return { ...toolbox, transfer, deposit, address: fromAddress };\n};\n",
9
+ "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n type AssetValue,\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n type GenericTransferParams,\n SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const mayachainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { createStargateClient, getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.Maya);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.MAYA}/0`;\n\n const { address: fromAddress } = (await sdk.address.mayachainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const { makeSignDoc } = (await import(\"@cosmjs/amino\")).default;\n const { getDenomWithChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const account = await toolbox.getAccount(sender);\n if (!account) throw new Error(\"Account not found\");\n const { accountNumber, sequence = 0 } = account;\n const amount = assetValue.getBaseValue(\"string\");\n\n const isTransfer = recipient && recipient !== \"\";\n\n // TODO check if we can move to toolbox created msg\n const msg = isTransfer\n ? {\n type: \"mayachain/MsgSend\",\n value: {\n amount: [{ amount, denom: assetValue.symbol.toLowerCase() }],\n from_address: sender,\n to_address: recipient,\n },\n }\n : {\n type: \"mayachain/MsgDeposit\",\n value: {\n coins: [{ amount, asset: getDenomWithChain(assetValue) }],\n memo,\n signer: sender,\n },\n };\n\n const signDoc = makeSignDoc(\n [msg],\n { gas: \"500000000\", amount: [] },\n ChainId.Maya,\n memo,\n accountNumber?.toString(),\n sequence,\n );\n\n const sdkMethod = isTransfer\n ? sdk.mayachain.mayachainSignAminoTransfer\n : sdk.mayachain.mayachainSignAminoDeposit;\n\n // @ts-expect-error TC\n const signedTx = await sdkMethod({ signDoc, signerAddress: sender });\n const decodedBytes = atob(signedTx.serialized);\n return new Uint8Array(decodedBytes.length).map((_, i) => decodedBytes.charCodeAt(i));\n };\n\n const transfer = async ({ assetValue, recipient, memo }: GenericTransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: ThorchainDepositParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n return { ...toolbox, transfer, deposit, address: fromAddress };\n};\n",
10
+ "import type {\n KeepKeySdk,\n TypesThorchainSignDocDeposit,\n TypesThorchainSignDocTransfer,\n} from \"@keepkey/keepkey-sdk\";\nimport {\n type AssetValue,\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n type GenericTransferParams,\n SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const thorchainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { makeSignDoc } = (await import(\"@cosmjs/amino\")).default;\n const { buildAminoMsg, getDefaultChainFee, createStargateClient, getCosmosToolbox } =\n await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.THOR}/0`;\n\n const { address: fromAddress } = (await sdk.address.thorchainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const account = await toolbox.getAccount(sender);\n if (!account) throw new Error(\"Account not found\");\n const { accountNumber, sequence = 0 } = account;\n\n const isTransfer = recipient && recipient !== \"\";\n\n const msg = buildAminoMsg({ sender, recipient, assetValue, memo });\n\n const chainId = ChainId.THORChain;\n\n const signDoc = makeSignDoc(\n [msg],\n getDefaultChainFee(Chain.THORChain),\n chainId,\n memo,\n accountNumber?.toString(),\n sequence,\n );\n\n const signedTx = isTransfer\n ? await sdk.thorchain.thorchainSignAminoTransfer({\n signDoc: signDoc as TypesThorchainSignDocTransfer,\n signerAddress: sender,\n })\n : await sdk.thorchain.thorchainSignAminoDeposit({\n signDoc: signDoc as TypesThorchainSignDocDeposit,\n signerAddress: sender,\n });\n const decodedBytes = atob(signedTx.serialized);\n return new Uint8Array(decodedBytes.length).map((_, i) => decodedBytes.charCodeAt(i));\n };\n\n const transfer = async ({ assetValue, recipient, memo }: GenericTransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: ThorchainDepositParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n sender: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n // const signMessage = async (message: string) => {\n // const stargateClient = await createStargateClient(RPCUrl.THORChain);\n // // return signedTx;\n // };\n\n return { ...toolbox, transfer, deposit, address: fromAddress };\n};\n",
11
11
  "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n Chain,\n DerivationPath,\n type DerivationPathArray,\n FeeOption,\n type GenericTransferParams,\n type UTXOChain,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { Psbt } from \"bitcoinjs-lib\";\n\nimport type { UTXOToolboxes } from \"@swapkit/toolboxes/utxo\";\nimport { ChainToKeepKeyName, bip32ToAddressNList } from \"../coins\";\n\ninterface KeepKeyInputObject {\n addressNList: number[];\n scriptType: string;\n amount: string;\n vout: number;\n txid: string;\n hex: string;\n}\n\nexport const utxoWalletMethods = async ({\n sdk,\n chain,\n derivationPath,\n}: { sdk: KeepKeySdk; chain: UTXOChain; derivationPath?: DerivationPathArray }) => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n // This might not work for BCH\n const toolbox = await getUtxoToolbox(chain);\n const scriptType = [Chain.Bitcoin, Chain.Litecoin].includes(chain)\n ? (\"p2wpkh\" as const)\n : (\"p2pkh\" as const);\n\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath[chain]}/0`;\n\n const addressInfo = {\n coin: ChainToKeepKeyName[chain],\n script_type: scriptType,\n address_n: bip32ToAddressNList(derivationPathString),\n };\n\n const walletAddress: string = (await sdk.address.utxoGetAddress(addressInfo)).address;\n\n const signTransaction = async (psbt: Psbt, inputs: KeepKeyInputObject[], memo = \"\") => {\n const outputs = psbt.txOutputs\n .map((output) => {\n const { value, address, change } = output as {\n address: string;\n script: Buffer;\n value: number;\n change?: boolean;\n };\n\n const outputAddress =\n // @ts-expect-error - stripToCashAddress is not defined in the UTXO toolbox just only on BCH\n chain === Chain.BitcoinCash ? toolbox.stripToCashAddress(address) : address;\n\n if (change || address === walletAddress) {\n return {\n addressNList: addressInfo.address_n,\n isChange: true,\n addressType: \"change\",\n amount: value,\n scriptType,\n };\n }\n\n if (outputAddress) {\n return { address: outputAddress, amount: value, addressType: \"spend\" };\n }\n\n return null;\n })\n .filter(Boolean);\n\n const removeNullAndEmptyObjectsFromArray = (arr: any[]) => {\n return arr.filter(\n (item) => item !== null && typeof item === \"object\" && Object.keys(item).length > 0,\n );\n };\n\n const responseSign = await sdk.utxo.utxoSignTransaction({\n coin: ChainToKeepKeyName[chain],\n inputs,\n outputs: removeNullAndEmptyObjectsFromArray(outputs),\n opReturnData: memo,\n });\n\n return responseSign.serializedTx?.toString();\n };\n\n const transfer = async ({\n recipient,\n feeOptionKey,\n feeRate,\n memo,\n ...rest\n }: GenericTransferParams) => {\n if (!walletAddress) throw new Error(\"From address must be provided\");\n if (!recipient) throw new Error(\"Recipient address must be provided\");\n\n const createTxMethod =\n chain === Chain.BitcoinCash\n ? (toolbox as UTXOToolboxes[\"BCH\"]).buildTx\n : (toolbox as UTXOToolboxes[\"BTC\"]).createTransaction;\n\n const { psbt, inputs: rawInputs } = await createTxMethod({\n ...rest,\n memo,\n recipient,\n feeRate: feeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast],\n sender: walletAddress,\n fetchTxHex: true,\n });\n\n const inputs = rawInputs.map(({ value, index, hash, txHex }) => ({\n //@TODO don't hardcode master, lookup on blockbook what input this is for and what path that address is!\n addressNList: addressInfo.address_n,\n amount: value.toString(),\n hex: txHex || \"\",\n scriptType,\n txid: hash,\n vout: index,\n }));\n\n const txHex = await signTransaction(psbt, inputs, memo);\n return toolbox.broadcastTx(txHex);\n };\n\n return { ...toolbox, signTransaction, transfer, address: walletAddress };\n};\n"
12
12
  ],
13
- "mappings": "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",
14
- "debugId": "ED8287149CCB327064756E2164756E21",
13
+ "mappings": "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",
14
+ "debugId": "C1A7C5EC6AF41DFF64756E2164756E21",
15
15
  "names": []
16
16
  }
@@ -1,3 +1,3 @@
1
- import{a as l}from"../../chunk-czhtd6cy.js";import{c as d,d as u}from"../../chunk-p1kdg37m.js";import{AssetValue as F,Chain as t,ChainIdToChain as L,SwapKitError as b,WalletOption as B,createWallet as V,filterSupportedChains as j}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as P,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var T=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new Error("Unsupported chain")}};function w(e){if(!window.keepkey)throw new P("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function K({method:e,params:c,chain:r}){let o=w(r);return new Promise((n,i)=>{if(o&&"request"in o)o.request({method:e,params:c},(s,m)=>{s?i(s):n(m)});else i(new P("wallet_provider_not_found"))})}async function _(e){let c=w(e);if(!c)throw new P({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[o]=await c.request({method:r,params:[]});return o}async function f({assetValue:e,recipient:c,memo:r,gasLimit:o},n="transfer"){if(!e)throw new P("wallet_keepkey_asset_not_defined");let i=await _(e.chain),s=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:o}];return K({method:n,params:s,chain:e.chain})}function O(e,c){return{call:async({contractAddress:r,abi:o,funcName:n,funcParams:i=[],txOverrides:s})=>{if(!r)throw new P("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:p}=await import("@swapkit/toolboxes/evm");if(y({abi:o,funcName:n})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:o,funcName:n,funcParams:i,txOverrides:s});return e.send("eth_sendTransaction",[{value:p(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,o,e)[n]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:o,amount:n,from:i})=>{let{MAX_APPROVAL:s,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:p,to:k,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[o,BigInt(n||s)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(p||0)),from:i,to:k,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:o,to:n,data:i,value:s}=r;if(!n)throw new P("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(s||0)),from:o,to:n,data:i||"0x"}])}}}var H=V({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:B.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function o(n){let i=j({chains:n,supportedChains:c,walletType:r});return await Promise.all(i.map(async(s)=>{let m=await _(s),g=await R(s);e({...g,address:m,chain:s,walletType:r})})),!0}}),$=l(H);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:o}=await import("@swapkit/toolboxes/cosmos"),n=e===t.Maya?o:r;return{...c(e),deposit:(s)=>f({...s,recipient:""},"deposit"),transfer:(s)=>f({...s,gasLimit:n},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(L[e]);if(!r)throw new Error("Could not load signer");let o=c(e,{signer:r}),n=await r.getAccounts();if(!n?.[0]?.address)throw new Error("No accounts found");let[{address:i}]=n;return{...o,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{try{let n=T(e),i=await window?.keepkey?.[n]?.request({method:"request_balance"});return[F.from({chain:e,value:i[0].balance})]}catch(n){throw console.error("Error fetching balance:",n),n}},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:n}=await import("ethers"),i=w(e);if(!i)throw new b("wallet_keepkey_not_found");let s=new n(i,"any"),m=await s.getSigner(),g=await o(e,{provider:s,signer:m}),y=O(s,e);try{if(e!==t.Ethereum){let p=g.getNetworkParams();await r(s,e,p)}}catch(p){throw new b({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:B.KEEPKEY,chain:e}})}return c({provider:s,chain:e,toolbox:{...g,...y}})}default:return null}}export{H as keepkeyBexWallet,$ as KEEPKEY_BEX_SUPPORTED_CHAINS};
1
+ import{a as l}from"../../chunk-s6xqbsy0.js";import{c as d,d as u}from"../../chunk-38ztynv0.js";import{AssetValue as F,Chain as t,ChainIdToChain as L,SwapKitError as b,WalletOption as B,createWallet as V,filterSupportedChains as j}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as P,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var T=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new Error("Unsupported chain")}};function w(e){if(!window.keepkey)throw new P("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function K({method:e,params:c,chain:r}){let o=w(r);return new Promise((n,i)=>{if(o&&"request"in o)o.request({method:e,params:c},(s,m)=>{s?i(s):n(m)});else i(new P("wallet_provider_not_found"))})}async function _(e){let c=w(e);if(!c)throw new P({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[o]=await c.request({method:r,params:[]});return o}async function f({assetValue:e,recipient:c,memo:r,gasLimit:o},n="transfer"){if(!e)throw new P("wallet_keepkey_asset_not_defined");let i=await _(e.chain),s=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:o}];return K({method:n,params:s,chain:e.chain})}function O(e,c){return{call:async({contractAddress:r,abi:o,funcName:n,funcParams:i=[],txOverrides:s})=>{if(!r)throw new P("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:p}=await import("@swapkit/toolboxes/evm");if(y({abi:o,funcName:n})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:o,funcName:n,funcParams:i,txOverrides:s});return e.send("eth_sendTransaction",[{value:p(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,o,e)[n]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:o,amount:n,from:i})=>{let{MAX_APPROVAL:s,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:p,to:k,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[o,BigInt(n||s)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(p||0)),from:i,to:k,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:o,to:n,data:i,value:s}=r;if(!n)throw new P("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(s||0)),from:o,to:n,data:i||"0x"}])}}}var H=V({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:B.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function o(n){let i=j({chains:n,supportedChains:c,walletType:r});return await Promise.all(i.map(async(s)=>{let m=await _(s),g=await R(s);e({...g,address:m,chain:s,walletType:r})})),!0}}),$=l(H);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:o}=await import("@swapkit/toolboxes/cosmos"),n=e===t.Maya?o:r;return{...c(e),deposit:(s)=>f({...s,recipient:""},"deposit"),transfer:(s)=>f({...s,gasLimit:n},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(L[e]);if(!r)throw new Error("Could not load signer");let o=c(e,{signer:r}),n=await r.getAccounts();if(!n?.[0]?.address)throw new Error("No accounts found");let[{address:i}]=n;return{...o,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{try{let n=T(e),i=await window?.keepkey?.[n]?.request({method:"request_balance"});return[F.from({chain:e,value:i[0].balance})]}catch(n){throw console.error("Error fetching balance:",n),n}},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:n}=await import("ethers"),i=w(e);if(!i)throw new b("wallet_keepkey_not_found");let s=new n(i,"any"),m=await s.getSigner(),g=await o(e,{provider:s,signer:m}),y=O(s,e);try{if(e!==t.Ethereum){let p=g.getNetworkParams();await r(s,e,p)}}catch(p){throw new b({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:B.KEEPKEY,chain:e}})}return c({provider:s,chain:e,toolbox:{...g,...y}})}default:return null}}export{H as keepkeyBexWallet,$ as KEEPKEY_BEX_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=AFAB0E6C797C305A64756E2164756E21
@@ -1,3 +1,3 @@
1
- import{c as A,d as b}from"../../chunk-p1kdg37m.js";import{Chain as a,ChainId as r,ChainToChainId as f,WalletOption as h,createWallet as y,filterSupportedChains as F}from"@swapkit/helpers";import{ChainId as m}from"@swapkit/helpers";var l=new Map([[m.Kujira,{chainId:"kaiyo-1",chainName:"Kujira",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png",rpc:"https://kujira-rpc.nodes.defiantlabs.net",rest:"https://rest.cosmos.directory/kujira/",nodeProvider:{name:"PFC",email:"pfc-validator@protonmail.com",website:"https://pfc.zone/"},bip44:{coinType:118},bech32Config:{bech32PrefixAccAddr:"kujira",bech32PrefixAccPub:"kujirapub",bech32PrefixValAddr:"kujiravaloper",bech32PrefixValPub:"kujiravaloperpub",bech32PrefixConsAddr:"kujiravalcons",bech32PrefixConsPub:"kujiravalconspub"},currencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"bKUJI",coinMinimalDenom:"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji",coinDecimals:6,coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png"},{coinDenom:"AQLA",coinMinimalDenom:"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla",coinDecimals:6,coinGeckoId:"aqualibre",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png"}],feeCurrencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"axlUSDC",coinMinimalDenom:"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F",coinDecimals:6,coinGeckoId:"usd-coin"},{coinDenom:"ATOM",coinMinimalDenom:"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2",coinDecimals:6,coinGeckoId:"cosmos"},{coinDenom:"OSMO",coinMinimalDenom:"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23",coinDecimals:6,coinGeckoId:"osmosis"},{coinDenom:"CMDX",coinMinimalDenom:"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07",coinDecimals:6,coinGeckoId:"comdex"},{coinDenom:"EVMOS",coinMinimalDenom:"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10",coinDecimals:6,coinGeckoId:"evmos"},{coinDenom:"JUNO",coinMinimalDenom:"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5",coinDecimals:6,coinGeckoId:"juno-network"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"SCRT",coinMinimalDenom:"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5",coinDecimals:6,coinGeckoId:"secret"},{coinDenom:"STARS",coinMinimalDenom:"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602",coinDecimals:6,coinGeckoId:"stargaze"},{coinDenom:"wAVAX",coinMinimalDenom:"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2",coinDecimals:18,coinGeckoId:"avalanche-2"},{coinDenom:"wETH",coinMinimalDenom:"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7",coinDecimals:18,coinGeckoId:"ethereum"}],stakeCurrency:{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},features:["cosmwasm"]}],[m.THORChain,{chainId:"thorchain-1",chainName:"THORChain",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png",rpc:"https://rpc-thorchain.keplr.app",rest:"https://lcd-thorchain.keplr.app",bip44:{coinType:931},bech32Config:{bech32PrefixAccAddr:"thor",bech32PrefixAccPub:"thorpub",bech32PrefixValAddr:"thorvaloper",bech32PrefixValPub:"thorvaloperpub",bech32PrefixConsAddr:"thorvalcons",bech32PrefixConsPub:"thorvalconspub"},currencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png"}],feeCurrencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",gasPriceStep:{low:0.02,average:0.02,high:0.03}}],features:[]}]]);var I=[r.Cosmos,r.Kujira,r.THORChain],P=y({name:"connectKeplr",supportedChains:[a.Cosmos,a.Kujira,a.THORChain],connect:({addChain:p,supportedChains:u})=>async function x(D,o=h.KEPLR){let k=o===h.LEAP?"leap":"keplr",C=F({chains:D,supportedChains:u,walletType:o}),e=window[k];return await Promise.all(C.map(async(i)=>{let n=f[i];if(!I.includes(n)){let s=l.get(n);if(!s)throw new Error(`Unsupported chain ${i}`);await e.experimentalSuggestChain(s)}e?.enable(n);let c=e?.getOfflineSignerOnlyAmino(n);if(!c)throw new Error("Could not load signer");let{getCosmosToolbox:d}=await import("@swapkit/toolboxes/cosmos"),t=await c.getAccounts();if(!t?.[0]?.address)throw new Error("No accounts found");let[{address:g}]=t,E=d(i,{signer:c});p({...E,chain:i,address:g,walletType:o})})),!0}});export{P as keplrWallet};
1
+ import{c as A,d as b}from"../../chunk-38ztynv0.js";import{Chain as a,ChainId as r,ChainToChainId as f,WalletOption as h,createWallet as y,filterSupportedChains as F}from"@swapkit/helpers";import{ChainId as m}from"@swapkit/helpers";var l=new Map([[m.Kujira,{chainId:"kaiyo-1",chainName:"Kujira",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png",rpc:"https://kujira-rpc.nodes.defiantlabs.net",rest:"https://rest.cosmos.directory/kujira/",nodeProvider:{name:"PFC",email:"pfc-validator@protonmail.com",website:"https://pfc.zone/"},bip44:{coinType:118},bech32Config:{bech32PrefixAccAddr:"kujira",bech32PrefixAccPub:"kujirapub",bech32PrefixValAddr:"kujiravaloper",bech32PrefixValPub:"kujiravaloperpub",bech32PrefixConsAddr:"kujiravalcons",bech32PrefixConsPub:"kujiravalconspub"},currencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"bKUJI",coinMinimalDenom:"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji",coinDecimals:6,coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png"},{coinDenom:"AQLA",coinMinimalDenom:"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla",coinDecimals:6,coinGeckoId:"aqualibre",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png"}],feeCurrencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"axlUSDC",coinMinimalDenom:"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F",coinDecimals:6,coinGeckoId:"usd-coin"},{coinDenom:"ATOM",coinMinimalDenom:"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2",coinDecimals:6,coinGeckoId:"cosmos"},{coinDenom:"OSMO",coinMinimalDenom:"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23",coinDecimals:6,coinGeckoId:"osmosis"},{coinDenom:"CMDX",coinMinimalDenom:"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07",coinDecimals:6,coinGeckoId:"comdex"},{coinDenom:"EVMOS",coinMinimalDenom:"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10",coinDecimals:6,coinGeckoId:"evmos"},{coinDenom:"JUNO",coinMinimalDenom:"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5",coinDecimals:6,coinGeckoId:"juno-network"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"SCRT",coinMinimalDenom:"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5",coinDecimals:6,coinGeckoId:"secret"},{coinDenom:"STARS",coinMinimalDenom:"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602",coinDecimals:6,coinGeckoId:"stargaze"},{coinDenom:"wAVAX",coinMinimalDenom:"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2",coinDecimals:18,coinGeckoId:"avalanche-2"},{coinDenom:"wETH",coinMinimalDenom:"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7",coinDecimals:18,coinGeckoId:"ethereum"}],stakeCurrency:{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},features:["cosmwasm"]}],[m.THORChain,{chainId:"thorchain-1",chainName:"THORChain",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png",rpc:"https://rpc-thorchain.keplr.app",rest:"https://lcd-thorchain.keplr.app",bip44:{coinType:931},bech32Config:{bech32PrefixAccAddr:"thor",bech32PrefixAccPub:"thorpub",bech32PrefixValAddr:"thorvaloper",bech32PrefixValPub:"thorvaloperpub",bech32PrefixConsAddr:"thorvalcons",bech32PrefixConsPub:"thorvalconspub"},currencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png"}],feeCurrencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",gasPriceStep:{low:0.02,average:0.02,high:0.03}}],features:[]}]]);var I=[r.Cosmos,r.Kujira,r.THORChain],P=y({name:"connectKeplr",supportedChains:[a.Cosmos,a.Kujira,a.THORChain],connect:({addChain:p,supportedChains:u})=>async function x(D,o=h.KEPLR){let k=o===h.LEAP?"leap":"keplr",C=F({chains:D,supportedChains:u,walletType:o}),e=window[k];return await Promise.all(C.map(async(i)=>{let n=f[i];if(!I.includes(n)){let s=l.get(n);if(!s)throw new Error(`Unsupported chain ${i}`);await e.experimentalSuggestChain(s)}e?.enable(n);let c=e?.getOfflineSignerOnlyAmino(n);if(!c)throw new Error("Could not load signer");let{getCosmosToolbox:d}=await import("@swapkit/toolboxes/cosmos"),t=await c.getAccounts();if(!t?.[0]?.address)throw new Error("No accounts found");let[{address:g}]=t,E=d(i,{signer:c});p({...E,chain:i,address:g,walletType:o})})),!0}});export{P as keplrWallet};
2
2
 
3
3
  //# debugId=34CA93B29DF1AD6264756E2164756E21
@@ -1,3 +1,3 @@
1
- var A={};T(A,{validatePhrase:()=>P,keystoreWallet:()=>v,generatePhrase:()=>B,encryptToKeyStore:()=>C,decryptFromKeystore:()=>K,KEYSTORE_SUPPORTED_CHAINS:()=>E});module.exports=D(A);var t=require("@swapkit/helpers");var d=require("@scure/bip39"),g=require("@scure/bip39/wordlists/english");async function x(r){let{blake2bFinal:i,blake2bInit:s,blake2bUpdate:c}=await import("blakejs"),n=r;if(!(n instanceof Buffer))n=Buffer.from(n,"hex");let o=s(32);return c(o,n),Array.from(i(o)).map((e)=>e<16?`0${e.toString(16)}`:e.toString(16)).join("")}async function C(r,i){let{pbkdf2Sync:s,randomBytes:c,createCipheriv:n}=await import("node:crypto"),o="aes-128-ctr",e=c(16),p=c(32),a={c:262144,prf:"hmac-sha256",dklen:32,salt:p.toString("hex")},l=s(i,p,a.c,a.dklen,"sha256"),m=n("aes-128-ctr",l.subarray(0,16),e),f=Buffer.concat([m.update(Buffer.from(r,"utf8")),m.final()]),u=Buffer.concat([l.subarray(16,32),Buffer.from(f)]),y=await x(u);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:e.toString("hex")},ciphertext:f.toString("hex"),kdf:"pbkdf2",kdfparams:a,mac:y}}}function B(r=12){return d.generateMnemonic(g.wordlist,r===12?128:256)}function P(r){return d.validateMnemonic(r,g.wordlist)}async function K(r,i){let{createDecipheriv:s,pbkdf2Sync:c}=await import("node:crypto"),{SwapKitError:n}=await import("@swapkit/helpers");switch(r.version){case 1:{let o=r.crypto.kdfparams,e=Buffer.from(o.salt,"hex"),p=c(i,e,o.c,o.dklen,"sha256"),a=Buffer.from(r.crypto.ciphertext,"hex"),l=Buffer.concat([p.subarray(16,32),a]);if(await x(l)!==r.crypto.mac)throw new n("wallet_keystore_invalid_password");let f=s(r.crypto.cipher,p.subarray(0,16),Buffer.from(r.crypto.cipherparams.iv,"hex"));return Buffer.concat([f.update(a),f.final()]).toString("utf8")}default:throw new n("wallet_keystore_unsupported_version")}}var v=t.createWallet({name:"connectKeystore",walletType:t.WalletOption.KEYSTORE,supportedChains:[...t.EVMChains,...t.UTXOChains,...t.CosmosChains,t.Chain.Polkadot,t.Chain.Chainflip,t.Chain.Ripple,t.Chain.Solana],connect:({addChain:r,supportedChains:i,walletType:s})=>async function c(n,o,e){let p=t.filterSupportedChains({chains:n,supportedChains:i,walletType:s});return await Promise.all(p.map(async(a)=>{let l=typeof e==="number"?e:0,m=e&&typeof e==="object"?e[a]:void 0,f=t.NetworkDerivationPath[a].slice(0,a===t.Chain.Solana?4:5),u=m||t.updateDerivationPath(f,{index:l}),{getToolbox:y}=await import("@swapkit/toolboxes"),w=await y(a,{phrase:o,derivationPath:u}),k=await w.getAddress()||"",S={...w,address:k};r({...S,chain:a,walletType:t.WalletOption.KEYSTORE})})),!0}}),E=b(v);
1
+ var _={};E(_,{validatePhrase:()=>K,keystoreWallet:()=>x,generatePhrase:()=>P,encryptToKeyStore:()=>B,decryptFromKeystore:()=>D,KEYSTORE_SUPPORTED_CHAINS:()=>A});module.exports=T(_);var t=require("@swapkit/helpers");var o=require("node:crypto"),h=require("@scure/bip39"),d=require("@scure/bip39/wordlists/english");async function g(r){let{blake2bFinal:c,blake2bInit:p,blake2bUpdate:i}=(await import("blakejs")).default,a=r;if(!(a instanceof Buffer))a=Buffer.from(a,"hex");let n=p(32);return i(n,a),Array.from(c(n)).map((e)=>e<16?`0${e.toString(16)}`:e.toString(16)).join("")}async function B(r,c){let i=o.randomBytes(16),a=o.randomBytes(32),n={c:262144,prf:"hmac-sha256",dklen:32,salt:a.toString("hex")},e=o.pbkdf2Sync(c,a,n.c,n.dklen,"sha256"),f=o.createCipheriv("aes-128-ctr",e.subarray(0,16),i),s=Buffer.concat([f.update(Buffer.from(r,"utf8")),f.final()]),l=Buffer.concat([e.subarray(16,32),Buffer.from(s)]),m=await g(l);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:i.toString("hex")},ciphertext:s.toString("hex"),kdf:"pbkdf2",kdfparams:n,mac:m}}}function P(r=12){return h.generateMnemonic(d.wordlist,r===12?128:256)}function K(r){return h.validateMnemonic(r,d.wordlist)}async function D(r,c){let{SwapKitError:p}=await import("@swapkit/helpers");switch(r.version){case 1:{let i=r.crypto.kdfparams,a=Buffer.from(i.salt,"hex"),n=o.pbkdf2Sync(c,a,i.c,i.dklen,"sha256"),e=Buffer.from(r.crypto.ciphertext,"hex"),f=Buffer.concat([n.subarray(16,32),e]);if(await g(f)!==r.crypto.mac)throw new p("wallet_keystore_invalid_password");let l=o.createDecipheriv(r.crypto.cipher,n.subarray(0,16),Buffer.from(r.crypto.cipherparams.iv,"hex"));return Buffer.concat([l.update(e),l.final()]).toString("utf8")}default:throw new p("wallet_keystore_unsupported_version")}}var x=t.createWallet({name:"connectKeystore",walletType:t.WalletOption.KEYSTORE,supportedChains:[...t.EVMChains,...t.UTXOChains,...t.CosmosChains,t.Chain.Polkadot,t.Chain.Chainflip,t.Chain.Ripple,t.Chain.Solana],connect:({addChain:r,supportedChains:c,walletType:p})=>async function i(a,n,e){let f=t.filterSupportedChains({chains:a,supportedChains:c,walletType:p});return await Promise.all(f.map(async(s)=>{let l=typeof e==="number"?e:0,m=e&&typeof e==="object"?e[s]:void 0,v=t.NetworkDerivationPath[s].slice(0,s===t.Chain.Solana?4:5),b=m||t.updateDerivationPath(v,{index:l}),{getToolbox:k}=await import("@swapkit/toolboxes"),y=await k(s,{phrase:n,derivationPath:b}),S=await y.getAddress()||"",C={...y,address:S};r({...C,chain:s,walletType:t.WalletOption.KEYSTORE})})),!0}}),A=w(x);
2
2
 
3
- //# debugId=D50A7B6A4E41BE6E64756E2164756E21
3
+ //# debugId=BC4B6AA0A1750F4964756E2164756E21
@@ -3,9 +3,9 @@
3
3
  "sources": ["../src/keystore/index.ts", "../src/keystore/helpers.ts"],
4
4
  "sourcesContent": [
5
5
  "import {\n Chain,\n CosmosChains,\n type DerivationPathArray,\n EVMChains,\n NetworkDerivationPath,\n UTXOChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n updateDerivationPath,\n} from \"@swapkit/helpers\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nexport const keystoreWallet = createWallet({\n name: \"connectKeystore\",\n walletType: WalletOption.KEYSTORE,\n supportedChains: [\n ...EVMChains,\n ...UTXOChains,\n ...CosmosChains,\n Chain.Polkadot,\n Chain.Chainflip,\n Chain.Ripple,\n Chain.Solana,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeystore(\n chains: Chain[],\n phrase: string,\n derivationPathMapOrIndex?: { [chain in Chain]?: DerivationPathArray } | number,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const derivationPathIndex =\n typeof derivationPathMapOrIndex === \"number\" ? derivationPathMapOrIndex : 0;\n\n const derivationPathFromMap =\n derivationPathMapOrIndex && typeof derivationPathMapOrIndex === \"object\"\n ? derivationPathMapOrIndex[chain]\n : undefined;\n\n const derivationArrayToUpdate = NetworkDerivationPath[chain].slice(\n 0,\n chain === Chain.Solana ? 4 : 5,\n ) as DerivationPathArray;\n\n const derivationPath: DerivationPathArray =\n derivationPathFromMap ||\n updateDerivationPath(derivationArrayToUpdate, { index: derivationPathIndex });\n\n const { getToolbox } = await import(\"@swapkit/toolboxes\");\n\n const toolbox = await getToolbox(chain, { phrase, derivationPath });\n const address = (await toolbox.getAddress()) || \"\";\n\n const wallet = { ...toolbox, address };\n\n addChain({ ...wallet, chain, walletType: WalletOption.KEYSTORE });\n }),\n );\n\n return true;\n },\n});\n\nexport const KEYSTORE_SUPPORTED_CHAINS = getWalletSupportedChains(keystoreWallet);\n\nexport * from \"./helpers\";\n",
6
- "import { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = await import(\"blakejs\");\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const { pbkdf2Sync, randomBytes, createCipheriv } = await import(\"node:crypto\");\n\n const cipher = \"aes-128-ctr\";\n const iv = randomBytes(16);\n const salt = randomBytes(32);\n const kdfParams = { c: 262144, prf: \"hmac-sha256\", dklen: 32, salt: salt.toString(\"hex\") };\n\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n const cipherIV = createCipheriv(cipher, derivedKey.subarray(0, 16), iv);\n const ciphertext = Buffer.concat([\n cipherIV.update(Buffer.from(phrase, \"utf8\")),\n cipherIV.final(),\n ]);\n const initData = Buffer.concat([derivedKey.subarray(16, 32), Buffer.from(ciphertext)]);\n const mac = await blake256(initData);\n\n return {\n meta: \"xchain-keystore\",\n version: 1,\n crypto: {\n cipher,\n cipherparams: { iv: iv.toString(\"hex\") },\n ciphertext: ciphertext.toString(\"hex\"),\n kdf: \"pbkdf2\",\n kdfparams: kdfParams,\n mac,\n },\n };\n}\n\nexport function generatePhrase(size: 12 | 24 = 12) {\n return generateMnemonic(wordlist, size === 12 ? 128 : 256);\n}\n\nexport function validatePhrase(phrase: string) {\n return validateMnemonic(phrase, wordlist);\n}\n\nexport async function decryptFromKeystore(keystore: Keystore, password: string) {\n const { createDecipheriv, pbkdf2Sync } = await import(\"node:crypto\");\n const { SwapKitError } = await import(\"@swapkit/helpers\");\n\n switch (keystore.version) {\n case 1: {\n const kdfParams = keystore.crypto.kdfparams;\n const salt = Buffer.from(kdfParams.salt, \"hex\");\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n\n const ciphertext = Buffer.from(keystore.crypto.ciphertext, \"hex\");\n const initData = Buffer.concat([derivedKey.subarray(16, 32), ciphertext]);\n const mac = await blake256(initData);\n\n if (mac !== keystore.crypto.mac) {\n throw new SwapKitError(\"wallet_keystore_invalid_password\");\n }\n\n const decipher = createDecipheriv(\n keystore.crypto.cipher,\n derivedKey.subarray(0, 16),\n Buffer.from(keystore.crypto.cipherparams.iv, \"hex\"),\n );\n\n const phrase = Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n return phrase.toString(\"utf8\");\n }\n\n default:\n throw new SwapKitError(\"wallet_keystore_unsupported_version\");\n }\n}\n"
6
+ "import { createCipheriv, createDecipheriv, pbkdf2Sync, randomBytes } from \"node:crypto\";\nimport { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = (await import(\"blakejs\")).default;\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const cipher = \"aes-128-ctr\";\n const iv = randomBytes(16);\n const salt = randomBytes(32);\n const kdfParams = { c: 262144, prf: \"hmac-sha256\", dklen: 32, salt: salt.toString(\"hex\") };\n\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n const cipherIV = createCipheriv(cipher, derivedKey.subarray(0, 16), iv);\n const ciphertext = Buffer.concat([\n cipherIV.update(Buffer.from(phrase, \"utf8\")),\n cipherIV.final(),\n ]);\n const initData = Buffer.concat([derivedKey.subarray(16, 32), Buffer.from(ciphertext)]);\n const mac = await blake256(initData);\n\n return {\n meta: \"xchain-keystore\",\n version: 1,\n crypto: {\n cipher,\n cipherparams: { iv: iv.toString(\"hex\") },\n ciphertext: ciphertext.toString(\"hex\"),\n kdf: \"pbkdf2\",\n kdfparams: kdfParams,\n mac,\n },\n };\n}\n\nexport function generatePhrase(size: 12 | 24 = 12) {\n return generateMnemonic(wordlist, size === 12 ? 128 : 256);\n}\n\nexport function validatePhrase(phrase: string) {\n return validateMnemonic(phrase, wordlist);\n}\n\nexport async function decryptFromKeystore(keystore: Keystore, password: string) {\n const { SwapKitError } = await import(\"@swapkit/helpers\");\n\n switch (keystore.version) {\n case 1: {\n const kdfParams = keystore.crypto.kdfparams;\n const salt = Buffer.from(kdfParams.salt, \"hex\");\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n\n const ciphertext = Buffer.from(keystore.crypto.ciphertext, \"hex\");\n const initData = Buffer.concat([derivedKey.subarray(16, 32), ciphertext]);\n const mac = await blake256(initData);\n\n if (mac !== keystore.crypto.mac) {\n throw new SwapKitError(\"wallet_keystore_invalid_password\");\n }\n\n const decipher = createDecipheriv(\n keystore.crypto.cipher,\n derivedKey.subarray(0, 16),\n Buffer.from(keystore.crypto.cipherparams.iv, \"hex\"),\n );\n\n const phrase = Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n return phrase.toString(\"utf8\");\n }\n\n default:\n throw new SwapKitError(\"wallet_keystore_unsupported_version\");\n }\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "D50A7B6A4E41BE6E64756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "BC4B6AA0A1750F4964756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,3 +1,3 @@
1
- import{a as b}from"../../chunk-czhtd6cy.js";import{c as m,d as h}from"../../chunk-p1kdg37m.js";import{Chain as u,CosmosChains as P,EVMChains as K,NetworkDerivationPath as D,UTXOChains as T,WalletOption as v,createWallet as E,filterSupportedChains as A,updateDerivationPath as _}from"@swapkit/helpers";import{generateMnemonic as C,validateMnemonic as B}from"@scure/bip39";import{wordlist as w}from"@scure/bip39/wordlists/english";async function x(t){let{blake2bFinal:o,blake2bInit:i,blake2bUpdate:s}=await import("blakejs"),a=t;if(!(a instanceof Buffer))a=Buffer.from(a,"hex");let n=i(32);return s(n,a),Array.from(o(n)).map((r)=>r<16?`0${r.toString(16)}`:r.toString(16)).join("")}async function F(t,o){let{pbkdf2Sync:i,randomBytes:s,createCipheriv:a}=await import("node:crypto"),n="aes-128-ctr",r=s(16),c=s(32),e={c:262144,prf:"hmac-sha256",dklen:32,salt:c.toString("hex")},f=i(o,c,e.c,e.dklen,"sha256"),l=a("aes-128-ctr",f.subarray(0,16),r),p=Buffer.concat([l.update(Buffer.from(t,"utf8")),l.final()]),d=Buffer.concat([f.subarray(16,32),Buffer.from(p)]),y=await x(d);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:r.toString("hex")},ciphertext:p.toString("hex"),kdf:"pbkdf2",kdfparams:e,mac:y}}}function Y(t=12){return C(w,t===12?128:256)}function j(t){return B(t,w)}async function N(t,o){let{createDecipheriv:i,pbkdf2Sync:s}=await import("node:crypto"),{SwapKitError:a}=await import("@swapkit/helpers");switch(t.version){case 1:{let n=t.crypto.kdfparams,r=Buffer.from(n.salt,"hex"),c=s(o,r,n.c,n.dklen,"sha256"),e=Buffer.from(t.crypto.ciphertext,"hex"),f=Buffer.concat([c.subarray(16,32),e]);if(await x(f)!==t.crypto.mac)throw new a("wallet_keystore_invalid_password");let p=i(t.crypto.cipher,c.subarray(0,16),Buffer.from(t.crypto.cipherparams.iv,"hex"));return Buffer.concat([p.update(e),p.final()]).toString("utf8")}default:throw new a("wallet_keystore_unsupported_version")}}var R=E({name:"connectKeystore",walletType:v.KEYSTORE,supportedChains:[...K,...T,...P,u.Polkadot,u.Chainflip,u.Ripple,u.Solana],connect:({addChain:t,supportedChains:o,walletType:i})=>async function s(a,n,r){let c=A({chains:a,supportedChains:o,walletType:i});return await Promise.all(c.map(async(e)=>{let f=typeof r==="number"?r:0,l=r&&typeof r==="object"?r[e]:void 0,p=D[e].slice(0,e===u.Solana?4:5),d=l||_(p,{index:f}),{getToolbox:y}=await import("@swapkit/toolboxes"),g=await y(e,{phrase:n,derivationPath:d}),k=await g.getAddress()||"",S={...g,address:k};t({...S,chain:e,walletType:v.KEYSTORE})})),!0}}),X=b(R);export{j as validatePhrase,R as keystoreWallet,Y as generatePhrase,F as encryptToKeyStore,N as decryptFromKeystore,X as KEYSTORE_SUPPORTED_CHAINS};
1
+ import{a as v}from"../../chunk-s6xqbsy0.js";import{c as m,d as h}from"../../chunk-38ztynv0.js";import{Chain as f,CosmosChains as E,EVMChains as A,NetworkDerivationPath as _,UTXOChains as R,WalletOption as w,createWallet as U,filterSupportedChains as W,updateDerivationPath as F}from"@swapkit/helpers";import{createCipheriv as P,createDecipheriv as K,pbkdf2Sync as y,randomBytes as d}from"node:crypto";import{generateMnemonic as D,validateMnemonic as T}from"@scure/bip39";import{wordlist as g}from"@scure/bip39/wordlists/english";async function x(t){let{blake2bFinal:i,blake2bInit:s,blake2bUpdate:n}=(await import("blakejs")).default,e=t;if(!(e instanceof Buffer))e=Buffer.from(e,"hex");let a=s(32);return n(a,e),Array.from(i(a)).map((r)=>r<16?`0${r.toString(16)}`:r.toString(16)).join("")}async function V(t,i){let n=d(16),e=d(32),a={c:262144,prf:"hmac-sha256",dklen:32,salt:e.toString("hex")},r=y(i,e,a.c,a.dklen,"sha256"),c=P("aes-128-ctr",r.subarray(0,16),n),o=Buffer.concat([c.update(Buffer.from(t,"utf8")),c.final()]),p=Buffer.concat([r.subarray(16,32),Buffer.from(o)]),l=await x(p);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:n.toString("hex")},ciphertext:o.toString("hex"),kdf:"pbkdf2",kdfparams:a,mac:l}}}function H(t=12){return D(g,t===12?128:256)}function X(t){return T(t,g)}async function $(t,i){let{SwapKitError:s}=await import("@swapkit/helpers");switch(t.version){case 1:{let n=t.crypto.kdfparams,e=Buffer.from(n.salt,"hex"),a=y(i,e,n.c,n.dklen,"sha256"),r=Buffer.from(t.crypto.ciphertext,"hex"),c=Buffer.concat([a.subarray(16,32),r]);if(await x(c)!==t.crypto.mac)throw new s("wallet_keystore_invalid_password");let p=K(t.crypto.cipher,a.subarray(0,16),Buffer.from(t.crypto.cipherparams.iv,"hex"));return Buffer.concat([p.update(r),p.final()]).toString("utf8")}default:throw new s("wallet_keystore_unsupported_version")}}var Y=U({name:"connectKeystore",walletType:w.KEYSTORE,supportedChains:[...A,...R,...E,f.Polkadot,f.Chainflip,f.Ripple,f.Solana],connect:({addChain:t,supportedChains:i,walletType:s})=>async function n(e,a,r){let c=W({chains:e,supportedChains:i,walletType:s});return await Promise.all(c.map(async(o)=>{let p=typeof r==="number"?r:0,l=r&&typeof r==="object"?r[o]:void 0,b=_[o].slice(0,o===f.Solana?4:5),k=l||F(b,{index:p}),{getToolbox:S}=await import("@swapkit/toolboxes"),u=await S(o,{phrase:a,derivationPath:k}),C=await u.getAddress()||"",B={...u,address:C};t({...B,chain:o,walletType:w.KEYSTORE})})),!0}}),I=v(Y);export{X as validatePhrase,Y as keystoreWallet,H as generatePhrase,V as encryptToKeyStore,$ as decryptFromKeystore,I as KEYSTORE_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=EC8374AD79B021B164756E2164756E21
3
+ //# debugId=FCFD00914C62A12F64756E2164756E21
@@ -3,9 +3,9 @@
3
3
  "sources": ["../src/keystore/index.ts", "../src/keystore/helpers.ts"],
4
4
  "sourcesContent": [
5
5
  "import {\n Chain,\n CosmosChains,\n type DerivationPathArray,\n EVMChains,\n NetworkDerivationPath,\n UTXOChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n updateDerivationPath,\n} from \"@swapkit/helpers\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nexport const keystoreWallet = createWallet({\n name: \"connectKeystore\",\n walletType: WalletOption.KEYSTORE,\n supportedChains: [\n ...EVMChains,\n ...UTXOChains,\n ...CosmosChains,\n Chain.Polkadot,\n Chain.Chainflip,\n Chain.Ripple,\n Chain.Solana,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeystore(\n chains: Chain[],\n phrase: string,\n derivationPathMapOrIndex?: { [chain in Chain]?: DerivationPathArray } | number,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const derivationPathIndex =\n typeof derivationPathMapOrIndex === \"number\" ? derivationPathMapOrIndex : 0;\n\n const derivationPathFromMap =\n derivationPathMapOrIndex && typeof derivationPathMapOrIndex === \"object\"\n ? derivationPathMapOrIndex[chain]\n : undefined;\n\n const derivationArrayToUpdate = NetworkDerivationPath[chain].slice(\n 0,\n chain === Chain.Solana ? 4 : 5,\n ) as DerivationPathArray;\n\n const derivationPath: DerivationPathArray =\n derivationPathFromMap ||\n updateDerivationPath(derivationArrayToUpdate, { index: derivationPathIndex });\n\n const { getToolbox } = await import(\"@swapkit/toolboxes\");\n\n const toolbox = await getToolbox(chain, { phrase, derivationPath });\n const address = (await toolbox.getAddress()) || \"\";\n\n const wallet = { ...toolbox, address };\n\n addChain({ ...wallet, chain, walletType: WalletOption.KEYSTORE });\n }),\n );\n\n return true;\n },\n});\n\nexport const KEYSTORE_SUPPORTED_CHAINS = getWalletSupportedChains(keystoreWallet);\n\nexport * from \"./helpers\";\n",
6
- "import { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = await import(\"blakejs\");\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const { pbkdf2Sync, randomBytes, createCipheriv } = await import(\"node:crypto\");\n\n const cipher = \"aes-128-ctr\";\n const iv = randomBytes(16);\n const salt = randomBytes(32);\n const kdfParams = { c: 262144, prf: \"hmac-sha256\", dklen: 32, salt: salt.toString(\"hex\") };\n\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n const cipherIV = createCipheriv(cipher, derivedKey.subarray(0, 16), iv);\n const ciphertext = Buffer.concat([\n cipherIV.update(Buffer.from(phrase, \"utf8\")),\n cipherIV.final(),\n ]);\n const initData = Buffer.concat([derivedKey.subarray(16, 32), Buffer.from(ciphertext)]);\n const mac = await blake256(initData);\n\n return {\n meta: \"xchain-keystore\",\n version: 1,\n crypto: {\n cipher,\n cipherparams: { iv: iv.toString(\"hex\") },\n ciphertext: ciphertext.toString(\"hex\"),\n kdf: \"pbkdf2\",\n kdfparams: kdfParams,\n mac,\n },\n };\n}\n\nexport function generatePhrase(size: 12 | 24 = 12) {\n return generateMnemonic(wordlist, size === 12 ? 128 : 256);\n}\n\nexport function validatePhrase(phrase: string) {\n return validateMnemonic(phrase, wordlist);\n}\n\nexport async function decryptFromKeystore(keystore: Keystore, password: string) {\n const { createDecipheriv, pbkdf2Sync } = await import(\"node:crypto\");\n const { SwapKitError } = await import(\"@swapkit/helpers\");\n\n switch (keystore.version) {\n case 1: {\n const kdfParams = keystore.crypto.kdfparams;\n const salt = Buffer.from(kdfParams.salt, \"hex\");\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n\n const ciphertext = Buffer.from(keystore.crypto.ciphertext, \"hex\");\n const initData = Buffer.concat([derivedKey.subarray(16, 32), ciphertext]);\n const mac = await blake256(initData);\n\n if (mac !== keystore.crypto.mac) {\n throw new SwapKitError(\"wallet_keystore_invalid_password\");\n }\n\n const decipher = createDecipheriv(\n keystore.crypto.cipher,\n derivedKey.subarray(0, 16),\n Buffer.from(keystore.crypto.cipherparams.iv, \"hex\"),\n );\n\n const phrase = Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n return phrase.toString(\"utf8\");\n }\n\n default:\n throw new SwapKitError(\"wallet_keystore_unsupported_version\");\n }\n}\n"
6
+ "import { createCipheriv, createDecipheriv, pbkdf2Sync, randomBytes } from \"node:crypto\";\nimport { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = (await import(\"blakejs\")).default;\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const cipher = \"aes-128-ctr\";\n const iv = randomBytes(16);\n const salt = randomBytes(32);\n const kdfParams = { c: 262144, prf: \"hmac-sha256\", dklen: 32, salt: salt.toString(\"hex\") };\n\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n const cipherIV = createCipheriv(cipher, derivedKey.subarray(0, 16), iv);\n const ciphertext = Buffer.concat([\n cipherIV.update(Buffer.from(phrase, \"utf8\")),\n cipherIV.final(),\n ]);\n const initData = Buffer.concat([derivedKey.subarray(16, 32), Buffer.from(ciphertext)]);\n const mac = await blake256(initData);\n\n return {\n meta: \"xchain-keystore\",\n version: 1,\n crypto: {\n cipher,\n cipherparams: { iv: iv.toString(\"hex\") },\n ciphertext: ciphertext.toString(\"hex\"),\n kdf: \"pbkdf2\",\n kdfparams: kdfParams,\n mac,\n },\n };\n}\n\nexport function generatePhrase(size: 12 | 24 = 12) {\n return generateMnemonic(wordlist, size === 12 ? 128 : 256);\n}\n\nexport function validatePhrase(phrase: string) {\n return validateMnemonic(phrase, wordlist);\n}\n\nexport async function decryptFromKeystore(keystore: Keystore, password: string) {\n const { SwapKitError } = await import(\"@swapkit/helpers\");\n\n switch (keystore.version) {\n case 1: {\n const kdfParams = keystore.crypto.kdfparams;\n const salt = Buffer.from(kdfParams.salt, \"hex\");\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n\n const ciphertext = Buffer.from(keystore.crypto.ciphertext, \"hex\");\n const initData = Buffer.concat([derivedKey.subarray(16, 32), ciphertext]);\n const mac = await blake256(initData);\n\n if (mac !== keystore.crypto.mac) {\n throw new SwapKitError(\"wallet_keystore_invalid_password\");\n }\n\n const decipher = createDecipheriv(\n keystore.crypto.cipher,\n derivedKey.subarray(0, 16),\n Buffer.from(keystore.crypto.cipherparams.iv, \"hex\"),\n );\n\n const phrase = Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n return phrase.toString(\"utf8\");\n }\n\n default:\n throw new SwapKitError(\"wallet_keystore_unsupported_version\");\n }\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "EC8374AD79B021B164756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "FCFD00914C62A12F64756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var e0={};t0(e0,{ledgerWallet:()=>K0,LEDGER_SUPPORTED_CHAINS:()=>n0});module.exports=o0(e0);var J=require("@swapkit/helpers");var H=require("@swapkit/helpers"),E=async({chain:L,ledgerClient:_})=>{if(!_)return"";switch(L){case H.Chain.Cosmos:case H.Chain.THORChain:return _.connect();case H.Chain.Ethereum:case H.Chain.BinanceSmartChain:case H.Chain.Avalanche:case H.Chain.Polygon:case H.Chain.Arbitrum:case H.Chain.Optimism:case H.Chain.Base:return _.getAddress();case H.Chain.Bitcoin:case H.Chain.BitcoinCash:case H.Chain.Dash:case H.Chain.Dogecoin:case H.Chain.Litecoin:{let O=_;await O.connect();let B=await O.getAddress();return L===H.Chain.BitcoinCash?B.replace("bitcoincash:",""):B}default:throw new H.SwapKitError("wallet_chain_not_supported",{wallet:H.WalletOption.LEDGER,chain:L})}};var Y=require("@swapkit/helpers");var x=require("@swapkit/helpers");var w=require("@swapkit/helpers");var C=85,d=250;var K={GET_VERSION:0,INS_PUBLIC_KEY_SECP256K1:1,SIGN_SECP256K1:2,GET_ADDR_SECP256K1:4},k={INIT:0,ADD:1,LAST:2},i={ONLY_RETRIEVE:0,SHOW_ADDRESS_IN_DEVICE:1},f={JSON:0},R={NoError:36864},G0={1:"U2F: Unknown",2:"U2F: Bad request",3:"U2F: Configuration unsupported",4:"U2F: Device Ineligible",5:"U2F: Timeout",14:"Timeout",36864:"No errors",36865:"Device is busy",26626:"Error deriving keys",25600:"Execution Error",26368:"Wrong Length",27010:"Empty Buffer",27011:"Output buffer too small",27012:"Data is invalid",27013:"Conditions not satisfied",27014:"Transaction rejected",27264:"Bad key handle",27392:"Invalid P1/P2",27904:"Instruction not supported",28160:"App does not seem to be open",28416:"Unknown error",28417:"Sign/verify error"};function U(L){if(L in G0)return G0[L];return`Unknown Status Code: ${L}`}function h0(L){return typeof L==="object"&&L!==null&&!Array.isArray(L)&&!(L instanceof Date)}function M(L){if(L){if(h0(L)){if(Object.prototype.hasOwnProperty.call(L,"statusCode"))return{return_code:L.statusCode,error_message:U(L.statusCode)};if(Object.prototype.hasOwnProperty.call(L,"return_code")&&Object.prototype.hasOwnProperty.call(L,"error_message"))return L}return{return_code:65535,error_message:L.toString()}}return{return_code:65535,error_message:L.toString()}}async function p(L){return L.send(85,K.GET_VERSION,0,0).then((_)=>{let O=_.slice(-2),B=O[0]*256+O[1],G=0;if(_.length>=9)G=(_[5]<<24)+(_[6]<<16)+(_[7]<<8)+(_[8]<<0);return{return_code:B,error_message:U(B),test_mode:_[0]!==0,major:_[1],minor:_[2],patch:_[3],device_locked:_[4]===1,target_id:G.toString(16)}},M)}function B0(L){if(L==null||L.length<3)throw new Error("Invalid path.");if(L.length>10)throw new Error("Invalid path. Length should be <= 10");let _=Buffer.alloc(1+4*L.length);_.writeUInt8(L.length,0);for(let O=0;O<L.length;O+=1){let B=L[O]||0;if(O<3)B|=2147483648;_.writeInt32LE(B,1+O*4)}return _}async function o(L,_,O,B,G=f.JSON){return L.transport.send(C,K.SIGN_SECP256K1,_,G,B,[R.NoError,27012,27264]).then((j)=>{let X=j.slice(-2),F=X[0]*256+X[1],W=U(F);if(F===27264||F===27012)W=`${W} : ${j.slice(0,j.length-2).toString("ascii")}`;let $=null;if(j.length>2)$=j.slice(0,j.length-2);return{signature:$,return_code:F,error_message:W}},M)}function d0(L){if(L.length!==65)throw new Error("decompressed public key length should be 65 bytes");let _=L.slice(33,65),O=Buffer.from([2+(_[_.length-1]&1)]);return Buffer.concat([O,L.slice(1,33)])}async function j0(L,_){return L.transport.send(C,K.INS_PUBLIC_KEY_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let B=O.slice(-2),G=B[0]*256+B[1],j=Buffer.from(O.slice(0,65));return{pk:j,compressed_pk:d0(j),return_code:G,error_message:U(G)}},M)}function F0(L){if(!L||L.length!==5)throw new Error("Invalid path.");let _=Buffer.alloc(20);return _.writeUInt32LE(2147483648+L[0],0),_.writeUInt32LE(2147483648+L[1],4),_.writeUInt32LE(2147483648+L[2],8),_.writeUInt32LE(L[3],12),_.writeUInt32LE(L[4],16),_}function X0(L,_,O,B,G=f.JSON){let j=k.ADD;if(_===1)j=k.INIT;if(_===O)j=k.LAST;return o(L,j,0,B,G)}async function J0(L,_){return L.transport.send(C,K.GET_ADDR_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let B=O.slice(-2),G=B[0]*256+B[1];return{pk:"OBSOLETE PROPERTY",compressed_pk:Buffer.from(O.slice(0,33)),return_code:G,error_message:U(G)}},M)}class l{transport;versionResponse;constructor(L){if(!L)throw new Error("Transport has not been defined");this.transport=L}static serializeHRP(L){if(L==null||L.length<3||L.length>83)throw new Error("Invalid HRP");let _=Buffer.alloc(1+L.length);return _.writeUInt8(L.length,0),_.write(L,1),_}async serializePath(L){if(this.versionResponse=await p(this.transport),this.versionResponse.return_code!==R.NoError)throw this.versionResponse;switch(this.versionResponse.major){case 1:return B0(L);case 2:return F0(L);default:return Buffer.alloc(0)}}async signGetChunks(L,_){let O=await this.serializePath(L),B=[];B.push(O);for(let G=0;G<_.length;G+=d){let j=G+d;if(G>_.length)j=_.length;B.push(_.slice(G,j))}return B}async getVersion(){try{return this.versionResponse=await p(this.transport),this.versionResponse}catch(L){return M(L)}}async appInfo(){return this.transport.send(176,1,0,0).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1],B="",G="",j=0,X=0;if(L[0]!==1)return{return_code:36865,error_message:"response format ID not recognized"};let F=L[1];B=L.slice(2,2+F).toString("ascii");let W=2+F,$=L[W];W+=1,G=L.slice(W,W+$).toString("ascii"),W+=$;let Q=L[W];return W+=1,j=Q,X=L[W],{return_code:O,error_message:U(O),appName:B,appVersion:G,flagLen:j,flagsValue:X,flag_recovery:(X&1)!==0,flag_signed_mcu_code:(X&2)!==0,flag_onboarded:(X&4)!==0,flag_pin_validated:(X&128)!==0}},M)}async deviceInfo(){return this.transport.send(224,1,0,0,Buffer.from([]),[R.NoError,28160]).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1];if(O===28160)return{return_code:O,error_message:"This command is only available in the Dashboard"};let B=L.slice(0,4).toString("hex"),G=4,j=L[G];G+=1;let X=L.slice(G,G+j).toString();G+=j;let F=L[G];G+=1;let W=L.slice(G,G+F).toString("hex");G+=F;let $=L[G];G+=1;let Q=L.slice(G,G+$);if(Q[$-1]===0)Q=L.slice(G,G+$-1);let T=Q.toString();return{return_code:O,error_message:U(O),targetId:B,seVersion:X,flag:W,mcuVersion:T}},M)}async publicKey(L){try{let _=await this.serializePath(L);switch(this.versionResponse.major){case 1:return j0(this,_);case 2:{let O=Buffer.concat([l.serializeHRP("thor"),_]);return J0(this,O)}default:return{return_code:25600,error_message:"App Version is not supported"}}}catch(_){return M(_)}}async getAddressAndPubKey(L,_,O=!1){return this.serializePath(L).then((B)=>{let G=Buffer.concat([l.serializeHRP(_),B]);return this.transport.send(C,K.GET_ADDR_SECP256K1,O?i.SHOW_ADDRESS_IN_DEVICE:i.ONLY_RETRIEVE,0,G,[R.NoError]).then((j)=>{let X=j.slice(-2),F=X[0]*256+X[1],W=Buffer.from(j.slice(0,33));return{bech32_address:Buffer.from(j.slice(33,-2)).toString(),compressed_pk:W,return_code:F,error_message:U(F)}},M)}).catch((B)=>M(B))}showAddressAndPubKey(L,_){return this.getAddressAndPubKey(L,_,!0)}signSendChunk(L,_,O,B=f.JSON){switch(this.versionResponse.major){case 1:return o(this,L,_,O,B);case 2:return X0(this,L,_,O,B);default:return{return_code:25600,error_message:"App Version is not supported"}}}async sign(L,_,O=f.JSON){let B=Buffer.from(_),G=[],j;try{G=await this.signGetChunks(L,B),j=await this.signSendChunk(1,G.length,G[0],O)}catch(F){M(F)}let X={return_code:j.return_code,error_message:j.error_message,signature:null};for(let F=1;F<G.length;F+=1)if(X=await this.signSendChunk(1+F,G.length,G[F],O),X.return_code!==R.NoError)break;return{return_code:X.return_code,error_message:X.error_message,signature:X.signature}}}var b=require("@swapkit/helpers"),t=()=>navigator?.usb,i0=async()=>{let L=t();if(typeof L?.getDevices!=="function")return[];let{ledgerUSBVendorId:_}=await import("@ledgerhq/devices"),B=(await L?.getDevices()).filter((G)=>G.vendorId===_);if(B.length>0)return B[0];return L?.requestDevice({filters:[{vendorId:_}]})},N=async()=>{let L=await i0();if(!L)throw new b.SwapKitError("wallet_ledger_device_not_found");if(await L.open(),L.configuration===null)await L.selectConfiguration(1);try{await L.reset()}catch{}let _=L.configurations[0].interfaces.find(({alternates:F})=>F.some(({interfaceClass:W})=>W===255));if(!_)throw await L.close(),new b.SwapKitError("wallet_ledger_connection_error");try{await L.claimInterface(_.interfaceNumber)}catch(F){throw await L.close(),new b.SwapKitError("wallet_ledger_connection_claimed",F)}let{default:O}=await import("@ledgerhq/hw-transport-webusb");if(!await O.isSupported())throw new Error("WebUSB not supported");let{DisconnectedDevice:G}=await import("@ledgerhq/errors"),j=new O(L,_.interfaceNumber),X=(F)=>{if(L===F.device)t()?.removeEventListener("disconnect",X),j._emitDisconnect(new G)};return t()?.addEventListener("disconnect",X),j};class V{ledgerTimeout=50000;derivationPath=w.NetworkDerivationPath.GAIA;transport;ledgerApp;chain="thor";checkOrCreateTransportAndLedger=async(L=!1)=>{if(!L&&this.transport&&this.ledgerApp)return;try{switch(this.transport=L||!this.transport?await N():this.transport,this.chain){case"thor":{this.ledgerApp=L||!this.ledgerApp?new l(this.transport):this.ledgerApp;break}case"cosmos":{let{default:_}=await import("@ledgerhq/hw-app-cosmos");this.ledgerApp=L||!this.ledgerApp?new _(this.transport):this.ledgerApp}}return this.ledgerApp}catch(_){throw new w.SwapKitError("wallet_ledger_connection_error",_)}};validateResponse=(L,_)=>{switch(L){case w.LedgerErrorCode.NoError:return;case w.LedgerErrorCode.LockedDevice:throw new w.SwapKitError("wallet_ledger_device_locked",{message:`Ledger is locked: ${_}`});case w.LedgerErrorCode.TC_NotFound:throw new w.SwapKitError("wallet_ledger_device_not_found");default:{console.error(`Ledger error: ${L} ${_}`);break}}}}class n extends V{pubKey=null;derivationPath;constructor(L=x.NetworkDerivationPath.GAIA){super();this.chain="cosmos",this.derivationPath=x.derivationPathToString(L)}connect=async()=>{await this.checkOrCreateTransportAndLedger(!0);let{publicKey:L,address:_}=await this.getAddressAndPubKey();return this.pubKey=Buffer.from(L,"hex").toString("base64"),_};getAddressAndPubKey=async()=>{return await this.checkOrCreateTransportAndLedger(!0),await this.ledgerApp.getAddress(this.derivationPath,this.chain)};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:B,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,B),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:G}]};signAmino=async(L,_)=>{await this.checkOrCreateTransportAndLedger(!0);let O=await this.getAccounts();if(O.findIndex((Q)=>Q.address===L)===-1)throw new Error(`Address ${L} not found in wallet`);let{encodeSecp256k1Signature:G,serializeSignDoc:j}=await import("@cosmjs/amino"),{Secp256k1Signature:X}=await import("@cosmjs/crypto"),F=j(_),W=await this.ledgerApp.sign(this.derivationPath,F);this.validateResponse(W.return_code,W.error_message);let $=X.fromDer(W.signature).toFixedLength();return{signed:_,signature:G(O[0].pubkey,$)}};getAccounts=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.getAddressAndPubKey();return[{address:L.address,algo:"secp256k1",pubkey:Buffer.from(L.publicKey,"hex")}]}}var m=require("@swapkit/helpers"),W0=require("ethers");class y extends W0.AbstractSigner{chainId=m.ChainId.Ethereum;derivationPath="";ledgerApp=null;ledgerTimeout=50000;constructor({provider:L,derivationPath:_=m.NetworkDerivationPath.OP,chainId:O=m.ChainId.Optimism}){super(L);this.chainId=O||m.ChainId.Ethereum,this.derivationPath=typeof _==="string"?_:m.derivationPathToString(_),Object.defineProperty(this,"provider",{enumerable:!0,value:L||null,writable:!1})}connect=(L)=>new y({provider:L,derivationPath:this.derivationPath,chainId:this.chainId});checkOrCreateTransportAndLedger=async()=>{if(this.ledgerApp)return;await this.createTransportAndLedger()};createTransportAndLedger=async()=>{let L=await N(),{default:_}=await import("@ledgerhq/hw-app-eth");this.ledgerApp=new _(L)};getAddress=async()=>{let L=await this.getAddressAndPubKey();if(!L)throw new Error("Could not get Address");return L.address};getAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath)};showAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath,!0)};signMessage=async(L)=>{let{Signature:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.ledgerApp?.signPersonalMessage(this.derivationPath,L);if(!O)throw new Error("Signing failed");return O.r=`0x${O.r}`,O.s=`0x${O.s}`,_.from(O).serialized};sendTransaction=async(L)=>{if(!this.provider)throw new Error("No provider set");let _=await this.signTransaction(L);return await this.provider.broadcastTransaction(_)};signTypedData(){throw new Error("Method not implemented.")}signTransaction=async(L)=>{let{Transaction:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.provider?.getTransactionCount(L.from||await this.getAddress()),B={chainId:L.chainId||this.chainId,data:L.data,gasLimit:L.gasLimit,...L.gasPrice&&{gasPrice:L.gasPrice},...!L.gasPrice&&L.maxFeePerGas&&{maxFeePerGas:L.maxFeePerGas,maxPriorityFeePerGas:L.maxPriorityFeePerGas},nonce:L.nonce!==void 0?Number((L.nonce||O||0).toString()):O,to:L.to?.toString(),value:L.value,type:L.type&&!Number.isNaN(L.type)?L.type:L.maxFeePerGas?2:0},G=_.from(B).unsignedSerialized.slice(2),{ledgerService:j}=await import("@ledgerhq/hw-app-eth"),X=await j.resolveTransaction(G,{},{externalPlugins:!0,erc20:!0}),F=await this.ledgerApp?.signTransaction(this.derivationPath,G,X);if(!F)throw new Error("Could not sign transaction");let{r:W,s:$,v:Q}=F;return _.from({...B,signature:{v:Number(BigInt(Q)),r:`0x${W}`,s:`0x${$}`}}).serialized}}var $0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Ethereum,provider:L,derivationPath:_}),Q0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Avalanche,provider:L,derivationPath:_}),Y0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.BinanceSmartChain,provider:L,derivationPath:_}),Z0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Arbitrum,provider:L,derivationPath:_}),H0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Polygon,provider:L,derivationPath:_}),m0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Optimism,provider:L,derivationPath:_}),M0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Base,provider:L,derivationPath:_});var U0=require("@scure/base"),w0=require("@swapkit/helpers");var T0=require("@scure/base"),a=(L)=>{if(L.length<64)throw new Error("Invalid Signature: Too short");if(L[0]!==48)throw new Error("Invalid Ledger Signature TLV encoding: expected first byte 0x30");if(L[1]+2!==L.length)throw new Error("Invalid Signature: signature length does not match TLV");if(L[2]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let _=L[3],O=L.slice(4,_+4);if(O.length===33&&O[0]===0)O=O.slice(1,33);else if(O.length===33)throw new Error('Invalid signature: "r" too long');while(O.length<32)O.unshift(0);if(L[_+4]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let B=L[_+5];if(4+_+2+B!==L.length)throw new Error("Invalid Ledger Signature: TLV byte lengths do not match message length");let G=L.slice(_+6,L.length);if(G.length===33&&G[0]===0)G=G.slice(1,33);else if(G.length===33)throw new Error('Invalid signature: "s" too long');while(G.length<32)G.unshift(0);if(O.length!==32||G.length!==32)throw new Error("Invalid signatures: must be 32 bytes each");return T0.base64.encode(Buffer.concat([O,G]))};class s extends V{pubKey=null;derivationPath;constructor(L=w0.NetworkDerivationPath.THOR){super();this.chain="thor",this.derivationPath=L}get pubkey(){return this.pubKey}connect=async()=>{await this.checkOrCreateTransportAndLedger();let{compressed_pk:L,bech32_address:_}=await this.getAddressAndPubKey();return this.pubKey=U0.base64.encode(L),_};getAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.getAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};showAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.showAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:B,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,B),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:a(G)}]};sign=async(L)=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:_,error_message:O,signature:B}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(_,O),a(B)}}var q=require("@swapkit/helpers");var p0=async({psbt:L,inputUtxos:_,btcApp:O,derivationPath:B},G)=>{let{Transaction:j}=await import("bitcoinjs-lib"),X=_.map((T)=>{let D=j.fromHex(T.txHex||"");return[O.splitTransaction(D.toHex(),D.hasWitnesses()),T.index,void 0,void 0]}),F=L.data.globalMap.unsignedTx.toBuffer().toString("hex"),W=O.splitTransaction(F,!0),$=O.serializeTransactionOutputs(W).toString("hex"),Q={additionals:["bech32"],associatedKeysets:X.map(()=>B),inputs:X,outputScriptHex:$,segwit:!0,useTrustedInputForSegwit:!0};return O.createPaymentTransaction({...Q,...G})},A=({chain:L,additionalSignParams:_})=>{let O,B=null;async function G(X=!0){if(X&&!O)new q.SwapKitError("wallet_ledger_connection_error",{message:`Ledger connection failed:
2
- ${JSON.stringify({checkBtcApp:X,btcApp:O})}`});B||=await N()}async function j(){B=await N();let{default:X}=await import("@ledgerhq/hw-app-btc");O=new X({transport:B,currency:L})}return(X)=>{let F=typeof X==="string"?X:q.derivationPathToString(X),W=q.getWalletFormatFor(F);return{connect:async()=>{await G(!1);let{default:$}=await import("@ledgerhq/hw-app-btc");O=new $({transport:B,currency:L})},getExtendedPublicKey:async($="84'/0'/0'",Q=76067358)=>{return await G(!1),O.getWalletXpub({path:$,xpubVersion:Q})},signTransaction:async($,Q)=>{return await j(),p0({psbt:$,derivationPath:F,btcApp:O,inputUtxos:Q},_)},getAddress:async()=>{let{toCashAddress:$}=await import("@swapkit/toolboxes/utxo");await G(!1);let{bitcoinAddress:Q}=await O.getWalletPublicKey(F,{format:W});if(!Q)throw new q.SwapKitError("wallet_ledger_get_address_error",{message:`Cannot get ${L} address from ledger derivation path: ${F}`});return L==="bitcoin-cash"&&W==="legacy"?$(Q).replace(/(bchtest:|bitcoincash:)/,""):Q}}}},R0=A({chain:"bitcoin"}),y0=A({chain:"litecoin"}),D0=A({chain:"bitcoin-cash",additionalSignParams:{segwit:!1,additionals:["abc"],sigHashType:65}}),N0=A({chain:"dogecoin",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}}),z0=A({chain:"dash",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}});var I=async({chain:L,derivationPath:_})=>{switch(L){case Y.Chain.THORChain:return new s(_);case Y.Chain.Cosmos:return new n(_);case Y.Chain.Bitcoin:return R0(_);case Y.Chain.BitcoinCash:return D0(_);case Y.Chain.Dash:return z0(_);case Y.Chain.Dogecoin:return N0(_);case Y.Chain.Litecoin:return y0(_);case Y.Chain.Arbitrum:case Y.Chain.Avalanche:case Y.Chain.BinanceSmartChain:case Y.Chain.Ethereum:case Y.Chain.Optimism:case Y.Chain.Polygon:case Y.Chain.Base:{let{getProvider:O}=await import("@swapkit/toolboxes/evm"),B={provider:await O(L),derivationPath:_};switch(L){case Y.Chain.BinanceSmartChain:return Y0(B);case Y.Chain.Avalanche:return Q0(B);case Y.Chain.Arbitrum:return Z0(B);case Y.Chain.Optimism:return m0(B);case Y.Chain.Polygon:return H0(B);case Y.Chain.Base:return M0(B);default:return $0(B)}}default:throw new Y.SwapKitError("wallet_chain_not_supported",{wallet:Y.WalletOption.LEDGER,chain:L})}};var K0=J.createWallet({name:"connectLedger",supportedChains:[J.Chain.Arbitrum,J.Chain.Avalanche,J.Chain.Base,J.Chain.BinanceSmartChain,J.Chain.Bitcoin,J.Chain.BitcoinCash,J.Chain.Cosmos,J.Chain.Dash,J.Chain.Dogecoin,J.Chain.Ethereum,J.Chain.Litecoin,J.Chain.Optimism,J.Chain.Polygon,J.Chain.THORChain],walletType:J.WalletOption.LEDGER,connect:({addChain:L,supportedChains:_,walletType:O})=>async function B(G,j){let[X]=J.filterSupportedChains({chains:G,supportedChains:_,walletType:O});if(!X)return!1;let F=await r0({chain:X,derivationPath:j});return L({...F,chain:X,walletType:J.WalletOption.LEDGER}),!0}}),n0=q0(K0);function a0(L,_="t"){if(!L?.includes("=:"))return L;let O=L.includes(`:${_}:`)?L.split(`:${_}:`)[0]:L;return O?.substring(0,O.lastIndexOf(":"))}function v(L){if(Array.isArray(L))return L.forEach((B,G)=>{L[G]=v(B)}),L;if(typeof L!=="object")return L;let _={},O=Object.keys(L).sort();for(let B of O)_[B]=v(L[B]);return _}function s0(L){return JSON.stringify(v(L))}async function r0({chain:L,derivationPath:_}){switch(L){case J.Chain.BitcoinCash:case J.Chain.Bitcoin:case J.Chain.Dash:case J.Chain.Dogecoin:case J.Chain.Litecoin:{let{getUtxoToolbox:O}=await import("@swapkit/toolboxes/utxo"),B=await O(L),G=await I({chain:L,derivationPath:_}),j=await E({chain:L,ledgerClient:G});return{...B,address:j,transfer:async(F)=>{let W=F.feeRate||(await B.getFeeRates())[J.FeeOption.Average],$=[J.Chain.Bitcoin].includes(L)?F.memo:a0(F.memo),{psbt:Q,inputs:T}=await B.createTransaction({...F,feeRate:W,memo:$,sender:j,fetchTxHex:!0}),D=await G.signTransaction(Q,T);return await B.broadcastTx(D)}}}case J.Chain.Ethereum:case J.Chain.Avalanche:case J.Chain.Arbitrum:case J.Chain.Optimism:case J.Chain.Polygon:case J.Chain.BinanceSmartChain:case J.Chain.Base:{let{getEvmToolbox:O}=await import("@swapkit/toolboxes/evm"),B=await I({chain:L,derivationPath:_}),G=await E({chain:L,ledgerClient:B});return{...await O(L,{signer:B}),address:G}}case J.Chain.Cosmos:{let{createSigningStargateClient:O,getMsgSendDenom:B,getCosmosToolbox:G}=await import("@swapkit/toolboxes/cosmos"),j=await G(J.Chain.Cosmos),X=await I({chain:L,derivationPath:_}),F=await E({chain:L,ledgerClient:X});return{...j,address:F,transfer:async({assetValue:$,recipient:Q,memo:T})=>{if(!$)throw new Error("invalid asset");let D={amount:[{amount:$.getBaseValue("string"),denom:B(`u${$.symbol}`).toLowerCase()}],fromAddress:F,toAddress:Q},S=await O(J.SKConfig.get("rpcUrls")[L],X,"0.007uatom"),{transactionHash:P}=await S.signAndBroadcast(F,[{typeUrl:"/cosmos.bank.v1beta1.MsgSend",value:D}],2,T);return P}}}case J.Chain.THORChain:{let{SignMode:O}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:B}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),{encodePubkey:G,makeAuthInfoBytes:j}=await import("@cosmjs/proto-signing"),{createStargateClient:X,buildEncodedTxBody:F,getCosmosToolbox:W,buildAminoMsg:$,getDefaultChainFee:Q,fromBase64:T,parseAminoMessageForDirectSigning:D}=await import("@swapkit/toolboxes/cosmos"),S=await W(L),P=await I({chain:L,derivationPath:_}),g=await E({chain:L,ledgerClient:P}),c=Q(L),{pubkey:r,signTransaction:S0,sign:E0}=P,e=async({memo:z="",assetValue:L0,...C0})=>{let _0=await S.getAccount(g);if(!_0)throw new Error("invalid account");if(!L0)throw new Error("invalid asset");if(!r)throw new Error("Account pubkey not found");let{accountNumber:f0,sequence:I0}=_0,u=(I0||0).toString(),O0=v([$({sender:g,assetValue:L0,memo:z,...C0})]),l0=s0({account_number:f0?.toString(),chain_id:J.ChainId.THORChain,fee:c,memo:z,msgs:O0,sequence:u}),h=await S0(l0,u);if(!h)throw new Error("tx signing failed");let V0=G({type:"tendermint/PubKeySecp256k1",value:r}),A0=O0.map(D),P0=await F({msgs:A0,chain:L,memo:z}),k0=j([{pubkey:V0,sequence:Number(u)}],c.amount,Number.parseInt(c.gas),void 0,void 0,O.SIGN_MODE_LEGACY_AMINO_JSON),b0=h?.[0]?.signature?T(h[0].signature):Uint8Array.from([]),x0=B.fromPartial({bodyBytes:P0,authInfoBytes:k0,signatures:[b0]}),v0=B.encode(x0).finish(),{isStagenet:g0}=J.SKConfig.get("envs"),c0=await X(J.SKConfig.get("rpcUrls")[g0?J.StagenetChain.THORChain:J.Chain.THORChain]),{transactionHash:u0}=await c0.broadcastTx(v0);return u0};return{...S,address:g,deposit:(z)=>e(z),transfer:(z)=>e(z),signMessage:E0}}default:throw new Error("Unsupported chain")}}
1
+ var BL={};mL(BL,{ledgerWallet:()=>f0,LEDGER_SUPPORTED_CHAINS:()=>OL});module.exports=_L(BL);var B=require("@swapkit/helpers");var J=require("@swapkit/helpers"),E=async({chain:L,ledgerClient:_})=>{if(!_)return"";switch(L){case J.Chain.Cosmos:case J.Chain.THORChain:return _.connect();case J.Chain.Ethereum:case J.Chain.BinanceSmartChain:case J.Chain.Avalanche:case J.Chain.Polygon:case J.Chain.Arbitrum:case J.Chain.Optimism:case J.Chain.Base:return _.getAddress();case J.Chain.Bitcoin:case J.Chain.BitcoinCash:case J.Chain.Dash:case J.Chain.Dogecoin:case J.Chain.Litecoin:{let m=_;await m.connect();let y=await m.getAddress();return L===J.Chain.BitcoinCash?y.replace("bitcoincash:",""):y}case J.Chain.Ripple:return _.address;default:throw new J.SwapKitError("wallet_chain_not_supported",{wallet:J.WalletOption.LEDGER,chain:L})}};var j=require("@swapkit/helpers");var x=require("@swapkit/helpers");var U=require("@swapkit/helpers");var l=85,d=250;var q={GET_VERSION:0,INS_PUBLIC_KEY_SECP256K1:1,SIGN_SECP256K1:2,GET_ADDR_SECP256K1:4},k={INIT:0,ADD:1,LAST:2},t={ONLY_RETRIEVE:0,SHOW_ADDRESS_IN_DEVICE:1},P={JSON:0},M={NoError:36864},T0={1:"U2F: Unknown",2:"U2F: Bad request",3:"U2F: Configuration unsupported",4:"U2F: Device Ineligible",5:"U2F: Timeout",14:"Timeout",36864:"No errors",36865:"Device is busy",26626:"Error deriving keys",25600:"Execution Error",26368:"Wrong Length",27010:"Empty Buffer",27011:"Output buffer too small",27012:"Data is invalid",27013:"Conditions not satisfied",27014:"Transaction rejected",27264:"Bad key handle",27392:"Invalid P1/P2",27904:"Instruction not supported",28160:"App does not seem to be open",28416:"Unknown error",28417:"Sign/verify error"};function Z(L){if(L in T0)return T0[L];return`Unknown Status Code: ${L}`}function n0(L){return typeof L==="object"&&L!==null&&!Array.isArray(L)&&!(L instanceof Date)}function Q(L){if(L){if(n0(L)){if(Object.prototype.hasOwnProperty.call(L,"statusCode"))return{return_code:L.statusCode,error_message:Z(L.statusCode)};if(Object.prototype.hasOwnProperty.call(L,"return_code")&&Object.prototype.hasOwnProperty.call(L,"error_message"))return L}return{return_code:65535,error_message:L.toString()}}return{return_code:65535,error_message:L.toString()}}async function n(L){return L.send(85,q.GET_VERSION,0,0).then((_)=>{let m=_.slice(-2),y=m[0]*256+m[1],O=0;if(_.length>=9)O=(_[5]<<24)+(_[6]<<16)+(_[7]<<8)+(_[8]<<0);return{return_code:y,error_message:Z(y),test_mode:_[0]!==0,major:_[1],minor:_[2],patch:_[3],device_locked:_[4]===1,target_id:O.toString(16)}},Q)}function X0(L){if(L==null||L.length<3)throw new Error("Invalid path.");if(L.length>10)throw new Error("Invalid path. Length should be <= 10");let _=Buffer.alloc(1+4*L.length);_.writeUInt8(L.length,0);for(let m=0;m<L.length;m+=1){let y=L[m]||0;if(m<3)y|=2147483648;_.writeInt32LE(y,1+m*4)}return _}async function o(L,_,m,y,O=P.JSON){return L.transport.send(l,q.SIGN_SECP256K1,_,O,y,[M.NoError,27012,27264]).then((T)=>{let G=T.slice(-2),X=G[0]*256+G[1],F=Z(X);if(X===27264||X===27012)F=`${F} : ${T.slice(0,T.length-2).toString("ascii")}`;let w=null;if(T.length>2)w=T.slice(0,T.length-2);return{signature:w,return_code:X,error_message:F}},Q)}function o0(L){if(L.length!==65)throw new Error("decompressed public key length should be 65 bytes");let _=L.slice(33,65),m=Buffer.from([2+(_[_.length-1]&1)]);return Buffer.concat([m,L.slice(1,33)])}async function B0(L,_){return L.transport.send(l,q.INS_PUBLIC_KEY_SECP256K1,0,0,_,[M.NoError]).then((m)=>{let y=m.slice(-2),O=y[0]*256+y[1],T=Buffer.from(m.slice(0,65));return{pk:T,compressed_pk:o0(T),return_code:O,error_message:Z(O)}},Q)}function G0(L){if(!L||L.length!==5)throw new Error("Invalid path.");let _=Buffer.alloc(20);return _.writeUInt32LE(2147483648+L[0],0),_.writeUInt32LE(2147483648+L[1],4),_.writeUInt32LE(2147483648+L[2],8),_.writeUInt32LE(L[3],12),_.writeUInt32LE(L[4],16),_}function F0(L,_,m,y,O=P.JSON){let T=k.ADD;if(_===1)T=k.INIT;if(_===m)T=k.LAST;return o(L,T,0,y,O)}async function w0(L,_){return L.transport.send(l,q.GET_ADDR_SECP256K1,0,0,_,[M.NoError]).then((m)=>{let y=m.slice(-2),O=y[0]*256+y[1];return{pk:"OBSOLETE PROPERTY",compressed_pk:Buffer.from(m.slice(0,33)),return_code:O,error_message:Z(O)}},Q)}class I{transport;versionResponse;constructor(L){if(!L)throw new Error("Transport has not been defined");this.transport=L}static serializeHRP(L){if(L==null||L.length<3||L.length>83)throw new Error("Invalid HRP");let _=Buffer.alloc(1+L.length);return _.writeUInt8(L.length,0),_.write(L,1),_}async serializePath(L){if(this.versionResponse=await n(this.transport),this.versionResponse.return_code!==M.NoError)throw this.versionResponse;switch(this.versionResponse.major){case 1:return X0(L);case 2:return G0(L);default:return Buffer.alloc(0)}}async signGetChunks(L,_){let m=await this.serializePath(L),y=[];y.push(m);for(let O=0;O<_.length;O+=d){let T=O+d;if(O>_.length)T=_.length;y.push(_.slice(O,T))}return y}async getVersion(){try{return this.versionResponse=await n(this.transport),this.versionResponse}catch(L){return Q(L)}}async appInfo(){return this.transport.send(176,1,0,0).then((L)=>{let _=L.slice(-2),m=_[0]*256+_[1],y="",O="",T=0,G=0;if(L[0]!==1)return{return_code:36865,error_message:"response format ID not recognized"};let X=L[1];y=L.slice(2,2+X).toString("ascii");let F=2+X,w=L[F];F+=1,O=L.slice(F,F+w).toString("ascii"),F+=w;let R=L[F];return F+=1,T=R,G=L[F],{return_code:m,error_message:Z(m),appName:y,appVersion:O,flagLen:T,flagsValue:G,flag_recovery:(G&1)!==0,flag_signed_mcu_code:(G&2)!==0,flag_onboarded:(G&4)!==0,flag_pin_validated:(G&128)!==0}},Q)}async deviceInfo(){return this.transport.send(224,1,0,0,Buffer.from([]),[M.NoError,28160]).then((L)=>{let _=L.slice(-2),m=_[0]*256+_[1];if(m===28160)return{return_code:m,error_message:"This command is only available in the Dashboard"};let y=L.slice(0,4).toString("hex"),O=4,T=L[O];O+=1;let G=L.slice(O,O+T).toString();O+=T;let X=L[O];O+=1;let F=L.slice(O,O+X).toString("hex");O+=X;let w=L[O];O+=1;let R=L.slice(O,O+w);if(R[w-1]===0)R=L.slice(O,O+w-1);let Y=R.toString();return{return_code:m,error_message:Z(m),targetId:y,seVersion:G,flag:F,mcuVersion:Y}},Q)}async publicKey(L){try{let _=await this.serializePath(L);switch(this.versionResponse.major){case 1:return B0(this,_);case 2:{let m=Buffer.concat([I.serializeHRP("thor"),_]);return w0(this,m)}default:return{return_code:25600,error_message:"App Version is not supported"}}}catch(_){return Q(_)}}async getAddressAndPubKey(L,_,m=!1){return this.serializePath(L).then((y)=>{let O=Buffer.concat([I.serializeHRP(_),y]);return this.transport.send(l,q.GET_ADDR_SECP256K1,m?t.SHOW_ADDRESS_IN_DEVICE:t.ONLY_RETRIEVE,0,O,[M.NoError]).then((T)=>{let G=T.slice(-2),X=G[0]*256+G[1],F=Buffer.from(T.slice(0,33));return{bech32_address:Buffer.from(T.slice(33,-2)).toString(),compressed_pk:F,return_code:X,error_message:Z(X)}},Q)}).catch((y)=>Q(y))}showAddressAndPubKey(L,_){return this.getAddressAndPubKey(L,_,!0)}signSendChunk(L,_,m,y=P.JSON){switch(this.versionResponse.major){case 1:return o(this,L,_,m,y);case 2:return F0(this,L,_,m,y);default:return{return_code:25600,error_message:"App Version is not supported"}}}async sign(L,_,m=P.JSON){let y=Buffer.from(_),O=[],T;try{O=await this.signGetChunks(L,y),T=await this.signSendChunk(1,O.length,O[0],m)}catch(X){Q(X)}let G={return_code:T.return_code,error_message:T.error_message,signature:null};for(let X=1;X<O.length;X+=1)if(G=await this.signSendChunk(1+X,O.length,O[X],m),G.return_code!==M.NoError)break;return{return_code:G.return_code,error_message:G.error_message,signature:G.signature}}}var c=require("@swapkit/helpers"),p=()=>navigator?.usb,p0=async()=>{let L=p();if(typeof L?.getDevices!=="function")return[];let{ledgerUSBVendorId:_}=await import("@ledgerhq/devices"),y=(await L?.getDevices()).filter((O)=>O.vendorId===_);if(y.length>0)return y[0];return L?.requestDevice({filters:[{vendorId:_}]})},H=async()=>{let L=await p0();if(!L)throw new c.SwapKitError("wallet_ledger_device_not_found");if(await L.open(),L.configuration===null)await L.selectConfiguration(1);try{await L.reset()}catch{}let _=L.configurations[0].interfaces.find(({alternates:X})=>X.some(({interfaceClass:F})=>F===255));if(!_)throw await L.close(),new c.SwapKitError("wallet_ledger_connection_error");try{await L.claimInterface(_.interfaceNumber)}catch(X){throw await L.close(),new c.SwapKitError("wallet_ledger_connection_claimed",X)}let m=(await import("@ledgerhq/hw-transport-webusb")).default;if(!await m.isSupported())throw new Error("WebUSB not supported");let{DisconnectedDevice:O}=await import("@ledgerhq/errors"),T=new m(L,_.interfaceNumber),G=(X)=>{if(L===X.device)p()?.removeEventListener("disconnect",G),T._emitDisconnect(new O)};return p()?.addEventListener("disconnect",G),T};class V{ledgerTimeout=50000;derivationPath=U.NetworkDerivationPath.GAIA;transport;ledgerApp;chain="thor";checkOrCreateTransportAndLedger=async(L=!1)=>{if(!L&&this.transport&&this.ledgerApp)return;try{switch(this.transport=L||!this.transport?await H():this.transport,this.chain){case"thor":{this.ledgerApp=L||!this.ledgerApp?new I(this.transport):this.ledgerApp;break}case"cosmos":{let _=(await import("@ledgerhq/hw-app-cosmos")).default;this.ledgerApp=L||!this.ledgerApp?new _(this.transport):this.ledgerApp}}return this.ledgerApp}catch(_){throw new U.SwapKitError("wallet_ledger_connection_error",_)}};validateResponse=(L,_)=>{switch(L){case U.LedgerErrorCode.NoError:return;case U.LedgerErrorCode.LockedDevice:throw new U.SwapKitError("wallet_ledger_device_locked",{message:`Ledger is locked: ${_}`});case U.LedgerErrorCode.TC_NotFound:throw new U.SwapKitError("wallet_ledger_device_not_found");default:{console.error(`Ledger error: ${L} ${_}`);break}}}}class a extends V{pubKey=null;derivationPath;constructor(L=x.NetworkDerivationPath.GAIA){super();this.chain="cosmos",this.derivationPath=x.derivationPathToString(L)}connect=async()=>{await this.checkOrCreateTransportAndLedger(!0);let{publicKey:L,address:_}=await this.getAddressAndPubKey();return this.pubKey=Buffer.from(L,"hex").toString("base64"),_};getAddressAndPubKey=async()=>{return await this.checkOrCreateTransportAndLedger(!0),await this.ledgerApp.getAddress(this.derivationPath,this.chain)};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:m,error_message:y,signature:O}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(m,y),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:O}]};signAmino=async(L,_)=>{await this.checkOrCreateTransportAndLedger(!0);let m=await this.getAccounts();if(m.findIndex((R)=>R.address===L)===-1)throw new Error(`Address ${L} not found in wallet`);let{encodeSecp256k1Signature:O,serializeSignDoc:T}=(await import("@cosmjs/amino")).default,{Secp256k1Signature:G}=(await import("@cosmjs/crypto")).default,X=T(_),F=await this.ledgerApp.sign(this.derivationPath,X);this.validateResponse(F.return_code,F.error_message);let w=G.fromDer(F.signature).toFixedLength();return{signed:_,signature:O(m[0].pubkey,w)}};getAccounts=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.getAddressAndPubKey();return[{address:L.address,algo:"secp256k1",pubkey:Buffer.from(L.publicKey,"hex")}]}}var $=require("@swapkit/helpers"),R0=require("ethers");class S extends R0.AbstractSigner{chainId=$.ChainId.Ethereum;derivationPath="";ledgerApp=null;ledgerTimeout=50000;constructor({provider:L,derivationPath:_=$.NetworkDerivationPath.OP,chainId:m=$.ChainId.Optimism}){super(L);this.chainId=m||$.ChainId.Ethereum,this.derivationPath=typeof _==="string"?_:$.derivationPathToString(_),Object.defineProperty(this,"provider",{enumerable:!0,value:L||null,writable:!1})}connect=(L)=>new S({provider:L,derivationPath:this.derivationPath,chainId:this.chainId});checkOrCreateTransportAndLedger=async()=>{if(this.ledgerApp)return;await this.createTransportAndLedger()};createTransportAndLedger=async()=>{let L=await H(),_=(await import("@ledgerhq/hw-app-eth")).default;this.ledgerApp=new _(L)};getAddress=async()=>{let L=await this.getAddressAndPubKey();if(!L)throw new Error("Could not get Address");return L.address};getAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath)};showAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath,!0)};signMessage=async(L)=>{let{Signature:_}=await import("ethers");await this.createTransportAndLedger();let m=await this.ledgerApp?.signPersonalMessage(this.derivationPath,L);if(!m)throw new Error("Signing failed");return m.r=`0x${m.r}`,m.s=`0x${m.s}`,_.from(m).serialized};sendTransaction=async(L)=>{if(!this.provider)throw new Error("No provider set");let _=await this.signTransaction(L);return await this.provider.broadcastTransaction(_)};signTypedData(){throw new Error("Method not implemented.")}signTransaction=async(L)=>{let{Transaction:_}=await import("ethers");await this.createTransportAndLedger();let m=await this.provider?.getTransactionCount(L.from||await this.getAddress()),y={chainId:L.chainId||this.chainId,data:L.data,gasLimit:L.gasLimit,...L.gasPrice&&{gasPrice:L.gasPrice},...!L.gasPrice&&L.maxFeePerGas&&{maxFeePerGas:L.maxFeePerGas,maxPriorityFeePerGas:L.maxPriorityFeePerGas},nonce:L.nonce!==void 0?Number((L.nonce||m||0).toString()):m,to:L.to?.toString(),value:L.value,type:L.type&&!Number.isNaN(L.type)?L.type:L.maxFeePerGas?2:0},O=_.from(y).unsignedSerialized.slice(2),{ledgerService:T}=await import("@ledgerhq/hw-app-eth"),G=await T.resolveTransaction(O,{},{externalPlugins:!0,erc20:!0}),X=await this.ledgerApp?.signTransaction(this.derivationPath,O,G);if(!X)throw new Error("Could not sign transaction");let{r:F,s:w,v:R}=X;return _.from({...y,signature:{v:Number(BigInt(R)),r:`0x${F}`,s:`0x${w}`}}).serialized}}var W0=({provider:L,derivationPath:_})=>new S({chainId:$.ChainId.Ethereum,provider:L,derivationPath:_}),j0=({provider:L,derivationPath:_})=>new S({chainId:$.ChainId.Avalanche,provider:L,derivationPath:_}),J0=({provider:L,derivationPath:_})=>new S({chainId:$.ChainId.BinanceSmartChain,provider:L,derivationPath:_}),$0=({provider:L,derivationPath:_})=>new S({chainId:$.ChainId.Arbitrum,provider:L,derivationPath:_}),Q0=({provider:L,derivationPath:_})=>new S({chainId:$.ChainId.Polygon,provider:L,derivationPath:_}),Y0=({provider:L,derivationPath:_})=>new S({chainId:$.ChainId.Optimism,provider:L,derivationPath:_}),Z0=({provider:L,derivationPath:_})=>new S({chainId:$.ChainId.Base,provider:L,derivationPath:_});var U0=require("@scure/base"),M0=require("@swapkit/helpers");var H0=require("@scure/base"),s=(L)=>{if(L.length<64)throw new Error("Invalid Signature: Too short");if(L[0]!==48)throw new Error("Invalid Ledger Signature TLV encoding: expected first byte 0x30");if(L[1]+2!==L.length)throw new Error("Invalid Signature: signature length does not match TLV");if(L[2]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let _=L[3],m=L.slice(4,_+4);if(m.length===33&&m[0]===0)m=m.slice(1,33);else if(m.length===33)throw new Error('Invalid signature: "r" too long');while(m.length<32)m.unshift(0);if(L[_+4]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let y=L[_+5];if(4+_+2+y!==L.length)throw new Error("Invalid Ledger Signature: TLV byte lengths do not match message length");let O=L.slice(_+6,L.length);if(O.length===33&&O[0]===0)O=O.slice(1,33);else if(O.length===33)throw new Error('Invalid signature: "s" too long');while(O.length<32)O.unshift(0);if(m.length!==32||O.length!==32)throw new Error("Invalid signatures: must be 32 bytes each");return H0.base64.encode(Buffer.concat([m,O]))};class r extends V{pubKey=null;derivationPath;constructor(L=M0.NetworkDerivationPath.THOR){super();this.chain="thor",this.derivationPath=L}get pubkey(){return this.pubKey}connect=async()=>{await this.checkOrCreateTransportAndLedger();let{compressed_pk:L,bech32_address:_}=await this.getAddressAndPubKey();return this.pubKey=U0.base64.encode(L),_};getAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.getAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};showAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.showAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:m,error_message:y,signature:O}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(m,y),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:s(O)}]};sign=async(L)=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:_,error_message:m,signature:y}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(_,m),s(y)}}var z=require("@swapkit/helpers"),S0=require("bitcoinjs-lib");var a0=async({psbt:L,inputUtxos:_,btcApp:m,derivationPath:y},O)=>{let T=_.map((R)=>{let Y=S0.Transaction.fromHex(R.txHex||"");return[m.splitTransaction(Y.toHex(),Y.hasWitnesses()),R.index,void 0,void 0]}),G=L.data.globalMap.unsignedTx.toBuffer().toString("hex"),X=m.splitTransaction(G,!0),F=m.serializeTransactionOutputs(X).toString("hex"),w={additionals:["bech32"],associatedKeysets:T.map(()=>y),inputs:T,outputScriptHex:F,segwit:!0,useTrustedInputForSegwit:!0};return m.createPaymentTransaction({...w,...O})},b=({chain:L,additionalSignParams:_})=>{let m,y=null;async function O(G=!0){if(G&&!m)new z.SwapKitError("wallet_ledger_connection_error",{message:`Ledger connection failed:
2
+ ${JSON.stringify({checkBtcApp:G,btcApp:m})}`});y||=await H()}async function T(){y=await H(),m=new(await import("@ledgerhq/hw-app-btc")).default({transport:y,currency:L})}return(G)=>{let X=typeof G==="string"?G:z.derivationPathToString(G),F=z.getWalletFormatFor(X);return{connect:async()=>{await O(!1),m=new(await import("@ledgerhq/hw-app-btc")).default({transport:y,currency:L})},getExtendedPublicKey:async(w="84'/0'/0'",R=76067358)=>{return await O(!1),m.getWalletXpub({path:w,xpubVersion:R})},signTransaction:async(w,R)=>{return await T(),a0({psbt:w,derivationPath:X,btcApp:m,inputUtxos:R},_)},getAddress:async()=>{let{toCashAddress:w}=await import("@swapkit/toolboxes/utxo");await O(!1);let{bitcoinAddress:R}=await m.getWalletPublicKey(X,{format:F});if(!R)throw new z.SwapKitError("wallet_ledger_get_address_error",{message:`Cannot get ${L} address from ledger derivation path: ${X}`});return L==="bitcoin-cash"&&F==="legacy"?w(R).replace(/(bchtest:|bitcoincash:)/,""):R}}}},N0=b({chain:"bitcoin"}),D0=b({chain:"litecoin"}),K0=b({chain:"bitcoin-cash",additionalSignParams:{segwit:!1,additionals:["abc"],sigHashType:65}}),q0=b({chain:"dogecoin",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}}),z0=b({chain:"dash",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}});var A=require("@swapkit/helpers"),e=require("ripple-binary-codec");var s0=2147483648;function r0(L){let _={};for(let m in L)if(L[m]!==null&&L[m]!==void 0)_[m]=L[m];return _}async function e0(L){let{default:_}=await import("@ledgerhq/hw-app-xrp");return new _(L)}function LL({instance:L,derivationPath:_}){return L.getAddress(_)}var C0=async(L)=>{let _=A.derivationPathToString(L||A.NetworkDerivationPath[A.Chain.Ripple]),m=await H(),y=await e0(m),{address:O,publicKey:T}=await LL({instance:y,derivationPath:_});async function G(X){let{hashes:F}=await import("@swapkit/toolboxes/ripple"),R={...r0(X),Flags:X.Flags||s0,SigningPubKey:T.toUpperCase()},Y=e.encode(R),N=await y.signTransaction(_,Y),D=e.encode({...R,TxnSignature:N}),f=F.hashSignedTx(D);return{tx_blob:D,hash:f}}return{address:O,sign:G}};var C=async({chain:L,derivationPath:_})=>{switch(L){case j.Chain.THORChain:return new r(_);case j.Chain.Cosmos:return new a(_);case j.Chain.Bitcoin:return N0(_);case j.Chain.BitcoinCash:return K0(_);case j.Chain.Dash:return z0(_);case j.Chain.Dogecoin:return q0(_);case j.Chain.Litecoin:return D0(_);case j.Chain.Ripple:return C0(_);case j.Chain.Arbitrum:case j.Chain.Avalanche:case j.Chain.BinanceSmartChain:case j.Chain.Ethereum:case j.Chain.Optimism:case j.Chain.Polygon:case j.Chain.Base:{let{getProvider:m}=await import("@swapkit/toolboxes/evm"),y={provider:await m(L),derivationPath:_};switch(L){case j.Chain.BinanceSmartChain:return J0(y);case j.Chain.Avalanche:return j0(y);case j.Chain.Arbitrum:return $0(y);case j.Chain.Optimism:return Y0(y);case j.Chain.Polygon:return Q0(y);case j.Chain.Base:return Z0(y);default:return W0(y)}}default:throw new j.SwapKitError("wallet_chain_not_supported",{wallet:j.WalletOption.LEDGER,chain:L})}};var f0=B.createWallet({name:"connectLedger",supportedChains:[B.Chain.Arbitrum,B.Chain.Avalanche,B.Chain.Base,B.Chain.BinanceSmartChain,B.Chain.Bitcoin,B.Chain.BitcoinCash,B.Chain.Cosmos,B.Chain.Dash,B.Chain.Dogecoin,B.Chain.Ethereum,B.Chain.Litecoin,B.Chain.Optimism,B.Chain.Polygon,B.Chain.Ripple,B.Chain.THORChain],walletType:B.WalletOption.LEDGER,connect:({addChain:L,supportedChains:_,walletType:m})=>async function y(O,T){let[G]=B.filterSupportedChains({chains:O,supportedChains:_,walletType:m});if(!G)return!1;let X=await XL({chain:G,derivationPath:T});return L({...X,chain:G,walletType:B.WalletOption.LEDGER}),!0}}),OL=E0(f0);function yL(L,_="t"){if(!L?.includes("=:"))return L;let m=L.includes(`:${_}:`)?L.split(`:${_}:`)[0]:L;return m?.substring(0,m.lastIndexOf(":"))}function g(L){if(Array.isArray(L))return L.forEach((y,O)=>{L[O]=g(y)}),L;if(typeof L!=="object")return L;let _={},m=Object.keys(L).sort();for(let y of m)_[y]=g(L[y]);return _}function TL(L){return JSON.stringify(g(L))}async function XL({chain:L,derivationPath:_}){switch(L){case B.Chain.BitcoinCash:case B.Chain.Bitcoin:case B.Chain.Dash:case B.Chain.Dogecoin:case B.Chain.Litecoin:{let{getUtxoToolbox:m}=await import("@swapkit/toolboxes/utxo"),y=await m(L),O=await C({chain:L,derivationPath:_}),T=await E({chain:L,ledgerClient:O});return{...y,address:T,transfer:async(X)=>{let F=X.feeRate||(await y.getFeeRates())[B.FeeOption.Average],w=[B.Chain.Bitcoin].includes(L)?X.memo:yL(X.memo),{psbt:R,inputs:Y}=await y.createTransaction({...X,feeRate:F,memo:w,sender:T,fetchTxHex:!0}),N=await O.signTransaction(R,Y);return await y.broadcastTx(N)}}}case B.Chain.Ethereum:case B.Chain.Avalanche:case B.Chain.Arbitrum:case B.Chain.Optimism:case B.Chain.Polygon:case B.Chain.BinanceSmartChain:case B.Chain.Base:{let{getEvmToolbox:m}=await import("@swapkit/toolboxes/evm"),y=await C({chain:L,derivationPath:_}),O=await E({chain:L,ledgerClient:y});return{...await m(L,{signer:y}),address:O}}case B.Chain.Cosmos:{let{createSigningStargateClient:m,getMsgSendDenom:y,getCosmosToolbox:O}=await import("@swapkit/toolboxes/cosmos"),T=await O(B.Chain.Cosmos),G=await C({chain:L,derivationPath:_}),X=await E({chain:L,ledgerClient:G});return{...T,address:X,transfer:async({assetValue:w,recipient:R,memo:Y})=>{if(!w)throw new Error("invalid asset");let N={amount:[{amount:w.getBaseValue("string"),denom:y(`u${w.symbol}`).toLowerCase()}],fromAddress:X,toAddress:R},D=await m(B.SKConfig.get("rpcUrls")[L],G,"0.007uatom"),{transactionHash:f}=await D.signAndBroadcast(X,[{typeUrl:"/cosmos.bank.v1beta1.MsgSend",value:N}],2,Y);return f}}}case B.Chain.THORChain:{let{SignMode:m}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:y}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),{encodePubkey:O,makeAuthInfoBytes:T}=(await import("@cosmjs/proto-signing")).default,{createStargateClient:G,buildEncodedTxBody:X,getCosmosToolbox:F,buildAminoMsg:w,getDefaultChainFee:R,fromBase64:Y,parseAminoMessageForDirectSigning:N}=await import("@swapkit/toolboxes/cosmos"),D=await F(L),f=await C({chain:L,derivationPath:_}),v=await E({chain:L,ledgerClient:f}),u=R(L),{pubkey:L0,signTransaction:l0,sign:P0}=f,_0=async({memo:K="",assetValue:m0,...A0})=>{let O0=await D.getAccount(v);if(!O0)throw new Error("invalid account");if(!m0)throw new Error("invalid asset");if(!L0)throw new Error("Account pubkey not found");let{accountNumber:I0,sequence:V0}=O0,i=(V0||0).toString(),y0=g([w({sender:v,assetValue:m0,memo:K,...A0})]),b0=TL({account_number:I0?.toString(),chain_id:B.ChainId.THORChain,fee:u,memo:K,msgs:y0,sequence:i}),h=await l0(b0,i);if(!h)throw new Error("tx signing failed");let k0=O({type:"tendermint/PubKeySecp256k1",value:L0}),c0=y0.map(N),x0=await X({msgs:c0,chain:L,memo:K}),g0=T([{pubkey:k0,sequence:Number(i)}],u.amount,Number.parseInt(u.gas),void 0,void 0,m.SIGN_MODE_LEGACY_AMINO_JSON),v0=h?.[0]?.signature?Y(h[0].signature):Uint8Array.from([]),u0=y.fromPartial({bodyBytes:x0,authInfoBytes:g0,signatures:[v0]}),i0=y.encode(u0).finish(),{isStagenet:h0}=B.SKConfig.get("envs"),d0=await G(B.SKConfig.get("rpcUrls")[h0?B.StagenetChain.THORChain:B.Chain.THORChain]),{transactionHash:t0}=await d0.broadcastTx(i0);return t0};return{...D,address:v,deposit:(K)=>_0(K),transfer:(K)=>_0(K),signMessage:P0}}case B.Chain.Ripple:{let{getRippleToolbox:m}=await import("@swapkit/toolboxes/ripple"),y=await C({chain:L,derivationPath:_}),O=y.address;return{...await m({signer:y}),address:O}}default:throw new Error("Unsupported chain")}}
3
3
 
4
- //# debugId=D4E7D491EC73452064756E2164756E21
4
+ //# debugId=13F6147EB95E737664756E2164756E21