@swapkit/wallets 3.0.0-beta.25 → 3.0.0-beta.27

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 (38) hide show
  1. package/dist/src/bitget/index.js +1 -1
  2. package/dist/src/coinbase/index.js +1 -1
  3. package/dist/src/ctrl/index.js +1 -1
  4. package/dist/src/evm-extensions/index.js +1 -1
  5. package/dist/src/exodus/index.js +1 -1
  6. package/dist/src/index.js +1 -1
  7. package/dist/src/keepkey/index.cjs +2 -2
  8. package/dist/src/keepkey/index.cjs.map +5 -5
  9. package/dist/src/keepkey/index.js +2 -2
  10. package/dist/src/keepkey/index.js.map +5 -5
  11. package/dist/src/keepkey-bex/index.js +1 -1
  12. package/dist/src/keystore/index.js +1 -1
  13. package/dist/src/ledger/index.cjs +3 -3
  14. package/dist/src/ledger/index.cjs.map +4 -4
  15. package/dist/src/ledger/index.js +3 -3
  16. package/dist/src/ledger/index.js.map +4 -4
  17. package/dist/src/okx/index.js +1 -1
  18. package/dist/src/onekey/index.js +1 -1
  19. package/dist/src/phantom/index.js +1 -1
  20. package/dist/src/polkadotjs/index.js +1 -1
  21. package/dist/src/radix/index.js +1 -1
  22. package/dist/src/talisman/index.js +1 -1
  23. package/dist/src/trezor/index.js +1 -1
  24. package/dist/src/walletconnect/index.cjs +2 -2
  25. package/dist/src/walletconnect/index.cjs.map +3 -3
  26. package/dist/src/walletconnect/index.js +2 -2
  27. package/dist/src/walletconnect/index.js.map +3 -3
  28. package/package.json +3 -3
  29. package/src/keepkey/chains/mayachain.ts +1 -1
  30. package/src/keepkey/chains/thorchain.ts +1 -1
  31. package/src/keepkey/chains/utxo.ts +5 -1
  32. package/src/ledger/clients/cosmos.ts +2 -2
  33. package/src/ledger/index.ts +1 -1
  34. package/src/walletconnect/index.ts +2 -2
  35. /package/dist/{chunk-zfnkndsr.js → chunk-46yzxdmt.js} +0 -0
  36. /package/dist/{chunk-zfnkndsr.js.map → chunk-46yzxdmt.js.map} +0 -0
  37. /package/dist/{chunk-ad832c7c.js → chunk-esmvsmjp.js} +0 -0
  38. /package/dist/{chunk-ad832c7c.js.map → chunk-esmvsmjp.js.map} +0 -0
