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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. package/dist/chunk-czhtd6cy.js +4 -0
  2. package/dist/chunk-czhtd6cy.js.map +10 -0
  3. package/dist/{chunk-5m175wfy.js → chunk-p1kdg37m.js} +2 -2
  4. package/dist/{chunk-5m175wfy.js.map → chunk-p1kdg37m.js.map} +1 -1
  5. package/dist/{chunk-f76hj57k.js → chunk-q81hzyra.js} +2 -2
  6. package/dist/{chunk-f76hj57k.js.map → chunk-q81hzyra.js.map} +1 -1
  7. package/dist/chunk-qadd75nn.js +3 -0
  8. package/dist/chunk-qadd75nn.js.map +10 -0
  9. package/dist/src/bitget/index.cjs +2 -2
  10. package/dist/src/bitget/index.cjs.map +5 -5
  11. package/dist/src/bitget/index.js +2 -2
  12. package/dist/src/bitget/index.js.map +5 -5
  13. package/dist/src/coinbase/index.cjs +2 -2
  14. package/dist/src/coinbase/index.cjs.map +4 -4
  15. package/dist/src/coinbase/index.js +2 -3
  16. package/dist/src/coinbase/index.js.map +4 -4
  17. package/dist/src/ctrl/index.cjs +2 -2
  18. package/dist/src/ctrl/index.cjs.map +5 -5
  19. package/dist/src/ctrl/index.js +2 -2
  20. package/dist/src/ctrl/index.js.map +5 -5
  21. package/dist/src/evm-extensions/index.cjs +2 -2
  22. package/dist/src/evm-extensions/index.cjs.map +3 -3
  23. package/dist/src/evm-extensions/index.js +2 -3
  24. package/dist/src/evm-extensions/index.js.map +3 -3
  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 -3
  28. package/dist/src/exodus/index.js.map +3 -3
  29. package/dist/src/index.cjs +2 -2
  30. package/dist/src/index.cjs.map +3 -4
  31. package/dist/src/index.js +2 -2
  32. package/dist/src/index.js.map +3 -4
  33. package/dist/src/keepkey/index.cjs +2 -2
  34. package/dist/src/keepkey/index.cjs.map +7 -7
  35. package/dist/src/keepkey/index.js +2 -3
  36. package/dist/src/keepkey/index.js.map +7 -7
  37. package/dist/src/keepkey-bex/index.cjs +2 -2
  38. package/dist/src/keepkey-bex/index.cjs.map +4 -4
  39. package/dist/src/keepkey-bex/index.js +2 -3
  40. package/dist/src/keepkey-bex/index.js.map +4 -4
  41. package/dist/src/keplr/index.cjs +2 -2
  42. package/dist/src/keplr/index.cjs.map +3 -3
  43. package/dist/src/keplr/index.js +2 -3
  44. package/dist/src/keplr/index.js.map +3 -3
  45. package/dist/src/keystore/index.cjs +2 -2
  46. package/dist/src/keystore/index.cjs.map +4 -4
  47. package/dist/src/keystore/index.js +2 -3
  48. package/dist/src/keystore/index.js.map +4 -4
  49. package/dist/src/ledger/index.cjs +3 -3
  50. package/dist/src/ledger/index.cjs.map +8 -8
  51. package/dist/src/ledger/index.js +3 -4
  52. package/dist/src/ledger/index.js.map +8 -8
  53. package/dist/src/okx/index.cjs +2 -2
  54. package/dist/src/okx/index.cjs.map +4 -4
  55. package/dist/src/okx/index.js +2 -3
  56. package/dist/src/okx/index.js.map +4 -4
  57. package/dist/src/onekey/index.cjs +3 -0
  58. package/dist/src/onekey/index.cjs.map +10 -0
  59. package/dist/src/onekey/index.js +3 -0
  60. package/dist/src/onekey/index.js.map +10 -0
  61. package/dist/src/phantom/index.cjs +2 -2
  62. package/dist/src/phantom/index.cjs.map +3 -3
  63. package/dist/src/phantom/index.js +2 -3
  64. package/dist/src/phantom/index.js.map +3 -3
  65. package/dist/src/polkadotjs/index.cjs +2 -2
  66. package/dist/src/polkadotjs/index.cjs.map +3 -3
  67. package/dist/src/polkadotjs/index.js +2 -3
  68. package/dist/src/polkadotjs/index.js.map +3 -3
  69. package/dist/src/radix/index.cjs +2 -2
  70. package/dist/src/radix/index.cjs.map +3 -3
  71. package/dist/src/radix/index.js +2 -3
  72. package/dist/src/radix/index.js.map +3 -3
  73. package/dist/src/talisman/index.cjs +2 -2
  74. package/dist/src/talisman/index.cjs.map +3 -3
  75. package/dist/src/talisman/index.js +2 -3
  76. package/dist/src/talisman/index.js.map +3 -3
  77. package/dist/src/trezor/index.cjs +2 -2
  78. package/dist/src/trezor/index.cjs.map +3 -3
  79. package/dist/src/trezor/index.js +2 -3
  80. package/dist/src/trezor/index.js.map +3 -3
  81. package/dist/src/walletconnect/index.cjs +2 -2
  82. package/dist/src/walletconnect/index.cjs.map +5 -5
  83. package/dist/src/walletconnect/index.js +2 -3
  84. package/dist/src/walletconnect/index.js.map +5 -5
  85. package/package.json +31 -26
  86. package/src/bitget/helpers.ts +33 -93
  87. package/src/bitget/index.ts +32 -54
  88. package/src/coinbase/index.ts +2 -2
  89. package/src/coinbase/signer.ts +46 -42
  90. package/src/ctrl/index.ts +157 -22
  91. package/src/ctrl/walletHelpers.ts +45 -94
  92. package/src/evm-extensions/index.ts +21 -40
  93. package/src/exodus/index.ts +18 -28
  94. package/src/index.ts +2 -37
  95. package/src/keepkey/chains/cosmos.ts +10 -7
  96. package/src/keepkey/chains/mayachain.ts +24 -24
  97. package/src/keepkey/chains/thorchain.ts +19 -13
  98. package/src/keepkey/chains/utxo.ts +36 -48
  99. package/src/keepkey/index.ts +9 -23
  100. package/src/keepkey-bex/index.ts +25 -23
  101. package/src/keepkey-bex/walletHelpers.ts +8 -36
  102. package/src/keplr/index.ts +6 -53
  103. package/src/keystore/helpers.ts +34 -55
  104. package/src/keystore/index.ts +15 -183
  105. package/src/ledger/clients/evm.ts +3 -7
  106. package/src/ledger/clients/thorchain/lib.ts +0 -19
  107. package/src/ledger/clients/utxo.ts +3 -2
  108. package/src/ledger/helpers/getLedgerClient.ts +2 -2
  109. package/src/ledger/index.ts +20 -21
  110. package/src/ledger/types.ts +1 -1
  111. package/src/okx/helpers.ts +23 -33
  112. package/src/okx/index.ts +4 -47
  113. package/src/onekey/evmSigner.ts +133 -0
  114. package/src/onekey/index.ts +213 -0
  115. package/src/phantom/index.ts +18 -42
  116. package/src/polkadotjs/index.ts +5 -7
  117. package/src/radix/index.ts +31 -47
  118. package/src/talisman/index.ts +15 -32
  119. package/src/trezor/index.ts +46 -45
  120. package/src/types.ts +199 -0
  121. package/src/utils.ts +54 -0
  122. package/src/walletconnect/constants.ts +1 -1
  123. package/src/walletconnect/helpers.ts +2 -2
  124. package/src/walletconnect/index.ts +36 -37
  125. package/dist/chunk-ha78se5g.js +0 -4
  126. package/dist/chunk-ha78se5g.js.map +0 -10
  127. package/dist/chunk-yvbvzc0q.js +0 -3
  128. package/dist/chunk-yvbvzc0q.js.map +0 -10
  129. package/src/bitget/bitgetWallet.ts +0 -32
  130. package/src/ctrl/ctrlWallet.ts +0 -175
  131. package/src/helpers.ts +0 -8
  132. package/src/ledger/ledgerLive.ts +0 -429
@@ -2,9 +2,9 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/exodus/index.ts"],
4
4
  "sourcesContent": [
5
- "import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { NonETHToolbox } from \"@swapkit/toolboxes/evm\";\nimport type { UTXOTransferParams } from \"@swapkit/toolboxes/utxo\";\nimport type { Psbt } from \"@swapkit/toolboxes/utxo\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport {\n AddressPurpose,\n BitcoinNetworkType,\n type BitcoinProvider,\n type GetAddressOptions,\n type GetAddressResponse,\n type SignTransactionOptions,\n getAddress,\n signTransaction as satsSignTransaction,\n} from \"sats-connect\";\nimport { getWalletSupportedChains } from \"../helpers\";\n\nexport const getWalletMethods = async ({\n walletProvider,\n provider,\n chain,\n}: {\n walletProvider?: Eip1193Provider;\n provider: BrowserProvider | BitcoinProvider;\n chain: Chain;\n}) => {\n switch (chain) {\n case Chain.Bitcoin: {\n const { BTCToolbox, Psbt } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = BTCToolbox();\n\n let address = \"\";\n\n const getProvider: () => Promise<BitcoinProvider | undefined> = () =>\n new Promise((res) => res(provider as BitcoinProvider));\n\n const getAddressOptions: GetAddressOptions = {\n getProvider,\n payload: {\n purposes: [AddressPurpose.Payment],\n message: \"Address for receiving and sending payments\",\n network: { type: BitcoinNetworkType.Mainnet },\n },\n onFinish: (response: GetAddressResponse) => {\n if (!response.addresses[0]) throw new Error(\"No address found\");\n address = response.addresses[0].address;\n },\n onCancel: () => {\n throw new Error(\"Request canceled\");\n },\n };\n\n await getAddress(getAddressOptions);\n\n async function signTransaction(psbt: Psbt) {\n let signedPsbt: Psbt | undefined;\n const signPsbtOptions: SignTransactionOptions = {\n getProvider,\n payload: {\n message: \"Sign transaction\",\n network: {\n type: BitcoinNetworkType.Mainnet,\n },\n psbtBase64: psbt.toBase64(),\n broadcast: false,\n inputsToSign: [\n { address: address, signingIndexes: psbt.txInputs.map((_, index) => index) },\n ],\n },\n onFinish: (response) => {\n signedPsbt = Psbt.fromBase64(response.psbtBase64);\n },\n onCancel: () => {\n throw new Error(\"Signature canceled\");\n },\n };\n\n await satsSignTransaction(signPsbtOptions);\n if (!signedPsbt) throw new SwapKitError(\"wallet_exodus_sign_transaction_error\");\n return signedPsbt;\n }\n\n const transfer = (transferParams: UTXOTransferParams) => {\n return toolbox.transfer({\n ...transferParams,\n signTransaction,\n });\n };\n\n return { ...toolbox, transfer, address };\n }\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n if (!walletProvider) throw new Error(\"Requested web3 wallet is not installed\");\n const { getProvider, getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n\n const jsonRpcProvider = getProvider(chain);\n const browserProvider = provider as BrowserProvider;\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n const toolbox = getToolboxByChain(chain)({ provider: jsonRpcProvider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = (toolbox as NonETHToolbox).getNetworkParams();\n await switchEVMWalletNetwork(browserProvider, chain, networkParams);\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return {\n address,\n ...prepareNetworkSwitch<typeof toolbox>({ toolbox, chain, provider: browserProvider }),\n };\n }\n default:\n throw new Error(`Unsupported chain: ${chain}`);\n }\n};\n\nexport const exodusWallet = createWallet({\n name: \"connectExodusWallet\",\n walletType: WalletOption.EXODUS,\n supportedChains: [...EVMChains, Chain.Bitcoin],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectExodusWallet(chains: Chain[], wallet: Wallet) {\n if (!wallet) throw new Error(\"Missing Exodus Wallet instance\");\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n const { providers } = wallet;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const provider =\n chain === Chain.Bitcoin\n ? providers.bitcoin\n : new BrowserProvider(providers.ethereum, \"any\");\n\n const { address, ...walletMethods } = await getWalletMethods({\n chain,\n provider,\n walletProvider: providers.ethereum,\n });\n\n const getBalance = async (potentialScamFilter = true) =>\n walletMethods.getBalance(address, potentialScamFilter);\n\n const disconnect = () =>\n provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({\n ...walletMethods,\n disconnect,\n chain,\n address,\n getBalance,\n balance: [],\n walletType: WalletOption.EXODUS,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const EXODUS_SUPPORTED_CHAINS = getWalletSupportedChains(exodusWallet);\nexport * from \"@passkeys/react\";\nexport * from \"@passkeys/core\";\n"
5
+ "import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { Psbt } from \"bitcoinjs-lib\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport {\n AddressPurpose,\n BitcoinNetworkType,\n type BitcoinProvider,\n type GetAddressOptions,\n type GetAddressResponse,\n type SignTransactionOptions,\n getAddress,\n signTransaction as satsSignTransaction,\n} from \"sats-connect\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nasync function getWalletMethods({\n walletProvider,\n provider,\n chain,\n}: {\n walletProvider?: Eip1193Provider;\n provider: BrowserProvider | BitcoinProvider;\n chain: Chain;\n}) {\n switch (chain) {\n case Chain.Bitcoin: {\n const { Psbt } = await import(\"bitcoinjs-lib\");\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n let address = \"\";\n\n const getProvider: () => Promise<BitcoinProvider | undefined> = () =>\n new Promise((res) => res(provider as BitcoinProvider));\n\n const getAddressOptions: GetAddressOptions = {\n getProvider,\n payload: {\n purposes: [AddressPurpose.Payment],\n message: \"Address for receiving and sending payments\",\n network: { type: BitcoinNetworkType.Mainnet },\n },\n onFinish: (response: GetAddressResponse) => {\n if (!response.addresses[0]) throw new Error(\"No address found\");\n address = response.addresses[0].address;\n },\n onCancel: () => {\n throw new Error(\"Request canceled\");\n },\n };\n\n // TODO: Towan - probably not needed ?\n await getAddress(getAddressOptions);\n\n async function signTransaction(psbt: Psbt) {\n let signedPsbt: Psbt | undefined;\n const signPsbtOptions: SignTransactionOptions = {\n getProvider,\n payload: {\n message: \"Sign transaction\",\n network: {\n type: BitcoinNetworkType.Mainnet,\n },\n psbtBase64: psbt.toBase64(),\n broadcast: false,\n inputsToSign: [\n { address: address, signingIndexes: psbt.txInputs.map((_, index) => index) },\n ],\n },\n onFinish: (response) => {\n signedPsbt = Psbt.fromBase64(response.psbtBase64);\n },\n onCancel: () => {\n throw new Error(\"Signature canceled\");\n },\n };\n\n await satsSignTransaction(signPsbtOptions);\n if (!signedPsbt) throw new SwapKitError(\"wallet_exodus_sign_transaction_error\");\n return signedPsbt;\n }\n\n const signer = {\n signTransaction,\n getAddress: () => Promise.resolve(address),\n };\n const toolbox = await getUtxoToolbox(chain, { signer });\n\n return { ...toolbox, address };\n }\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n if (!walletProvider) throw new Error(\"Requested web3 wallet is not installed\");\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const jsonRpcProvider = await getProvider(chain);\n const browserProvider = provider as BrowserProvider;\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider: jsonRpcProvider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(browserProvider, chain, networkParams);\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return { ...prepareNetworkSwitch({ toolbox, chain, provider: browserProvider }), address };\n }\n default:\n throw new Error(`Unsupported chain: ${chain}`);\n }\n}\n\nexport const exodusWallet = createWallet({\n name: \"connectExodusWallet\",\n walletType: WalletOption.EXODUS,\n supportedChains: [...EVMChains, Chain.Bitcoin],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectExodusWallet(chains: Chain[], wallet: Wallet) {\n if (!wallet) throw new Error(\"Missing Exodus Wallet instance\");\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n const { providers } = wallet;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const provider =\n chain === Chain.Bitcoin\n ? providers.bitcoin\n : new BrowserProvider(providers.ethereum, \"any\");\n\n const { address, ...walletMethods } = await getWalletMethods({\n chain,\n provider,\n walletProvider: providers.ethereum,\n });\n\n const disconnect = () =>\n provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({\n ...walletMethods,\n disconnect,\n chain,\n address,\n walletType: WalletOption.EXODUS,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const EXODUS_SUPPORTED_CHAINS = getWalletSupportedChains(exodusWallet);\nexport * from \"@passkeys/react\";\nexport * from \"@passkeys/core\";\n"
6
6
  ],