@@ -1,3 +1,3 @@
1
- import{A as h}from"../../chunk-zfnkndsr.js";import{C as w,D as p}from"../../chunk-qwd1kp32.js";import{Chain as m,EVMChains as P,WalletOption as v,createWallet as k,filterSupportedChains as y}from"@swapkit/helpers";import{Chain as n,ChainId as u,SwapKitError as c,prepareNetworkSwitch as _,switchEVMWalletNetwork as b}from"@swapkit/helpers";import{Psbt as C}from"bitcoinjs-lib";async function g(i){let t=window.bitkeep;switch(i){case n.Ethereum:case n.Base:case n.Avalanche:case n.Arbitrum:case n.Optimism:case n.Polygon:case n.BinanceSmartChain:{if(!(t&&("ethereum"in t)))throw new c("wallet_bitkeep_not_found");let o=t.ethereum,[a]=await o.send("eth_requestAccounts",[]);return{...await x({chain:i,walletProvider:o}),address:a}}case n.Bitcoin:{if(!(t&&("unisat"in t)))throw new c("wallet_bitkeep_not_found");let{unisat:o}=t,{getUtxoToolbox:a}=await import("@swapkit/toolboxes/utxo"),[e]=await o.requestAccounts();async function r(d){let f=await o.signPsbt(d.toHex(),{autoFinalized:!1});return C.fromHex(f)}let s={getAddress:()=>Promise.resolve(e),signTransaction:r};return{...await a(n.Bitcoin,{signer:s}),address:e}}case n.Cosmos:{if(!(t&&("keplr"in t)))throw new c("wallet_bitkeep_not_found");let{keplr:o}=t;await o.enable(u.Cosmos);let a=o.getOfflineSignerOnlyAmino(u.Cosmos),e=await a.getAccounts();if(!e?.[0])throw new c("wallet_bitkeep_no_accounts",{chain:n.Cosmos});let{getCosmosToolbox:r}=await import("@swapkit/toolboxes/cosmos"),[{address:s}]=e,l={...a,getAddress:()=>Promise.resolve(s),signTransaction:async()=>Promise.resolve({})};return{...r(n.Cosmos,{signer:l}),address:s}}case n.Solana:{if(!(t&&("solana"in t)))throw new c("wallet_bitkeep_not_found");let{getSolanaToolbox:o}=await import("@swapkit/toolboxes/solana"),a=t?.solana,e=o({signer:a}),s=(await a.connect()).publicKey.toString();return{...e,address:s}}default:throw new c("wallet_chain_not_supported")}}var x=async({chain:i,walletProvider:t})=>{let{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:a}=await import("ethers");if(!t)throw new c("wallet_provider_not_found");let e=new a(t,"any"),r=await e.getSigner(),s=await o(i,{provider:e,signer:r});try{if(i!==n.Ethereum&&"getNetworkParams"in s)await b(e,i,s.getNetworkParams())}catch(l){throw new c("wallet_bitkeep_failed_to_switch_network",{chain:i})}return _({chain:i,toolbox:s,provider:e})};var S=k({name:"connectBitget",walletType:v.BITGET,supportedChains:[...P,m.Cosmos,m.Bitcoin,m.Solana],connect:({addChain:i,walletType:t,supportedChains:o})=>async function a(e){let r=y({chains:e,supportedChains:o,walletType:t});return await Promise.all(r.map(async(s)=>{let l=await g(s),d=await l.getAddress()||"";i({...l,address:d,chain:s,walletType:t})})),!0}}),N=h(S);export{S as bitgetWallet,N as BITGET_SUPPORTED_CHAINS};
1
+ import{A as h}from"../../chunk-46yzxdmt.js";import{C as w,D as p}from"../../chunk-qwd1kp32.js";import{Chain as m,EVMChains as P,WalletOption as v,createWallet as k,filterSupportedChains as y}from"@swapkit/helpers";import{Chain as n,ChainId as u,SwapKitError as c,prepareNetworkSwitch as _,switchEVMWalletNetwork as b}from"@swapkit/helpers";import{Psbt as C}from"bitcoinjs-lib";async function g(i){let t=window.bitkeep;switch(i){case n.Ethereum:case n.Base:case n.Avalanche:case n.Arbitrum:case n.Optimism:case n.Polygon:case n.BinanceSmartChain:{if(!(t&&("ethereum"in t)))throw new c("wallet_bitkeep_not_found");let o=t.ethereum,[a]=await o.send("eth_requestAccounts",[]);return{...await x({chain:i,walletProvider:o}),address:a}}case n.Bitcoin:{if(!(t&&("unisat"in t)))throw new c("wallet_bitkeep_not_found");let{unisat:o}=t,{getUtxoToolbox:a}=await import("@swapkit/toolboxes/utxo"),[e]=await o.requestAccounts();async function r(d){let f=await o.signPsbt(d.toHex(),{autoFinalized:!1});return C.fromHex(f)}let s={getAddress:()=>Promise.resolve(e),signTransaction:r};return{...await a(n.Bitcoin,{signer:s}),address:e}}case n.Cosmos:{if(!(t&&("keplr"in t)))throw new c("wallet_bitkeep_not_found");let{keplr:o}=t;await o.enable(u.Cosmos);let a=o.getOfflineSignerOnlyAmino(u.Cosmos),e=await a.getAccounts();if(!e?.[0])throw new c("wallet_bitkeep_no_accounts",{chain:n.Cosmos});let{getCosmosToolbox:r}=await import("@swapkit/toolboxes/cosmos"),[{address:s}]=e,l={...a,getAddress:()=>Promise.resolve(s),signTransaction:async()=>Promise.resolve({})};return{...r(n.Cosmos,{signer:l}),address:s}}case n.Solana:{if(!(t&&("solana"in t)))throw new c("wallet_bitkeep_not_found");let{getSolanaToolbox:o}=await import("@swapkit/toolboxes/solana"),a=t?.solana,e=o({signer:a}),s=(await a.connect()).publicKey.toString();return{...e,address:s}}default:throw new c("wallet_chain_not_supported")}}var x=async({chain:i,walletProvider:t})=>{let{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:a}=await import("ethers");if(!t)throw new c("wallet_provider_not_found");let e=new a(t,"any"),r=await e.getSigner(),s=await o(i,{provider:e,signer:r});try{if(i!==n.Ethereum&&"getNetworkParams"in s)await b(e,i,s.getNetworkParams())}catch(l){throw new c("wallet_bitkeep_failed_to_switch_network",{chain:i})}return _({chain:i,toolbox:s,provider:e})};var S=k({name:"connectBitget",walletType:v.BITGET,supportedChains:[...P,m.Cosmos,m.Bitcoin,m.Solana],connect:({addChain:i,walletType:t,supportedChains:o})=>async function a(e){let r=y({chains:e,supportedChains:o,walletType:t});return await Promise.all(r.map(async(s)=>{let l=await g(s),d=await l.getAddress()||"";i({...l,address:d,chain:s,walletType:t})})),!0}}),N=h(S);export{S as bitgetWallet,N as BITGET_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=EA85396D0A49B08564756E2164756E21
@@ -1,3 +1,3 @@
1
- import{A as g}from"../../chunk-zfnkndsr.js";import{C as h,D as u}from"../../chunk-qwd1kp32.js";import{Chain as a,ChainToChainId as P,SKConfig as y,WalletOption as S,createWallet as v,filterSupportedChains as W}from"@swapkit/helpers";import{Chain as s,SwapKitError as m}from"@swapkit/helpers";async function b(t,o){let{AbstractSigner:i}=await import("ethers");class n extends i{#e;constructor(e,r){super(r);this.#e=e}async getAddress(){let e=await this.#e.request({method:"eth_requestAccounts"});if(!e[0])throw new m("wallet_coinbase_no_accounts");return e[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(e){return await this.#e.request({method:"personal_sign",params:[e,await this.getAddress()]})}signTypedData=()=>{throw new m("wallet_coinbase_method_not_supported",{method:"signTypedData"})};connect(e){return new n(this.#e,e)}}return new n(t,o)}var w=async({chain:t,coinbaseSdk:o})=>{switch(t){case s.Ethereum:case s.Avalanche:case s.Arbitrum:case s.Optimism:case s.Polygon:case s.BinanceSmartChain:{let i=o.getProvider(),{getEvmToolbox:n,getProvider:e}=await import("@swapkit/toolboxes/evm"),r=await e(t),c=await b(i,r),d=await n(t,{provider:r,signer:c}),p=await c.getAddress();return{...d,address:p}}default:throw new m("wallet_coinbase_chain_not_supported",{chain:t})}};var _=v({name:"connectCoinbaseWallet",walletType:S.COINBASE_MOBILE,supportedChains:[a.Arbitrum,a.Avalanche,a.Base,a.BinanceSmartChain,a.Ethereum,a.Optimism,a.Polygon],connect:({addChain:t,walletType:o,supportedChains:i})=>async function n(e){let{createCoinbaseWalletSDK:r}=await import("@coinbase/wallet-sdk"),c=W({chains:e,supportedChains:i,walletType:o}),d=y.get("integrations").coinbase||{appName:"Swapkit Playground"},p=r({...d,appChainIds:c.map((l)=>Number(P[l]))});return await Promise.all(c.map(async(l)=>{let C=await w({chain:l,coinbaseSdk:p});t({...C,chain:l,walletType:o})})),!0}}),O=g(_);export{_ as coinbaseWallet,O as COINBASE_SUPPORTED_CHAINS};
1
+ import{A as g}from"../../chunk-46yzxdmt.js";import{C as h,D as u}from"../../chunk-qwd1kp32.js";import{Chain as a,ChainToChainId as P,SKConfig as y,WalletOption as S,createWallet as v,filterSupportedChains as W}from"@swapkit/helpers";import{Chain as s,SwapKitError as m}from"@swapkit/helpers";async function b(t,o){let{AbstractSigner:i}=await import("ethers");class n extends i{#e;constructor(e,r){super(r);this.#e=e}async getAddress(){let e=await this.#e.request({method:"eth_requestAccounts"});if(!e[0])throw new m("wallet_coinbase_no_accounts");return e[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(e){return await this.#e.request({method:"personal_sign",params:[e,await this.getAddress()]})}signTypedData=()=>{throw new m("wallet_coinbase_method_not_supported",{method:"signTypedData"})};connect(e){return new n(this.#e,e)}}return new n(t,o)}var w=async({chain:t,coinbaseSdk:o})=>{switch(t){case s.Ethereum:case s.Avalanche:case s.Arbitrum:case s.Optimism:case s.Polygon:case s.BinanceSmartChain:{let i=o.getProvider(),{getEvmToolbox:n,getProvider:e}=await import("@swapkit/toolboxes/evm"),r=await e(t),c=await b(i,r),d=await n(t,{provider:r,signer:c}),p=await c.getAddress();return{...d,address:p}}default:throw new m("wallet_coinbase_chain_not_supported",{chain:t})}};var _=v({name:"connectCoinbaseWallet",walletType:S.COINBASE_MOBILE,supportedChains:[a.Arbitrum,a.Avalanche,a.Base,a.BinanceSmartChain,a.Ethereum,a.Optimism,a.Polygon],connect:({addChain:t,walletType:o,supportedChains:i})=>async function n(e){let{createCoinbaseWalletSDK:r}=await import("@coinbase/wallet-sdk"),c=W({chains:e,supportedChains:i,walletType:o}),d=y.get("integrations").coinbase||{appName:"Swapkit Playground"},p=r({...d,appChainIds:c.map((l)=>Number(P[l]))});return await Promise.all(c.map(async(l)=>{let C=await w({chain:l,coinbaseSdk:p});t({...C,chain:l,walletType:o})})),!0}}),O=g(_);export{_ as coinbaseWallet,O as COINBASE_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=18D577AF5E04806A64756E2164756E21
@@ -1,3 +1,3 @@
1
- import{A}from"../../chunk-zfnkndsr.js";import{C as G,D as H}from"../../chunk-qwd1kp32.js";import{Chain as J,ChainToChainId as w,SwapKitError as I,WalletOption as T,createWallet as v,filterSupportedChains as u}from"@swapkit/helpers";import{Chain as q,ChainToChainId as b,EVMChains as P,SwapKitError as _,WalletOption as E,providerRequest as f}from"@swapkit/helpers";import{erc20ABI as g}from"@swapkit/helpers/contracts";async function L(z){if(!window.xfi)throw new _("wallet_ctrl_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(q.Arbitrum,q.Avalanche,q.Base,q.BinanceSmartChain,q.Ethereum,q.Optimism,q.Polygon,()=>window.xfi?.ethereum).with(q.Cosmos,q.Kujira,()=>window.xfi?.keplr).with(q.Bitcoin,()=>window.xfi?.bitcoin).with(q.BitcoinCash,()=>window.xfi?.bitcoincash).with(q.Dogecoin,()=>window.xfi?.dogecoin).with(q.Litecoin,()=>window.xfi?.litecoin).with(q.Solana,()=>window.xfi?.solana).with(q.THORChain,()=>window.xfi?.thorchain).with(q.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function x({method:z,params:Z,chain:D}){let Q=await L(D);return new Promise(($,F)=>{if(Q&&"request"in Q)Q.request({method:z,params:Z},(X,Y)=>{X?F(X):$(Y)})})}async function V(z){try{let Z=await L(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});if([q.Cosmos,q.Kujira].includes(z)){let Q=await L(q.Cosmos);if(!Q||"request"in Q)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});let $=b[z];await Q.enable($);let F=Q.getOfflineSigner($),[X]=await F.getAccounts();return X?.address}if(P.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:Q}=await import("ethers"),$=new Q(Z,"any"),[F]=await f({provider:$,method:"eth_requestAccounts",params:[]});return F}if(z===q.Solana)return(await(await L(q.Solana)).connect()).publicKey.toString();if(z===q.Near){if(!window.xfi?.near)throw new _("wallet_ctrl_not_found",{chain:q.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}})}}async function O({assetValue:z,recipient:Z,memo:D,gasLimit:Q},$="transfer"){if(!z)throw new _("wallet_ctrl_asset_not_defined");let F=await V(z.chain),X=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},memo:D||"",from:F,recipient:Z,gasLimit:Q}];return x({method:$,params:X,chain:z.chain})}function S(z,Z){return{call:async({contractAddress:D,abi:Q,funcName:$,funcParams:F=[],txOverrides:X})=>{if(!D)throw new _("wallet_ctrl_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:y,isStateChangingCall:B}=await import("@swapkit/toolboxes/evm");if(B({abi:Q,funcName:$})){let j=y({provider:z,chain:Z}),{value:W,from:K,to:N,data:k}=await j({contractAddress:D,abi:Q,funcName:$,funcParams:F,txOverrides:X});return(await(await z.getSigner()).sendTransaction({value:BigInt(W||0),from:K,to:N,data:k||"0x"})).hash}let R=await Y(D,Q,z)[$]?.(...F);return typeof R?.hash==="string"?R?.hash:R},approve:async({assetAddress:D,spenderAddress:Q,amount:$,from:F})=>{let{MAX_APPROVAL:X,getCreateContractTxObject:Y}=await import("@swapkit/toolboxes/evm"),y=[Q,BigInt($||X)],U={contractAddress:D,abi:g,funcName:"approve",funcParams:y,txOverrides:{from:F}},M=Y({provider:z,chain:Z}),{value:R,to:j,data:W}=await M(U);return(await(await z.getSigner()).sendTransaction({value:BigInt(R||0),from:F,to:j,data:W||"0x"})).hash},sendTransaction:async(D)=>{let{from:Q,to:$,data:F,value:X}=D;if(!$)throw new _("wallet_ctrl_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({value:BigInt(X||0),from:Q,to:$,data:F||"0x"})).hash}}}var m=v({name:"connectCtrl",walletType:T.CTRL,supportedChains:[J.Arbitrum,J.Avalanche,J.Base,J.BinanceSmartChain,J.Bitcoin,J.BitcoinCash,J.Cosmos,J.Dogecoin,J.Ethereum,J.Kujira,J.Litecoin,J.Maya,J.Near,J.Optimism,J.Polygon,J.Solana,J.THORChain],connect:({addChain:z,walletType:Z,supportedChains:D})=>async function Q($){let X=u({chains:$,supportedChains:D,walletType:Z}).map(async(Y)=>{let y=await V(Y),B=await C(Y);z({...B,address:y,chain:Y,walletType:Z})});return await Promise.all(X),!0}}),t=A(m);async function C(z){switch(z){case J.Solana:{let{getSolanaToolbox:Z}=await import("@swapkit/toolboxes/solana"),D=window.xfi?.solana;if(!D)throw new I("wallet_ctrl_not_found");return{...Z({signer:D})}}case J.Maya:case J.THORChain:{let{getCosmosToolbox:Z,THORCHAIN_GAS_VALUE:D,MAYA_GAS_VALUE:Q}=await import("@swapkit/toolboxes/cosmos"),$=z===J.Maya?Q:D;return{...await Z(z),deposit:(X)=>O({...X,recipient:""},"deposit"),transfer:(X)=>O({...X,gasLimit:$},"transfer")}}case J.Cosmos:case J.Kujira:{let{getCosmosToolbox:Z}=await import("@swapkit/toolboxes/cosmos"),D=w[z],Q=await L(z);await Q?.enable(D);let $=Q?.getOfflineSignerOnlyAmino(D);if(!$)throw new I("wallet_ctrl_not_found");return Z(z,{signer:$})}case J.Bitcoin:case J.BitcoinCash:case J.Dogecoin:case J.Litecoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo");return{...await Z(z),transfer:O}}case J.Arbitrum:case J.Avalanche:case J.Base:case J.BinanceSmartChain:case J.Ethereum:case J.Optimism:case J.Polygon:{let{prepareNetworkSwitch:Z,switchEVMWalletNetwork:D}=await import("@swapkit/helpers"),{getEvmToolbox:Q}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:$}=await import("ethers"),F=await L(z);if(!F)throw new I("wallet_ctrl_not_found");let X=new $(F,"any"),Y=await X.getSigner(),y=await Q(z,{provider:X,signer:Y}),B=S(X,z);try{if(z!==J.Ethereum){let U=y.getNetworkParams();await D(X,z,U)}}catch(U){throw new I({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:T.CTRL,chain:z}})}return Z({provider:window.xfi?.ethereum,chain:z,toolbox:{...y,...B}})}case J.Near:{if(!window.xfi?.near)throw new I("wallet_ctrl_not_found",{chain:J.Near});let{createNearSignerFromProvider:Z}=await import("../../chunk-dcj9twam.js"),{getNearToolbox:D}=await import("@swapkit/toolboxes/near"),Q=window.xfi.near,$=await Z(Q,"CTRL"),F=await $.getAddress();return{...await D({signer:$}),transfer:async(B)=>{let{transfer:U}=await import("near-api-js/lib/transaction"),M=B.assetValue.getBaseValue("string"),R=U(BigInt(M)),j={signerId:F,receiverId:B.recipient,actions:[R]};return await Q.request({method:"signAndSendTransaction",params:{transaction:j}})},createTransaction:async(B)=>{let{functionCall:U,transfer:M}=await import("near-api-js/lib/transaction");if(B.functionCall){let{methodName:W,args:K,attachedDeposit:N}=B.functionCall,k=U(W,K,BigInt("30000000000000"),BigInt(N||"0"));return{signerId:F,receiverId:B.recipient,actions:[k]}}let R=B.assetValue.getBaseValue("string"),j=M(BigInt(R));return{signerId:F,receiverId:B.recipient,actions:[j]}}}}default:return null}}export{m as ctrlWallet,t as CTRL_SUPPORTED_CHAINS};
1
+ import{A}from"../../chunk-46yzxdmt.js";import{C as G,D as H}from"../../chunk-qwd1kp32.js";import{Chain as J,ChainToChainId as w,SwapKitError as I,WalletOption as T,createWallet as v,filterSupportedChains as u}from"@swapkit/helpers";import{Chain as q,ChainToChainId as b,EVMChains as P,SwapKitError as _,WalletOption as E,providerRequest as f}from"@swapkit/helpers";import{erc20ABI as g}from"@swapkit/helpers/contracts";async function L(z){if(!window.xfi)throw new _("wallet_ctrl_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(q.Arbitrum,q.Avalanche,q.Base,q.BinanceSmartChain,q.Ethereum,q.Optimism,q.Polygon,()=>window.xfi?.ethereum).with(q.Cosmos,q.Kujira,()=>window.xfi?.keplr).with(q.Bitcoin,()=>window.xfi?.bitcoin).with(q.BitcoinCash,()=>window.xfi?.bitcoincash).with(q.Dogecoin,()=>window.xfi?.dogecoin).with(q.Litecoin,()=>window.xfi?.litecoin).with(q.Solana,()=>window.xfi?.solana).with(q.THORChain,()=>window.xfi?.thorchain).with(q.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function x({method:z,params:Z,chain:D}){let Q=await L(D);return new Promise(($,F)=>{if(Q&&"request"in Q)Q.request({method:z,params:Z},(X,Y)=>{X?F(X):$(Y)})})}async function V(z){try{let Z=await L(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});if([q.Cosmos,q.Kujira].includes(z)){let Q=await L(q.Cosmos);if(!Q||"request"in Q)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});let $=b[z];await Q.enable($);let F=Q.getOfflineSigner($),[X]=await F.getAccounts();return X?.address}if(P.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:Q}=await import("ethers"),$=new Q(Z,"any"),[F]=await f({provider:$,method:"eth_requestAccounts",params:[]});return F}if(z===q.Solana)return(await(await L(q.Solana)).connect()).publicKey.toString();if(z===q.Near){if(!window.xfi?.near)throw new _("wallet_ctrl_not_found",{chain:q.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}})}}async function O({assetValue:z,recipient:Z,memo:D,gasLimit:Q},$="transfer"){if(!z)throw new _("wallet_ctrl_asset_not_defined");let F=await V(z.chain),X=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},memo:D||"",from:F,recipient:Z,gasLimit:Q}];return x({method:$,params:X,chain:z.chain})}function S(z,Z){return{call:async({contractAddress:D,abi:Q,funcName:$,funcParams:F=[],txOverrides:X})=>{if(!D)throw new _("wallet_ctrl_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:y,isStateChangingCall:B}=await import("@swapkit/toolboxes/evm");if(B({abi:Q,funcName:$})){let j=y({provider:z,chain:Z}),{value:W,from:K,to:N,data:k}=await j({contractAddress:D,abi:Q,funcName:$,funcParams:F,txOverrides:X});return(await(await z.getSigner()).sendTransaction({value:BigInt(W||0),from:K,to:N,data:k||"0x"})).hash}let R=await Y(D,Q,z)[$]?.(...F);return typeof R?.hash==="string"?R?.hash:R},approve:async({assetAddress:D,spenderAddress:Q,amount:$,from:F})=>{let{MAX_APPROVAL:X,getCreateContractTxObject:Y}=await import("@swapkit/toolboxes/evm"),y=[Q,BigInt($||X)],U={contractAddress:D,abi:g,funcName:"approve",funcParams:y,txOverrides:{from:F}},M=Y({provider:z,chain:Z}),{value:R,to:j,data:W}=await M(U);return(await(await z.getSigner()).sendTransaction({value:BigInt(R||0),from:F,to:j,data:W||"0x"})).hash},sendTransaction:async(D)=>{let{from:Q,to:$,data:F,value:X}=D;if(!$)throw new _("wallet_ctrl_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({value:BigInt(X||0),from:Q,to:$,data:F||"0x"})).hash}}}var m=v({name:"connectCtrl",walletType:T.CTRL,supportedChains:[J.Arbitrum,J.Avalanche,J.Base,J.BinanceSmartChain,J.Bitcoin,J.BitcoinCash,J.Cosmos,J.Dogecoin,J.Ethereum,J.Kujira,J.Litecoin,J.Maya,J.Near,J.Optimism,J.Polygon,J.Solana,J.THORChain],connect:({addChain:z,walletType:Z,supportedChains:D})=>async function Q($){let X=u({chains:$,supportedChains:D,walletType:Z}).map(async(Y)=>{let y=await V(Y),B=await C(Y);z({...B,address:y,chain:Y,walletType:Z})});return await Promise.all(X),!0}}),t=A(m);async function C(z){switch(z){case J.Solana:{let{getSolanaToolbox:Z}=await import("@swapkit/toolboxes/solana"),D=window.xfi?.solana;if(!D)throw new I("wallet_ctrl_not_found");return{...Z({signer:D})}}case J.Maya:case J.THORChain:{let{getCosmosToolbox:Z,THORCHAIN_GAS_VALUE:D,MAYA_GAS_VALUE:Q}=await import("@swapkit/toolboxes/cosmos"),$=z===J.Maya?Q:D;return{...await Z(z),deposit:(X)=>O({...X,recipient:""},"deposit"),transfer:(X)=>O({...X,gasLimit:$},"transfer")}}case J.Cosmos:case J.Kujira:{let{getCosmosToolbox:Z}=await import("@swapkit/toolboxes/cosmos"),D=w[z],Q=await L(z);await Q?.enable(D);let $=Q?.getOfflineSignerOnlyAmino(D);if(!$)throw new I("wallet_ctrl_not_found");return Z(z,{signer:$})}case J.Bitcoin:case J.BitcoinCash:case J.Dogecoin:case J.Litecoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo");return{...await Z(z),transfer:O}}case J.Arbitrum:case J.Avalanche:case J.Base:case J.BinanceSmartChain:case J.Ethereum:case J.Optimism:case J.Polygon:{let{prepareNetworkSwitch:Z,switchEVMWalletNetwork:D}=await import("@swapkit/helpers"),{getEvmToolbox:Q}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:$}=await import("ethers"),F=await L(z);if(!F)throw new I("wallet_ctrl_not_found");let X=new $(F,"any"),Y=await X.getSigner(),y=await Q(z,{provider:X,signer:Y}),B=S(X,z);try{if(z!==J.Ethereum){let U=y.getNetworkParams();await D(X,z,U)}}catch(U){throw new I({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:T.CTRL,chain:z}})}return Z({provider:window.xfi?.ethereum,chain:z,toolbox:{...y,...B}})}case J.Near:{if(!window.xfi?.near)throw new I("wallet_ctrl_not_found",{chain:J.Near});let{createNearSignerFromProvider:Z}=await import("../../chunk-dcj9twam.js"),{getNearToolbox:D}=await import("@swapkit/toolboxes/near"),Q=window.xfi.near,$=await Z(Q,"CTRL"),F=await $.getAddress();return{...await D({signer:$}),transfer:async(B)=>{let{transfer:U}=await import("near-api-js/lib/transaction"),M=B.assetValue.getBaseValue("string"),R=U(BigInt(M)),j={signerId:F,receiverId:B.recipient,actions:[R]};return await Q.request({method:"signAndSendTransaction",params:{transaction:j}})},createTransaction:async(B)=>{let{functionCall:U,transfer:M}=await import("near-api-js/lib/transaction");if(B.functionCall){let{methodName:W,args:K,attachedDeposit:N}=B.functionCall,k=U(W,K,BigInt("30000000000000"),BigInt(N||"0"));return{signerId:F,receiverId:B.recipient,actions:[k]}}let R=B.assetValue.getBaseValue("string"),j=M(BigInt(R));return{signerId:F,receiverId:B.recipient,actions:[j]}}}}default:return null}}export{m as ctrlWallet,t as CTRL_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=62BD16C82F053DB864756E2164756E21
@@ -1,3 +1,3 @@
1
- import{A as h}from"../../chunk-zfnkndsr.js";import{C as u,D as O}from"../../chunk-qwd1kp32.js";import{Chain as S,ChainToHexChainId as A,EVMChains as B,SwapKitError as d,WalletOption as l,createWallet as C,filterSupportedChains as P,prepareNetworkSwitch as f,switchEVMWalletNetwork as v}from"@swapkit/helpers";var _=(r)=>{switch(r){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},g=async({address:r,walletProvider:w,chain:e,provider:o})=>{if(!w)throw new d("wallet_evm_extensions_not_found");let{getEvmToolbox:t}=await import("@swapkit/toolboxes/evm"),a=await o.getSigner(),i=await t(e,{provider:o,signer:a});if(e!==S.Ethereum){if((await o.getNetwork()).chainId.toString()!==A[e])try{let n=i.getNetworkParams();await v(o,e,n)}catch(n){throw new d("wallet_evm_extensions_failed_to_switch_network",{chain:e})}}return f({toolbox:{...i,getBalance:()=>i.getBalance(r)},chain:e,provider:o})},x=C({name:"connectEVMWallet",supportedChains:[...B],connect:({addChain:r,supportedChains:w})=>async function e(o,t=l.METAMASK,a){let i=P({chains:o,supportedChains:w,walletType:t}),{BrowserProvider:c}=await import("ethers");return await Promise.all(i.map(async(n)=>{if(t===l.EIP6963){if(!a)throw new d("wallet_evm_extensions_no_provider");let E=new c(a,"any");await E.send("eth_requestAccounts",[]);let W=await(await E.getSigner()).getAddress(),M=await g({address:W,chain:n,provider:E,walletProvider:a});r({...M,address:W,chain:n,walletType:t});return}let s=new c(_(t),"any");await s.send("eth_requestAccounts",[]);let p=await(await s.getSigner()).getAddress(),m=await g({address:p,chain:n,walletProvider:_(t),provider:s});r({...m,address:p,chain:n,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:t})})),!0}}),L=h(x);export{g as getWeb3WalletMethods,x as evmWallet,L as EVM_EXTENSIONS_SUPPORTED_CHAINS};
1
+ import{A as h}from"../../chunk-46yzxdmt.js";import{C as u,D as O}from"../../chunk-qwd1kp32.js";import{Chain as S,ChainToHexChainId as A,EVMChains as B,SwapKitError as d,WalletOption as l,createWallet as C,filterSupportedChains as P,prepareNetworkSwitch as f,switchEVMWalletNetwork as v}from"@swapkit/helpers";var _=(r)=>{switch(r){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},g=async({address:r,walletProvider:w,chain:e,provider:o})=>{if(!w)throw new d("wallet_evm_extensions_not_found");let{getEvmToolbox:t}=await import("@swapkit/toolboxes/evm"),a=await o.getSigner(),i=await t(e,{provider:o,signer:a});if(e!==S.Ethereum){if((await o.getNetwork()).chainId.toString()!==A[e])try{let n=i.getNetworkParams();await v(o,e,n)}catch(n){throw new d("wallet_evm_extensions_failed_to_switch_network",{chain:e})}}return f({toolbox:{...i,getBalance:()=>i.getBalance(r)},chain:e,provider:o})},x=C({name:"connectEVMWallet",supportedChains:[...B],connect:({addChain:r,supportedChains:w})=>async function e(o,t=l.METAMASK,a){let i=P({chains:o,supportedChains:w,walletType:t}),{BrowserProvider:c}=await import("ethers");return await Promise.all(i.map(async(n)=>{if(t===l.EIP6963){if(!a)throw new d("wallet_evm_extensions_no_provider");let E=new c(a,"any");await E.send("eth_requestAccounts",[]);let W=await(await E.getSigner()).getAddress(),M=await g({address:W,chain:n,provider:E,walletProvider:a});r({...M,address:W,chain:n,walletType:t});return}let s=new c(_(t),"any");await s.send("eth_requestAccounts",[]);let p=await(await s.getSigner()).getAddress(),m=await g({address:p,chain:n,walletProvider:_(t),provider:s});r({...m,address:p,chain:n,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:t})})),!0}}),L=h(x);export{g as getWeb3WalletMethods,x as evmWallet,L as EVM_EXTENSIONS_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=BE8AD4EE99FDBC2364756E2164756E21
@@ -1,3 +1,3 @@
1
- import{A as m}from"../../chunk-zfnkndsr.js";import{C as U,D as f}from"../../chunk-qwd1kp32.js";import{Chain as F,EVMChains as B,SwapKitError as I,WalletOption as j,createWallet as M,filterSupportedChains as N,prepareNetworkSwitch as O,switchEVMWalletNetwork as y}from"@swapkit/helpers";import{Psbt as W}from"bitcoinjs-lib";import{AddressPurpose as u,BitcoinNetworkType as V,getAddress as K,signTransaction as k}from"sats-connect";export*from"@passkeys/react";export*from"@passkeys/core";async function T({walletProvider:$,provider:Z,chain:z}){switch(z){case F.Bitcoin:{let{getUtxoToolbox:_}=await import("@swapkit/toolboxes/utxo"),G="",J=()=>new Promise((q)=>q(Z)),H={getProvider:J,payload:{purposes:[u.Payment],message:"Address for receiving and sending payments",network:{type:V.Mainnet}},onFinish:(q)=>{if(!q.addresses[0])throw new I("wallet_exodus_no_address");G=q.addresses[0].address},onCancel:()=>{throw new I("wallet_exodus_request_canceled")}};await K(H);async function Q(q){let Y,D={getProvider:J,payload:{message:"Sign transaction",network:{type:V.Mainnet},psbtBase64:q.toBase64(),broadcast:!1,inputsToSign:[{address:G,signingIndexes:q.txInputs.map((R,A)=>A)}]},onFinish:(R)=>{Y=W.fromBase64(R.psbtBase64)},onCancel:()=>{throw new I("wallet_exodus_signature_canceled")}};if(await k(D),!Y)throw new I("wallet_exodus_sign_transaction_error");return Y}return{...await _(z,{signer:{signTransaction:Q,getAddress:()=>Promise.resolve(G)}}),address:G}}case F.Arbitrum:case F.Avalanche:case F.Base:case F.BinanceSmartChain:case F.Ethereum:case F.Optimism:case F.Polygon:{if(!$)throw new I("wallet_exodus_not_found");let{getProvider:_,getEvmToolbox:G}=await import("@swapkit/toolboxes/evm"),J=await _(z),H=Z;await H.send("eth_requestAccounts",[]);let Q=await H.getSigner(),X=await Q.getAddress(),L=await G(z,{provider:J,signer:Q});try{if(z!==F.Ethereum){let q=L.getNetworkParams();await y(H,z,q)}}catch(q){throw new I("wallet_exodus_failed_to_switch_network",{chain:z})}return{...O({toolbox:L,chain:z,provider:H}),address:X}}default:throw new I("wallet_exodus_chain_not_supported",{chain:z})}}var x=M({name:"connectExodusWallet",walletType:j.EXODUS,supportedChains:[...B,F.Bitcoin],connect:({addChain:$,walletType:Z,supportedChains:z})=>async function _(G,J){if(!J)throw new I("wallet_exodus_instance_missing");let H=N({chains:G,supportedChains:z,walletType:Z}),{BrowserProvider:Q}=await import("ethers"),{providers:X}=J;return await Promise.all(H.map(async(L)=>{let q=L===F.Bitcoin?X.bitcoin:new Q(X.ethereum,"any"),{address:Y,...D}=await T({chain:L,provider:q,walletProvider:X.ethereum});$({...D,disconnect:()=>q.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:L,address:Y,walletType:j.EXODUS})})),!0}}),C=m(x);export{x as exodusWallet,C as EXODUS_SUPPORTED_CHAINS};
1
+ import{A as m}from"../../chunk-46yzxdmt.js";import{C as U,D as f}from"../../chunk-qwd1kp32.js";import{Chain as F,EVMChains as B,SwapKitError as I,WalletOption as j,createWallet as M,filterSupportedChains as N,prepareNetworkSwitch as O,switchEVMWalletNetwork as y}from"@swapkit/helpers";import{Psbt as W}from"bitcoinjs-lib";import{AddressPurpose as u,BitcoinNetworkType as V,getAddress as K,signTransaction as k}from"sats-connect";export*from"@passkeys/react";export*from"@passkeys/core";async function T({walletProvider:$,provider:Z,chain:z}){switch(z){case F.Bitcoin:{let{getUtxoToolbox:_}=await import("@swapkit/toolboxes/utxo"),G="",J=()=>new Promise((q)=>q(Z)),H={getProvider:J,payload:{purposes:[u.Payment],message:"Address for receiving and sending payments",network:{type:V.Mainnet}},onFinish:(q)=>{if(!q.addresses[0])throw new I("wallet_exodus_no_address");G=q.addresses[0].address},onCancel:()=>{throw new I("wallet_exodus_request_canceled")}};await K(H);async function Q(q){let Y,D={getProvider:J,payload:{message:"Sign transaction",network:{type:V.Mainnet},psbtBase64:q.toBase64(),broadcast:!1,inputsToSign:[{address:G,signingIndexes:q.txInputs.map((R,A)=>A)}]},onFinish:(R)=>{Y=W.fromBase64(R.psbtBase64)},onCancel:()=>{throw new I("wallet_exodus_signature_canceled")}};if(await k(D),!Y)throw new I("wallet_exodus_sign_transaction_error");return Y}return{...await _(z,{signer:{signTransaction:Q,getAddress:()=>Promise.resolve(G)}}),address:G}}case F.Arbitrum:case F.Avalanche:case F.Base:case F.BinanceSmartChain:case F.Ethereum:case F.Optimism:case F.Polygon:{if(!$)throw new I("wallet_exodus_not_found");let{getProvider:_,getEvmToolbox:G}=await import("@swapkit/toolboxes/evm"),J=await _(z),H=Z;await H.send("eth_requestAccounts",[]);let Q=await H.getSigner(),X=await Q.getAddress(),L=await G(z,{provider:J,signer:Q});try{if(z!==F.Ethereum){let q=L.getNetworkParams();await y(H,z,q)}}catch(q){throw new I("wallet_exodus_failed_to_switch_network",{chain:z})}return{...O({toolbox:L,chain:z,provider:H}),address:X}}default:throw new I("wallet_exodus_chain_not_supported",{chain:z})}}var x=M({name:"connectExodusWallet",walletType:j.EXODUS,supportedChains:[...B,F.Bitcoin],connect:({addChain:$,walletType:Z,supportedChains:z})=>async function _(G,J){if(!J)throw new I("wallet_exodus_instance_missing");let H=N({chains:G,supportedChains:z,walletType:Z}),{BrowserProvider:Q}=await import("ethers"),{providers:X}=J;return await Promise.all(H.map(async(L)=>{let q=L===F.Bitcoin?X.bitcoin:new Q(X.ethereum,"any"),{address:Y,...D}=await T({chain:L,provider:q,walletProvider:X.ethereum});$({...D,disconnect:()=>q.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:L,address:Y,walletType:j.EXODUS})})),!0}}),C=m(x);export{x as exodusWallet,C as EXODUS_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=CC0047348829D7C664756E2164756E21
package/dist/src/index.js CHANGED
@@ -1,3 +1,3 @@
1
- import{A as l,B as n}from"../chunk-zfnkndsr.js";import"../chunk-qwd1kp32.js";export{n as loadWallet,l as getWalletSupportedChains};
1
+ import{A as l,B as n}from"../chunk-46yzxdmt.js";import"../chunk-qwd1kp32.js";export{n as loadWallet,l as getWalletSupportedChains};
2
2
 
3
3
  //# debugId=A65C19099338DCD964756E2164756E21
@@ -1,3 +1,3 @@
1
- var Jz={};i(Jz,{keepkeyWallet:()=>d,KEEPKEY_SUPPORTED_CHAINS:()=>a});module.exports=t(Jz);var z=require("@swapkit/helpers"),h=require("@keepkey/keepkey-sdk");var b=require("@swapkit/helpers");var S=require("@swapkit/helpers"),C=2147483648,P;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(P||={});function n(J){if(J==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(J)}function E(J){let Q=J;if(!n(Q))throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:`Not a bip32 path: '${Q}'`});if(/^m\//i.test(Q))Q=Q.slice(2);let X=Q.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 W=/(\d+)([hH']?)/.exec(Y);if(W===null)throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:"Invalid input"});let[,$="",q=""]=W;if(R[Z]=Number.parseInt($,10),R[Z]>=C)throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:"Invalid child index"});if(q==="h"||q==="H"||q==="'")R[Z]+=C;else if(q.length>0)throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:"Invalid modifier"})}}return R}var g=async({sdk:J,derivationPath:Q})=>{let{DEFAULT_COSMOS_FEE_MAINNET:X,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos"),W=Q?b.derivationPathToString(Q):`${b.DerivationPath.GAIA}/0`,{address:$}=await J.address.cosmosGetAddress({address_n:E(W)}),q=await R(b.Chain.Cosmos);if(X.amount[0])X.amount[0].amount=String(await Z(b.ChainId.Cosmos,500));return{...q,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=M.getBaseValue("string"),B=await q.getAccount($),_=await J.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:X,memo:L||"",sequence:B?.sequence.toString()??"",chain_id:b.ChainId.Cosmos,account_number:B?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:G}],to_address:j,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),V=atob(_.serialized),O=new Uint8Array(V.length).map((f,w)=>V.charCodeAt(w));return(await(await Y(b.SKConfig.get("rpcUrls")[b.Chain.Cosmos])).broadcastTx(O)).transactionHash},address:$}};var F=require("@swapkit/helpers"),l=require("ethers");class k extends l.AbstractSigner{sdk;chain;derivationPath;address;provider;constructor({sdk:J,chain:Q,derivationPath:X,provider:R}){super();this.sdk=J,this.chain=Q,this.derivationPath=X||F.NetworkDerivationPath.ETH,this.address="",this.provider=R}signTypedData(){throw new F.SwapKitError("wallet_keepkey_method_not_supported",{method:"signTypedData"})}getAddress=async()=>{if(this.address)return this.address;let{address:J}=await this.sdk.address.ethereumGetAddress({address_n:E(F.derivationPathToString(this.derivationPath))});return this.address=J,J};signMessage=(J)=>this.sdk.eth.ethSign({address:this.address,message:J});signTransaction=async({to:J,value:Q,gasLimit:X,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:W,gasPrice:$})=>{if(!J)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing to address"});if(!X)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing gasLimit"});if(!Z)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing data"});let q=!!((Y||W)&&!$);if(q&&!Y)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing maxFeePerGas"});if(q&&!W)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing maxPriorityFeePerGas"});if(!(q||$))throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing gasPrice"});let{toHexString:U}=await import("@swapkit/toolboxes/evm"),M=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),j={gas:U(BigInt(X)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:U(BigInt(F.ChainToChainId[this.chain])),to:J.toString(),value:U(BigInt(Q||0)),nonce:U(M),data:Z,...q&&{maxFeePerGas:U(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:U(BigInt(W?.toString()||"0"))},...!q&&{gasPrice:U(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(j)).serialized};sendTransaction=async(J)=>{if(!this.provider)throw new F.SwapKitError("wallet_keepkey_no_provider");let Q=await this.signTransaction(J);return await this.provider.broadcastTransaction(Q)};connect=(J)=>new k({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:J})}var N=require("@swapkit/helpers");var p=async({sdk:J,derivationPath:Q})=>{let{createStargateClient:X,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(N.Chain.Maya),Y=Q?N.derivationPathToString(Q):`${N.DerivationPath.MAYA}/0`,{address:W}=await J.address.mayachainGetAddress({address_n:E(Y)}),$=async({assetValue:M,recipient:j,sender:L,memo:G})=>{let{makeSignDoc:B}=(await import("@cosmjs/amino")).default,{getDenomWithChain:_}=await import("@swapkit/toolboxes/cosmos"),V=await Z.getAccount(L);if(!V)throw new N.SwapKitError("wallet_keepkey_account_not_found");let{accountNumber:O,sequence:H=0}=V,A=M.getBaseValue("string"),f=j&&j!=="",w=f?{type:"mayachain/MsgSend",value:{amount:[{amount:A,denom:M.symbol.toLowerCase()}],from_address:L,to_address:j}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:A,asset:_(M)}],memo:G,signer:L}},K=B([w],{gas:"500000000",amount:[]},N.ChainId.Maya,G,O?.toString(),H),x=await(f?J.mayachain.mayachainSignAminoTransfer:J.mayachain.mayachainSignAminoDeposit)({signDoc:K,signerAddress:L}),v=atob(x.serialized);return new Uint8Array(v.length).map((s,u)=>v.charCodeAt(u))};return{...Z,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=await X(N.SKConfig.get("rpcUrls")[N.Chain.Maya]),B=await $({assetValue:M,recipient:j,memo:L,sender:W}),{transactionHash:_}=await G.broadcastTx(B);return _},deposit:async({assetValue:M,memo:j})=>{let L=await X(N.SKConfig.get("rpcUrls")[N.Chain.Maya]),G=await $({assetValue:M,memo:j,sender:W}),{transactionHash:B}=await L.broadcastTx(G);return B},address:W}};var I=require("@swapkit/helpers");var m=async({sdk:J,derivationPath:Q})=>{let{makeSignDoc:X}=(await import("@cosmjs/amino")).default,{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:W}=await import("@swapkit/toolboxes/cosmos"),$=await W(I.Chain.THORChain),q=Q?I.derivationPathToString(Q):`${I.DerivationPath.THOR}/0`,{address:U}=await J.address.thorchainGetAddress({address_n:E(q)}),M=async({assetValue:G,recipient:B,sender:_,memo:V})=>{let O=await $.getAccount(_);if(!O)throw new I.SwapKitError("wallet_keepkey_account_not_found");let{accountNumber:H,sequence:A=0}=O,f=B&&B!=="",w=R({sender:_,recipient:B,assetValue:G,memo:V}),K=I.ChainId.THORChain,T=X([w],Z(I.Chain.THORChain),K,V,H?.toString(),A),x=f?await J.thorchain.thorchainSignAminoTransfer({signDoc:T,signerAddress:_}):await J.thorchain.thorchainSignAminoDeposit({signDoc:T,signerAddress:_}),v=atob(x.serialized);return new Uint8Array(v.length).map((s,u)=>v.charCodeAt(u))};return{...$,transfer:async({assetValue:G,recipient:B,memo:_})=>{let V=await Y(I.SKConfig.get("rpcUrls")[I.Chain.THORChain]),O=await M({assetValue:G,recipient:B,memo:_,sender:U}),{transactionHash:H}=await V.broadcastTx(O);return H},deposit:async({assetValue:G,memo:B})=>{let _=await Y(I.SKConfig.get("rpcUrls")[I.Chain.THORChain]),V=await M({assetValue:G,memo:B,sender:U}),{transactionHash:O}=await _.broadcastTx(V);return O},address:U}};var D=require("@swapkit/helpers");var c=async({sdk:J,chain:Q,derivationPath:X})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(Q),Y=[D.Chain.Bitcoin,D.Chain.Litecoin].includes(Q)?"p2wpkh":"p2pkh",W=X?D.derivationPathToString(X):`${D.DerivationPath[Q]}/0`,$={coin:P[Q],script_type:Y,address_n:E(W)},q=(await J.address.utxoGetAddress($)).address,U=async(j,L,G="")=>{let B=j.txOutputs.map((O)=>{let{value:H,address:A,change:f}=O,w=Q===D.Chain.BitcoinCash?Z.stripToCashAddress(A):A;if(f||A===q)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:H,scriptType:Y};if(w)return{address:w,amount:H,addressType:"spend"};return null}).filter(Boolean),_=(O)=>{return O.filter((H)=>H!==null&&typeof H==="object"&&Object.keys(H).length>0)};return(await J.utxo.utxoSignTransaction({coin:P[Q],inputs:L,outputs:_(B),opReturnData:G})).serializedTx?.toString()};return{...Z,signTransaction:U,transfer:async({recipient:j,feeOptionKey:L,feeRate:G,memo:B,..._})=>{if(!q)throw new D.SwapKitError("wallet_keepkey_invalid_params",{reason:"From address must be provided"});if(!j)throw new D.SwapKitError("wallet_keepkey_invalid_params",{reason:"Recipient address must be provided"});let V=Q===D.Chain.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:O,inputs:H}=await V({..._,memo:B,recipient:j,feeRate:G||(await Z.getFeeRates())[L||D.FeeOption.Fast],sender:q,fetchTxHex:!0}),A=H.map(({value:w,index:K,hash:T,txHex:x})=>({addressNList:$.address_n,amount:w.toString(),hex:x||"",scriptType:Y,txid:T,vout:K})),f=await U(O,A,B);return Z.broadcastTx(f)},address:q}};var d=z.createWallet({name:"connectKeepkey",supportedChains:[z.Chain.Arbitrum,z.Chain.Avalanche,z.Chain.Base,z.Chain.BinanceSmartChain,z.Chain.Bitcoin,z.Chain.BitcoinCash,z.Chain.Cosmos,z.Chain.Dogecoin,z.Chain.Dash,z.Chain.Ethereum,z.Chain.Litecoin,z.Chain.Optimism,z.Chain.Polygon,z.Chain.THORChain,z.Chain.Maya],walletType:z.WalletOption.KEEPKEY,connect:({addChain:J,supportedChains:Q,walletType:X})=>async function R(Z,Y){let W=z.filterSupportedChains({chains:Z,supportedChains:Q,walletType:X}),$=z.SKConfig.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");let q=z.SKConfig.get("apiKeys").keepKey||"1234";await o();let U={apiKey:q,pairingInfo:$},M=await h.KeepKeySdk.create(U);if(U.apiKey&&U.apiKey!==q)z.SKConfig.setApiKey("keepKey",U.apiKey);return await Promise.all(W.map(async(j)=>{let L=await e({chain:j,derivationPath:Y?.[j]||z.NetworkDerivationPath[j],sdk:M}),G=await L.getAddress()||"";J({...L,address:G,chain:j,walletType:z.WalletOption.KEEPKEY})})),!0}}),a=r(d);async function e({sdk:J,chain:Q,derivationPath:X}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(Q){case z.Chain.BinanceSmartChain:case z.Chain.Arbitrum:case z.Chain.Optimism:case z.Chain.Polygon:case z.Chain.Avalanche:case z.Chain.Base:case z.Chain.Ethereum:{let Y=await R(Q),W=new k({sdk:J,chain:Q,derivationPath:X,provider:Y});return await Z(Q,{provider:Y,signer:W})}case z.Chain.Cosmos:return g({sdk:J,derivationPath:X});case z.Chain.THORChain:return m({sdk:J,derivationPath:X});case z.Chain.Maya:return p({sdk:J,derivationPath:X});case z.Chain.Bitcoin:case z.Chain.BitcoinCash:case z.Chain.Dash:case z.Chain.Dogecoin:case z.Chain.Litecoin:return c({sdk:J,chain:Q,derivationPath:X});default:throw new z.SwapKitError("wallet_keepkey_chain_not_supported",{chain:Q})}}async function o(J=0){if(J>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await zz())window.location.assign("keepkey://launch"),await new Promise((X)=>setTimeout(X,30000)),o(J+1)}async function zz(J="http://localhost:1646/spec/swagger.json"){try{return(await fetch(J)).status===200}catch(Q){return!1}}
1
+ var Jz={};i(Jz,{keepkeyWallet:()=>d,KEEPKEY_SUPPORTED_CHAINS:()=>a});module.exports=t(Jz);var z=require("@swapkit/helpers"),h=require("@keepkey/keepkey-sdk");var b=require("@swapkit/helpers");var S=require("@swapkit/helpers"),C=2147483648,P;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(P||={});function n(J){if(J==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(J)}function E(J){let Q=J;if(!n(Q))throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:`Not a bip32 path: '${Q}'`});if(/^m\//i.test(Q))Q=Q.slice(2);let X=Q.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 W=/(\d+)([hH']?)/.exec(Y);if(W===null)throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:"Invalid input"});let[,$="",q=""]=W;if(R[Z]=Number.parseInt($,10),R[Z]>=C)throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:"Invalid child index"});if(q==="h"||q==="H"||q==="'")R[Z]+=C;else if(q.length>0)throw new S.SwapKitError("wallet_keepkey_invalid_params",{reason:"Invalid modifier"})}}return R}var g=async({sdk:J,derivationPath:Q})=>{let{DEFAULT_COSMOS_FEE_MAINNET:X,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos"),W=Q?b.derivationPathToString(Q):`${b.DerivationPath.GAIA}/0`,{address:$}=await J.address.cosmosGetAddress({address_n:E(W)}),q=await R(b.Chain.Cosmos);if(X.amount[0])X.amount[0].amount=String(await Z(b.ChainId.Cosmos,500));return{...q,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=M.getBaseValue("string"),B=await q.getAccount($),_=await J.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:X,memo:L||"",sequence:B?.sequence.toString()??"",chain_id:b.ChainId.Cosmos,account_number:B?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:G}],to_address:j,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),V=atob(_.serialized),O=new Uint8Array(V.length).map((f,w)=>V.charCodeAt(w));return(await(await Y(b.SKConfig.get("rpcUrls")[b.Chain.Cosmos])).broadcastTx(O)).transactionHash},address:$}};var F=require("@swapkit/helpers"),l=require("ethers");class k extends l.AbstractSigner{sdk;chain;derivationPath;address;provider;constructor({sdk:J,chain:Q,derivationPath:X,provider:R}){super();this.sdk=J,this.chain=Q,this.derivationPath=X||F.NetworkDerivationPath.ETH,this.address="",this.provider=R}signTypedData(){throw new F.SwapKitError("wallet_keepkey_method_not_supported",{method:"signTypedData"})}getAddress=async()=>{if(this.address)return this.address;let{address:J}=await this.sdk.address.ethereumGetAddress({address_n:E(F.derivationPathToString(this.derivationPath))});return this.address=J,J};signMessage=(J)=>this.sdk.eth.ethSign({address:this.address,message:J});signTransaction=async({to:J,value:Q,gasLimit:X,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:W,gasPrice:$})=>{if(!J)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing to address"});if(!X)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing gasLimit"});if(!Z)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing data"});let q=!!((Y||W)&&!$);if(q&&!Y)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing maxFeePerGas"});if(q&&!W)throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing maxPriorityFeePerGas"});if(!(q||$))throw new F.SwapKitError("wallet_keepkey_invalid_params",{reason:"Missing gasPrice"});let{toHexString:U}=await import("@swapkit/toolboxes/evm"),M=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),j={gas:U(BigInt(X)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:U(BigInt(F.ChainToChainId[this.chain])),to:J.toString(),value:U(BigInt(Q||0)),nonce:U(M),data:Z,...q&&{maxFeePerGas:U(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:U(BigInt(W?.toString()||"0"))},...!q&&{gasPrice:U(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(j)).serialized};sendTransaction=async(J)=>{if(!this.provider)throw new F.SwapKitError("wallet_keepkey_no_provider");let Q=await this.signTransaction(J);return await this.provider.broadcastTransaction(Q)};connect=(J)=>new k({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:J})}var N=require("@swapkit/helpers");var p=async({sdk:J,derivationPath:Q})=>{let{createStargateClient:X,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(N.Chain.Maya),Y=Q?N.derivationPathToString(Q):`${N.DerivationPath.MAYA}/0`,{address:W}=await J.address.mayachainGetAddress({address_n:E(Y)}),$=async({assetValue:M,recipient:j,sender:L,memo:G})=>{let{makeSignDoc:B}=await import("@cosmjs/amino"),{getDenomWithChain:_}=await import("@swapkit/toolboxes/cosmos"),V=await Z.getAccount(L);if(!V)throw new N.SwapKitError("wallet_keepkey_account_not_found");let{accountNumber:O,sequence:H=0}=V,A=M.getBaseValue("string"),f=j&&j!=="",w=f?{type:"mayachain/MsgSend",value:{amount:[{amount:A,denom:M.symbol.toLowerCase()}],from_address:L,to_address:j}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:A,asset:_(M)}],memo:G,signer:L}},K=B([w],{gas:"500000000",amount:[]},N.ChainId.Maya,G,O?.toString(),H),x=await(f?J.mayachain.mayachainSignAminoTransfer:J.mayachain.mayachainSignAminoDeposit)({signDoc:K,signerAddress:L}),v=atob(x.serialized);return new Uint8Array(v.length).map((s,u)=>v.charCodeAt(u))};return{...Z,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=await X(N.SKConfig.get("rpcUrls")[N.Chain.Maya]),B=await $({assetValue:M,recipient:j,memo:L,sender:W}),{transactionHash:_}=await G.broadcastTx(B);return _},deposit:async({assetValue:M,memo:j})=>{let L=await X(N.SKConfig.get("rpcUrls")[N.Chain.Maya]),G=await $({assetValue:M,memo:j,sender:W}),{transactionHash:B}=await L.broadcastTx(G);return B},address:W}};var I=require("@swapkit/helpers");var m=async({sdk:J,derivationPath:Q})=>{let{makeSignDoc:X}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:W}=await import("@swapkit/toolboxes/cosmos"),$=await W(I.Chain.THORChain),q=Q?I.derivationPathToString(Q):`${I.DerivationPath.THOR}/0`,{address:U}=await J.address.thorchainGetAddress({address_n:E(q)}),M=async({assetValue:G,recipient:B,sender:_,memo:V})=>{let O=await $.getAccount(_);if(!O)throw new I.SwapKitError("wallet_keepkey_account_not_found");let{accountNumber:H,sequence:A=0}=O,f=B&&B!=="",w=R({sender:_,recipient:B,assetValue:G,memo:V}),K=I.ChainId.THORChain,T=X([w],Z(I.Chain.THORChain),K,V,H?.toString(),A),x=f?await J.thorchain.thorchainSignAminoTransfer({signDoc:T,signerAddress:_}):await J.thorchain.thorchainSignAminoDeposit({signDoc:T,signerAddress:_}),v=atob(x.serialized);return new Uint8Array(v.length).map((s,u)=>v.charCodeAt(u))};return{...$,transfer:async({assetValue:G,recipient:B,memo:_})=>{let V=await Y(I.SKConfig.get("rpcUrls")[I.Chain.THORChain]),O=await M({assetValue:G,recipient:B,memo:_,sender:U}),{transactionHash:H}=await V.broadcastTx(O);return H},deposit:async({assetValue:G,memo:B})=>{let _=await Y(I.SKConfig.get("rpcUrls")[I.Chain.THORChain]),V=await M({assetValue:G,memo:B,sender:U}),{transactionHash:O}=await _.broadcastTx(V);return O},address:U}};var D=require("@swapkit/helpers");var c=async({sdk:J,chain:Q,derivationPath:X})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(Q),Y=[D.Chain.Bitcoin,D.Chain.Litecoin].includes(Q)?"p2wpkh":"p2pkh",W=X?D.derivationPathToString(X):`${D.DerivationPath[Q]}/0`,$={coin:P[Q],script_type:Y,address_n:E(W)},q=(await J.address.utxoGetAddress($)).address,U=async(j,L,G="")=>{let B=j.txOutputs.map((O)=>{let{value:H,address:A,change:f}=O,w=Q===D.Chain.BitcoinCash?Z.stripToCashAddress(A):A;if(f||A===q)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:H,scriptType:Y};if(w)return{address:w,amount:H,addressType:"spend"};return null}).filter(Boolean),_=(O)=>{return O.filter((H)=>H!==null&&typeof H==="object"&&Object.keys(H).length>0)};return(await J.utxo.utxoSignTransaction({coin:P[Q],inputs:L,outputs:_(B),opReturnData:G})).serializedTx?.toString()};return{...Z,signTransaction:U,transfer:async({recipient:j,feeOptionKey:L,feeRate:G,memo:B,..._})=>{if(!q)throw new D.SwapKitError("wallet_keepkey_invalid_params",{reason:"From address must be provided"});if(!j)throw new D.SwapKitError("wallet_keepkey_invalid_params",{reason:"Recipient address must be provided"});let V=Q===D.Chain.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:O,inputs:H}=await V({..._,memo:B,recipient:j,feeRate:G||(await Z.getFeeRates())[L||D.FeeOption.Fast],sender:q,fetchTxHex:!0}),A=H.map(({value:w,index:K,hash:T,txHex:x})=>({addressNList:$.address_n,amount:w.toString(),hex:x||"",scriptType:Y,txid:T,vout:K})),f=await U(O,A,B);return Z.broadcastTx(f)},address:q}};var d=z.createWallet({name:"connectKeepkey",supportedChains:[z.Chain.Arbitrum,z.Chain.Avalanche,z.Chain.Base,z.Chain.BinanceSmartChain,z.Chain.Bitcoin,z.Chain.BitcoinCash,z.Chain.Cosmos,z.Chain.Dogecoin,z.Chain.Dash,z.Chain.Ethereum,z.Chain.Litecoin,z.Chain.Optimism,z.Chain.Polygon,z.Chain.THORChain,z.Chain.Maya],walletType:z.WalletOption.KEEPKEY,connect:({addChain:J,supportedChains:Q,walletType:X})=>async function R(Z,Y){let W=z.filterSupportedChains({chains:Z,supportedChains:Q,walletType:X}),$=z.SKConfig.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");let q=z.SKConfig.get("apiKeys").keepKey||"1234";await o();let U={apiKey:q,pairingInfo:$},M=await h.KeepKeySdk.create(U);if(U.apiKey&&U.apiKey!==q)z.SKConfig.setApiKey("keepKey",U.apiKey);return await Promise.all(W.map(async(j)=>{let L=await e({chain:j,derivationPath:Y?.[j]||z.NetworkDerivationPath[j],sdk:M}),G=await L.getAddress()||"";J({...L,address:G,chain:j,walletType:z.WalletOption.KEEPKEY})})),!0}}),a=r(d);async function e({sdk:J,chain:Q,derivationPath:X}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(Q){case z.Chain.BinanceSmartChain:case z.Chain.Arbitrum:case z.Chain.Optimism:case z.Chain.Polygon:case z.Chain.Avalanche:case z.Chain.Base:case z.Chain.Ethereum:{let Y=await R(Q),W=new k({sdk:J,chain:Q,derivationPath:X,provider:Y});return await Z(Q,{provider:Y,signer:W})}case z.Chain.Cosmos:return g({sdk:J,derivationPath:X});case z.Chain.THORChain:return m({sdk:J,derivationPath:X});case z.Chain.Maya:return p({sdk:J,derivationPath:X});case z.Chain.Bitcoin:case z.Chain.BitcoinCash:case z.Chain.Dash:case z.Chain.Dogecoin:case z.Chain.Litecoin:return c({sdk:J,chain:Q,derivationPath:X});default:throw new z.SwapKitError("wallet_keepkey_chain_not_supported",{chain:Q})}}async function o(J=0){if(J>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await zz())window.location.assign("keepkey://launch"),await new Promise((X)=>setTimeout(X,30000)),o(J+1)}async function zz(J="http://localhost:1646/spec/swagger.json"){try{return(await fetch(J)).status===200}catch(Q){return!1}}
2
2
 
3
- //# debugId=C9737DDBCA29DE9E64756E2164756E21
3
+ //# debugId=1FF832DBB17026E064756E2164756E21
@@ -6,11 +6,11 @@
6
6
  "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { GenericTransferParams } from \"@swapkit/helpers\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\nexport const cosmosWalletMethods = async ({\n sdk,\n derivationPath,\n}: { sdk: KeepKeySdk; derivationPath?: DerivationPathArray }) => {\n const {\n DEFAULT_COSMOS_FEE_MAINNET,\n getCosmosToolbox,\n getFeeRateFromThorswap,\n createStargateClient,\n } = await import(\"@swapkit/toolboxes/cosmos\");\n 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};\n",
7
7
  "/*\n KeepKey Specific bip32 path conventions\n*/\n\nimport { SwapKitError } from \"@swapkit/helpers\";\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 SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: `Not a bip32 path: '${path}'`,\n });\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Invalid input\" });\n\n const [, num = \"\", modifier = \"\"] = tmp;\n\n ret[i] = Number.parseInt(num, 10);\n\n if (ret[i] >= HARDENED)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Invalid child index\" });\n\n if (modifier === \"h\" || modifier === \"H\" || modifier === \"'\") {\n ret[i] += HARDENED;\n } else if (modifier.length > 0) {\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"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 SwapKitError,\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 SwapKitError(\"wallet_keepkey_method_not_supported\", { method: \"signTypedData\" });\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing to address\" });\n if (!gasLimit)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing gasLimit\" });\n if (!data) throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing data\" });\n\n const isEIP1559 = !!((maxFeePerGas || maxPriorityFeePerGas) && !gasPrice);\n if (isEIP1559 && !maxFeePerGas)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing maxFeePerGas\" });\n if (isEIP1559 && !maxPriorityFeePerGas)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"Missing maxPriorityFeePerGas\",\n });\n if (!(isEIP1559 || gasPrice))\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"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 SwapKitError(\"wallet_keepkey_no_provider\");\n\n const signedTxHex = await this.signTransaction(tx);\n\n return await this.provider.broadcastTransaction(signedTxHex);\n };\n\n connect = (provider: Provider) =>\n new KeepKeySigner({\n sdk: this.sdk,\n chain: this.chain,\n derivationPath: this.derivationPath,\n provider,\n });\n}\n",
9
- "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n type AssetValue,\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const mayachainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { createStargateClient, getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.Maya);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.MAYA}/0`;\n\n const { address: fromAddress } = (await sdk.address.mayachainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const { makeSignDoc } = (await import(\"@cosmjs/amino\")).default;\n const { getDenomWithChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const account = await toolbox.getAccount(sender);\n if (!account) throw new SwapKitError(\"wallet_keepkey_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 SwapKitError,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const thorchainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { makeSignDoc } = (await import(\"@cosmjs/amino\")).default;\n const { buildAminoMsg, getDefaultChainFee, createStargateClient, getCosmosToolbox } =\n await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.THOR}/0`;\n\n const { address: fromAddress } = (await sdk.address.thorchainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const account = await toolbox.getAccount(sender);\n if (!account) throw new SwapKitError(\"wallet_keepkey_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 SwapKitError,\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"From address must be provided\",\n });\n if (!recipient)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"Recipient address must be provided\",\n });\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"
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 SwapKitError,\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 SwapKitError(\"wallet_keepkey_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 SwapKitError,\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 SwapKitError(\"wallet_keepkey_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 SwapKitError,\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}: {\n sdk: KeepKeySdk;\n chain: Exclude<UTXOChain, Chain.Zcash>;\n derivationPath?: DerivationPathArray;\n}) => {\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"From address must be provided\",\n });\n if (!recipient)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"Recipient address must be provided\",\n });\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": "C9737DDBCA29DE9E64756E2164756E21",
13
+ "mappings": "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",
14
+ "debugId": "1FF832DBB17026E064756E2164756E21",
15
15
  "names": []
16
16
  }
@@ -1,3 +1,3 @@
1
- import{A as i}from"../../chunk-zfnkndsr.js";import{C as b,D as A}from"../../chunk-qwd1kp32.js";import{Chain as X,NetworkDerivationPath as Iz,SKConfig as C,SwapKitError as Vz,WalletOption as n,createWallet as Hz,filterSupportedChains as Fz}from"@swapkit/helpers";import{KeepKeySdk as Nz}from"@keepkey/keepkey-sdk";import{Chain as l,ChainId as p,DerivationPath as zz,SKConfig as Jz,derivationPathToString as Qz}from"@swapkit/helpers";import{SwapKitError as T}from"@swapkit/helpers";var g=2147483648,x;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(x||={});function e(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function N(z){let J=z;if(!e(J))throw new T("wallet_keepkey_invalid_params",{reason:`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 W=/(\d+)([hH']?)/.exec(Y);if(W===null)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid input"});let[,$="",q=""]=W;if(R[Z]=Number.parseInt($,10),R[Z]>=g)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid child index"});if(q==="h"||q==="H"||q==="'")R[Z]+=g;else if(q.length>0)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid modifier"})}}return R}var m=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos"),W=J?Qz(J):`${zz.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:N(W)}),q=await R(l.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(p.Cosmos,500));return{...q,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=M.getBaseValue("string"),B=await q.getAccount($),_=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:B?.sequence.toString()??"",chain_id:p.Cosmos,account_number:B?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:G}],to_address:j,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),I=atob(_.serialized),O=new Uint8Array(I.length).map((D,F)=>I.charCodeAt(F));return(await(await Y(Jz.get("rpcUrls")[l.Cosmos])).broadcastTx(O)).transactionHash},address:$}};import{ChainToChainId as Xz,NetworkDerivationPath as Yz,SwapKitError as w,derivationPathToString as Zz}from"@swapkit/helpers";import{AbstractSigner as $z}from"ethers";class v extends $z{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||Yz.ETH,this.address="",this.provider=R}signTypedData(){throw new w("wallet_keepkey_method_not_supported",{method:"signTypedData"})}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:N(Zz(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:W,gasPrice:$})=>{if(!z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing to address"});if(!Q)throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasLimit"});if(!Z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing data"});let q=!!((Y||W)&&!$);if(q&&!Y)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxFeePerGas"});if(q&&!W)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxPriorityFeePerGas"});if(!(q||$))throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasPrice"});let{toHexString:U}=await import("@swapkit/toolboxes/evm"),M=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),j={gas:U(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:U(BigInt(Xz[this.chain])),to:z.toString(),value:U(BigInt(J||0)),nonce:U(M),data:Z,...q&&{maxFeePerGas:U(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:U(BigInt(W?.toString()||"0"))},...!q&&{gasPrice:U(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(j)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new w("wallet_keepkey_no_provider");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new v({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as u,ChainId as qz,DerivationPath as jz,SKConfig as c,SwapKitError as Uz,derivationPathToString as Bz}from"@swapkit/helpers";var h=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(u.Maya),Y=J?Bz(J):`${jz.MAYA}/0`,{address:W}=await z.address.mayachainGetAddress({address_n:N(Y)}),$=async({assetValue:M,recipient:j,sender:L,memo:G})=>{let{makeSignDoc:B}=(await import("@cosmjs/amino")).default,{getDenomWithChain:_}=await import("@swapkit/toolboxes/cosmos"),I=await Z.getAccount(L);if(!I)throw new Uz("wallet_keepkey_account_not_found");let{accountNumber:O,sequence:V=0}=I,H=M.getBaseValue("string"),D=j&&j!=="",F=D?{type:"mayachain/MsgSend",value:{amount:[{amount:H,denom:M.symbol.toLowerCase()}],from_address:L,to_address:j}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:H,asset:_(M)}],memo:G,signer:L}},E=B([F],{gas:"500000000",amount:[]},qz.Maya,G,O?.toString(),V),y=await(D?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:E,signerAddress:L}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...Z,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=await Q(c.get("rpcUrls")[u.Maya]),B=await $({assetValue:M,recipient:j,memo:L,sender:W}),{transactionHash:_}=await G.broadcastTx(B);return _},deposit:async({assetValue:M,memo:j})=>{let L=await Q(c.get("rpcUrls")[u.Maya]),G=await $({assetValue:M,memo:j,sender:W}),{transactionHash:B}=await L.broadcastTx(G);return B},address:W}};import{Chain as S,ChainId as Rz,DerivationPath as Wz,SKConfig as d,SwapKitError as Gz,derivationPathToString as Lz}from"@swapkit/helpers";var o=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=(await import("@cosmjs/amino")).default,{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:W}=await import("@swapkit/toolboxes/cosmos"),$=await W(S.THORChain),q=J?Lz(J):`${Wz.THOR}/0`,{address:U}=await z.address.thorchainGetAddress({address_n:N(q)}),M=async({assetValue:G,recipient:B,sender:_,memo:I})=>{let O=await $.getAccount(_);if(!O)throw new Gz("wallet_keepkey_account_not_found");let{accountNumber:V,sequence:H=0}=O,D=B&&B!=="",F=R({sender:_,recipient:B,assetValue:G,memo:I}),E=Rz.THORChain,f=Q([F],Z(S.THORChain),E,I,V?.toString(),H),y=D?await z.thorchain.thorchainSignAminoTransfer({signDoc:f,signerAddress:_}):await z.thorchain.thorchainSignAminoDeposit({signDoc:f,signerAddress:_}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...$,transfer:async({assetValue:G,recipient:B,memo:_})=>{let I=await Y(d.get("rpcUrls")[S.THORChain]),O=await M({assetValue:G,recipient:B,memo:_,sender:U}),{transactionHash:V}=await I.broadcastTx(O);return V},deposit:async({assetValue:G,memo:B})=>{let _=await Y(d.get("rpcUrls")[S.THORChain]),I=await M({assetValue:G,memo:B,sender:U}),{transactionHash:O}=await _.broadcastTx(I);return O},address:U}};import{Chain as P,DerivationPath as _z,FeeOption as Mz,SwapKitError as r,derivationPathToString as Oz}from"@swapkit/helpers";var s=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[P.Bitcoin,P.Litecoin].includes(J)?"p2wpkh":"p2pkh",W=Q?Oz(Q):`${_z[J]}/0`,$={coin:x[J],script_type:Y,address_n:N(W)},q=(await z.address.utxoGetAddress($)).address,U=async(j,L,G="")=>{let B=j.txOutputs.map((O)=>{let{value:V,address:H,change:D}=O,F=J===P.BitcoinCash?Z.stripToCashAddress(H):H;if(D||H===q)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:V,scriptType:Y};if(F)return{address:F,amount:V,addressType:"spend"};return null}).filter(Boolean),_=(O)=>{return O.filter((V)=>V!==null&&typeof V==="object"&&Object.keys(V).length>0)};return(await z.utxo.utxoSignTransaction({coin:x[J],inputs:L,outputs:_(B),opReturnData:G})).serializedTx?.toString()};return{...Z,signTransaction:U,transfer:async({recipient:j,feeOptionKey:L,feeRate:G,memo:B,..._})=>{if(!q)throw new r("wallet_keepkey_invalid_params",{reason:"From address must be provided"});if(!j)throw new r("wallet_keepkey_invalid_params",{reason:"Recipient address must be provided"});let I=J===P.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:O,inputs:V}=await I({..._,memo:B,recipient:j,feeRate:G||(await Z.getFeeRates())[L||Mz.Fast],sender:q,fetchTxHex:!0}),H=V.map(({value:F,index:E,hash:f,txHex:y})=>({addressNList:$.address_n,amount:F.toString(),hex:y||"",scriptType:Y,txid:f,vout:E})),D=await U(O,H,B);return Z.broadcastTx(D)},address:q}};var Dz=Hz({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:n.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let W=Fz({chains:Z,supportedChains:J,walletType:Q}),$=C.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");let q=C.get("apiKeys").keepKey||"1234";await t();let U={apiKey:q,pairingInfo:$},M=await Nz.create(U);if(U.apiKey&&U.apiKey!==q)C.setApiKey("keepKey",U.apiKey);return await Promise.all(W.map(async(j)=>{let L=await bz({chain:j,derivationPath:Y?.[j]||Iz[j],sdk:M}),G=await L.getAddress()||"";z({...L,address:G,chain:j,walletType:n.KEEPKEY})})),!0}}),az=i(Dz);async function bz({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.Base:case X.Ethereum:{let Y=await R(J),W=new v({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:W})}case X.Cosmos:return m({sdk:z,derivationPath:Q});case X.THORChain:return o({sdk:z,derivationPath:Q});case X.Maya:return h({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return s({sdk:z,chain:J,derivationPath:Q});default:throw new Vz("wallet_keepkey_chain_not_supported",{chain:J})}}async function t(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Az())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),t(z+1)}async function Az(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return!1}}export{Dz as keepkeyWallet,az as KEEPKEY_SUPPORTED_CHAINS};
1
+ import{A as i}from"../../chunk-46yzxdmt.js";import{C as b,D as A}from"../../chunk-qwd1kp32.js";import{Chain as X,NetworkDerivationPath as Iz,SKConfig as C,SwapKitError as Vz,WalletOption as n,createWallet as Hz,filterSupportedChains as Fz}from"@swapkit/helpers";import{KeepKeySdk as Nz}from"@keepkey/keepkey-sdk";import{Chain as l,ChainId as p,DerivationPath as zz,SKConfig as Jz,derivationPathToString as Qz}from"@swapkit/helpers";import{SwapKitError as T}from"@swapkit/helpers";var g=2147483648,x;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(x||={});function e(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function N(z){let J=z;if(!e(J))throw new T("wallet_keepkey_invalid_params",{reason:`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 W=/(\d+)([hH']?)/.exec(Y);if(W===null)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid input"});let[,$="",q=""]=W;if(R[Z]=Number.parseInt($,10),R[Z]>=g)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid child index"});if(q==="h"||q==="H"||q==="'")R[Z]+=g;else if(q.length>0)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid modifier"})}}return R}var m=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos"),W=J?Qz(J):`${zz.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:N(W)}),q=await R(l.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(p.Cosmos,500));return{...q,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=M.getBaseValue("string"),B=await q.getAccount($),_=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:B?.sequence.toString()??"",chain_id:p.Cosmos,account_number:B?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:G}],to_address:j,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),I=atob(_.serialized),O=new Uint8Array(I.length).map((D,F)=>I.charCodeAt(F));return(await(await Y(Jz.get("rpcUrls")[l.Cosmos])).broadcastTx(O)).transactionHash},address:$}};import{ChainToChainId as Xz,NetworkDerivationPath as Yz,SwapKitError as w,derivationPathToString as Zz}from"@swapkit/helpers";import{AbstractSigner as $z}from"ethers";class v extends $z{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||Yz.ETH,this.address="",this.provider=R}signTypedData(){throw new w("wallet_keepkey_method_not_supported",{method:"signTypedData"})}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:N(Zz(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:W,gasPrice:$})=>{if(!z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing to address"});if(!Q)throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasLimit"});if(!Z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing data"});let q=!!((Y||W)&&!$);if(q&&!Y)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxFeePerGas"});if(q&&!W)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxPriorityFeePerGas"});if(!(q||$))throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasPrice"});let{toHexString:U}=await import("@swapkit/toolboxes/evm"),M=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),j={gas:U(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:U(BigInt(Xz[this.chain])),to:z.toString(),value:U(BigInt(J||0)),nonce:U(M),data:Z,...q&&{maxFeePerGas:U(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:U(BigInt(W?.toString()||"0"))},...!q&&{gasPrice:U(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(j)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new w("wallet_keepkey_no_provider");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new v({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as u,ChainId as qz,DerivationPath as jz,SKConfig as c,SwapKitError as Uz,derivationPathToString as Bz}from"@swapkit/helpers";var h=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(u.Maya),Y=J?Bz(J):`${jz.MAYA}/0`,{address:W}=await z.address.mayachainGetAddress({address_n:N(Y)}),$=async({assetValue:M,recipient:j,sender:L,memo:G})=>{let{makeSignDoc:B}=await import("@cosmjs/amino"),{getDenomWithChain:_}=await import("@swapkit/toolboxes/cosmos"),I=await Z.getAccount(L);if(!I)throw new Uz("wallet_keepkey_account_not_found");let{accountNumber:O,sequence:V=0}=I,H=M.getBaseValue("string"),D=j&&j!=="",F=D?{type:"mayachain/MsgSend",value:{amount:[{amount:H,denom:M.symbol.toLowerCase()}],from_address:L,to_address:j}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:H,asset:_(M)}],memo:G,signer:L}},E=B([F],{gas:"500000000",amount:[]},qz.Maya,G,O?.toString(),V),y=await(D?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:E,signerAddress:L}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...Z,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=await Q(c.get("rpcUrls")[u.Maya]),B=await $({assetValue:M,recipient:j,memo:L,sender:W}),{transactionHash:_}=await G.broadcastTx(B);return _},deposit:async({assetValue:M,memo:j})=>{let L=await Q(c.get("rpcUrls")[u.Maya]),G=await $({assetValue:M,memo:j,sender:W}),{transactionHash:B}=await L.broadcastTx(G);return B},address:W}};import{Chain as S,ChainId as Rz,DerivationPath as Wz,SKConfig as d,SwapKitError as Gz,derivationPathToString as Lz}from"@swapkit/helpers";var o=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:W}=await import("@swapkit/toolboxes/cosmos"),$=await W(S.THORChain),q=J?Lz(J):`${Wz.THOR}/0`,{address:U}=await z.address.thorchainGetAddress({address_n:N(q)}),M=async({assetValue:G,recipient:B,sender:_,memo:I})=>{let O=await $.getAccount(_);if(!O)throw new Gz("wallet_keepkey_account_not_found");let{accountNumber:V,sequence:H=0}=O,D=B&&B!=="",F=R({sender:_,recipient:B,assetValue:G,memo:I}),E=Rz.THORChain,f=Q([F],Z(S.THORChain),E,I,V?.toString(),H),y=D?await z.thorchain.thorchainSignAminoTransfer({signDoc:f,signerAddress:_}):await z.thorchain.thorchainSignAminoDeposit({signDoc:f,signerAddress:_}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...$,transfer:async({assetValue:G,recipient:B,memo:_})=>{let I=await Y(d.get("rpcUrls")[S.THORChain]),O=await M({assetValue:G,recipient:B,memo:_,sender:U}),{transactionHash:V}=await I.broadcastTx(O);return V},deposit:async({assetValue:G,memo:B})=>{let _=await Y(d.get("rpcUrls")[S.THORChain]),I=await M({assetValue:G,memo:B,sender:U}),{transactionHash:O}=await _.broadcastTx(I);return O},address:U}};import{Chain as P,DerivationPath as _z,FeeOption as Mz,SwapKitError as r,derivationPathToString as Oz}from"@swapkit/helpers";var s=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[P.Bitcoin,P.Litecoin].includes(J)?"p2wpkh":"p2pkh",W=Q?Oz(Q):`${_z[J]}/0`,$={coin:x[J],script_type:Y,address_n:N(W)},q=(await z.address.utxoGetAddress($)).address,U=async(j,L,G="")=>{let B=j.txOutputs.map((O)=>{let{value:V,address:H,change:D}=O,F=J===P.BitcoinCash?Z.stripToCashAddress(H):H;if(D||H===q)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:V,scriptType:Y};if(F)return{address:F,amount:V,addressType:"spend"};return null}).filter(Boolean),_=(O)=>{return O.filter((V)=>V!==null&&typeof V==="object"&&Object.keys(V).length>0)};return(await z.utxo.utxoSignTransaction({coin:x[J],inputs:L,outputs:_(B),opReturnData:G})).serializedTx?.toString()};return{...Z,signTransaction:U,transfer:async({recipient:j,feeOptionKey:L,feeRate:G,memo:B,..._})=>{if(!q)throw new r("wallet_keepkey_invalid_params",{reason:"From address must be provided"});if(!j)throw new r("wallet_keepkey_invalid_params",{reason:"Recipient address must be provided"});let I=J===P.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:O,inputs:V}=await I({..._,memo:B,recipient:j,feeRate:G||(await Z.getFeeRates())[L||Mz.Fast],sender:q,fetchTxHex:!0}),H=V.map(({value:F,index:E,hash:f,txHex:y})=>({addressNList:$.address_n,amount:F.toString(),hex:y||"",scriptType:Y,txid:f,vout:E})),D=await U(O,H,B);return Z.broadcastTx(D)},address:q}};var Dz=Hz({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:n.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let W=Fz({chains:Z,supportedChains:J,walletType:Q}),$=C.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");let q=C.get("apiKeys").keepKey||"1234";await t();let U={apiKey:q,pairingInfo:$},M=await Nz.create(U);if(U.apiKey&&U.apiKey!==q)C.setApiKey("keepKey",U.apiKey);return await Promise.all(W.map(async(j)=>{let L=await bz({chain:j,derivationPath:Y?.[j]||Iz[j],sdk:M}),G=await L.getAddress()||"";z({...L,address:G,chain:j,walletType:n.KEEPKEY})})),!0}}),az=i(Dz);async function bz({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.Base:case X.Ethereum:{let Y=await R(J),W=new v({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:W})}case X.Cosmos:return m({sdk:z,derivationPath:Q});case X.THORChain:return o({sdk:z,derivationPath:Q});case X.Maya:return h({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return s({sdk:z,chain:J,derivationPath:Q});default:throw new Vz("wallet_keepkey_chain_not_supported",{chain:J})}}async function t(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Az())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),t(z+1)}async function Az(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return!1}}export{Dz as keepkeyWallet,az as KEEPKEY_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=C358D755D9B9BFA964756E2164756E21
3
+ //# debugId=D430A6A5BB1C684964756E2164756E21
@@ -6,11 +6,11 @@
6
6
  "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n SKConfig,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { GenericTransferParams } from \"@swapkit/helpers\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\nexport const cosmosWalletMethods = async ({\n sdk,\n derivationPath,\n}: { sdk: KeepKeySdk; derivationPath?: DerivationPathArray }) => {\n const {\n DEFAULT_COSMOS_FEE_MAINNET,\n getCosmosToolbox,\n getFeeRateFromThorswap,\n createStargateClient,\n } = await import(\"@swapkit/toolboxes/cosmos\");\n 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};\n",
7
7
  "/*\n KeepKey Specific bip32 path conventions\n*/\n\nimport { SwapKitError } from \"@swapkit/helpers\";\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 SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: `Not a bip32 path: '${path}'`,\n });\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Invalid input\" });\n\n const [, num = \"\", modifier = \"\"] = tmp;\n\n ret[i] = Number.parseInt(num, 10);\n\n if (ret[i] >= HARDENED)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Invalid child index\" });\n\n if (modifier === \"h\" || modifier === \"H\" || modifier === \"'\") {\n ret[i] += HARDENED;\n } else if (modifier.length > 0) {\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"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 SwapKitError,\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 SwapKitError(\"wallet_keepkey_method_not_supported\", { method: \"signTypedData\" });\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing to address\" });\n if (!gasLimit)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing gasLimit\" });\n if (!data) throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing data\" });\n\n const isEIP1559 = !!((maxFeePerGas || maxPriorityFeePerGas) && !gasPrice);\n if (isEIP1559 && !maxFeePerGas)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"Missing maxFeePerGas\" });\n if (isEIP1559 && !maxPriorityFeePerGas)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"Missing maxPriorityFeePerGas\",\n });\n if (!(isEIP1559 || gasPrice))\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", { reason: \"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 SwapKitError(\"wallet_keepkey_no_provider\");\n\n const signedTxHex = await this.signTransaction(tx);\n\n return await this.provider.broadcastTransaction(signedTxHex);\n };\n\n connect = (provider: Provider) =>\n new KeepKeySigner({\n sdk: this.sdk,\n chain: this.chain,\n derivationPath: this.derivationPath,\n provider,\n });\n}\n",
9
- "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n type AssetValue,\n Chain,\n ChainId,\n DerivationPath,\n type DerivationPathArray,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const mayachainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { createStargateClient, getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.Maya);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.MAYA}/0`;\n\n const { address: fromAddress } = (await sdk.address.mayachainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const { makeSignDoc } = (await import(\"@cosmjs/amino\")).default;\n const { getDenomWithChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const account = await toolbox.getAccount(sender);\n if (!account) throw new SwapKitError(\"wallet_keepkey_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 SwapKitError,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams } from \"@swapkit/toolboxes/cosmos\";\n\nimport { bip32ToAddressNList } from \"../coins\";\n\ntype SignTransactionParams = {\n assetValue: AssetValue;\n recipient?: string;\n sender: string;\n memo: string | undefined;\n};\n\nexport const thorchainWalletMethods = async ({\n sdk,\n derivationPath,\n}: {\n sdk: KeepKeySdk;\n derivationPath?: DerivationPathArray;\n}) => {\n const { makeSignDoc } = (await import(\"@cosmjs/amino\")).default;\n const { buildAminoMsg, getDefaultChainFee, createStargateClient, getCosmosToolbox } =\n await import(\"@swapkit/toolboxes/cosmos\");\n\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath.THOR}/0`;\n\n const { address: fromAddress } = (await sdk.address.thorchainGetAddress({\n address_n: bip32ToAddressNList(derivationPathString),\n })) as { address: string };\n\n const signTransaction = async ({\n assetValue,\n recipient,\n sender,\n memo,\n }: SignTransactionParams) => {\n const account = await toolbox.getAccount(sender);\n if (!account) throw new SwapKitError(\"wallet_keepkey_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 SwapKitError,\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"From address must be provided\",\n });\n if (!recipient)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"Recipient address must be provided\",\n });\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"
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 SwapKitError,\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 SwapKitError(\"wallet_keepkey_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 SwapKitError,\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 SwapKitError(\"wallet_keepkey_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 SwapKitError,\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}: {\n sdk: KeepKeySdk;\n chain: Exclude<UTXOChain, Chain.Zcash>;\n derivationPath?: DerivationPathArray;\n}) => {\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)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"From address must be provided\",\n });\n if (!recipient)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"Recipient address must be provided\",\n });\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": "iGAAA,cACE,2BAEA,eACA,kBACA,mBACA,kBACA,4BACA,0BAGF,qBAAS,8BCVT,gBACE,aACA,oBACA,eAEA,6BACA,0BCHF,uBAAS,yBAET,IAAM,EAAW,WAEL,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,EAAa,gCAAiC,CACtD,OAAQ,sBAAsB,IAChC,CAAC,EAGH,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,KACV,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,eAAgB,CAAC,EAErF,KAAS,EAAM,GAAI,EAAW,IAAM,EAIpC,GAFA,EAAI,GAAK,OAAO,SAAS,EAAK,EAAE,EAE5B,EAAI,IAAM,EACZ,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,qBAAsB,CAAC,EAE3F,GAAI,IAAa,KAAO,IAAa,KAAO,IAAa,IACvD,EAAI,IAAM,EACL,QAAI,EAAS,OAAS,EAC3B,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,kBAAmB,CAAC,GAK5F,OAAO,EDvDF,IAAM,EAAsB,OACjC,MACA,oBAC+D,CAC/D,IACE,6BACA,mBACA,yBACA,wBACE,KAAa,qCACX,EAAuB,EACzB,GAAuB,CAAc,EACrC,GAAG,GAAe,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,GAAS,IAAI,SAAS,EAAE,EAAM,OAAO,GACjD,YAAY,CAAU,GAEpC,iBAGa,QAAS,CAAY,GE3EtD,yBAEE,4BAEA,mBACA,4BACA,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,EAAa,sCAAuC,CAAE,OAAQ,eAAgB,CAAC,EAG3F,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,EACH,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,oBAAqB,CAAC,EAC1F,IAAK,EACH,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,kBAAmB,CAAC,EACxF,IAAK,EAAM,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,cAAe,CAAC,EAE7F,IAAM,MAAgB,GAAgB,KAA0B,GAChE,GAAI,IAAc,EAChB,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,sBAAuB,CAAC,EAC5F,GAAI,IAAc,EAChB,MAAM,IAAI,EAAa,gCAAiC,CACtD,OAAQ,8BACV,CAAC,EACH,KAAM,GAAa,GACjB,MAAM,IAAI,EAAa,gCAAiC,CAAE,OAAQ,kBAAmB,CAAC,EAExF,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,GAAe,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,EAAa,4BAA4B,EAEvE,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,CC3HA,gBAEE,aACA,qBACA,eAGA,kBACA,6BACA,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,gBAAiB,KAAa,0BAAkB,SAChD,qBAAsB,KAAa,qCAErC,EAAU,MAAM,EAAQ,WAAW,CAAM,EAC/C,IAAK,EAAS,MAAM,IAAI,GAAa,kCAAkC,EACvE,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,GCnH/D,gBAEE,aACA,qBACA,eAGA,kBACA,6BACA,0BAaK,IAAM,EAAyB,OACpC,MACA,oBAII,CACJ,IAAQ,gBAAiB,KAAa,0BAAkB,SAChD,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,GAAa,kCAAkC,EACvE,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,GClH/D,gBACE,oBACA,gBAEA,mBAEA,4BAEA,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,GA+C7C,MAAO,IAAK,EAAS,kBAAiB,SA5CrB,OACf,YACA,eACA,UACA,UACG,KACwB,CAC3B,IAAK,EACH,MAAM,IAAI,EAAa,gCAAiC,CACtD,OAAQ,+BACV,CAAC,EACH,IAAK,EACH,MAAM,IAAI,EAAa,gCAAiC,CACtD,OAAQ,oCACV,CAAC,EAEH,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,GNxHlE,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,EAAc,EAAS,IAAI,cAAc,EAAE,QACjD,IAAK,EAAa,MAAM,IAAI,MAAM,0BAA0B,EAE5D,IAAM,EAAgB,EAAS,IAAI,SAAS,EAAE,SAAW,OAEzD,MAAM,EAAe,EAGrB,IAAM,EAAgB,CAAE,OAAQ,EAAe,aAAY,EACrD,EAAa,MAAM,GAAW,OAAO,CAAa,EAGxD,GAAI,EAAc,QAAU,EAAc,SAAW,EACnD,EAAS,UAAU,UAAW,EAAc,MAAM,EAepD,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,UACN,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,GAAa,qCAAsC,CAAE,OAAM,CAAC,GAM5E,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,EAAQ,CACf,MAAO",
14
- "debugId": "C358D755D9B9BFA964756E2164756E21",
13
+ "mappings": "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",
14
+ "debugId": "D430A6A5BB1C684964756E2164756E21",
15
15
  "names": []
16
16
  }
@@ -1,3 +1,3 @@
1
- import{A as B}from"../../chunk-zfnkndsr.js";import{C as d,D as u}from"../../chunk-qwd1kp32.js";import{AssetValue as L,Chain as t,ChainIdToChain as V,SwapKitError as _,WalletOption as b,createWallet as j,filterSupportedChains as H}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as p,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var O=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new p("wallet_keepkey_chain_not_supported",{chain:e})}};function w(e){if(!window.keepkey)throw new p("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function F({method:e,params:c,chain:r}){let s=w(r);return new Promise((o,i)=>{if(s&&"request"in s)s.request({method:e,params:c},(n,m)=>{n?i(n):o(m)});else i(new p("wallet_provider_not_found"))})}async function k(e){let c=w(e);if(!c)throw new p({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[s]=await c.request({method:r,params:[]});return s}async function f({assetValue:e,recipient:c,memo:r,gasLimit:s},o="transfer"){if(!e)throw new p("wallet_keepkey_asset_not_defined");let i=await k(e.chain),n=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:s}];return F({method:o,params:n,chain:e.chain})}function l(e,c){return{call:async({contractAddress:r,abi:s,funcName:o,funcParams:i=[],txOverrides:n})=>{if(!r)throw new p("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:P}=await import("@swapkit/toolboxes/evm");if(y({abi:s,funcName:o})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:s,funcName:o,funcParams:i,txOverrides:n});return e.send("eth_sendTransaction",[{value:P(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,s,e)[o]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:s,amount:o,from:i})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:P,to:T,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[s,BigInt(o||n)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(P||0)),from:i,to:T,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:s,to:o,data:i,value:n}=r;if(!o)throw new p("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(n||0)),from:s,to:o,data:i||"0x"}])}}}var K=j({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:b.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function s(o){let i=H({chains:o,supportedChains:c,walletType:r});return await Promise.all(i.map(async(n)=>{let m=await k(n),g=await R(n);e({...g,address:m,chain:n,walletType:r})})),!0}}),S=B(K);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:s}=await import("@swapkit/toolboxes/cosmos"),o=e===t.Maya?s:r;return{...c(e),deposit:(n)=>f({...n,recipient:""},"deposit"),transfer:(n)=>f({...n,gasLimit:o},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(V[e]);if(!r)throw new _("wallet_keepkey_signer_not_found");let s=c(e,{signer:r}),o=await r.getAccounts();if(!o?.[0]?.address)throw new _("wallet_keepkey_no_accounts");let[{address:i}]=o;return{...s,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{let o=O(e),i=await window?.keepkey?.[o]?.request({method:"request_balance"});return[L.from({chain:e,value:i[0].balance})]},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:s}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:o}=await import("ethers"),i=w(e);if(!i)throw new _("wallet_keepkey_not_found");let n=new o(i,"any"),m=await n.getSigner(),g=await s(e,{provider:n,signer:m}),y=l(n,e);try{if(e!==t.Ethereum){let P=g.getNetworkParams();await r(n,e,P)}}catch(P){throw new _({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:b.KEEPKEY,chain:e}})}return c({provider:n,chain:e,toolbox:{...g,...y}})}default:return null}}export{K as keepkeyBexWallet,S as KEEPKEY_BEX_SUPPORTED_CHAINS};
1
+ import{A as B}from"../../chunk-46yzxdmt.js";import{C as d,D as u}from"../../chunk-qwd1kp32.js";import{AssetValue as L,Chain as t,ChainIdToChain as V,SwapKitError as _,WalletOption as b,createWallet as j,filterSupportedChains as H}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as p,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var O=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new p("wallet_keepkey_chain_not_supported",{chain:e})}};function w(e){if(!window.keepkey)throw new p("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function F({method:e,params:c,chain:r}){let s=w(r);return new Promise((o,i)=>{if(s&&"request"in s)s.request({method:e,params:c},(n,m)=>{n?i(n):o(m)});else i(new p("wallet_provider_not_found"))})}async function k(e){let c=w(e);if(!c)throw new p({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[s]=await c.request({method:r,params:[]});return s}async function f({assetValue:e,recipient:c,memo:r,gasLimit:s},o="transfer"){if(!e)throw new p("wallet_keepkey_asset_not_defined");let i=await k(e.chain),n=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:s}];return F({method:o,params:n,chain:e.chain})}function l(e,c){return{call:async({contractAddress:r,abi:s,funcName:o,funcParams:i=[],txOverrides:n})=>{if(!r)throw new p("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:P}=await import("@swapkit/toolboxes/evm");if(y({abi:s,funcName:o})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:s,funcName:o,funcParams:i,txOverrides:n});return e.send("eth_sendTransaction",[{value:P(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,s,e)[o]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:s,amount:o,from:i})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:P,to:T,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[s,BigInt(o||n)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(P||0)),from:i,to:T,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:s,to:o,data:i,value:n}=r;if(!o)throw new p("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(n||0)),from:s,to:o,data:i||"0x"}])}}}var K=j({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:b.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function s(o){let i=H({chains:o,supportedChains:c,walletType:r});return await Promise.all(i.map(async(n)=>{let m=await k(n),g=await R(n);e({...g,address:m,chain:n,walletType:r})})),!0}}),S=B(K);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:s}=await import("@swapkit/toolboxes/cosmos"),o=e===t.Maya?s:r;return{...c(e),deposit:(n)=>f({...n,recipient:""},"deposit"),transfer:(n)=>f({...n,gasLimit:o},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(V[e]);if(!r)throw new _("wallet_keepkey_signer_not_found");let s=c(e,{signer:r}),o=await r.getAccounts();if(!o?.[0]?.address)throw new _("wallet_keepkey_no_accounts");let[{address:i}]=o;return{...s,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{let o=O(e),i=await window?.keepkey?.[o]?.request({method:"request_balance"});return[L.from({chain:e,value:i[0].balance})]},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:s}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:o}=await import("ethers"),i=w(e);if(!i)throw new _("wallet_keepkey_not_found");let n=new o(i,"any"),m=await n.getSigner(),g=await s(e,{provider:n,signer:m}),y=l(n,e);try{if(e!==t.Ethereum){let P=g.getNetworkParams();await r(n,e,P)}}catch(P){throw new _({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:b.KEEPKEY,chain:e}})}return c({provider:n,chain:e,toolbox:{...g,...y}})}default:return null}}export{K as keepkeyBexWallet,S as KEEPKEY_BEX_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=0F160E0AAF7196EF64756E2164756E21
@@ -1,3 +1,3 @@
1
- import{A as v}from"../../chunk-zfnkndsr.js";import{C as m,D as h}from"../../chunk-qwd1kp32.js";import{Chain as c,CosmosChains as E,EVMChains as A,NetworkDerivationPath as _,UTXOChains as R,WalletOption as w,createWallet as U,filterSupportedChains as W,updateDerivationPath as F}from"@swapkit/helpers";import{createCipheriv as P,createDecipheriv as K,pbkdf2Sync as y,randomBytes as d}from"node:crypto";import{generateMnemonic as T,validateMnemonic as D}from"@scure/bip39";import{wordlist as g}from"@scure/bip39/wordlists/english";async function x(t){let{blake2bFinal:i,blake2bInit:s,blake2bUpdate:n}=(await import("blakejs")).default,e=t;if(!(e instanceof Buffer))e=Buffer.from(e,"hex");let a=s(32);return n(a,e),Array.from(i(a)).map((r)=>r<16?`0${r.toString(16)}`:r.toString(16)).join("")}async function V(t,i){let n=d(16),e=d(32),a={c:262144,prf:"hmac-sha256",dklen:32,salt:e.toString("hex")},r=y(i,e,a.c,a.dklen,"sha256"),p=P("aes-128-ctr",r.subarray(0,16),n),o=Buffer.concat([p.update(Buffer.from(t,"utf8")),p.final()]),f=Buffer.concat([r.subarray(16,32),Buffer.from(o)]),l=await x(f);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:n.toString("hex")},ciphertext:o.toString("hex"),kdf:"pbkdf2",kdfparams:a,mac:l}}}function H(t=12){return T(g,t===12?128:256)}function X(t){return D(t,g)}async function $(t,i){let{SwapKitError:s}=await import("@swapkit/helpers");switch(t.version){case 1:{let n=t.crypto.kdfparams,e=Buffer.from(n.salt,"hex"),a=y(i,e,n.c,n.dklen,"sha256"),r=Buffer.from(t.crypto.ciphertext,"hex"),p=Buffer.concat([a.subarray(16,32),r]);if(await x(p)!==t.crypto.mac)throw new s("wallet_keystore_invalid_password");let f=K(t.crypto.cipher,a.subarray(0,16),Buffer.from(t.crypto.cipherparams.iv,"hex"));return Buffer.concat([f.update(r),f.final()]).toString("utf8")}default:throw new s("wallet_keystore_unsupported_version")}}var N=U({name:"connectKeystore",walletType:w.KEYSTORE,supportedChains:[...A,...R,...E,c.Polkadot,c.Chainflip,c.Ripple,c.Solana,c.Tron,c.Near],connect:({addChain:t,supportedChains:i,walletType:s})=>async function n(e,a,r){let p=W({chains:e,supportedChains:i,walletType:s});return await Promise.all(p.map(async(o)=>{let f=typeof r==="number"?r:0,l=r&&typeof r==="object"?r[o]:void 0,b=_[o].slice(0,o===c.Solana?4:5),k=l||F(b,{index:f}),{getToolbox:S}=await import("@swapkit/toolboxes"),u=await S(o,{phrase:a,derivationPath:k}),C=await u.getAddress()||"",B={...u,address:C};t({...B,chain:o,walletType:w.KEYSTORE})})),!0}}),I=v(N);export{X as validatePhrase,N as keystoreWallet,H as generatePhrase,V as encryptToKeyStore,$ as decryptFromKeystore,I as KEYSTORE_SUPPORTED_CHAINS};
1
+ import{A as v}from"../../chunk-46yzxdmt.js";import{C as m,D as h}from"../../chunk-qwd1kp32.js";import{Chain as c,CosmosChains as E,EVMChains as A,NetworkDerivationPath as _,UTXOChains as R,WalletOption as w,createWallet as U,filterSupportedChains as W,updateDerivationPath as F}from"@swapkit/helpers";import{createCipheriv as P,createDecipheriv as K,pbkdf2Sync as y,randomBytes as d}from"node:crypto";import{generateMnemonic as T,validateMnemonic as D}from"@scure/bip39";import{wordlist as g}from"@scure/bip39/wordlists/english";async function x(t){let{blake2bFinal:i,blake2bInit:s,blake2bUpdate:n}=(await import("blakejs")).default,e=t;if(!(e instanceof Buffer))e=Buffer.from(e,"hex");let a=s(32);return n(a,e),Array.from(i(a)).map((r)=>r<16?`0${r.toString(16)}`:r.toString(16)).join("")}async function V(t,i){let n=d(16),e=d(32),a={c:262144,prf:"hmac-sha256",dklen:32,salt:e.toString("hex")},r=y(i,e,a.c,a.dklen,"sha256"),p=P("aes-128-ctr",r.subarray(0,16),n),o=Buffer.concat([p.update(Buffer.from(t,"utf8")),p.final()]),f=Buffer.concat([r.subarray(16,32),Buffer.from(o)]),l=await x(f);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:n.toString("hex")},ciphertext:o.toString("hex"),kdf:"pbkdf2",kdfparams:a,mac:l}}}function H(t=12){return T(g,t===12?128:256)}function X(t){return D(t,g)}async function $(t,i){let{SwapKitError:s}=await import("@swapkit/helpers");switch(t.version){case 1:{let n=t.crypto.kdfparams,e=Buffer.from(n.salt,"hex"),a=y(i,e,n.c,n.dklen,"sha256"),r=Buffer.from(t.crypto.ciphertext,"hex"),p=Buffer.concat([a.subarray(16,32),r]);if(await x(p)!==t.crypto.mac)throw new s("wallet_keystore_invalid_password");let f=K(t.crypto.cipher,a.subarray(0,16),Buffer.from(t.crypto.cipherparams.iv,"hex"));return Buffer.concat([f.update(r),f.final()]).toString("utf8")}default:throw new s("wallet_keystore_unsupported_version")}}var N=U({name:"connectKeystore",walletType:w.KEYSTORE,supportedChains:[...A,...R,...E,c.Polkadot,c.Chainflip,c.Ripple,c.Solana,c.Tron,c.Near],connect:({addChain:t,supportedChains:i,walletType:s})=>async function n(e,a,r){let p=W({chains:e,supportedChains:i,walletType:s});return await Promise.all(p.map(async(o)=>{let f=typeof r==="number"?r:0,l=r&&typeof r==="object"?r[o]:void 0,b=_[o].slice(0,o===c.Solana?4:5),k=l||F(b,{index:f}),{getToolbox:S}=await import("@swapkit/toolboxes"),u=await S(o,{phrase:a,derivationPath:k}),C=await u.getAddress()||"",B={...u,address:C};t({...B,chain:o,walletType:w.KEYSTORE})})),!0}}),I=v(N);export{X as validatePhrase,N as keystoreWallet,H as generatePhrase,V as encryptToKeyStore,$ as decryptFromKeystore,I as KEYSTORE_SUPPORTED_CHAINS};
2
2
 
3
3
  //# debugId=111FA87A0901E32464756E2164756E21