7
- "mappings": "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",
8
- "debugId": "1E0115554FCEE90064756E2164756E21",
7
+ "mappings": "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",
8
+ "debugId": "5DC2E5570624007664756E2164756E21",
9
9
  "names": []
10
10
  }
@@ -1,3 +1,3 @@
1
- var w={};b(w,{wallets:()=>g});module.exports=y(w);var g={...t,...o,...l,...r,...e,...m,...a,...p,...i,...f,...W,...k,...n,...s,...c,...x,...d};
1
+ var n={};t(n,{loadWallet:()=>l,getWalletSupportedChains:()=>o});module.exports=e(n);
2
2
 
3
- //# debugId=D87C28D1AD514D8B64756E2164756E21
3
+ //# debugId=3162B6312526CAB064756E2164756E21
@@ -1,10 +1,9 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/index.ts"],
3
+ "sources": [],
4
4
  "sourcesContent": [
5
- "import { bitgetWallet } from \"./bitget\";\nimport { coinbaseWallet } from \"./coinbase\";\nimport { ctrlWallet } from \"./ctrl\";\nimport { evmWallet } from \"./evm-extensions\";\nimport { exodusWallet } from \"./exodus\";\nimport { keepkeyWallet } from \"./keepkey\";\nimport { keepkeyBexWallet } from \"./keepkey-bex\";\nimport { keplrWallet } from \"./keplr\";\nimport { keystoreWallet } from \"./keystore\";\nimport { ledgerWallet } from \"./ledger\";\nimport { okxWallet } from \"./okx\";\nimport { phantomWallet } from \"./phantom\";\nimport { polkadotWallet } from \"./polkadotjs\";\nimport { radixWallet } from \"./radix\";\nimport { talismanWallet } from \"./talisman\";\nimport { trezorWallet } from \"./trezor\";\nimport { walletconnectWallet } from \"./walletconnect\";\n\nexport const wallets = {\n ...bitgetWallet,\n ...coinbaseWallet,\n ...ctrlWallet,\n ...evmWallet,\n ...exodusWallet,\n ...keepkeyWallet,\n ...keepkeyBexWallet,\n ...keplrWallet,\n ...keystoreWallet,\n ...ledgerWallet,\n ...okxWallet,\n ...phantomWallet,\n ...polkadotWallet,\n ...radixWallet,\n ...talismanWallet,\n ...trezorWallet,\n ...walletconnectWallet,\n};\n"
6
5
  ],
7
- "mappings": "kDAkBO,IAAM,EAAU,IAClB,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,CACL",
8
- "debugId": "D87C28D1AD514D8B64756E2164756E21",
6
+ "mappings": "",
7
+ "debugId": "3162B6312526CAB064756E2164756E21",
9
8
  "names": []
10
9
  }
package/dist/src/index.js CHANGED
@@ -1,3 +1,3 @@
1
- import{a as x}from"./trezor/index.js";import{b as d}from"./walletconnect/index.js";import{c as p}from"./keplr/index.js";import{d as i}from"./keystore/index.js";import{e as f}from"./ledger/index.js";import{f as W}from"./okx/index.js";import{g as k}from"./phantom/index.js";import{h as n}from"./polkadotjs/index.js";import{i as s}from"./radix/index.js";import{j as c}from"./talisman/index.js";import{k as t}from"./bitget/index.js";import{l as o}from"./coinbase/index.js";import{m as l}from"./ctrl/index.js";import{n as r}from"./evm-extensions/index.js";import{o as e}from"./exodus/index.js";import{p as m}from"./keepkey/index.js";import{q as a}from"./keepkey-bex/index.js";import"../chunk-ha78se5g.js";import"../chunk-5m175wfy.js";var H={...t,...o,...l,...r,...e,...m,...a,...p,...i,...f,...W,...k,...n,...s,...c,...x,...d};export{H as wallets};
1
+ import{a as l,b as n}from"../chunk-czhtd6cy.js";import"../chunk-p1kdg37m.js";export{n as loadWallet,l as getWalletSupportedChains};
2
2
 
3
- //# debugId=01250412823A41E864756E2164756E21
3
+ //# debugId=83059F908E6CD5F764756E2164756E21
@@ -1,10 +1,9 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/index.ts"],
3
+ "sources": [],
4
4
  "sourcesContent": [
5
- "import { bitgetWallet } from \"./bitget\";\nimport { coinbaseWallet } from \"./coinbase\";\nimport { ctrlWallet } from \"./ctrl\";\nimport { evmWallet } from \"./evm-extensions\";\nimport { exodusWallet } from \"./exodus\";\nimport { keepkeyWallet } from \"./keepkey\";\nimport { keepkeyBexWallet } from \"./keepkey-bex\";\nimport { keplrWallet } from \"./keplr\";\nimport { keystoreWallet } from \"./keystore\";\nimport { ledgerWallet } from \"./ledger\";\nimport { okxWallet } from \"./okx\";\nimport { phantomWallet } from \"./phantom\";\nimport { polkadotWallet } from \"./polkadotjs\";\nimport { radixWallet } from \"./radix\";\nimport { talismanWallet } from \"./talisman\";\nimport { trezorWallet } from \"./trezor\";\nimport { walletconnectWallet } from \"./walletconnect\";\n\nexport const wallets = {\n ...bitgetWallet,\n ...coinbaseWallet,\n ...ctrlWallet,\n ...evmWallet,\n ...exodusWallet,\n ...keepkeyWallet,\n ...keepkeyBexWallet,\n ...keplrWallet,\n ...keystoreWallet,\n ...ledgerWallet,\n ...okxWallet,\n ...phantomWallet,\n ...polkadotWallet,\n ...radixWallet,\n ...talismanWallet,\n ...trezorWallet,\n ...walletconnectWallet,\n};\n"
6
5
  ],
7
- "mappings": "00BAkBO,GAAM,PAAU,FAClB,HACA,NACA,FACA,CACA,JACA,DACA,HACA,DACA,LACA,KACA,HACA,FACA,EACA,AACA,AACA,KACA,CACL",
8
- "debugId": "01250412823A41E864756E2164756E21",
6
+ "mappings": "",
7
+ "debugId": "83059F908E6CD5F764756E2164756E21",
9
8
  "names": []
10
9
  }
@@ -1,3 +1,3 @@
1
- var e={};n(e,{keepkeyWallet:()=>h,KEEPKEY_SUPPORTED_CHAINS:()=>t});module.exports=s(e);var Q=require("@swapkit/helpers"),m=require("@keepkey/keepkey-sdk");var w=require("@swapkit/helpers");var x;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(x||={});function o(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function A(z){let J=z;if(!o(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let X=J.split("/");if(X.length===1&&X[0]==="")return[];let R=new Array(X.length);for(let Z=0;Z<X.length;Z++){let Y=X[Z];if(Y){let $=/(\d+)([hH']?)/.exec(Y);if($===null)throw new Error("Invalid input");let[,q="",j=""]=$;if(R[Z]=Number.parseInt(q,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var u=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:X,GaiaToolbox:R,createStargateClient:Z}=await import("@swapkit/toolboxes/cosmos");try{let Y=J?w.derivationPathToString(J):`${w.DerivationPath.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:A(Y)}),q=R();if(X.amount[0])X.amount[0].amount=String(await q?.getFeeRateFromThorswap?.(w.ChainId.Cosmos,500));return{...q,transfer:async({assetValue:W,recipient:U,memo:G})=>{let M=W.getBaseValue("string"),L=await q.getAccount($),_=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:X,memo:G||"",sequence:L?.sequence.toString()??"",chain_id:w.ChainId.Cosmos,account_number:L?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:M}],to_address:U,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),B=atob(_.serialized),I=new Uint8Array(B.length).map((V,N)=>B.charCodeAt(N));return(await(await Z(w.SKConfig.get("rpcUrls")[w.Chain.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(Y){throw console.error(Y),Y}};var v=require("@swapkit/helpers"),C=require("ethers");class f extends C.AbstractSigner{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:X,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=X||v.NetworkDerivationPath.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:A(v.derivationPathToString(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:X,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:$,gasPrice:q})=>{if(!z)throw new Error("Missing to address");if(!X)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((Y||$)&&!q);if(j&&!Y)throw new Error("Missing maxFeePerGas");if(j&&!$)throw new Error("Missing maxFeePerGas");if(!(j||q))throw new Error("Missing gasPrice");let{toHexString:W}=await import("@swapkit/toolboxes/evm"),U=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),G={gas:W(BigInt(X)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:W(BigInt(v.ChainToChainId[this.chain])),to:z.toString(),value:W(BigInt(J||0)),nonce:W(U),data:Z,...j&&{maxFeePerGas:W(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:W(BigInt($?.toString()||"0"))},...!j&&{gasPrice:W(BigInt(q?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(G)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new f({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}var E=require("@swapkit/helpers");var g=async({sdk:z,derivationPath:J})=>{let{createStargateClient:X,getToolboxByChain:R}=await import("@swapkit/toolboxes/cosmos"),Z=R(E.Chain.Maya)(),Y=J?E.derivationPathToString(J):`${E.DerivationPath.MAYA}/0`,{address:$}=await z.address.mayachainGetAddress({address_n:A(Y)}),q=async({assetValue:U,recipient:G,from:M,memo:L})=>{let{makeSignDoc:_}=await import("@cosmjs/amino"),{getDenomWithChain:B}=await import("@swapkit/toolboxes/cosmos"),I=await Z.getAccount(M);if(!I)throw new Error("Account not found");let{accountNumber:H,sequence:O=0}=I,V=U.getBaseValue("string"),N=G&&G!=="",b=N?{type:"mayachain/MsgSend",value:{amount:[{amount:V,denom:U.symbol.toLowerCase()}],from_address:M,to_address:G}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:V,asset:B(U)}],memo:L,signer:M}},S=_([b],{gas:"500000000",amount:[]},E.ChainId.Maya,L,H?.toString(),O),y=N?await z.mayachain.mayachainSignAminoTransfer({signDoc:S,signerAddress:M}):await z.mayachain.mayachainSignAminoDeposit({signDoc:S,signerAddress:M}),T=atob(y.serialized);return new Uint8Array(T.length).map((k,P)=>T.charCodeAt(P))};return{...Z,transfer:async({assetValue:U,recipient:G,memo:M})=>{let L=await X(E.SKConfig.get("rpcUrls")[E.Chain.Maya]),_=await q({assetValue:U,recipient:G,memo:M,from:$}),{transactionHash:B}=await L.broadcastTx(_);return B},deposit:async({assetValue:U,memo:G})=>{let M=await X(E.SKConfig.get("rpcUrls")[E.Chain.Maya]),L=await q({assetValue:U,memo:G,from:$}),{transactionHash:_}=await M.broadcastTx(L);return _},address:$}};var D=require("@swapkit/helpers");var l=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:X}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,ThorchainToolbox:$}=await import("@swapkit/toolboxes/cosmos"),q=$(),j=J?D.derivationPathToString(J):`${D.DerivationPath.THOR}/0`,{address:W}=await z.address.thorchainGetAddress({address_n:A(j)}),U=async({assetValue:L,recipient:_,from:B,memo:I})=>{let H=await q.getAccount(B);if(!H)throw new Error("Account not found");let{accountNumber:O,sequence:V=0}=H,N=_&&_!=="",b=R({chain:D.Chain.THORChain,from:B,recipient:_,assetValue:L,memo:I}),S=D.ChainId.THORChain,y=X([b],Z(D.Chain.THORChain),S,I,O?.toString(),V),T=N?await z.thorchain.thorchainSignAminoTransfer({signDoc:y,signerAddress:B}):await z.thorchain.thorchainSignAminoDeposit({signDoc:y,signerAddress:B}),k=atob(T.serialized);return new Uint8Array(k.length).map((P,r)=>k.charCodeAt(r))};return{...q,transfer:async({assetValue:L,recipient:_,memo:B})=>{let I=await Y(D.SKConfig.get("rpcUrls")[D.Chain.THORChain]),H=await U({assetValue:L,recipient:_,memo:B,from:W}),{transactionHash:O}=await I.broadcastTx(H);return O},deposit:async({assetValue:L,memo:_})=>{let B=await Y(D.SKConfig.get("rpcUrls")[D.Chain.THORChain]),I=await U({assetValue:L,memo:_,from:W}),{transactionHash:H}=await B.broadcastTx(I);return H},address:W}};var F=require("@swapkit/helpers");var p=async({sdk:z,chain:J,derivationPath:X})=>{let{getToolboxByChain:R}=await import("@swapkit/toolboxes/utxo"),Z=R(J)(),Y=[F.Chain.Bitcoin,F.Chain.Litecoin].includes(J)?"p2wpkh":"p2pkh",$=X?F.derivationPathToString(X):`${F.DerivationPath[J]}/0`,q={coin:x[J],script_type:Y,address_n:A($)},{address:j}=await z.address.utxoGetAddress(q),W=async(G,M,L="")=>{let _=G.txOutputs.map((H)=>{let{value:O,address:V,change:N}=H,b=J===F.Chain.BitcoinCash?Z.stripToCashAddress(V):V;if(N||V===j)return{addressNList:q.address_n,isChange:!0,addressType:"change",amount:O,scriptType:Y};if(b)return{address:b,amount:O,addressType:"spend"};return null}).filter(Boolean),B=(H)=>{return H.filter((O)=>O!==null&&typeof O==="object"&&Object.keys(O).length>0)};return(await z.utxo.utxoSignTransaction({coin:x[J],inputs:M,outputs:B(_),version:1,locktime:0,opReturnData:L})).serializedTx};return{...Z,signTransaction:W,transfer:async({from:G,recipient:M,feeOptionKey:L,feeRate:_,memo:B,...I})=>{if(!G)throw new Error("From address must be provided");if(!M)throw new Error("Recipient address must be provided");let{psbt:H,inputs:O}=await Z.buildTx({...I,memo:B,recipient:M,feeRate:_||(await Z.getFeeRates())[L||F.FeeOption.Fast],sender:G,fetchTxHex:J===F.Chain.BitcoinCash}),V=O.map(({value:b,index:S,hash:y,txHex:T})=>({addressNList:q.address_n,scriptType:Y,amount:b.toString(),vout:S,txid:y,hex:T||""})),N=await W(H,V,B);return Z.broadcastTx(N)},address:j}};var h=Q.createWallet({name:"connectKeepkey",supportedChains:[Q.Chain.Arbitrum,Q.Chain.Avalanche,Q.Chain.Base,Q.Chain.BinanceSmartChain,Q.Chain.Bitcoin,Q.Chain.BitcoinCash,Q.Chain.Cosmos,Q.Chain.Dogecoin,Q.Chain.Dash,Q.Chain.Ethereum,Q.Chain.Litecoin,Q.Chain.Optimism,Q.Chain.Polygon,Q.Chain.THORChain,Q.Chain.Maya],walletType:Q.WalletOption.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:X})=>async function R(Z,Y){let $=Q.filterSupportedChains({chains:Z,supportedChains:J,walletType:X}),q=Q.SKConfig.get("integrations").keepKey;if(!q)throw new Error("KeepKey config not found");await d();let j={...q,apiKey:Q.SKConfig.get("apiKeys").keepKey},W=await m.KeepKeySdk.create(j);return await Promise.all($.map(async(U)=>{let G=await i({chain:U,derivationPath:Y?.[U]||Q.NetworkDerivationPath[U],sdk:W});z({...G,balance:[],chain:U,walletType:Q.WalletOption.KEEPKEY})})),!0}}),t=c(h);async function i({sdk:z,chain:J,derivationPath:X}){let{getProvider:R,getToolboxByChain:Z}=await import("@swapkit/toolboxes/evm");switch(J){case Q.Chain.BinanceSmartChain:case Q.Chain.Arbitrum:case Q.Chain.Optimism:case Q.Chain.Polygon:case Q.Chain.Avalanche:case Q.Chain.Ethereum:{let Y=R(J),$=new f({sdk:z,chain:J,derivationPath:X,provider:Y}),q=await $.getAddress(),j=Z(J)({provider:Y,signer:$});return{address:q,...j}}case Q.Chain.Cosmos:return u({sdk:z,derivationPath:X});case Q.Chain.THORChain:return l({sdk:z,derivationPath:X});case Q.Chain.Maya:return g({sdk:z,derivationPath:X});case Q.Chain.Bitcoin:case Q.Chain.BitcoinCash:case Q.Chain.Dash:case Q.Chain.Dogecoin:case Q.Chain.Litecoin:return p({sdk:z,chain:J,derivationPath:X});default:throw new Error(`Chain not supported ${J}`)}}async function d(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await a())window.location.assign("keepkey://launch"),await new Promise((X)=>setTimeout(X,30000)),d(z+1)}async function a(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}
1
+ var e={};s(e,{keepkeyWallet:()=>c,KEEPKEY_SUPPORTED_CHAINS:()=>t});module.exports=n(e);var Q=require("@swapkit/helpers"),m=require("@keepkey/keepkey-sdk");var V=require("@swapkit/helpers");var v;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(v||={});function o(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function A(z){let J=z;if(!o(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let X=J.split("/");if(X.length===1&&X[0]==="")return[];let R=new Array(X.length);for(let Z=0;Z<X.length;Z++){let Y=X[Z];if(Y){let q=/(\d+)([hH']?)/.exec(Y);if(q===null)throw new Error("Invalid input");let[,$="",j=""]=q;if(R[Z]=Number.parseInt($,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var u=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:X,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos");try{let q=J?V.derivationPathToString(J):`${V.DerivationPath.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:A(q)}),j=await R(V.Chain.Cosmos);if(X.amount[0])X.amount[0].amount=String(await Z(V.ChainId.Cosmos,500));return{...j,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=B.getBaseValue("string"),U=await j.getAccount($),H=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:X,memo:L||"",sequence:U?.sequence.toString()??"",chain_id:V.ChainId.Cosmos,account_number:U?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:_}],to_address:W,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),M=atob(H.serialized),I=new Uint8Array(M.length).map((b,F)=>M.charCodeAt(F));return(await(await Y(V.SKConfig.get("rpcUrls")[V.Chain.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(q){throw console.error(q),q}};var f=require("@swapkit/helpers"),C=require("ethers");class k extends C.AbstractSigner{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:X,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=X||f.NetworkDerivationPath.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:A(f.derivationPathToString(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:X,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:q,gasPrice:$})=>{if(!z)throw new Error("Missing to address");if(!X)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((Y||q)&&!$);if(j&&!Y)throw new Error("Missing maxFeePerGas");if(j&&!q)throw new Error("Missing maxFeePerGas");if(!(j||$))throw new Error("Missing gasPrice");let{toHexString:G}=await import("@swapkit/toolboxes/evm"),B=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),W={gas:G(BigInt(X)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:G(BigInt(f.ChainToChainId[this.chain])),to:z.toString(),value:G(BigInt(J||0)),nonce:G(B),data:Z,...j&&{maxFeePerGas:G(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:G(BigInt(q?.toString()||"0"))},...!j&&{gasPrice:G(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(W)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new k({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}var E=require("@swapkit/helpers");var g=async({sdk:z,derivationPath:J})=>{let{createStargateClient:X,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(E.Chain.Maya),Y=J?E.derivationPathToString(J):`${E.DerivationPath.MAYA}/0`,{address:q}=await z.address.mayachainGetAddress({address_n:A(Y)}),$=async({assetValue:B,recipient:W,sender:L,memo:_})=>{let{makeSignDoc:U}=await import("@cosmjs/amino"),{getDenomWithChain:H}=await import("@swapkit/toolboxes/cosmos"),M=await Z.getAccount(L);if(!M)throw new Error("Account not found");let{accountNumber:I,sequence:D=0}=M,N=B.getBaseValue("string"),b=W&&W!=="",F=b?{type:"mayachain/MsgSend",value:{amount:[{amount:N,denom:B.symbol.toLowerCase()}],from_address:L,to_address:W}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:N,asset:H(B)}],memo:_,signer:L}},y=U([F],{gas:"500000000",amount:[]},E.ChainId.Maya,_,I?.toString(),D),T=await(b?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:y,signerAddress:L}),x=atob(T.serialized);return new Uint8Array(x.length).map((r,P)=>x.charCodeAt(P))};return{...Z,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=await X(E.SKConfig.get("rpcUrls")[E.Chain.Maya]),U=await $({assetValue:B,recipient:W,memo:L,sender:q}),{transactionHash:H}=await _.broadcastTx(U);return H},deposit:async({assetValue:B,memo:W})=>{let L=await X(E.SKConfig.get("rpcUrls")[E.Chain.Maya]),_=await $({assetValue:B,memo:W,sender:q}),{transactionHash:U}=await L.broadcastTx(_);return U},address:q}};var O=require("@swapkit/helpers");var l=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:X}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:q}=await import("@swapkit/toolboxes/cosmos"),$=await q(O.Chain.THORChain),j=J?O.derivationPathToString(J):`${O.DerivationPath.THOR}/0`,{address:G}=await z.address.thorchainGetAddress({address_n:A(j)}),B=async({assetValue:_,recipient:U,sender:H,memo:M})=>{let I=await $.getAccount(H);if(!I)throw new Error("Account not found");let{accountNumber:D,sequence:N=0}=I,b=U&&U!=="",F=R({sender:H,recipient:U,assetValue:_,memo:M}),y=O.ChainId.THORChain,S=X([F],Z(O.Chain.THORChain),y,M,D?.toString(),N),T=b?await z.thorchain.thorchainSignAminoTransfer({signDoc:S,signerAddress:H}):await z.thorchain.thorchainSignAminoDeposit({signDoc:S,signerAddress:H}),x=atob(T.serialized);return new Uint8Array(x.length).map((r,P)=>x.charCodeAt(P))};return{...$,transfer:async({assetValue:_,recipient:U,memo:H})=>{let M=await Y(O.SKConfig.get("rpcUrls")[O.Chain.THORChain]),I=await B({assetValue:_,recipient:U,memo:H,sender:G}),{transactionHash:D}=await M.broadcastTx(I);return D},deposit:async({assetValue:_,memo:U})=>{let H=await Y(O.SKConfig.get("rpcUrls")[O.Chain.THORChain]),M=await B({assetValue:_,memo:U,sender:G}),{transactionHash:I}=await H.broadcastTx(M);return I},address:G}};var w=require("@swapkit/helpers");var p=async({sdk:z,chain:J,derivationPath:X})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[w.Chain.Bitcoin,w.Chain.Litecoin].includes(J)?"p2wpkh":"p2pkh",q=X?w.derivationPathToString(X):`${w.DerivationPath[J]}/0`,$={coin:v[J],script_type:Y,address_n:A(q)},j=(await z.address.utxoGetAddress($)).address,G=async(W,L,_="")=>{let U=W.txOutputs.map((I)=>{let{value:D,address:N,change:b}=I,F=J===w.Chain.BitcoinCash?Z.stripToCashAddress(N):N;if(b||N===j)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:D,scriptType:Y};if(F)return{address:F,amount:D,addressType:"spend"};return null}).filter(Boolean),H=(I)=>{return I.filter((D)=>D!==null&&typeof D==="object"&&Object.keys(D).length>0)};return(await z.utxo.utxoSignTransaction({coin:v[J],inputs:L,outputs:H(U),opReturnData:_})).serializedTx?.toString()};return{...Z,signTransaction:G,transfer:async({recipient:W,feeOptionKey:L,feeRate:_,memo:U,...H})=>{if(!j)throw new Error("From address must be provided");if(!W)throw new Error("Recipient address must be provided");let M=J===w.Chain.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:I,inputs:D}=await M({...H,memo:U,recipient:W,feeRate:_||(await Z.getFeeRates())[L||w.FeeOption.Fast],sender:j,fetchTxHex:!0}),N=D.map(({value:F,index:y,hash:S,txHex:T})=>({addressNList:$.address_n,amount:F.toString(),hex:T||"",scriptType:Y,txid:S,vout:y})),b=await G(I,N,U);return Z.broadcastTx(b)},address:j}};var c=Q.createWallet({name:"connectKeepkey",supportedChains:[Q.Chain.Arbitrum,Q.Chain.Avalanche,Q.Chain.Base,Q.Chain.BinanceSmartChain,Q.Chain.Bitcoin,Q.Chain.BitcoinCash,Q.Chain.Cosmos,Q.Chain.Dogecoin,Q.Chain.Dash,Q.Chain.Ethereum,Q.Chain.Litecoin,Q.Chain.Optimism,Q.Chain.Polygon,Q.Chain.THORChain,Q.Chain.Maya],walletType:Q.WalletOption.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:X})=>async function R(Z,Y){let q=Q.filterSupportedChains({chains:Z,supportedChains:J,walletType:X}),$=Q.SKConfig.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");await h();let j={...$,apiKey:Q.SKConfig.get("apiKeys").keepKey},G=await m.KeepKeySdk.create(j);return await Promise.all(q.map(async(B)=>{let W=await i({chain:B,derivationPath:Y?.[B]||Q.NetworkDerivationPath[B],sdk:G}),L=await W.getAddress()||"";z({...W,address:L,chain:B,walletType:Q.WalletOption.KEEPKEY})})),!0}}),t=d(c);async function i({sdk:z,chain:J,derivationPath:X}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case Q.Chain.BinanceSmartChain:case Q.Chain.Arbitrum:case Q.Chain.Optimism:case Q.Chain.Polygon:case Q.Chain.Avalanche:case Q.Chain.Ethereum:{let Y=await R(J),q=new k({sdk:z,chain:J,derivationPath:X,provider:Y});return await Z(J,{provider:Y,signer:q})}case Q.Chain.Cosmos:return u({sdk:z,derivationPath:X});case Q.Chain.THORChain:return l({sdk:z,derivationPath:X});case Q.Chain.Maya:return g({sdk:z,derivationPath:X});case Q.Chain.Bitcoin:case Q.Chain.BitcoinCash:case Q.Chain.Dash:case Q.Chain.Dogecoin:case Q.Chain.Litecoin:return p({sdk:z,chain:J,derivationPath:X});default:throw new Error(`Chain not supported ${J}`)}}async function h(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await a())window.location.assign("keepkey://launch"),await new Promise((X)=>setTimeout(X,30000)),h(z+1)}async function a(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}
2
2
 
3
- //# debugId=AB3CEFC16ADAEDC964756E2164756E21
3
+ //# debugId=3425E50F666F8FF064756E2164756E21
@@ -2,15 +2,15 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/keepkey/index.ts", "../src/keepkey/chains/cosmos.ts", "../src/keepkey/coins.ts", "../src/keepkey/chains/evm.ts", "../src/keepkey/chains/mayachain.ts", "../src/keepkey/chains/thorchain.ts", "../src/keepkey/chains/utxo.ts"],
4
4
  "sourcesContent": [
5
- "import {\n Chain,\n type DerivationPathArray,\n NetworkDerivationPath,\n SKConfig,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nexport type { PairingInfo } from \"@keepkey/keepkey-sdk\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport { cosmosWalletMethods } from \"./chains/cosmos\";\nimport { KeepKeySigner } from \"./chains/evm\";\nimport { mayachainWalletMethods } from \"./chains/mayachain\";\nimport { thorchainWalletMethods } from \"./chains/thorchain\";\nimport { utxoWalletMethods } from \"./chains/utxo\";\n\nexport const keepkeyWallet = createWallet({\n name: \"connectKeepkey\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Ethereum,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Maya,\n ],\n walletType: WalletOption.KEEPKEY,\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeepkey(\n chains: Chain[],\n derivationPathMap?: Record<Chain, DerivationPathArray>,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const config = SKConfig.get(\"integrations\").keepKey;\n\n if (!config) throw new Error(\"KeepKey config not found\");\n\n await checkAndLaunch();\n\n const keepkeyConfig = { ...config, apiKey: SKConfig.get(\"apiKeys\").keepKey };\n const keepKeySdk = await KeepKeySdk.create(keepkeyConfig);\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({\n chain,\n derivationPath: derivationPathMap?.[chain] || NetworkDerivationPath[chain],\n sdk: keepKeySdk,\n });\n\n addChain({\n ...walletMethods,\n balance: [],\n chain,\n walletType: WalletOption.KEEPKEY,\n });\n }),\n );\n return true;\n },\n});\n\nexport const KEEPKEY_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyWallet);\n\nasync function getWalletMethods({\n sdk,\n chain,\n derivationPath,\n}: { sdk: KeepKeySdk; chain: Chain; derivationPath?: DerivationPathArray }) {\n const { getProvider, getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n\n switch (chain) {\n case Chain.BinanceSmartChain:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche:\n case Chain.Ethereum: {\n const provider = getProvider(chain);\n const signer = new KeepKeySigner({\n sdk,\n chain,\n derivationPath,\n provider,\n });\n const address = await signer.getAddress();\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n return { address, ...toolbox };\n }\n case Chain.Cosmos: {\n return cosmosWalletMethods({ sdk, derivationPath });\n }\n case Chain.THORChain: {\n return thorchainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Maya: {\n return mayachainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n return utxoWalletMethods({\n sdk,\n chain,\n derivationPath,\n });\n }\n default:\n throw new Error(`Chain not supported ${chain}`);\n }\n}\n\n// kk-sdk docs: https://medium.com/@highlander_35968/building-on-the-keepkey-sdk-2023fda41f38\n// test spec: if offline, launch keepkey-bridge\nasync function checkAndLaunch(attempts = 0) {\n if (attempts >= 3) {\n alert(\n \"KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started\",\n );\n }\n const isAvailable = await checkKeepkeyAvailability();\n\n if (!isAvailable) {\n window.location.assign(\"keepkey://launch\");\n await new Promise((resolve) => setTimeout(resolve, 30000));\n checkAndLaunch(attempts + 1);\n }\n}\n\nasync function checkKeepkeyAvailability(spec = \"http://localhost:1646/spec/swagger.json\") {\n try {\n const response = await fetch(spec);\n return response.status === 200;\n } catch (error) {\n console.error(error);\n return false;\n }\n}\n",
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 { TransferParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\nexport const cosmosWalletMethods = async ({\n sdk,\n derivationPath,\n}: { sdk: KeepKeySdk; derivationPath?: DerivationPathArray }) => {\n const { DEFAULT_COSMOS_FEE_MAINNET, GaiaToolbox, createStargateClient } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\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 = GaiaToolbox();\n\n if (DEFAULT_COSMOS_FEE_MAINNET.amount[0]) {\n DEFAULT_COSMOS_FEE_MAINNET.amount[0].amount = String(\n await toolbox?.getFeeRateFromThorswap?.(ChainId.Cosmos, 500),\n );\n }\n\n // TODO support other cosmos assets\n const transfer = async ({ assetValue, recipient, memo }: TransferParams) => {\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",
5
+ "import {\n Chain,\n type DerivationPathArray,\n NetworkDerivationPath,\n SKConfig,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nexport type { PairingInfo } from \"@keepkey/keepkey-sdk\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport { cosmosWalletMethods } from \"./chains/cosmos\";\nimport { KeepKeySigner } from \"./chains/evm\";\nimport { mayachainWalletMethods } from \"./chains/mayachain\";\nimport { thorchainWalletMethods } from \"./chains/thorchain\";\nimport { utxoWalletMethods } from \"./chains/utxo\";\n\nexport const keepkeyWallet = createWallet({\n name: \"connectKeepkey\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Ethereum,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Maya,\n ],\n walletType: WalletOption.KEEPKEY,\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeepkey(\n chains: Chain[],\n derivationPathMap?: Record<Chain, DerivationPathArray>,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const config = SKConfig.get(\"integrations\").keepKey;\n\n if (!config) throw new Error(\"KeepKey config not found\");\n\n await checkAndLaunch();\n\n const keepkeyConfig = { ...config, apiKey: SKConfig.get(\"apiKeys\").keepKey };\n const keepKeySdk = await KeepKeySdk.create(keepkeyConfig);\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({\n chain,\n derivationPath: derivationPathMap?.[chain] || NetworkDerivationPath[chain],\n sdk: keepKeySdk,\n });\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType: WalletOption.KEEPKEY });\n }),\n );\n return true;\n },\n});\n\nexport const KEEPKEY_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyWallet);\n\nasync function getWalletMethods({\n sdk,\n chain,\n derivationPath,\n}: { sdk: KeepKeySdk; chain: Chain; derivationPath?: DerivationPathArray }) {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n switch (chain) {\n case Chain.BinanceSmartChain:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche:\n case Chain.Ethereum: {\n const provider = await getProvider(chain);\n const signer = new KeepKeySigner({ sdk, chain, derivationPath, provider });\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return toolbox;\n }\n case Chain.Cosmos: {\n return cosmosWalletMethods({ sdk, derivationPath });\n }\n case Chain.THORChain: {\n return thorchainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Maya: {\n return mayachainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n return utxoWalletMethods({ sdk, chain, derivationPath });\n }\n default:\n throw new Error(`Chain not supported ${chain}`);\n }\n}\n\n// kk-sdk docs: https://medium.com/@highlander_35968/building-on-the-keepkey-sdk-2023fda41f38\n// test spec: if offline, launch keepkey-bridge\nasync function checkAndLaunch(attempts = 0) {\n if (attempts >= 3) {\n alert(\n \"KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started\",\n );\n }\n const isAvailable = await checkKeepkeyAvailability();\n\n if (!isAvailable) {\n window.location.assign(\"keepkey://launch\");\n await new Promise((resolve) => setTimeout(resolve, 30000));\n checkAndLaunch(attempts + 1);\n }\n}\n\nasync function checkKeepkeyAvailability(spec = \"http://localhost:1646/spec/swagger.json\") {\n try {\n const response = await fetch(spec);\n return response.status === 200;\n } catch (error) {\n console.error(error);\n return false;\n }\n}\n",
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 SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { DepositParam, TransferParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n from: 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, getToolboxByChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = getToolboxByChain(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 ({ assetValue, recipient, from, memo }: SignTransactionParams) => {\n const { makeSignDoc } = await import(\"@cosmjs/amino\");\n const { getDenomWithChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const account = await toolbox.getAccount(from);\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: from,\n to_address: recipient,\n },\n }\n : {\n type: \"mayachain/MsgDeposit\",\n value: {\n coins: [{ amount, asset: getDenomWithChain(assetValue) }],\n memo,\n signer: from,\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 signedTx = isTransfer\n ? await sdk.mayachain.mayachainSignAminoTransfer({\n // TODO can we ignore this ?\n // @ts-expect-error readonly cant be assigned to writable\n signDoc,\n signerAddress: from,\n })\n : await sdk.mayachain.mayachainSignAminoDeposit({\n // @ts-expect-error\n signDoc,\n signerAddress: from,\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 }: TransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n from: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: DepositParam) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n from: 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 SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { DepositParam, TransferParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n from: 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, ThorchainToolbox } =\n await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = ThorchainToolbox();\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 ({ assetValue, recipient, from, memo }: SignTransactionParams) => {\n const account = await toolbox.getAccount(from);\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({ chain: Chain.THORChain, from, 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: from,\n })\n : await sdk.thorchain.thorchainSignAminoDeposit({\n signDoc: signDoc as TypesThorchainSignDocDeposit,\n signerAddress: from,\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 }: TransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n from: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: DepositParam) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n from: 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
- "import {\n Chain,\n DerivationPath,\n type DerivationPathArray,\n FeeOption,\n type UTXOChain,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { BCHToolbox, Psbt, UTXOToolbox, UTXOTransferParams } from \"@swapkit/toolboxes/utxo\";\n\nimport { ChainToKeepKeyName, bip32ToAddressNList } from \"../coins\";\n\ntype KKUtxoWalletParams = {\n sdk: any;\n chain: UTXOChain;\n derivationPath?: DerivationPathArray;\n};\n\ninterface psbtTxOutput {\n address: string;\n script: Buffer;\n value: number;\n change?: boolean; // Optional, assuming it indicates if the output is a change\n}\ninterface ExtendedPsbt extends Psbt {\n txOutputs: psbtTxOutput[];\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}: KKUtxoWalletParams): Promise<\n UTXOToolbox & {\n address: string;\n signTransaction: (\n psbt: ExtendedPsbt,\n inputs: KeepKeyInputObject[],\n memo?: string,\n ) => Promise<string>;\n transfer: (params: UTXOTransferParams) => Promise<string>;\n }\n> => {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/utxo\");\n\n const toolbox = getToolboxByChain(chain)();\n const scriptType = [Chain.Bitcoin, Chain.Litecoin].includes(chain) ? \"p2wpkh\" : \"p2pkh\";\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 { address: walletAddress } = await sdk.address.utxoGetAddress(addressInfo);\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 psbtTxOutput;\n\n const outputAddress =\n chain === Chain.BitcoinCash\n ? (toolbox as ReturnType<typeof BCHToolbox>).stripToCashAddress(address)\n : 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 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 version: 1,\n locktime: 0,\n opReturnData: memo,\n });\n return responseSign.serializedTx;\n };\n\n const transfer = async ({\n from,\n recipient,\n feeOptionKey,\n feeRate,\n memo,\n ...rest\n }: UTXOTransferParams) => {\n if (!from) throw new Error(\"From address must be provided\");\n if (!recipient) throw new Error(\"Recipient address must be provided\");\n\n const { psbt, inputs: rawInputs } = await toolbox.buildTx({\n ...rest,\n memo,\n recipient,\n feeRate: feeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast],\n sender: from,\n fetchTxHex: chain === Chain.BitcoinCash,\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 scriptType,\n amount: value.toString(),\n vout: index,\n txid: hash,\n hex: txHex || \"\",\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"
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",
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": "AB3CEFC16ADAEDC964756E2164756E21",
13
+ "mappings": "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",
14
+ "debugId": "3425E50F666F8FF064756E2164756E21",
15
15
  "names": []
16
16
  }
@@ -1,4 +1,3 @@
1
- import{r as d}from"../../chunk-ha78se5g.js";import{s as w,t as F}from"../../chunk-5m175wfy.js";import{Chain as Y,NetworkDerivationPath as Wz,SKConfig as m,WalletOption as h,createWallet as Gz,filterSupportedChains as Lz}from"@swapkit/helpers";import{KeepKeySdk as _z}from"@keepkey/keepkey-sdk";import{Chain as n,ChainId as P,DerivationPath as t,SKConfig as i,derivationPathToString as a}from"@swapkit/helpers";var S;((X)=>{X.BTC="Bitcoin";X.BCH="BitcoinCash";X.DOGE="Dogecoin";X.LTC="Litecoin";X.DASH="Dash"})(S||={});function s(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function V(z){let J=z;if(!s(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let X=Q[Z];if(X){let $=/(\d+)([hH']?)/.exec(X);if($===null)throw new Error("Invalid input");let[,q="",j=""]=$;if(R[Z]=Number.parseInt(q,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var u=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,GaiaToolbox:R,createStargateClient:Z}=await import("@swapkit/toolboxes/cosmos");try{let X=J?a(J):`${t.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:V(X)}),q=R();if(Q.amount[0])Q.amount[0].amount=String(await q?.getFeeRateFromThorswap?.(P.Cosmos,500));return{...q,transfer:async({assetValue:W,recipient:U,memo:G})=>{let M=W.getBaseValue("string"),L=await q.getAccount($),_=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:G||"",sequence:L?.sequence.toString()??"",chain_id:P.Cosmos,account_number:L?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:M}],to_address:U,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),B=atob(_.serialized),I=new Uint8Array(B.length).map((D,E)=>B.charCodeAt(E));return(await(await Z(i.get("rpcUrls")[n.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(X){throw console.error(X),X}};import{ChainToChainId as e,NetworkDerivationPath as zz,derivationPathToString as Jz}from"@swapkit/helpers";import{AbstractSigner as Qz}from"ethers";class y extends Qz{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||zz.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:V(Jz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:X,maxPriorityFeePerGas:$,gasPrice:q})=>{if(!z)throw new Error("Missing to address");if(!Q)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((X||$)&&!q);if(j&&!X)throw new Error("Missing maxFeePerGas");if(j&&!$)throw new Error("Missing maxFeePerGas");if(!(j||q))throw new Error("Missing gasPrice");let{toHexString:W}=await import("@swapkit/toolboxes/evm"),U=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),G={gas:W(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:W(BigInt(e[this.chain])),to:z.toString(),value:W(BigInt(J||0)),nonce:W(U),data:Z,...j&&{maxFeePerGas:W(BigInt(X?.toString()||"0")),maxPriorityFeePerGas:W(BigInt($?.toString()||"0"))},...!j&&{gasPrice:W(BigInt(q?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(G)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new y({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as f,ChainId as Xz,DerivationPath as Yz,SKConfig as C,derivationPathToString as Zz}from"@swapkit/helpers";var g=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getToolboxByChain:R}=await import("@swapkit/toolboxes/cosmos"),Z=R(f.Maya)(),X=J?Zz(J):`${Yz.MAYA}/0`,{address:$}=await z.address.mayachainGetAddress({address_n:V(X)}),q=async({assetValue:U,recipient:G,from:M,memo:L})=>{let{makeSignDoc:_}=await import("@cosmjs/amino"),{getDenomWithChain:B}=await import("@swapkit/toolboxes/cosmos"),I=await Z.getAccount(M);if(!I)throw new Error("Account not found");let{accountNumber:H,sequence:O=0}=I,D=U.getBaseValue("string"),E=G&&G!=="",N=E?{type:"mayachain/MsgSend",value:{amount:[{amount:D,denom:U.symbol.toLowerCase()}],from_address:M,to_address:G}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:D,asset:B(U)}],memo:L,signer:M}},A=_([N],{gas:"500000000",amount:[]},Xz.Maya,L,H?.toString(),O),K=E?await z.mayachain.mayachainSignAminoTransfer({signDoc:A,signerAddress:M}):await z.mayachain.mayachainSignAminoDeposit({signDoc:A,signerAddress:M}),b=atob(K.serialized);return new Uint8Array(b.length).map((x,k)=>b.charCodeAt(k))};return{...Z,transfer:async({assetValue:U,recipient:G,memo:M})=>{let L=await Q(C.get("rpcUrls")[f.Maya]),_=await q({assetValue:U,recipient:G,memo:M,from:$}),{transactionHash:B}=await L.broadcastTx(_);return B},deposit:async({assetValue:U,memo:G})=>{let M=await Q(C.get("rpcUrls")[f.Maya]),L=await q({assetValue:U,memo:G,from:$}),{transactionHash:_}=await M.broadcastTx(L);return _},address:$}};import{Chain as T,ChainId as $z,DerivationPath as qz,SKConfig as l,derivationPathToString as jz}from"@swapkit/helpers";var p=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:X,ThorchainToolbox:$}=await import("@swapkit/toolboxes/cosmos"),q=$(),j=J?jz(J):`${qz.THOR}/0`,{address:W}=await z.address.thorchainGetAddress({address_n:V(j)}),U=async({assetValue:L,recipient:_,from:B,memo:I})=>{let H=await q.getAccount(B);if(!H)throw new Error("Account not found");let{accountNumber:O,sequence:D=0}=H,E=_&&_!=="",N=R({chain:T.THORChain,from:B,recipient:_,assetValue:L,memo:I}),A=$z.THORChain,K=Q([N],Z(T.THORChain),A,I,O?.toString(),D),b=E?await z.thorchain.thorchainSignAminoTransfer({signDoc:K,signerAddress:B}):await z.thorchain.thorchainSignAminoDeposit({signDoc:K,signerAddress:B}),x=atob(b.serialized);return new Uint8Array(x.length).map((k,o)=>x.charCodeAt(o))};return{...q,transfer:async({assetValue:L,recipient:_,memo:B})=>{let I=await X(l.get("rpcUrls")[T.THORChain]),H=await U({assetValue:L,recipient:_,memo:B,from:W}),{transactionHash:O}=await I.broadcastTx(H);return O},deposit:async({assetValue:L,memo:_})=>{let B=await X(l.get("rpcUrls")[T.THORChain]),I=await U({assetValue:L,memo:_,from:W}),{transactionHash:H}=await B.broadcastTx(I);return H},address:W}};import{Chain as v,DerivationPath as Rz,FeeOption as Uz,derivationPathToString as Bz}from"@swapkit/helpers";var c=async({sdk:z,chain:J,derivationPath:Q})=>{let{getToolboxByChain:R}=await import("@swapkit/toolboxes/utxo"),Z=R(J)(),X=[v.Bitcoin,v.Litecoin].includes(J)?"p2wpkh":"p2pkh",$=Q?Bz(Q):`${Rz[J]}/0`,q={coin:S[J],script_type:X,address_n:V($)},{address:j}=await z.address.utxoGetAddress(q),W=async(G,M,L="")=>{let _=G.txOutputs.map((H)=>{let{value:O,address:D,change:E}=H,N=J===v.BitcoinCash?Z.stripToCashAddress(D):D;if(E||D===j)return{addressNList:q.address_n,isChange:!0,addressType:"change",amount:O,scriptType:X};if(N)return{address:N,amount:O,addressType:"spend"};return null}).filter(Boolean),B=(H)=>{return H.filter((O)=>O!==null&&typeof O==="object"&&Object.keys(O).length>0)};return(await z.utxo.utxoSignTransaction({coin:S[J],inputs:M,outputs:B(_),version:1,locktime:0,opReturnData:L})).serializedTx};return{...Z,signTransaction:W,transfer:async({from:G,recipient:M,feeOptionKey:L,feeRate:_,memo:B,...I})=>{if(!G)throw new Error("From address must be provided");if(!M)throw new Error("Recipient address must be provided");let{psbt:H,inputs:O}=await Z.buildTx({...I,memo:B,recipient:M,feeRate:_||(await Z.getFeeRates())[L||Uz.Fast],sender:G,fetchTxHex:J===v.BitcoinCash}),D=O.map(({value:N,index:A,hash:K,txHex:b})=>({addressNList:q.address_n,scriptType:X,amount:N.toString(),vout:A,txid:K,hex:b||""})),E=await W(H,D,B);return Z.broadcastTx(E)},address:j}};var Mz=Gz({name:"connectKeepkey",supportedChains:[Y.Arbitrum,Y.Avalanche,Y.Base,Y.BinanceSmartChain,Y.Bitcoin,Y.BitcoinCash,Y.Cosmos,Y.Dogecoin,Y.Dash,Y.Ethereum,Y.Litecoin,Y.Optimism,Y.Polygon,Y.THORChain,Y.Maya],walletType:h.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,X){let $=Lz({chains:Z,supportedChains:J,walletType:Q}),q=m.get("integrations").keepKey;if(!q)throw new Error("KeepKey config not found");await r();let j={...q,apiKey:m.get("apiKeys").keepKey},W=await _z.create(j);return await Promise.all($.map(async(U)=>{let G=await Hz({chain:U,derivationPath:X?.[U]||Wz[U],sdk:W});z({...G,balance:[],chain:U,walletType:h.KEEPKEY})})),!0}}),hz=d(Mz);async function Hz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getToolboxByChain:Z}=await import("@swapkit/toolboxes/evm");switch(J){case Y.BinanceSmartChain:case Y.Arbitrum:case Y.Optimism:case Y.Polygon:case Y.Avalanche:case Y.Ethereum:{let X=R(J),$=new y({sdk:z,chain:J,derivationPath:Q,provider:X}),q=await $.getAddress(),j=Z(J)({provider:X,signer:$});return{address:q,...j}}case Y.Cosmos:return u({sdk:z,derivationPath:Q});case Y.THORChain:return p({sdk:z,derivationPath:Q});case Y.Maya:return g({sdk:z,derivationPath:Q});case Y.Bitcoin:case Y.BitcoinCash:case Y.Dash:case Y.Dogecoin:case Y.Litecoin:return c({sdk:z,chain:J,derivationPath:Q});default:throw new Error(`Chain not supported ${J}`)}}async function r(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Oz())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),r(z+1)}async function Oz(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}export{Mz as keepkeyWallet,hz as KEEPKEY_SUPPORTED_CHAINS};
2
- export{Mz as p};
1
+ import{a as o}from"../../chunk-czhtd6cy.js";import{c as w,d as F}from"../../chunk-p1kdg37m.js";import{Chain as X,NetworkDerivationPath as Wz,SKConfig as h,WalletOption as d,createWallet as Gz,filterSupportedChains as Lz}from"@swapkit/helpers";import{KeepKeySdk as _z}from"@keepkey/keepkey-sdk";import{Chain as P,ChainId as u,DerivationPath as t,SKConfig as i,derivationPathToString as a}from"@swapkit/helpers";var y;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(y||={});function s(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function V(z){let J=z;if(!s(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let Y=Q[Z];if(Y){let q=/(\d+)([hH']?)/.exec(Y);if(q===null)throw new Error("Invalid input");let[,$="",j=""]=q;if(R[Z]=Number.parseInt($,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var C=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos");try{let q=J?a(J):`${t.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:V(q)}),j=await R(P.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(u.Cosmos,500));return{...j,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=B.getBaseValue("string"),U=await j.getAccount($),H=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:U?.sequence.toString()??"",chain_id:u.Cosmos,account_number:U?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:_}],to_address:W,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),M=atob(H.serialized),I=new Uint8Array(M.length).map((N,E)=>M.charCodeAt(E));return(await(await Y(i.get("rpcUrls")[P.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(q){throw console.error(q),q}};import{ChainToChainId as e,NetworkDerivationPath as zz,derivationPathToString as Jz}from"@swapkit/helpers";import{AbstractSigner as Qz}from"ethers";class S extends Qz{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||zz.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:V(Jz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:q,gasPrice:$})=>{if(!z)throw new Error("Missing to address");if(!Q)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((Y||q)&&!$);if(j&&!Y)throw new Error("Missing maxFeePerGas");if(j&&!q)throw new Error("Missing maxFeePerGas");if(!(j||$))throw new Error("Missing gasPrice");let{toHexString:G}=await import("@swapkit/toolboxes/evm"),B=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),W={gas:G(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:G(BigInt(e[this.chain])),to:z.toString(),value:G(BigInt(J||0)),nonce:G(B),data:Z,...j&&{maxFeePerGas:G(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:G(BigInt(q?.toString()||"0"))},...!j&&{gasPrice:G(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(W)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new S({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as k,ChainId as Xz,DerivationPath as Yz,SKConfig as g,derivationPathToString as Zz}from"@swapkit/helpers";var l=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(k.Maya),Y=J?Zz(J):`${Yz.MAYA}/0`,{address:q}=await z.address.mayachainGetAddress({address_n:V(Y)}),$=async({assetValue:B,recipient:W,sender:L,memo:_})=>{let{makeSignDoc:U}=await import("@cosmjs/amino"),{getDenomWithChain:H}=await import("@swapkit/toolboxes/cosmos"),M=await Z.getAccount(L);if(!M)throw new Error("Account not found");let{accountNumber:I,sequence:D=0}=M,O=B.getBaseValue("string"),N=W&&W!=="",E=N?{type:"mayachain/MsgSend",value:{amount:[{amount:O,denom:B.symbol.toLowerCase()}],from_address:L,to_address:W}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:O,asset:H(B)}],memo:_,signer:L}},A=U([E],{gas:"500000000",amount:[]},Xz.Maya,_,I?.toString(),D),K=await(N?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:A,signerAddress:L}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...Z,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=await Q(g.get("rpcUrls")[k.Maya]),U=await $({assetValue:B,recipient:W,memo:L,sender:q}),{transactionHash:H}=await _.broadcastTx(U);return H},deposit:async({assetValue:B,memo:W})=>{let L=await Q(g.get("rpcUrls")[k.Maya]),_=await $({assetValue:B,memo:W,sender:q}),{transactionHash:U}=await L.broadcastTx(_);return U},address:q}};import{Chain as T,ChainId as $z,DerivationPath as qz,SKConfig as p,derivationPathToString as jz}from"@swapkit/helpers";var m=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:q}=await import("@swapkit/toolboxes/cosmos"),$=await q(T.THORChain),j=J?jz(J):`${qz.THOR}/0`,{address:G}=await z.address.thorchainGetAddress({address_n:V(j)}),B=async({assetValue:_,recipient:U,sender:H,memo:M})=>{let I=await $.getAccount(H);if(!I)throw new Error("Account not found");let{accountNumber:D,sequence:O=0}=I,N=U&&U!=="",E=R({sender:H,recipient:U,assetValue:_,memo:M}),A=$z.THORChain,b=Q([E],Z(T.THORChain),A,M,D?.toString(),O),K=N?await z.thorchain.thorchainSignAminoTransfer({signDoc:b,signerAddress:H}):await z.thorchain.thorchainSignAminoDeposit({signDoc:b,signerAddress:H}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...$,transfer:async({assetValue:_,recipient:U,memo:H})=>{let M=await Y(p.get("rpcUrls")[T.THORChain]),I=await B({assetValue:_,recipient:U,memo:H,sender:G}),{transactionHash:D}=await M.broadcastTx(I);return D},deposit:async({assetValue:_,memo:U})=>{let H=await Y(p.get("rpcUrls")[T.THORChain]),M=await B({assetValue:_,memo:U,sender:G}),{transactionHash:I}=await H.broadcastTx(M);return I},address:G}};import{Chain as x,DerivationPath as Uz,FeeOption as Rz,derivationPathToString as Bz}from"@swapkit/helpers";var c=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[x.Bitcoin,x.Litecoin].includes(J)?"p2wpkh":"p2pkh",q=Q?Bz(Q):`${Uz[J]}/0`,$={coin:y[J],script_type:Y,address_n:V(q)},j=(await z.address.utxoGetAddress($)).address,G=async(W,L,_="")=>{let U=W.txOutputs.map((I)=>{let{value:D,address:O,change:N}=I,E=J===x.BitcoinCash?Z.stripToCashAddress(O):O;if(N||O===j)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:D,scriptType:Y};if(E)return{address:E,amount:D,addressType:"spend"};return null}).filter(Boolean),H=(I)=>{return I.filter((D)=>D!==null&&typeof D==="object"&&Object.keys(D).length>0)};return(await z.utxo.utxoSignTransaction({coin:y[J],inputs:L,outputs:H(U),opReturnData:_})).serializedTx?.toString()};return{...Z,signTransaction:G,transfer:async({recipient:W,feeOptionKey:L,feeRate:_,memo:U,...H})=>{if(!j)throw new Error("From address must be provided");if(!W)throw new Error("Recipient address must be provided");let M=J===x.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:I,inputs:D}=await M({...H,memo:U,recipient:W,feeRate:_||(await Z.getFeeRates())[L||Rz.Fast],sender:j,fetchTxHex:!0}),O=D.map(({value:E,index:A,hash:b,txHex:K})=>({addressNList:$.address_n,amount:E.toString(),hex:K||"",scriptType:Y,txid:b,vout:A})),N=await G(I,O,U);return Z.broadcastTx(N)},address:j}};var Hz=Gz({name:"connectKeepkey",supportedChains:[X.Arbitrum,X.Avalanche,X.Base,X.BinanceSmartChain,X.Bitcoin,X.BitcoinCash,X.Cosmos,X.Dogecoin,X.Dash,X.Ethereum,X.Litecoin,X.Optimism,X.Polygon,X.THORChain,X.Maya],walletType:d.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let q=Lz({chains:Z,supportedChains:J,walletType:Q}),$=h.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");await r();let j={...$,apiKey:h.get("apiKeys").keepKey},G=await _z.create(j);return await Promise.all(q.map(async(B)=>{let W=await Iz({chain:B,derivationPath:Y?.[B]||Wz[B],sdk:G}),L=await W.getAddress()||"";z({...W,address:L,chain:B,walletType:d.KEEPKEY})})),!0}}),hz=o(Hz);async function Iz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case X.BinanceSmartChain:case X.Arbitrum:case X.Optimism:case X.Polygon:case X.Avalanche:case X.Ethereum:{let Y=await R(J),q=new S({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:q})}case X.Cosmos:return C({sdk:z,derivationPath:Q});case X.THORChain:return m({sdk:z,derivationPath:Q});case X.Maya:return l({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return c({sdk:z,chain:J,derivationPath:Q});default:throw new Error(`Chain not supported ${J}`)}}async function r(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Mz())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),r(z+1)}async function Mz(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}export{Hz as keepkeyWallet,hz as KEEPKEY_SUPPORTED_CHAINS};
3
2
 
4
- //# debugId=2CA5ACE6D0A1425A64756E2164756E21
3
+ //# debugId=ED8287149CCB327064756E2164756E21
@@ -2,15 +2,15 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/keepkey/index.ts", "../src/keepkey/chains/cosmos.ts", "../src/keepkey/coins.ts", "../src/keepkey/chains/evm.ts", "../src/keepkey/chains/mayachain.ts", "../src/keepkey/chains/thorchain.ts", "../src/keepkey/chains/utxo.ts"],
4
4
  "sourcesContent": [
5
- "import {\n Chain,\n type DerivationPathArray,\n NetworkDerivationPath,\n SKConfig,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nexport type { PairingInfo } from \"@keepkey/keepkey-sdk\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport { cosmosWalletMethods } from \"./chains/cosmos\";\nimport { KeepKeySigner } from \"./chains/evm\";\nimport { mayachainWalletMethods } from \"./chains/mayachain\";\nimport { thorchainWalletMethods } from \"./chains/thorchain\";\nimport { utxoWalletMethods } from \"./chains/utxo\";\n\nexport const keepkeyWallet = createWallet({\n name: \"connectKeepkey\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Ethereum,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Maya,\n ],\n walletType: WalletOption.KEEPKEY,\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeepkey(\n chains: Chain[],\n derivationPathMap?: Record<Chain, DerivationPathArray>,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const config = SKConfig.get(\"integrations\").keepKey;\n\n if (!config) throw new Error(\"KeepKey config not found\");\n\n await checkAndLaunch();\n\n const keepkeyConfig = { ...config, apiKey: SKConfig.get(\"apiKeys\").keepKey };\n const keepKeySdk = await KeepKeySdk.create(keepkeyConfig);\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({\n chain,\n derivationPath: derivationPathMap?.[chain] || NetworkDerivationPath[chain],\n sdk: keepKeySdk,\n });\n\n addChain({\n ...walletMethods,\n balance: [],\n chain,\n walletType: WalletOption.KEEPKEY,\n });\n }),\n );\n return true;\n },\n});\n\nexport const KEEPKEY_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyWallet);\n\nasync function getWalletMethods({\n sdk,\n chain,\n derivationPath,\n}: { sdk: KeepKeySdk; chain: Chain; derivationPath?: DerivationPathArray }) {\n const { getProvider, getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n\n switch (chain) {\n case Chain.BinanceSmartChain:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche:\n case Chain.Ethereum: {\n const provider = getProvider(chain);\n const signer = new KeepKeySigner({\n sdk,\n chain,\n derivationPath,\n provider,\n });\n const address = await signer.getAddress();\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n return { address, ...toolbox };\n }\n case Chain.Cosmos: {\n return cosmosWalletMethods({ sdk, derivationPath });\n }\n case Chain.THORChain: {\n return thorchainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Maya: {\n return mayachainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n return utxoWalletMethods({\n sdk,\n chain,\n derivationPath,\n });\n }\n default:\n throw new Error(`Chain not supported ${chain}`);\n }\n}\n\n// kk-sdk docs: https://medium.com/@highlander_35968/building-on-the-keepkey-sdk-2023fda41f38\n// test spec: if offline, launch keepkey-bridge\nasync function checkAndLaunch(attempts = 0) {\n if (attempts >= 3) {\n alert(\n \"KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started\",\n );\n }\n const isAvailable = await checkKeepkeyAvailability();\n\n if (!isAvailable) {\n window.location.assign(\"keepkey://launch\");\n await new Promise((resolve) => setTimeout(resolve, 30000));\n checkAndLaunch(attempts + 1);\n }\n}\n\nasync function checkKeepkeyAvailability(spec = \"http://localhost:1646/spec/swagger.json\") {\n try {\n const response = await fetch(spec);\n return response.status === 200;\n } catch (error) {\n console.error(error);\n return false;\n }\n}\n",
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 { TransferParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\nexport const cosmosWalletMethods = async ({\n sdk,\n derivationPath,\n}: { sdk: KeepKeySdk; derivationPath?: DerivationPathArray }) => {\n const { DEFAULT_COSMOS_FEE_MAINNET, GaiaToolbox, createStargateClient } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\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 = GaiaToolbox();\n\n if (DEFAULT_COSMOS_FEE_MAINNET.amount[0]) {\n DEFAULT_COSMOS_FEE_MAINNET.amount[0].amount = String(\n await toolbox?.getFeeRateFromThorswap?.(ChainId.Cosmos, 500),\n );\n }\n\n // TODO support other cosmos assets\n const transfer = async ({ assetValue, recipient, memo }: TransferParams) => {\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",
5
+ "import {\n Chain,\n type DerivationPathArray,\n NetworkDerivationPath,\n SKConfig,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nexport type { PairingInfo } from \"@keepkey/keepkey-sdk\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport { cosmosWalletMethods } from \"./chains/cosmos\";\nimport { KeepKeySigner } from \"./chains/evm\";\nimport { mayachainWalletMethods } from \"./chains/mayachain\";\nimport { thorchainWalletMethods } from \"./chains/thorchain\";\nimport { utxoWalletMethods } from \"./chains/utxo\";\n\nexport const keepkeyWallet = createWallet({\n name: \"connectKeepkey\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Ethereum,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Maya,\n ],\n walletType: WalletOption.KEEPKEY,\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeepkey(\n chains: Chain[],\n derivationPathMap?: Record<Chain, DerivationPathArray>,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const config = SKConfig.get(\"integrations\").keepKey;\n\n if (!config) throw new Error(\"KeepKey config not found\");\n\n await checkAndLaunch();\n\n const keepkeyConfig = { ...config, apiKey: SKConfig.get(\"apiKeys\").keepKey };\n const keepKeySdk = await KeepKeySdk.create(keepkeyConfig);\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({\n chain,\n derivationPath: derivationPathMap?.[chain] || NetworkDerivationPath[chain],\n sdk: keepKeySdk,\n });\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType: WalletOption.KEEPKEY });\n }),\n );\n return true;\n },\n});\n\nexport const KEEPKEY_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyWallet);\n\nasync function getWalletMethods({\n sdk,\n chain,\n derivationPath,\n}: { sdk: KeepKeySdk; chain: Chain; derivationPath?: DerivationPathArray }) {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n switch (chain) {\n case Chain.BinanceSmartChain:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche:\n case Chain.Ethereum: {\n const provider = await getProvider(chain);\n const signer = new KeepKeySigner({ sdk, chain, derivationPath, provider });\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return toolbox;\n }\n case Chain.Cosmos: {\n return cosmosWalletMethods({ sdk, derivationPath });\n }\n case Chain.THORChain: {\n return thorchainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Maya: {\n return mayachainWalletMethods({ sdk, derivationPath });\n }\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n return utxoWalletMethods({ sdk, chain, derivationPath });\n }\n default:\n throw new Error(`Chain not supported ${chain}`);\n }\n}\n\n// kk-sdk docs: https://medium.com/@highlander_35968/building-on-the-keepkey-sdk-2023fda41f38\n// test spec: if offline, launch keepkey-bridge\nasync function checkAndLaunch(attempts = 0) {\n if (attempts >= 3) {\n alert(\n \"KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started\",\n );\n }\n const isAvailable = await checkKeepkeyAvailability();\n\n if (!isAvailable) {\n window.location.assign(\"keepkey://launch\");\n await new Promise((resolve) => setTimeout(resolve, 30000));\n checkAndLaunch(attempts + 1);\n }\n}\n\nasync function checkKeepkeyAvailability(spec = \"http://localhost:1646/spec/swagger.json\") {\n try {\n const response = await fetch(spec);\n return response.status === 200;\n } catch (error) {\n console.error(error);\n return false;\n }\n}\n",
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 SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { DepositParam, TransferParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n from: 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, getToolboxByChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = getToolboxByChain(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 ({ assetValue, recipient, from, memo }: SignTransactionParams) => {\n const { makeSignDoc } = await import(\"@cosmjs/amino\");\n const { getDenomWithChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const account = await toolbox.getAccount(from);\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: from,\n to_address: recipient,\n },\n }\n : {\n type: \"mayachain/MsgDeposit\",\n value: {\n coins: [{ amount, asset: getDenomWithChain(assetValue) }],\n memo,\n signer: from,\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 signedTx = isTransfer\n ? await sdk.mayachain.mayachainSignAminoTransfer({\n // TODO can we ignore this ?\n // @ts-expect-error readonly cant be assigned to writable\n signDoc,\n signerAddress: from,\n })\n : await sdk.mayachain.mayachainSignAminoDeposit({\n // @ts-expect-error\n signDoc,\n signerAddress: from,\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 }: TransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n from: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: DepositParam) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.Maya]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n from: 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 SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { DepositParam, TransferParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n from: 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, ThorchainToolbox } =\n await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = ThorchainToolbox();\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 ({ assetValue, recipient, from, memo }: SignTransactionParams) => {\n const account = await toolbox.getAccount(from);\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({ chain: Chain.THORChain, from, 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: from,\n })\n : await sdk.thorchain.thorchainSignAminoDeposit({\n signDoc: signDoc as TypesThorchainSignDocDeposit,\n signerAddress: from,\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 }: TransferParams) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n recipient,\n memo,\n from: fromAddress,\n });\n const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);\n\n return transactionHash;\n };\n\n const deposit = async ({ assetValue, memo }: DepositParam) => {\n const stargateClient = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const signedTransaction = await signTransaction({\n assetValue,\n memo,\n from: 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
- "import {\n Chain,\n DerivationPath,\n type DerivationPathArray,\n FeeOption,\n type UTXOChain,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { BCHToolbox, Psbt, UTXOToolbox, UTXOTransferParams } from \"@swapkit/toolboxes/utxo\";\n\nimport { ChainToKeepKeyName, bip32ToAddressNList } from \"../coins\";\n\ntype KKUtxoWalletParams = {\n sdk: any;\n chain: UTXOChain;\n derivationPath?: DerivationPathArray;\n};\n\ninterface psbtTxOutput {\n address: string;\n script: Buffer;\n value: number;\n change?: boolean; // Optional, assuming it indicates if the output is a change\n}\ninterface ExtendedPsbt extends Psbt {\n txOutputs: psbtTxOutput[];\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}: KKUtxoWalletParams): Promise<\n UTXOToolbox & {\n address: string;\n signTransaction: (\n psbt: ExtendedPsbt,\n inputs: KeepKeyInputObject[],\n memo?: string,\n ) => Promise<string>;\n transfer: (params: UTXOTransferParams) => Promise<string>;\n }\n> => {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/utxo\");\n\n const toolbox = getToolboxByChain(chain)();\n const scriptType = [Chain.Bitcoin, Chain.Litecoin].includes(chain) ? \"p2wpkh\" : \"p2pkh\";\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 { address: walletAddress } = await sdk.address.utxoGetAddress(addressInfo);\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 psbtTxOutput;\n\n const outputAddress =\n chain === Chain.BitcoinCash\n ? (toolbox as ReturnType<typeof BCHToolbox>).stripToCashAddress(address)\n : 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 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 version: 1,\n locktime: 0,\n opReturnData: memo,\n });\n return responseSign.serializedTx;\n };\n\n const transfer = async ({\n from,\n recipient,\n feeOptionKey,\n feeRate,\n memo,\n ...rest\n }: UTXOTransferParams) => {\n if (!from) throw new Error(\"From address must be provided\");\n if (!recipient) throw new Error(\"Recipient address must be provided\");\n\n const { psbt, inputs: rawInputs } = await toolbox.buildTx({\n ...rest,\n memo,\n recipient,\n feeRate: feeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast],\n sender: from,\n fetchTxHex: chain === Chain.BitcoinCash,\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 scriptType,\n amount: value.toString(),\n vout: index,\n txid: hash,\n hex: txHex || \"\",\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"
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",
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": "2CA5ACE6D0A1425A64756E2164756E21",
13
+ "mappings": "iGAAA,cACE,2BAEA,eACA,kBACA,kBACA,4BACA,0BAGF,qBAAS,8BCTT,gBACE,aACA,oBACA,cAEA,4BACA,yBCDK,IAAK,GAAL,CAAK,IAAL,CACL,MAAM,UACN,MAAM,cACN,OAAO,WACP,MAAM,WACN,OAAO,SALG,QAYL,SAAS,CAAS,CAAC,EAAc,CACtC,GAAI,IAAS,KAAM,MAAO,GAE1B,MAAO,6DAA6D,KAAK,CAAI,EAIxE,SAAS,CAAmB,CAAC,EAA4B,CAC9D,IAAI,EAAO,EAEX,IAAK,EAAU,CAAI,EACjB,MAAM,IAAI,MAAM,sBAAsB,IAAO,EAG/C,GAAI,QAAQ,KAAK,CAAI,EACnB,EAAO,EAAK,MAAM,CAAC,EAErB,IAAM,EAAW,EAAK,MAAM,GAAG,EAE/B,GAAI,EAAS,SAAW,GAAK,EAAS,KAAO,GAAI,MAAO,CAAC,EAEzD,IAAM,EAAM,IAAI,MAAM,EAAS,MAAM,EAErC,QAAS,EAAI,EAAG,EAAI,EAAS,OAAQ,IAAK,CAExC,IAAM,EAAU,EAAS,GACzB,GAAI,EAAS,CACX,IAAM,EAAM,gBAAgB,KAAK,CAAO,EACxC,GAAI,IAAQ,KAAM,MAAM,IAAI,MAAM,eAAe,EAEjD,KAAS,EAAM,GAAI,EAAW,IAAM,EAIpC,GAFA,EAAI,GAAK,OAAO,SAAS,EAAK,EAAE,EAE5B,EAAI,IAhDG,WAgDa,MAAM,IAAI,MAAM,qBAAqB,EAE7D,GAAI,IAAa,KAAO,IAAa,KAAO,IAAa,IACvD,EAAI,IAnDK,WAoDJ,QAAI,EAAS,OAAS,EAC3B,MAAM,IAAI,MAAM,kBAAkB,GAKxC,OAAO,EDjDF,IAAM,EAAsB,OACjC,MACA,oBAC+D,CAC/D,IACE,6BACA,mBACA,yBACA,wBACE,KAAa,qCAEjB,GAAI,CACF,IAAM,EAAuB,EACzB,EAAuB,CAAc,EACrC,GAAG,EAAe,UAEd,QAAS,GAAiB,MAAM,EAAI,QAAQ,iBAAiB,CACnE,UAAW,EAAoB,CAAoB,CACrD,CAAC,EAEK,EAAU,MAAM,EAAiB,EAAM,MAAM,EAEnD,GAAI,EAA2B,OAAO,GACpC,EAA2B,OAAO,GAAG,OAAS,OAC5C,MAAM,EAAuB,EAAQ,OAAQ,GAAG,CAClD,EAwCF,MAAO,IAAK,EAAS,SApCJ,OAAS,aAAY,YAAW,UAAkC,CACjF,IAAM,EAAS,EAAW,aAAa,QAAQ,EACzC,EAAc,MAAM,EAAQ,WAAW,CAAW,EAElD,EAAkB,MAAM,EAAI,OAAO,gBAAgB,CACvD,cAAe,EACf,QAAS,CACP,IAAK,EACL,KAAM,GAAQ,GACd,SAAU,GAAa,SAAS,SAAS,GAAK,GAC9C,SAAU,EAAQ,OAClB,eAAgB,GAAa,cAAc,SAAS,GAAK,GACzD,KAAM,CACJ,CACE,MAAO,CACL,OAAQ,CAAC,CAAE,MAAO,QAAS,QAAO,CAAC,EACnC,WAAY,EACZ,aAAc,CAChB,EACA,KAAM,oBACR,CACF,CACF,CACF,CAAC,EAEK,EAAe,KAAK,EAAgB,UAAU,EAC9C,EAAa,IAAI,WAAW,EAAa,MAAM,EAAE,IAAI,CAAC,EAAG,IAC7D,EAAa,WAAW,CAAC,CAC3B,EAKA,OAFiB,MADF,MAAM,EAAqB,EAAS,IAAI,SAAS,EAAE,EAAM,OAAO,GACjD,YAAY,CAAU,GAEpC,iBAGa,QAAS,CAAY,EACpD,MAAO,EAAG,CAEV,MADA,QAAQ,MAAM,CAAC,EACT,IEhFV,yBAEE,2BAEA,6BACA,0BAGF,yBAAS,gBAWF,MAAM,UAAsB,EAAe,CACxC,IACA,MACA,eACA,QACC,SAET,WAAW,EAAG,MAAK,QAAO,iBAAgB,YAAoC,CAC5E,MAAM,EACN,KAAK,IAAM,EACX,KAAK,MAAQ,EACb,KAAK,eAAiB,GAAkB,GAAsB,IAC9D,KAAK,QAAU,GACf,KAAK,SAAW,EAGlB,aAAa,EAAoB,CAC/B,MAAM,IAAI,MAAM,gCAAgC,EAGlD,WAAa,SAAY,CACvB,GAAI,KAAK,QAAS,OAAO,KAAK,QAC9B,IAAQ,WAAY,MAAM,KAAK,IAAI,QAAQ,mBAAmB,CAC5D,UAAW,EAAoB,GAAuB,KAAK,cAAc,CAAC,CAC5E,CAAC,EAGD,OADA,KAAK,QAAU,EACR,GAGT,YAAc,CAAC,IACb,KAAK,IAAI,IAAI,QAAQ,CAAE,QAAS,KAAK,QAAS,SAAQ,CAAC,EAEzD,gBAAkB,OAChB,KACA,QACA,WACA,QACA,OACA,eACA,uBACA,cAEwB,CACxB,IAAK,EAAI,MAAM,IAAI,MAAM,oBAAoB,EAC7C,IAAK,EAAU,MAAM,IAAI,MAAM,kBAAkB,EACjD,IAAK,EAAM,MAAM,IAAI,MAAM,cAAc,EAEzC,IAAM,MAAgB,GAAgB,KAA0B,GAChE,GAAI,IAAc,EAAc,MAAM,IAAI,MAAM,sBAAsB,EACtE,GAAI,IAAc,EAAsB,MAAM,IAAI,MAAM,sBAAsB,EAC9E,KAAM,GAAa,GAAW,MAAM,IAAI,MAAM,kBAAkB,EAEhE,IAAQ,eAAgB,KAAa,kCAE/B,EAAa,EACf,OAAO,CAAK,EACZ,OAAO,MAAM,KAAK,SAAS,oBAAoB,MAAM,KAAK,WAAW,EAAG,SAAS,CAAC,EAEhF,EAAQ,CACZ,IAAK,EAAY,OAAO,CAAQ,CAAC,EACjC,aAAc,CAAC,WAAY,WAAY,WAAY,EAAG,CAAC,EACvD,KAAM,KAAK,QACX,QAAS,EAAY,OAAO,EAAe,KAAK,MAAM,CAAC,EACvD,GAAI,EAAG,SAAS,EAChB,MAAO,EAAY,OAAO,GAAS,CAAC,CAAC,EACrC,MAAO,EAAY,CAAU,EAC7B,UACI,GAAa,CACf,aAAc,EAAY,OAAO,GAAc,SAAS,GAAK,GAAG,CAAC,EACjE,qBAAsB,EAAY,OAAO,GAAsB,SAAS,GAAK,GAAG,CAAC,CACnF,MACK,GAAa,CAEhB,SAAU,EAAY,OAAO,GAAU,SAAS,GAAK,GAAG,CAAC,CAC3D,CACF,EAEA,OADqB,MAAM,KAAK,IAAI,IAAI,mBAAmB,CAAK,GAC5C,YAGtB,gBAAkB,MAAO,IAAyC,CAChE,IAAK,KAAK,SAAU,MAAM,IAAI,MAAM,iBAAiB,EAErD,IAAM,EAAc,MAAM,KAAK,gBAAgB,CAAE,EAEjD,OAAO,MAAM,KAAK,SAAS,qBAAqB,CAAW,GAG7D,QAAU,CAAC,IACT,IAAI,EAAc,CAChB,IAAK,KAAK,IACV,MAAO,KAAK,MACZ,eAAgB,KAAK,eACrB,UACF,CAAC,CACL,CCnHA,gBAEE,aACA,qBACA,eAGA,4BACA,0BAaK,IAAM,EAAyB,OACpC,MACA,oBAII,CACJ,IAAQ,uBAAsB,oBAAqB,KAAa,qCAE1D,EAAU,MAAM,EAAiB,EAAM,IAAI,EAC3C,EAAuB,EACzB,GAAuB,CAAc,EACrC,GAAG,GAAe,UAEd,QAAS,GAAiB,MAAM,EAAI,QAAQ,oBAAoB,CACtE,UAAW,EAAoB,CAAoB,CACrD,CAAC,EAEK,EAAkB,OACtB,aACA,YACA,SACA,UAC2B,CAC3B,IAAQ,eAAgB,KAAa,0BAC7B,qBAAsB,KAAa,qCAErC,EAAU,MAAM,EAAQ,WAAW,CAAM,EAC/C,IAAK,EAAS,MAAM,IAAI,MAAM,mBAAmB,EACjD,IAAQ,gBAAe,WAAW,GAAM,EAClC,EAAS,EAAW,aAAa,QAAQ,EAEzC,EAAa,GAAa,IAAc,GAGxC,EAAM,EACR,CACE,KAAM,oBACN,MAAO,CACL,OAAQ,CAAC,CAAE,SAAQ,MAAO,EAAW,OAAO,YAAY,CAAE,CAAC,EAC3D,aAAc,EACd,WAAY,CACd,CACF,EACA,CACE,KAAM,uBACN,MAAO,CACL,MAAO,CAAC,CAAE,SAAQ,MAAO,EAAkB,CAAU,CAAE,CAAC,EACxD,OACA,OAAQ,CACV,CACF,EAEE,EAAU,EACd,CAAC,CAAG,EACJ,CAAE,IAAK,YAAa,OAAQ,CAAC,CAAE,EAC/B,GAAQ,KACR,EACA,GAAe,SAAS,EACxB,CACF,EAOM,EAAW,MALC,EACd,EAAI,UAAU,2BACd,EAAI,UAAU,2BAGe,CAAE,UAAS,cAAe,CAAO,CAAC,EAC7D,EAAe,KAAK,EAAS,UAAU,EAC7C,OAAO,IAAI,WAAW,EAAa,MAAM,EAAE,IAAI,CAAC,EAAG,IAAM,EAAa,WAAW,CAAC,CAAC,GA4BrF,MAAO,IAAK,EAAS,SAzBJ,OAAS,aAAY,YAAW,UAAkC,CACjF,IAAM,EAAiB,MAAM,EAAqB,EAAS,IAAI,SAAS,EAAE,EAAM,KAAK,EAC/E,EAAoB,MAAM,EAAgB,CAC9C,aACA,YACA,OACA,OAAQ,CACV,CAAC,GACO,mBAAoB,MAAM,EAAe,YAAY,CAAiB,EAE9E,OAAO,GAesB,QAZf,OAAS,aAAY,UAAmC,CACtE,IAAM,EAAiB,MAAM,EAAqB,EAAS,IAAI,SAAS,EAAE,EAAM,KAAK,EAC/E,EAAoB,MAAM,EAAgB,CAC9C,aACA,OACA,OAAQ,CACV,CAAC,GACO,mBAAoB,MAAM,EAAe,YAAY,CAAiB,EAE9E,OAAO,GAG+B,QAAS,CAAY,GClH/D,gBAEE,aACA,qBACA,eAGA,4BACA,0BAaK,IAAM,EAAyB,OACpC,MACA,oBAII,CACJ,IAAQ,eAAgB,KAAa,0BAC7B,gBAAe,qBAAoB,uBAAsB,oBAC/D,KAAa,qCAET,EAAU,MAAM,EAAiB,EAAM,SAAS,EAChD,EAAuB,EACzB,GAAuB,CAAc,EACrC,GAAG,GAAe,UAEd,QAAS,GAAiB,MAAM,EAAI,QAAQ,oBAAoB,CACtE,UAAW,EAAoB,CAAoB,CACrD,CAAC,EAEK,EAAkB,OACtB,aACA,YACA,SACA,UAC2B,CAC3B,IAAM,EAAU,MAAM,EAAQ,WAAW,CAAM,EAC/C,IAAK,EAAS,MAAM,IAAI,MAAM,mBAAmB,EACjD,IAAQ,gBAAe,WAAW,GAAM,EAElC,EAAa,GAAa,IAAc,GAExC,EAAM,EAAc,CAAE,SAAQ,YAAW,aAAY,MAAK,CAAC,EAE3D,EAAU,GAAQ,UAElB,EAAU,EACd,CAAC,CAAG,EACJ,EAAmB,EAAM,SAAS,EAClC,EACA,EACA,GAAe,SAAS,EACxB,CACF,EAEM,EAAW,EACb,MAAM,EAAI,UAAU,2BAA2B,CAC7C,QAAS,EACT,cAAe,CACjB,CAAC,EACD,MAAM,EAAI,UAAU,0BAA0B,CAC5C,QAAS,EACT,cAAe,CACjB,CAAC,EACC,EAAe,KAAK,EAAS,UAAU,EAC7C,OAAO,IAAI,WAAW,EAAa,MAAM,EAAE,IAAI,CAAC,EAAG,IAAM,EAAa,WAAW,CAAC,CAAC,GAiCrF,MAAO,IAAK,EAAS,SA9BJ,OAAS,aAAY,YAAW,UAAkC,CACjF,IAAM,EAAiB,MAAM,EAAqB,EAAS,IAAI,SAAS,EAAE,EAAM,UAAU,EACpF,EAAoB,MAAM,EAAgB,CAC9C,aACA,YACA,OACA,OAAQ,CACV,CAAC,GACO,mBAAoB,MAAM,EAAe,YAAY,CAAiB,EAE9E,OAAO,GAoBsB,QAjBf,OAAS,aAAY,UAAmC,CACtE,IAAM,EAAiB,MAAM,EAAqB,EAAS,IAAI,SAAS,EAAE,EAAM,UAAU,EACpF,EAAoB,MAAM,EAAgB,CAC9C,aACA,OACA,OAAQ,CACV,CAAC,GACO,mBAAoB,MAAM,EAAe,YAAY,CAAiB,EAE9E,OAAO,GAQ+B,QAAS,CAAY,GCjH/D,gBACE,oBACA,gBAEA,6BAGA,0BAgBK,IAAM,EAAoB,OAC/B,MACA,QACA,oBACiF,CACjF,IAAQ,kBAAmB,KAAa,mCAElC,EAAU,MAAM,EAAe,CAAK,EACpC,EAAa,CAAC,EAAM,QAAS,EAAM,QAAQ,EAAE,SAAS,CAAK,EAC5D,SACA,QAEC,EAAuB,EACzB,GAAuB,CAAc,EACrC,GAAG,GAAe,OAEhB,EAAc,CAClB,KAAM,EAAmB,GACzB,YAAa,EACb,UAAW,EAAoB,CAAoB,CACrD,EAEM,GAAyB,MAAM,EAAI,QAAQ,eAAe,CAAW,GAAG,QAExE,EAAkB,MAAO,EAAY,EAA8B,EAAO,KAAO,CACrF,IAAM,EAAU,EAAK,UAClB,IAAI,CAAC,IAAW,CACf,IAAQ,QAAO,UAAS,UAAW,EAO7B,EAEJ,IAAU,EAAM,YAAc,EAAQ,mBAAmB,CAAO,EAAI,EAEtE,GAAI,GAAU,IAAY,EACxB,MAAO,CACL,aAAc,EAAY,UAC1B,SAAU,GACV,YAAa,SACb,OAAQ,EACR,YACF,EAGF,GAAI,EACF,MAAO,CAAE,QAAS,EAAe,OAAQ,EAAO,YAAa,OAAQ,EAGvE,OAAO,KACR,EACA,OAAO,OAAO,EAEX,EAAqC,CAAC,IAAe,CACzD,OAAO,EAAI,OACT,CAAC,IAAS,IAAS,MAAQ,OAAO,IAAS,UAAY,OAAO,KAAK,CAAI,EAAE,OAAS,CACpF,GAUF,OAPqB,MAAM,EAAI,KAAK,oBAAoB,CACtD,KAAM,EAAmB,GACzB,SACA,QAAS,EAAmC,CAAO,EACnD,aAAc,CAChB,CAAC,GAEmB,cAAc,SAAS,GAyC7C,MAAO,IAAK,EAAS,kBAAiB,SAtCrB,OACf,YACA,eACA,UACA,UACG,KACwB,CAC3B,IAAK,EAAe,MAAM,IAAI,MAAM,+BAA+B,EACnE,IAAK,EAAW,MAAM,IAAI,MAAM,oCAAoC,EAEpE,IAAM,EACJ,IAAU,EAAM,YACX,EAAiC,QACjC,EAAiC,mBAEhC,OAAM,OAAQ,GAAc,MAAM,EAAe,IACpD,EACH,OACA,YACA,QAAS,IAAY,MAAM,EAAQ,YAAY,GAAG,GAAgB,GAAU,MAC5E,OAAQ,EACR,WAAY,EACd,CAAC,EAEK,EAAS,EAAU,IAAI,EAAG,QAAO,QAAO,OAAM,YAAa,CAE/D,aAAc,EAAY,UAC1B,OAAQ,EAAM,SAAS,EACvB,IAAK,GAAS,GACd,aACA,KAAM,EACN,KAAM,CACR,EAAE,EAEI,EAAQ,MAAM,EAAgB,EAAM,EAAQ,CAAI,EACtD,OAAO,EAAQ,YAAY,CAAK,GAGc,QAAS,CAAc,GNlHlE,IAAM,GAAgB,GAAa,CACxC,KAAM,iBACN,gBAAiB,CACf,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,QACN,EAAM,YACN,EAAM,OACN,EAAM,SACN,EAAM,KACN,EAAM,SACN,EAAM,SACN,EAAM,SACN,EAAM,QACN,EAAM,UACN,EAAM,IACR,EACA,WAAY,EAAa,QACzB,QAAS,EAAG,WAAU,kBAAiB,gBACrC,eAAe,CAAc,CAC3B,EACA,EACA,CACA,IAAM,EAAiB,GAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAC9E,EAAS,EAAS,IAAI,cAAc,EAAE,QAE5C,IAAK,EAAQ,MAAM,IAAI,MAAM,0BAA0B,EAEvD,MAAM,EAAe,EAErB,IAAM,EAAgB,IAAK,EAAQ,OAAQ,EAAS,IAAI,SAAS,EAAE,OAAQ,EACrE,EAAa,MAAM,GAAW,OAAO,CAAa,EAcxD,OAZA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,GAAiB,CAC3C,QACA,eAAgB,IAAoB,IAAU,GAAsB,GACpE,IAAK,CACP,CAAC,EACK,EAAW,MAAM,EAAc,WAAW,GAAM,GAEtD,EAAS,IAAK,EAAe,UAAS,QAAO,WAAY,EAAa,OAAQ,CAAC,EAChF,CACH,EACO,GAEb,CAAC,EAEY,GAA2B,EAAyB,EAAa,EAE9E,eAAe,EAAgB,EAC7B,MACA,QACA,kBAC0E,CAC1E,IAAQ,cAAa,iBAAkB,KAAa,kCAEpD,OAAQ,QACD,EAAM,uBACN,EAAM,cACN,EAAM,cACN,EAAM,aACN,EAAM,eACN,EAAM,SAAU,CACnB,IAAM,EAAW,MAAM,EAAY,CAAK,EAClC,EAAS,IAAI,EAAc,CAAE,MAAK,QAAO,iBAAgB,UAAS,CAAC,EAGzE,OAFgB,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,CAGjE,MACK,EAAM,OACT,OAAO,EAAoB,CAAE,MAAK,gBAAe,CAAC,OAE/C,EAAM,UACT,OAAO,EAAuB,CAAE,MAAK,gBAAe,CAAC,OAElD,EAAM,KACT,OAAO,EAAuB,CAAE,MAAK,gBAAe,CAAC,OAElD,EAAM,aACN,EAAM,iBACN,EAAM,UACN,EAAM,cACN,EAAM,SACT,OAAO,EAAkB,CAAE,MAAK,QAAO,gBAAe,CAAC,UAGvD,MAAM,IAAI,MAAM,uBAAuB,GAAO,GAMpD,eAAe,CAAc,CAAC,EAAW,EAAG,CAC1C,GAAI,GAAY,EACd,MACE,2FACF,EAIF,IAFoB,MAAM,GAAyB,EAGjD,OAAO,SAAS,OAAO,kBAAkB,EACzC,MAAM,IAAI,QAAQ,CAAC,IAAY,WAAW,EAAS,KAAK,CAAC,EACzD,EAAe,EAAW,CAAC,EAI/B,eAAe,EAAwB,CAAC,EAAO,0CAA2C,CACxF,GAAI,CAEF,OADiB,MAAM,MAAM,CAAI,GACjB,SAAW,IAC3B,MAAO,EAAO,CAEd,OADA,QAAQ,MAAM,CAAK,EACZ",
14
+ "debugId": "ED8287149CCB327064756E2164756E21",
15
15
  "names": []
16
16
  }