@swapkit/wallets 3.0.0-beta.15 → 3.0.0-beta.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/bitget/index.js +1 -1
- package/dist/src/coinbase/index.js +1 -1
- package/dist/src/ctrl/index.cjs +2 -2
- package/dist/src/ctrl/index.cjs.map +3 -3
- package/dist/src/ctrl/index.js +2 -2
- package/dist/src/ctrl/index.js.map +3 -3
- package/dist/src/evm-extensions/index.js +1 -1
- package/dist/src/exodus/index.js +1 -1
- package/dist/src/index.js +1 -1
- package/dist/src/keepkey/index.js +1 -1
- package/dist/src/keepkey-bex/index.js +1 -1
- package/dist/src/keystore/index.js +1 -1
- package/dist/src/ledger/index.cjs +2 -2
- package/dist/src/ledger/index.cjs.map +4 -4
- package/dist/src/ledger/index.js +2 -2
- package/dist/src/ledger/index.js.map +4 -4
- package/dist/src/okx/index.js +1 -1
- package/dist/src/onekey/index.js +1 -1
- package/dist/src/phantom/index.js +1 -1
- package/dist/src/polkadotjs/index.js +1 -1
- package/dist/src/radix/index.js +1 -1
- package/dist/src/talisman/index.js +1 -1
- package/dist/src/trezor/index.js +1 -1
- package/dist/src/walletconnect/index.js +1 -1
- package/package.json +3 -3
- package/src/ctrl/walletHelpers.ts +24 -8
- package/src/ledger/clients/evm.ts +1 -1
- package/src/ledger/helpers/getLedgerTransport.ts +1 -1
- /package/dist/{chunk-95tkswae.js → chunk-ndpqxys9.js} +0 -0
- /package/dist/{chunk-95tkswae.js.map → chunk-ndpqxys9.js.map} +0 -0
- /package/dist/{chunk-0vabeczs.js → chunk-wja505db.js} +0 -0
- /package/dist/{chunk-0vabeczs.js.map → chunk-wja505db.js.map} +0 -0
package/dist/src/bitget/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as h}from"../../chunk-
|
|
1
|
+
import{a as h}from"../../chunk-wja505db.js";import{c as w,d}from"../../chunk-p1kdg37m.js";import{Chain as m,EVMChains as P,WalletOption as v,createWallet as E,filterSupportedChains as y}from"@swapkit/helpers";import{Chain as s,ChainId as u,SwapKitError as l,prepareNetworkSwitch as b,switchEVMWalletNetwork as C}from"@swapkit/helpers";import{Psbt as _}from"bitcoinjs-lib";async function g(a){let t=window.bitkeep;switch(a){case s.Ethereum:case s.Base:case s.Avalanche:case s.Arbitrum:case s.Optimism:case s.Polygon:case s.BinanceSmartChain:{if(!(t&&("ethereum"in t)))throw new l("wallet_bitkeep_not_found");let e=t.ethereum,[r]=await e.send("eth_requestAccounts",[]);return{...await x({chain:a,walletProvider:e}),address:r}}case s.Bitcoin:{if(!(t&&("unisat"in t)))throw new l("wallet_bitkeep_not_found");let{unisat:e}=t,{getUtxoToolbox:r}=await import("@swapkit/toolboxes/utxo"),[o]=await e.requestAccounts();async function i(p){let f=await e.signPsbt(p.toHex(),{autoFinalized:!1});return _.fromHex(f)}let n={getAddress:()=>Promise.resolve(o),signTransaction:i};return{...await r(s.Bitcoin,{signer:n}),address:o}}case s.Cosmos:{if(!(t&&("keplr"in t)))throw new l("wallet_bitkeep_not_found");let{keplr:e}=t;await e.enable(u.Cosmos);let r=e.getOfflineSignerOnlyAmino(u.Cosmos),o=await r.getAccounts();if(!o?.[0])throw new Error("No cosmos account found");let{getCosmosToolbox:i}=await import("@swapkit/toolboxes/cosmos"),[{address:n}]=o,c={...r,getAddress:()=>Promise.resolve(n),signTransaction:async()=>Promise.resolve({})};return{...i(s.Cosmos,{signer:c}),address:n}}case s.Solana:{if(!(t&&("solana"in t)))throw new l("wallet_bitkeep_not_found");let{getSolanaToolbox:e}=await import("@swapkit/toolboxes/solana"),r=t?.solana,o=e({signer:r}),n=(await r.connect()).publicKey.toString();return{...o,address:n}}default:throw new l("wallet_chain_not_supported")}}var x=async({chain:a,walletProvider:t})=>{let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:r}=await import("ethers");if(!t)throw new l("wallet_provider_not_found");let o=new r(t,"any"),i=await o.getSigner(),n=await e(a,{provider:o,signer:i});try{if(a!==s.Ethereum&&"getNetworkParams"in n)await C(o,a,n.getNetworkParams())}catch(c){throw new Error(`Failed to add/switch ${a} network: ${a}`)}return b({chain:a,toolbox:n,provider:o})};var S=E({name:"connectBitget",walletType:v.BITGET,supportedChains:[...P,m.Cosmos,m.Bitcoin,m.Solana],connect:({addChain:a,walletType:t,supportedChains:e})=>async function r(o){let i=y({chains:o,supportedChains:e,walletType:t});return await Promise.all(i.map(async(n)=>{let c=await g(n),p=await c.getAddress()||"";a({...c,address:p,chain:n,walletType:t})})),!0}}),N=h(S);export{S as bitgetWallet,N as BITGET_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=39BB292BD7B8372B64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as g}from"../../chunk-
|
|
1
|
+
import{a as g}from"../../chunk-wja505db.js";import{c as p,d as h}from"../../chunk-p1kdg37m.js";import{Chain as a,ChainToChainId as b,SKConfig as P,WalletOption as f,createWallet as v,filterSupportedChains as y}from"@swapkit/helpers";import{Chain as s}from"@swapkit/helpers";async function w(t,r){let{AbstractSigner:i}=await import("ethers");class o extends i{#e;constructor(e,n){super(n);this.#e=e}async getAddress(){let e=await this.#e.request({method:"eth_requestAccounts"});if(!e[0])throw new Error("No Account found");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 Error("this method is not implemented")};connect(e){return new o(this.#e,e)}}return new o(t,r)}var u=async({chain:t,coinbaseSdk:r})=>{switch(t){case s.Ethereum:case s.Avalanche:case s.Arbitrum:case s.Optimism:case s.Polygon:case s.BinanceSmartChain:{let i=r.getProvider(),{getEvmToolbox:o,getProvider:e}=await import("@swapkit/toolboxes/evm"),n=await e(t),c=await w(i,n),d=await o(t,{provider:n,signer:c}),m=await c.getAddress();return{...d,address:m}}default:throw new Error(`No wallet for chain ${t}`)}};var S=v({name:"connectCoinbaseWallet",walletType:f.COINBASE_MOBILE,supportedChains:[a.Arbitrum,a.Avalanche,a.Base,a.BinanceSmartChain,a.Ethereum,a.Optimism,a.Polygon],connect:({addChain:t,walletType:r,supportedChains:i})=>async function o(e){let{createCoinbaseWalletSDK:n}=await import("@coinbase/wallet-sdk"),c=y({chains:e,supportedChains:i,walletType:r}),d=P.get("integrations").coinbase||{appName:"Swapkit Playground"},m=n({...d,appChainIds:c.map((l)=>Number(b[l]))});return await Promise.all(c.map(async(l)=>{let C=await u({chain:l,coinbaseSdk:m});t({...C,chain:l,walletType:r})})),!0}}),T=g(S);export{S as coinbaseWallet,T as COINBASE_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=537C3F16ED1E206364756E2164756E21
|
package/dist/src/ctrl/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
var
|
|
1
|
+
var Z={};J(Z,{ctrlWallet:()=>O,CTRL_SUPPORTED_CHAINS:()=>N});module.exports=F(Z);var o=require("@swapkit/helpers");var w=require("@swapkit/helpers"),E=require("@swapkit/helpers/contracts");async function R(t){if(!window.xfi)throw new w.SwapKitError("wallet_ctrl_not_found");let{match:y}=await import("ts-pattern");return y(t).with(w.Chain.Arbitrum,w.Chain.Avalanche,w.Chain.Base,w.Chain.BinanceSmartChain,w.Chain.Ethereum,w.Chain.Optimism,w.Chain.Polygon,()=>window.xfi?.ethereum).with(w.Chain.Cosmos,w.Chain.Kujira,w.Chain.Maya,w.Chain.THORChain,()=>window.xfi?.keplr).with(w.Chain.Bitcoin,()=>window.xfi?.bitcoin).with(w.Chain.BitcoinCash,()=>window.xfi?.bitcoincash).with(w.Chain.Dogecoin,()=>window.xfi?.dogecoin).with(w.Chain.Litecoin,()=>window.xfi?.litecoin).with(w.Chain.Solana,()=>window.xfi?.solana).otherwise(()=>{return})}async function A({method:t,params:y,chain:_}){let f=await R(_);return new Promise((l,n)=>{if(f&&"request"in f)f.request({method:t,params:y},(T,g)=>{T?n(T):l(g)})})}async function W(t){let y=await R(t);if(!y)throw new w.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:w.WalletOption.CTRL,chain:t}});if([w.Chain.Cosmos,w.Chain.Kujira].includes(t)){let l=await R(w.Chain.Cosmos);if(!l||"request"in l)throw new w.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:w.WalletOption.CTRL,chain:t}});let n=w.ChainToChainId[t];await l.enable(n);let T=l.getOfflineSigner(n),[g]=await T.getAccounts();return g?.address}if(w.EVMChains.includes(t)){let{BrowserProvider:l}=await import("ethers"),n=new l(y,"any"),[T]=await w.providerRequest({provider:n,method:"eth_requestAccounts",params:[]});return T}if(t===w.Chain.Solana)return(await(await R(w.Chain.Solana)).connect()).publicKey.toString();let{BrowserProvider:_}=await import("ethers"),f=new _(y,"any");try{let[l]=await w.providerRequest({provider:f,method:"eth_requestAccounts",params:[]});return l}catch(l){throw new w.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:w.WalletOption.CTRL,chain:t}})}}async function S({assetValue:t,recipient:y,memo:_,gasLimit:f},l="transfer"){if(!t)throw new w.SwapKitError("wallet_ctrl_asset_not_defined");let n=await W(t.chain),T=[{amount:{amount:t.getBaseValue("number"),decimals:t.decimal},asset:{chain:t.chain,symbol:t.symbol.toUpperCase(),ticker:t.symbol.toUpperCase()},memo:_||"",from:n,recipient:y,gasLimit:f}];return A({method:l,params:T,chain:t.chain})}function I(t,y){return{call:async({contractAddress:_,abi:f,funcName:l,funcParams:n=[],txOverrides:T})=>{if(!_)throw new w.SwapKitError("wallet_ctrl_contract_address_not_provided");let{createContract:g,getCreateContractTxObject:L,isStateChangingCall:M,toHexString:b}=await import("@swapkit/toolboxes/evm");if(M({abi:f,funcName:l})){let D=L({provider:t,chain:y}),{value:U,from:k,to:m,data:z}=await D({contractAddress:_,abi:f,funcName:l,funcParams:n,txOverrides:T});return t.send("eth_sendTransaction",[{value:b(BigInt(U||0)),from:k,to:m,data:z||"0x"}])}let G=await g(_,f,t)[l]?.(...n);return typeof G?.hash==="string"?G?.hash:G},approve:async({assetAddress:_,spenderAddress:f,amount:l,from:n})=>{let{MAX_APPROVAL:T,getCreateContractTxObject:g,toHexString:L}=await import("@swapkit/toolboxes/evm"),M=[f,BigInt(l||T)],x={contractAddress:_,abi:E.erc20ABI,funcName:"approve",funcParams:M,txOverrides:{from:n}},H=g({provider:t,chain:y}),{value:G,to:D,data:U}=await H(x);return t.send("eth_sendTransaction",[{value:L(BigInt(G||0)),from:n,to:D,data:U||"0x"}])},sendTransaction:async(_)=>{let{from:f,to:l,data:n,value:T}=_;if(!l)throw new w.SwapKitError("wallet_ctrl_send_transaction_no_address");let{toHexString:g}=await import("@swapkit/toolboxes/evm");return t.send("eth_sendTransaction",[{value:g(BigInt(T||0)),from:f,to:l,data:n||"0x"}])}}}var O=o.createWallet({name:"connectCtrl",walletType:o.WalletOption.CTRL,supportedChains:[o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Base,o.Chain.BinanceSmartChain,o.Chain.Bitcoin,o.Chain.BitcoinCash,o.Chain.Cosmos,o.Chain.Dogecoin,o.Chain.Ethereum,o.Chain.Kujira,o.Chain.Litecoin,o.Chain.Maya,o.Chain.Optimism,o.Chain.Polygon,o.Chain.Solana,o.Chain.THORChain],connect:({addChain:t,walletType:y,supportedChains:_})=>async function f(l){let T=o.filterSupportedChains({chains:l,supportedChains:_,walletType:y}).map(async(g)=>{let L=await W(g),M=await Q(g);t({...M,address:L,chain:g,walletType:y})});return await Promise.all(T),!0}}),N=Y(O);async function Q(t){switch(t){case o.Chain.Solana:{let{getSolanaToolbox:y}=await import("@swapkit/toolboxes/solana"),_=window.xfi?.solana;if(!_)throw new o.SwapKitError("wallet_ctrl_not_found");return{...y({signer:_})}}case o.Chain.Maya:case o.Chain.THORChain:{let{getCosmosToolbox:y,THORCHAIN_GAS_VALUE:_,MAYA_GAS_VALUE:f}=await import("@swapkit/toolboxes/cosmos"),l=t===o.Chain.Maya?f:_;return{...await y(t),deposit:(T)=>S({...T,recipient:""},"deposit"),transfer:(T)=>S({...T,gasLimit:l},"transfer")}}case o.Chain.Cosmos:case o.Chain.Kujira:{let{getCosmosToolbox:y}=await import("@swapkit/toolboxes/cosmos"),_=o.ChainToChainId[t],f=await R(t);await f?.enable(_);let l=f?.getOfflineSignerOnlyAmino(_);if(!l)throw new o.SwapKitError("wallet_ctrl_not_found");return y(t,{signer:l})}case o.Chain.Bitcoin:case o.Chain.BitcoinCash:case o.Chain.Dogecoin:case o.Chain.Litecoin:{let{getUtxoToolbox:y}=await import("@swapkit/toolboxes/utxo");return{...await y(t),transfer:S}}case o.Chain.Arbitrum:case o.Chain.Avalanche:case o.Chain.Base:case o.Chain.BinanceSmartChain:case o.Chain.Ethereum:case o.Chain.Optimism:case o.Chain.Polygon:{let{prepareNetworkSwitch:y,switchEVMWalletNetwork:_}=await import("@swapkit/helpers"),{getEvmToolbox:f}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:l}=await import("ethers"),n=await R(t);if(!n)throw new o.SwapKitError("wallet_ctrl_not_found");let T=new l(n,"any"),g=await T.getSigner(),L=await f(t,{provider:T,signer:g}),M=I(T,t);try{if(t!==o.Chain.Ethereum){let b=L.getNetworkParams();await _(T,t,b)}}catch(b){throw new o.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:o.WalletOption.CTRL,chain:t}})}return y({provider:window.xfi?.ethereum,chain:t,toolbox:{...L,...M}})}default:return null}}
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=BF6EABAD47C4D37864756E2164756E21
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n default:\n return null;\n }\n}\n",
|
|
6
|
-
"import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n const [response] = await
|
|
6
|
+
"import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n\n try {\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall, toHexString } =\n await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject, toHexString } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n sendTransaction: async (tx: EVMTxParams) => {\n const { from, to, data, value } = tx;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n };\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "iFAQO,IARP,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "BF6EABAD47C4D37864756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
package/dist/src/ctrl/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as A}from"../../chunk-wja505db.js";import{c as B,d as L}from"../../chunk-p1kdg37m.js";import{Chain as t,ChainToChainId as P,SwapKitError as W,WalletOption as z,createWallet as j,filterSupportedChains as X}from"@swapkit/helpers";import{Chain as n,ChainToChainId as Q,EVMChains as Z,SwapKitError as b,WalletOption as E,providerRequest as k}from"@swapkit/helpers";import{erc20ABI as $}from"@swapkit/helpers/contracts";async function G(o){if(!window.xfi)throw new b("wallet_ctrl_not_found");let{match:_}=await import("ts-pattern");return _(o).with(n.Arbitrum,n.Avalanche,n.Base,n.BinanceSmartChain,n.Ethereum,n.Optimism,n.Polygon,()=>window.xfi?.ethereum).with(n.Cosmos,n.Kujira,n.Maya,n.THORChain,()=>window.xfi?.keplr).with(n.Bitcoin,()=>window.xfi?.bitcoin).with(n.BitcoinCash,()=>window.xfi?.bitcoincash).with(n.Dogecoin,()=>window.xfi?.dogecoin).with(n.Litecoin,()=>window.xfi?.litecoin).with(n.Solana,()=>window.xfi?.solana).otherwise(()=>{return})}async function c({method:o,params:_,chain:l}){let T=await G(l);return new Promise((w,f)=>{if(T&&"request"in T)T.request({method:o,params:_},(y,g)=>{y?f(y):w(g)})})}async function I(o){let _=await G(o);if(!_)throw new b({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:o}});if([n.Cosmos,n.Kujira].includes(o)){let w=await G(n.Cosmos);if(!w||"request"in w)throw new b({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:o}});let f=Q[o];await w.enable(f);let y=w.getOfflineSigner(f),[g]=await y.getAccounts();return g?.address}if(Z.includes(o)){let{BrowserProvider:w}=await import("ethers"),f=new w(_,"any"),[y]=await k({provider:f,method:"eth_requestAccounts",params:[]});return y}if(o===n.Solana)return(await(await G(n.Solana)).connect()).publicKey.toString();let{BrowserProvider:l}=await import("ethers"),T=new l(_,"any");try{let[w]=await k({provider:T,method:"eth_requestAccounts",params:[]});return w}catch(w){throw new b({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:o}})}}async function U({assetValue:o,recipient:_,memo:l,gasLimit:T},w="transfer"){if(!o)throw new b("wallet_ctrl_asset_not_defined");let f=await I(o.chain),y=[{amount:{amount:o.getBaseValue("number"),decimals:o.decimal},asset:{chain:o.chain,symbol:o.symbol.toUpperCase(),ticker:o.symbol.toUpperCase()},memo:l||"",from:f,recipient:_,gasLimit:T}];return c({method:w,params:y,chain:o.chain})}function m(o,_){return{call:async({contractAddress:l,abi:T,funcName:w,funcParams:f=[],txOverrides:y})=>{if(!l)throw new b("wallet_ctrl_contract_address_not_provided");let{createContract:g,getCreateContractTxObject:M,isStateChangingCall:R,toHexString:S}=await import("@swapkit/toolboxes/evm");if(R({abi:T,funcName:w})){let x=M({provider:o,chain:_}),{value:H,from:F,to:J,data:N}=await x({contractAddress:l,abi:T,funcName:w,funcParams:f,txOverrides:y});return o.send("eth_sendTransaction",[{value:S(BigInt(H||0)),from:F,to:J,data:N||"0x"}])}let D=await g(l,T,o)[w]?.(...f);return typeof D?.hash==="string"?D?.hash:D},approve:async({assetAddress:l,spenderAddress:T,amount:w,from:f})=>{let{MAX_APPROVAL:y,getCreateContractTxObject:g,toHexString:M}=await import("@swapkit/toolboxes/evm"),R=[T,BigInt(w||y)],O={contractAddress:l,abi:$,funcName:"approve",funcParams:R,txOverrides:{from:f}},Y=g({provider:o,chain:_}),{value:D,to:x,data:H}=await Y(O);return o.send("eth_sendTransaction",[{value:M(BigInt(D||0)),from:f,to:x,data:H||"0x"}])},sendTransaction:async(l)=>{let{from:T,to:w,data:f,value:y}=l;if(!w)throw new b("wallet_ctrl_send_transaction_no_address");let{toHexString:g}=await import("@swapkit/toolboxes/evm");return o.send("eth_sendTransaction",[{value:g(BigInt(y||0)),from:T,to:w,data:f||"0x"}])}}}var K=j({name:"connectCtrl",walletType:z.CTRL,supportedChains:[t.Arbitrum,t.Avalanche,t.Base,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Cosmos,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],connect:({addChain:o,walletType:_,supportedChains:l})=>async function T(w){let y=X({chains:w,supportedChains:l,walletType:_}).map(async(g)=>{let M=await I(g),R=await q(g);o({...R,address:M,chain:g,walletType:_})});return await Promise.all(y),!0}}),d=A(K);async function q(o){switch(o){case t.Solana:{let{getSolanaToolbox:_}=await import("@swapkit/toolboxes/solana"),l=window.xfi?.solana;if(!l)throw new W("wallet_ctrl_not_found");return{..._({signer:l})}}case t.Maya:case t.THORChain:{let{getCosmosToolbox:_,THORCHAIN_GAS_VALUE:l,MAYA_GAS_VALUE:T}=await import("@swapkit/toolboxes/cosmos"),w=o===t.Maya?T:l;return{...await _(o),deposit:(y)=>U({...y,recipient:""},"deposit"),transfer:(y)=>U({...y,gasLimit:w},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:_}=await import("@swapkit/toolboxes/cosmos"),l=P[o],T=await G(o);await T?.enable(l);let w=T?.getOfflineSignerOnlyAmino(l);if(!w)throw new W("wallet_ctrl_not_found");return _(o,{signer:w})}case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:_}=await import("@swapkit/toolboxes/utxo");return{...await _(o),transfer:U}}case t.Arbitrum:case t.Avalanche:case t.Base:case t.BinanceSmartChain:case t.Ethereum:case t.Optimism:case t.Polygon:{let{prepareNetworkSwitch:_,switchEVMWalletNetwork:l}=await import("@swapkit/helpers"),{getEvmToolbox:T}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:w}=await import("ethers"),f=await G(o);if(!f)throw new W("wallet_ctrl_not_found");let y=new w(f,"any"),g=await y.getSigner(),M=await T(o,{provider:y,signer:g}),R=m(y,o);try{if(o!==t.Ethereum){let S=M.getNetworkParams();await l(y,o,S)}}catch(S){throw new W({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:z.CTRL,chain:o}})}return _({provider:window.xfi?.ethereum,chain:o,toolbox:{...M,...R}})}default:return null}}export{K as ctrlWallet,d as CTRL_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=DDB500493B3F745264756E2164756E21
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n default:\n return null;\n }\n}\n",
|
|
6
|
-
"import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n const [response] = await
|
|
6
|
+
"import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n\n try {\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall, toHexString } =\n await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject, toHexString } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n sendTransaction: async (tx: EVMTxParams) => {\n const { from, to, data, value } = tx;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n };\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "iGAAA,cACE,oBACA,kBAEA,kBACA,kBACA,2BACA,yBCNF,gBAEE,oBACA,eAEA,kBAEA,kBACA,yBAEF,mBAAS,mCAwBT,eAAsB,CAAgC,CACpD,EASA,CACA,IAAK,OAAO,IAAK,MAAM,IAAI,EAAa,uBAAuB,EAC/D,IAAQ,SAAU,KAAa,sBAG/B,OAAO,EAAM,CAAc,EACxB,KACC,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,SACN,EAAM,SACN,EAAM,QACN,IAAM,OAAO,KAAK,QACpB,EACC,KAAK,EAAM,OAAQ,EAAM,OAAQ,EAAM,KAAM,EAAM,UAAW,IAAM,OAAO,KAAK,KAAK,EACrF,KAAK,EAAM,QAAS,IAAM,OAAO,KAAK,OAAO,EAC7C,KAAK,EAAM,YAAa,IAAM,OAAO,KAAK,WAAW,EACrD,KAAK,EAAM,SAAU,IAAM,OAAO,KAAK,QAAQ,EAC/C,KAAK,EAAM,SAAU,IAAM,OAAO,KAAK,QAAQ,EAC/C,KAAK,EAAM,OAAQ,IAAM,OAAO,KAAK,MAAM,EAC3C,UAAU,IAAG,CAAG,OAAS,EAG9B,eAAe,CAAW,EACxB,SACA,SACA,SAKkB,CAClB,IAAM,EAAS,MAAM,EAAgB,CAAK,EAE1C,OAAO,IAAI,QAAgB,CAAC,EAAS,IAAW,CAC9C,GAAI,GAAU,YAAa,EAEzB,EAAO,QAAQ,CAAE,SAAQ,QAAO,EAAG,CAAC,EAAa,IAAe,CAC9D,EAAM,EAAO,CAAG,EAAI,EAAQ,CAAE,EAC/B,EAEJ,EAGH,eAAsB,CAAc,CAAC,EAAc,CACjD,IAAM,EAAe,MAAM,EAAgB,CAAK,EAChD,IAAK,EACH,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAGH,GAAI,CAAC,EAAM,OAAQ,EAAM,MAAM,EAAE,SAAS,CAAK,EAAG,CAChD,IAAM,EAAW,MAAM,EAAgB,EAAM,MAAM,EACnD,IAAK,GAAY,YAAa,EAC5B,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAMH,IAAM,EAAU,EAAe,GAC/B,MAAM,EAAS,OAAO,CAAO,EAE7B,IAAM,EAAgB,EAAS,iBAAiB,CAAO,GAEhD,GAAQ,MAAM,EAAc,YAAY,EAC/C,OAAO,GAAM,QAGf,GAAI,EAAU,SAAS,CAAiB,EAAG,CACzC,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "DDB500493B3F745264756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as M}from"../../chunk-
|
|
1
|
+
import{a as M}from"../../chunk-wja505db.js";import{c as u,d as O}from"../../chunk-p1kdg37m.js";import{Chain as A,ChainToHexChainId as m,EVMChains as B,WalletOption as l,createWallet as C,filterSupportedChains as P,prepareNetworkSwitch as f,switchEVMWalletNetwork as N}from"@swapkit/helpers";var W=(n)=>{switch(n){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},g=async({address:n,walletProvider:w,chain:t,provider:r})=>{if(!w)throw new Error("Requested web3 wallet is not installed");let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm"),a=await r.getSigner(),i=await e(t,{provider:r,signer:a});if(t!==A.Ethereum){if((await r.getNetwork()).chainId.toString()!==m[t])try{let o=i.getNetworkParams();await N(r,t,o)}catch(o){throw new Error(`Failed to add/switch ${t} network: ${t}`)}}return f({toolbox:{...i,getBalance:()=>i.getBalance(n)},chain:t,provider:r})},T=C({name:"connectEVMWallet",supportedChains:[...B],connect:({addChain:n,supportedChains:w})=>async function t(r,e=l.METAMASK,a){let i=P({chains:r,supportedChains:w,walletType:e}),{BrowserProvider:c}=await import("ethers");return await Promise.all(i.map(async(o)=>{if(e===l.EIP6963){if(!a)throw new Error("Missing provider");let E=new c(a,"any");await E.send("eth_requestAccounts",[]);let p=await(await E.getSigner()).getAddress(),S=await g({address:p,chain:o,provider:E,walletProvider:a});n({...S,address:p,chain:o,walletType:e});return}let s=new c(W(e),"any");await s.send("eth_requestAccounts",[]);let d=await(await s.getSigner()).getAddress(),h=await g({address:d,chain:o,walletProvider:W(e),provider:s});n({...h,address:d,chain:o,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:e})})),!0}}),x=M(T);export{g as getWeb3WalletMethods,T as evmWallet,x as EVM_EXTENSIONS_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=7A8B333E21590AB164756E2164756E21
|
package/dist/src/exodus/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as j}from"../../chunk-
|
|
1
|
+
import{a as j}from"../../chunk-wja505db.js";import{c as K,d as R}from"../../chunk-p1kdg37m.js";import{Chain as F,EVMChains as m,SwapKitError as A,WalletOption as U,createWallet as B,filterSupportedChains as E,prepareNetworkSwitch as M,switchEVMWalletNetwork as N}from"@swapkit/helpers";import{Psbt as S}from"bitcoinjs-lib";import{AddressPurpose as O,BitcoinNetworkType as f,getAddress as y,signTransaction as W}from"sats-connect";export*from"@passkeys/react";export*from"@passkeys/core";async function u({walletProvider:_,provider:Y,chain:z}){switch(z){case F.Bitcoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo"),G="",I=()=>new Promise((q)=>q(Y)),H={getProvider:I,payload:{purposes:[O.Payment],message:"Address for receiving and sending payments",network:{type:f.Mainnet}},onFinish:(q)=>{if(!q.addresses[0])throw new Error("No address found");G=q.addresses[0].address},onCancel:()=>{throw new Error("Request canceled")}};await y(H);async function L(q){let X,$={getProvider:I,payload:{message:"Sign transaction",network:{type:f.Mainnet},psbtBase64:q.toBase64(),broadcast:!1,inputsToSign:[{address:G,signingIndexes:q.txInputs.map((D,V)=>V)}]},onFinish:(D)=>{X=S.fromBase64(D.psbtBase64)},onCancel:()=>{throw new Error("Signature canceled")}};if(await W($),!X)throw new A("wallet_exodus_sign_transaction_error");return X}return{...await Z(z,{signer:{signTransaction:L,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 Error("Requested web3 wallet is not installed");let{getProvider:Z,getEvmToolbox:G}=await import("@swapkit/toolboxes/evm"),I=await Z(z),H=Y;await H.send("eth_requestAccounts",[]);let L=await H.getSigner(),Q=await L.getAddress(),J=await G(z,{provider:I,signer:L});try{if(z!==F.Ethereum){let q=J.getNetworkParams();await N(H,z,q)}}catch(q){throw new Error(`Failed to add/switch ${z} network: ${z}`)}return{...M({toolbox:J,chain:z,provider:H}),address:Q}}default:throw new Error(`Unsupported chain: ${z}`)}}var k=B({name:"connectExodusWallet",walletType:U.EXODUS,supportedChains:[...m,F.Bitcoin],connect:({addChain:_,walletType:Y,supportedChains:z})=>async function Z(G,I){if(!I)throw new Error("Missing Exodus Wallet instance");let H=E({chains:G,supportedChains:z,walletType:Y}),{BrowserProvider:L}=await import("ethers"),{providers:Q}=I;return await Promise.all(H.map(async(J)=>{let q=J===F.Bitcoin?Q.bitcoin:new L(Q.ethereum,"any"),{address:X,...$}=await u({chain:J,provider:q,walletProvider:Q.ethereum});_({...$,disconnect:()=>q.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:J,address:X,walletType:U.EXODUS})})),!0}}),C=j(k);export{k as exodusWallet,C as EXODUS_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=3A555307E01DF90164756E2164756E21
|
package/dist/src/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as l,b as n}from"../chunk-
|
|
1
|
+
import{a as l,b as n}from"../chunk-wja505db.js";import"../chunk-p1kdg37m.js";export{n as loadWallet,l as getWalletSupportedChains};
|
|
2
2
|
|
|
3
3
|
//# debugId=83059F908E6CD5F764756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as o}from"../../chunk-0vabeczs.js";import{c as w,d as F}from"../../chunk-p1kdg37m.js";import{Chain as X,NetworkDerivationPath as Wz,SKConfig as h,WalletOption as d,createWallet as Gz,filterSupportedChains as Lz}from"@swapkit/helpers";import{KeepKeySdk as _z}from"@keepkey/keepkey-sdk";import{Chain as P,ChainId as u,DerivationPath as t,SKConfig as i,derivationPathToString as a}from"@swapkit/helpers";var y;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(y||={});function s(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function V(z){let J=z;if(!s(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let Y=Q[Z];if(Y){let q=/(\d+)([hH']?)/.exec(Y);if(q===null)throw new Error("Invalid input");let[,$="",j=""]=q;if(R[Z]=Number.parseInt($,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var C=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos");try{let q=J?a(J):`${t.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:V(q)}),j=await R(P.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(u.Cosmos,500));return{...j,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=B.getBaseValue("string"),U=await j.getAccount($),H=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:U?.sequence.toString()??"",chain_id:u.Cosmos,account_number:U?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:_}],to_address:W,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),M=atob(H.serialized),I=new Uint8Array(M.length).map((N,E)=>M.charCodeAt(E));return(await(await Y(i.get("rpcUrls")[P.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(q){throw console.error(q),q}};import{ChainToChainId as e,NetworkDerivationPath as zz,derivationPathToString as Jz}from"@swapkit/helpers";import{AbstractSigner as Qz}from"ethers";class S extends Qz{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||zz.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:V(Jz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:q,gasPrice:$})=>{if(!z)throw new Error("Missing to address");if(!Q)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((Y||q)&&!$);if(j&&!Y)throw new Error("Missing maxFeePerGas");if(j&&!q)throw new Error("Missing maxFeePerGas");if(!(j||$))throw new Error("Missing gasPrice");let{toHexString:G}=await import("@swapkit/toolboxes/evm"),B=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),W={gas:G(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:G(BigInt(e[this.chain])),to:z.toString(),value:G(BigInt(J||0)),nonce:G(B),data:Z,...j&&{maxFeePerGas:G(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:G(BigInt(q?.toString()||"0"))},...!j&&{gasPrice:G(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(W)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new S({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as k,ChainId as Xz,DerivationPath as Yz,SKConfig as g,derivationPathToString as Zz}from"@swapkit/helpers";var l=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(k.Maya),Y=J?Zz(J):`${Yz.MAYA}/0`,{address:q}=await z.address.mayachainGetAddress({address_n:V(Y)}),$=async({assetValue:B,recipient:W,sender:L,memo:_})=>{let{makeSignDoc:U}=(await import("@cosmjs/amino")).default,{getDenomWithChain:H}=await import("@swapkit/toolboxes/cosmos"),M=await Z.getAccount(L);if(!M)throw new Error("Account not found");let{accountNumber:I,sequence:D=0}=M,O=B.getBaseValue("string"),N=W&&W!=="",E=N?{type:"mayachain/MsgSend",value:{amount:[{amount:O,denom:B.symbol.toLowerCase()}],from_address:L,to_address:W}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:O,asset:H(B)}],memo:_,signer:L}},A=U([E],{gas:"500000000",amount:[]},Xz.Maya,_,I?.toString(),D),K=await(N?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:A,signerAddress:L}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...Z,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=await Q(g.get("rpcUrls")[k.Maya]),U=await $({assetValue:B,recipient:W,memo:L,sender:q}),{transactionHash:H}=await _.broadcastTx(U);return H},deposit:async({assetValue:B,memo:W})=>{let L=await Q(g.get("rpcUrls")[k.Maya]),_=await $({assetValue:B,memo:W,sender:q}),{transactionHash:U}=await L.broadcastTx(_);return U},address:q}};import{Chain as T,ChainId as $z,DerivationPath as qz,SKConfig as p,derivationPathToString as jz}from"@swapkit/helpers";var m=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=(await import("@cosmjs/amino")).default,{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:q}=await import("@swapkit/toolboxes/cosmos"),$=await q(T.THORChain),j=J?jz(J):`${qz.THOR}/0`,{address:G}=await z.address.thorchainGetAddress({address_n:V(j)}),B=async({assetValue:_,recipient:U,sender:H,memo:M})=>{let I=await $.getAccount(H);if(!I)throw new Error("Account not found");let{accountNumber:D,sequence:O=0}=I,N=U&&U!=="",E=R({sender:H,recipient:U,assetValue:_,memo:M}),A=$z.THORChain,b=Q([E],Z(T.THORChain),A,M,D?.toString(),O),K=N?await z.thorchain.thorchainSignAminoTransfer({signDoc:b,signerAddress:H}):await z.thorchain.thorchainSignAminoDeposit({signDoc:b,signerAddress:H}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...$,transfer:async({assetValue:_,recipient:U,memo:H})=>{let M=await Y(p.get("rpcUrls")[T.THORChain]),I=await B({assetValue:_,recipient:U,memo:H,sender:G}),{transactionHash:D}=await M.broadcastTx(I);return D},deposit:async({assetValue:_,memo:U})=>{let H=await Y(p.get("rpcUrls")[T.THORChain]),M=await B({assetValue:_,memo:U,sender:G}),{transactionHash:I}=await H.broadcastTx(M);return I},address:G}};import{Chain as x,DerivationPath as Uz,FeeOption as Rz,derivationPathToString as Bz}from"@swapkit/helpers";var c=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[x.Bitcoin,x.Litecoin].includes(J)?"p2wpkh":"p2pkh",q=Q?Bz(Q):`${Uz[J]}/0`,$={coin:y[J],script_type:Y,address_n:V(q)},j=(await z.address.utxoGetAddress($)).address,G=async(W,L,_="")=>{let U=W.txOutputs.map((I)=>{let{value:D,address:O,change:N}=I,E=J===x.BitcoinCash?Z.stripToCashAddress(O):O;if(N||O===j)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:D,scriptType:Y};if(E)return{address:E,amount:D,addressType:"spend"};return null}).filter(Boolean),H=(I)=>{return I.filter((D)=>D!==null&&typeof D==="object"&&Object.keys(D).length>0)};return(await z.utxo.utxoSignTransaction({coin:y[J],inputs:L,outputs:H(U),opReturnData:_})).serializedTx?.toString()};return{...Z,signTransaction:G,transfer:async({recipient:W,feeOptionKey:L,feeRate:_,memo:U,...H})=>{if(!j)throw new Error("From address must be provided");if(!W)throw new Error("Recipient address must be provided");let M=J===x.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:I,inputs:D}=await M({...H,memo:U,recipient:W,feeRate:_||(await Z.getFeeRates())[L||Rz.Fast],sender:j,fetchTxHex:!0}),O=D.map(({value:E,index:A,hash:b,txHex:K})=>({addressNList:$.address_n,amount:E.toString(),hex:K||"",scriptType:Y,txid:b,vout:A})),N=await G(I,O,U);return Z.broadcastTx(N)},address:j}};var Hz=Gz({name:"connectKeepkey",supportedChains:[X.Arbitrum,X.Avalanche,X.Base,X.BinanceSmartChain,X.Bitcoin,X.BitcoinCash,X.Cosmos,X.Dogecoin,X.Dash,X.Ethereum,X.Litecoin,X.Optimism,X.Polygon,X.THORChain,X.Maya],walletType:d.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let q=Lz({chains:Z,supportedChains:J,walletType:Q}),$=h.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");await r();let j={...$,apiKey:h.get("apiKeys").keepKey},G=await _z.create(j);return await Promise.all(q.map(async(B)=>{let W=await Iz({chain:B,derivationPath:Y?.[B]||Wz[B],sdk:G}),L=await W.getAddress()||"";z({...W,address:L,chain:B,walletType:d.KEEPKEY})})),!0}}),hz=o(Hz);async function Iz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case X.BinanceSmartChain:case X.Arbitrum:case X.Optimism:case X.Polygon:case X.Avalanche:case X.Ethereum:{let Y=await R(J),q=new S({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:q})}case X.Cosmos:return C({sdk:z,derivationPath:Q});case X.THORChain:return m({sdk:z,derivationPath:Q});case X.Maya:return l({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return c({sdk:z,chain:J,derivationPath:Q});default:throw new Error(`Chain not supported ${J}`)}}async function r(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Mz())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),r(z+1)}async function Mz(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}export{Hz as keepkeyWallet,hz as KEEPKEY_SUPPORTED_CHAINS};
|
|
1
|
+
import{a as o}from"../../chunk-wja505db.js";import{c as w,d as F}from"../../chunk-p1kdg37m.js";import{Chain as X,NetworkDerivationPath as Wz,SKConfig as h,WalletOption as d,createWallet as Gz,filterSupportedChains as Lz}from"@swapkit/helpers";import{KeepKeySdk as _z}from"@keepkey/keepkey-sdk";import{Chain as P,ChainId as u,DerivationPath as t,SKConfig as i,derivationPathToString as a}from"@swapkit/helpers";var y;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(y||={});function s(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function V(z){let J=z;if(!s(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let Y=Q[Z];if(Y){let q=/(\d+)([hH']?)/.exec(Y);if(q===null)throw new Error("Invalid input");let[,$="",j=""]=q;if(R[Z]=Number.parseInt($,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var C=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos");try{let q=J?a(J):`${t.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:V(q)}),j=await R(P.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(u.Cosmos,500));return{...j,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=B.getBaseValue("string"),U=await j.getAccount($),H=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:U?.sequence.toString()??"",chain_id:u.Cosmos,account_number:U?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:_}],to_address:W,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),M=atob(H.serialized),I=new Uint8Array(M.length).map((N,E)=>M.charCodeAt(E));return(await(await Y(i.get("rpcUrls")[P.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(q){throw console.error(q),q}};import{ChainToChainId as e,NetworkDerivationPath as zz,derivationPathToString as Jz}from"@swapkit/helpers";import{AbstractSigner as Qz}from"ethers";class S extends Qz{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||zz.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:V(Jz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:q,gasPrice:$})=>{if(!z)throw new Error("Missing to address");if(!Q)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((Y||q)&&!$);if(j&&!Y)throw new Error("Missing maxFeePerGas");if(j&&!q)throw new Error("Missing maxFeePerGas");if(!(j||$))throw new Error("Missing gasPrice");let{toHexString:G}=await import("@swapkit/toolboxes/evm"),B=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),W={gas:G(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:G(BigInt(e[this.chain])),to:z.toString(),value:G(BigInt(J||0)),nonce:G(B),data:Z,...j&&{maxFeePerGas:G(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:G(BigInt(q?.toString()||"0"))},...!j&&{gasPrice:G(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(W)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new S({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as k,ChainId as Xz,DerivationPath as Yz,SKConfig as g,derivationPathToString as Zz}from"@swapkit/helpers";var l=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(k.Maya),Y=J?Zz(J):`${Yz.MAYA}/0`,{address:q}=await z.address.mayachainGetAddress({address_n:V(Y)}),$=async({assetValue:B,recipient:W,sender:L,memo:_})=>{let{makeSignDoc:U}=(await import("@cosmjs/amino")).default,{getDenomWithChain:H}=await import("@swapkit/toolboxes/cosmos"),M=await Z.getAccount(L);if(!M)throw new Error("Account not found");let{accountNumber:I,sequence:D=0}=M,O=B.getBaseValue("string"),N=W&&W!=="",E=N?{type:"mayachain/MsgSend",value:{amount:[{amount:O,denom:B.symbol.toLowerCase()}],from_address:L,to_address:W}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:O,asset:H(B)}],memo:_,signer:L}},A=U([E],{gas:"500000000",amount:[]},Xz.Maya,_,I?.toString(),D),K=await(N?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:A,signerAddress:L}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...Z,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=await Q(g.get("rpcUrls")[k.Maya]),U=await $({assetValue:B,recipient:W,memo:L,sender:q}),{transactionHash:H}=await _.broadcastTx(U);return H},deposit:async({assetValue:B,memo:W})=>{let L=await Q(g.get("rpcUrls")[k.Maya]),_=await $({assetValue:B,memo:W,sender:q}),{transactionHash:U}=await L.broadcastTx(_);return U},address:q}};import{Chain as T,ChainId as $z,DerivationPath as qz,SKConfig as p,derivationPathToString as jz}from"@swapkit/helpers";var m=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=(await import("@cosmjs/amino")).default,{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:q}=await import("@swapkit/toolboxes/cosmos"),$=await q(T.THORChain),j=J?jz(J):`${qz.THOR}/0`,{address:G}=await z.address.thorchainGetAddress({address_n:V(j)}),B=async({assetValue:_,recipient:U,sender:H,memo:M})=>{let I=await $.getAccount(H);if(!I)throw new Error("Account not found");let{accountNumber:D,sequence:O=0}=I,N=U&&U!=="",E=R({sender:H,recipient:U,assetValue:_,memo:M}),A=$z.THORChain,b=Q([E],Z(T.THORChain),A,M,D?.toString(),O),K=N?await z.thorchain.thorchainSignAminoTransfer({signDoc:b,signerAddress:H}):await z.thorchain.thorchainSignAminoDeposit({signDoc:b,signerAddress:H}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...$,transfer:async({assetValue:_,recipient:U,memo:H})=>{let M=await Y(p.get("rpcUrls")[T.THORChain]),I=await B({assetValue:_,recipient:U,memo:H,sender:G}),{transactionHash:D}=await M.broadcastTx(I);return D},deposit:async({assetValue:_,memo:U})=>{let H=await Y(p.get("rpcUrls")[T.THORChain]),M=await B({assetValue:_,memo:U,sender:G}),{transactionHash:I}=await H.broadcastTx(M);return I},address:G}};import{Chain as x,DerivationPath as Uz,FeeOption as Rz,derivationPathToString as Bz}from"@swapkit/helpers";var c=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[x.Bitcoin,x.Litecoin].includes(J)?"p2wpkh":"p2pkh",q=Q?Bz(Q):`${Uz[J]}/0`,$={coin:y[J],script_type:Y,address_n:V(q)},j=(await z.address.utxoGetAddress($)).address,G=async(W,L,_="")=>{let U=W.txOutputs.map((I)=>{let{value:D,address:O,change:N}=I,E=J===x.BitcoinCash?Z.stripToCashAddress(O):O;if(N||O===j)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:D,scriptType:Y};if(E)return{address:E,amount:D,addressType:"spend"};return null}).filter(Boolean),H=(I)=>{return I.filter((D)=>D!==null&&typeof D==="object"&&Object.keys(D).length>0)};return(await z.utxo.utxoSignTransaction({coin:y[J],inputs:L,outputs:H(U),opReturnData:_})).serializedTx?.toString()};return{...Z,signTransaction:G,transfer:async({recipient:W,feeOptionKey:L,feeRate:_,memo:U,...H})=>{if(!j)throw new Error("From address must be provided");if(!W)throw new Error("Recipient address must be provided");let M=J===x.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:I,inputs:D}=await M({...H,memo:U,recipient:W,feeRate:_||(await Z.getFeeRates())[L||Rz.Fast],sender:j,fetchTxHex:!0}),O=D.map(({value:E,index:A,hash:b,txHex:K})=>({addressNList:$.address_n,amount:E.toString(),hex:K||"",scriptType:Y,txid:b,vout:A})),N=await G(I,O,U);return Z.broadcastTx(N)},address:j}};var Hz=Gz({name:"connectKeepkey",supportedChains:[X.Arbitrum,X.Avalanche,X.Base,X.BinanceSmartChain,X.Bitcoin,X.BitcoinCash,X.Cosmos,X.Dogecoin,X.Dash,X.Ethereum,X.Litecoin,X.Optimism,X.Polygon,X.THORChain,X.Maya],walletType:d.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let q=Lz({chains:Z,supportedChains:J,walletType:Q}),$=h.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");await r();let j={...$,apiKey:h.get("apiKeys").keepKey},G=await _z.create(j);return await Promise.all(q.map(async(B)=>{let W=await Iz({chain:B,derivationPath:Y?.[B]||Wz[B],sdk:G}),L=await W.getAddress()||"";z({...W,address:L,chain:B,walletType:d.KEEPKEY})})),!0}}),hz=o(Hz);async function Iz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case X.BinanceSmartChain:case X.Arbitrum:case X.Optimism:case X.Polygon:case X.Avalanche:case X.Ethereum:{let Y=await R(J),q=new S({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:q})}case X.Cosmos:return C({sdk:z,derivationPath:Q});case X.THORChain:return m({sdk:z,derivationPath:Q});case X.Maya:return l({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return c({sdk:z,chain:J,derivationPath:Q});default:throw new Error(`Chain not supported ${J}`)}}async function r(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Mz())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),r(z+1)}async function Mz(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}export{Hz as keepkeyWallet,hz as KEEPKEY_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=C1A7C5EC6AF41DFF64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as l}from"../../chunk-
|
|
1
|
+
import{a as l}from"../../chunk-wja505db.js";import{c as d,d as u}from"../../chunk-p1kdg37m.js";import{AssetValue as F,Chain as t,ChainIdToChain as L,SwapKitError as b,WalletOption as B,createWallet as V,filterSupportedChains as j}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as P,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var T=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new Error("Unsupported chain")}};function w(e){if(!window.keepkey)throw new P("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function K({method:e,params:c,chain:r}){let o=w(r);return new Promise((n,i)=>{if(o&&"request"in o)o.request({method:e,params:c},(s,m)=>{s?i(s):n(m)});else i(new P("wallet_provider_not_found"))})}async function _(e){let c=w(e);if(!c)throw new P({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[o]=await c.request({method:r,params:[]});return o}async function f({assetValue:e,recipient:c,memo:r,gasLimit:o},n="transfer"){if(!e)throw new P("wallet_keepkey_asset_not_defined");let i=await _(e.chain),s=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:o}];return K({method:n,params:s,chain:e.chain})}function O(e,c){return{call:async({contractAddress:r,abi:o,funcName:n,funcParams:i=[],txOverrides:s})=>{if(!r)throw new P("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:p}=await import("@swapkit/toolboxes/evm");if(y({abi:o,funcName:n})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:o,funcName:n,funcParams:i,txOverrides:s});return e.send("eth_sendTransaction",[{value:p(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,o,e)[n]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:o,amount:n,from:i})=>{let{MAX_APPROVAL:s,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:p,to:k,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[o,BigInt(n||s)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(p||0)),from:i,to:k,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:o,to:n,data:i,value:s}=r;if(!n)throw new P("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(s||0)),from:o,to:n,data:i||"0x"}])}}}var H=V({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:B.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function o(n){let i=j({chains:n,supportedChains:c,walletType:r});return await Promise.all(i.map(async(s)=>{let m=await _(s),g=await R(s);e({...g,address:m,chain:s,walletType:r})})),!0}}),$=l(H);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:o}=await import("@swapkit/toolboxes/cosmos"),n=e===t.Maya?o:r;return{...c(e),deposit:(s)=>f({...s,recipient:""},"deposit"),transfer:(s)=>f({...s,gasLimit:n},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(L[e]);if(!r)throw new Error("Could not load signer");let o=c(e,{signer:r}),n=await r.getAccounts();if(!n?.[0]?.address)throw new Error("No accounts found");let[{address:i}]=n;return{...o,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{try{let n=T(e),i=await window?.keepkey?.[n]?.request({method:"request_balance"});return[F.from({chain:e,value:i[0].balance})]}catch(n){throw console.error("Error fetching balance:",n),n}},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:n}=await import("ethers"),i=w(e);if(!i)throw new b("wallet_keepkey_not_found");let s=new n(i,"any"),m=await s.getSigner(),g=await o(e,{provider:s,signer:m}),y=O(s,e);try{if(e!==t.Ethereum){let p=g.getNetworkParams();await r(s,e,p)}}catch(p){throw new b({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:B.KEEPKEY,chain:e}})}return c({provider:s,chain:e,toolbox:{...g,...y}})}default:return null}}export{H as keepkeyBexWallet,$ as KEEPKEY_BEX_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=AFAB0E6C797C305A64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as v}from"../../chunk-
|
|
1
|
+
import{a as v}from"../../chunk-wja505db.js";import{c as m,d as h}from"../../chunk-p1kdg37m.js";import{Chain as f,CosmosChains as E,EVMChains as A,NetworkDerivationPath as _,UTXOChains as R,WalletOption as w,createWallet as U,filterSupportedChains as W,updateDerivationPath as F}from"@swapkit/helpers";import{createCipheriv as P,createDecipheriv as K,pbkdf2Sync as y,randomBytes as d}from"node:crypto";import{generateMnemonic as D,validateMnemonic as T}from"@scure/bip39";import{wordlist as g}from"@scure/bip39/wordlists/english";async function x(t){let{blake2bFinal:i,blake2bInit:s,blake2bUpdate:n}=(await import("blakejs")).default,e=t;if(!(e instanceof Buffer))e=Buffer.from(e,"hex");let a=s(32);return n(a,e),Array.from(i(a)).map((r)=>r<16?`0${r.toString(16)}`:r.toString(16)).join("")}async function V(t,i){let n=d(16),e=d(32),a={c:262144,prf:"hmac-sha256",dklen:32,salt:e.toString("hex")},r=y(i,e,a.c,a.dklen,"sha256"),c=P("aes-128-ctr",r.subarray(0,16),n),o=Buffer.concat([c.update(Buffer.from(t,"utf8")),c.final()]),p=Buffer.concat([r.subarray(16,32),Buffer.from(o)]),l=await x(p);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:n.toString("hex")},ciphertext:o.toString("hex"),kdf:"pbkdf2",kdfparams:a,mac:l}}}function H(t=12){return D(g,t===12?128:256)}function X(t){return T(t,g)}async function $(t,i){let{SwapKitError:s}=await import("@swapkit/helpers");switch(t.version){case 1:{let n=t.crypto.kdfparams,e=Buffer.from(n.salt,"hex"),a=y(i,e,n.c,n.dklen,"sha256"),r=Buffer.from(t.crypto.ciphertext,"hex"),c=Buffer.concat([a.subarray(16,32),r]);if(await x(c)!==t.crypto.mac)throw new s("wallet_keystore_invalid_password");let p=K(t.crypto.cipher,a.subarray(0,16),Buffer.from(t.crypto.cipherparams.iv,"hex"));return Buffer.concat([p.update(r),p.final()]).toString("utf8")}default:throw new s("wallet_keystore_unsupported_version")}}var Y=U({name:"connectKeystore",walletType:w.KEYSTORE,supportedChains:[...A,...R,...E,f.Polkadot,f.Chainflip,f.Ripple,f.Solana],connect:({addChain:t,supportedChains:i,walletType:s})=>async function n(e,a,r){let c=W({chains:e,supportedChains:i,walletType:s});return await Promise.all(c.map(async(o)=>{let p=typeof r==="number"?r:0,l=r&&typeof r==="object"?r[o]:void 0,b=_[o].slice(0,o===f.Solana?4:5),k=l||F(b,{index:p}),{getToolbox:S}=await import("@swapkit/toolboxes"),u=await S(o,{phrase:a,derivationPath:k}),C=await u.getAddress()||"",B={...u,address:C};t({...B,chain:o,walletType:w.KEYSTORE})})),!0}}),I=v(Y);export{X as validatePhrase,Y as keystoreWallet,H as generatePhrase,V as encryptToKeyStore,$ as decryptFromKeystore,I as KEYSTORE_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=FCFD00914C62A12F64756E2164756E21
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var L2={};n0(L2,{ledgerWallet:()=>q0,LEDGER_SUPPORTED_CHAINS:()=>a0});module.exports=t0(L2);var X=require("@swapkit/helpers");var H=require("@swapkit/helpers"),S=async({chain:L,ledgerClient:_})=>{if(!_)return"";switch(L){case H.Chain.Cosmos:case H.Chain.THORChain:return _.connect();case H.Chain.Ethereum:case H.Chain.BinanceSmartChain:case H.Chain.Avalanche:case H.Chain.Polygon:case H.Chain.Arbitrum:case H.Chain.Optimism:case H.Chain.Base:return _.getAddress();case H.Chain.Bitcoin:case H.Chain.BitcoinCash:case H.Chain.Dash:case H.Chain.Dogecoin:case H.Chain.Litecoin:{let O=_;await O.connect();let G=await O.getAddress();return L===H.Chain.BitcoinCash?G.replace("bitcoincash:",""):G}default:throw new H.SwapKitError("wallet_chain_not_supported",{wallet:H.WalletOption.LEDGER,chain:L})}};var Y=require("@swapkit/helpers");var x=require("@swapkit/helpers");var w=require("@swapkit/helpers");var E=85,d=250;var z={GET_VERSION:0,INS_PUBLIC_KEY_SECP256K1:1,SIGN_SECP256K1:2,GET_ADDR_SECP256K1:4},k={INIT:0,ADD:1,LAST:2},i={ONLY_RETRIEVE:0,SHOW_ADDRESS_IN_DEVICE:1},C={JSON:0},R={NoError:36864},B0={1:"U2F: Unknown",2:"U2F: Bad request",3:"U2F: Configuration unsupported",4:"U2F: Device Ineligible",5:"U2F: Timeout",14:"Timeout",36864:"No errors",36865:"Device is busy",26626:"Error deriving keys",25600:"Execution Error",26368:"Wrong Length",27010:"Empty Buffer",27011:"Output buffer too small",27012:"Data is invalid",27013:"Conditions not satisfied",27014:"Transaction rejected",27264:"Bad key handle",27392:"Invalid P1/P2",27904:"Instruction not supported",28160:"App does not seem to be open",28416:"Unknown error",28417:"Sign/verify error"};function U(L){if(L in B0)return B0[L];return`Unknown Status Code: ${L}`}function d0(L){return typeof L==="object"&&L!==null&&!Array.isArray(L)&&!(L instanceof Date)}function M(L){if(L){if(d0(L)){if(Object.prototype.hasOwnProperty.call(L,"statusCode"))return{return_code:L.statusCode,error_message:U(L.statusCode)};if(Object.prototype.hasOwnProperty.call(L,"return_code")&&Object.prototype.hasOwnProperty.call(L,"error_message"))return L}return{return_code:65535,error_message:L.toString()}}return{return_code:65535,error_message:L.toString()}}async function p(L){return L.send(85,z.GET_VERSION,0,0).then((_)=>{let O=_.slice(-2),G=O[0]*256+O[1],B=0;if(_.length>=9)B=(_[5]<<24)+(_[6]<<16)+(_[7]<<8)+(_[8]<<0);return{return_code:G,error_message:U(G),test_mode:_[0]!==0,major:_[1],minor:_[2],patch:_[3],device_locked:_[4]===1,target_id:B.toString(16)}},M)}function G0(L){if(L==null||L.length<3)throw new Error("Invalid path.");if(L.length>10)throw new Error("Invalid path. Length should be <= 10");let _=Buffer.alloc(1+4*L.length);_.writeUInt8(L.length,0);for(let O=0;O<L.length;O+=1){let G=L[O]||0;if(O<3)G|=2147483648;_.writeInt32LE(G,1+O*4)}return _}async function o(L,_,O,G,B=C.JSON){return L.transport.send(E,z.SIGN_SECP256K1,_,B,G,[R.NoError,27012,27264]).then((j)=>{let J=j.slice(-2),F=J[0]*256+J[1],W=U(F);if(F===27264||F===27012)W=`${W} : ${j.slice(0,j.length-2).toString("ascii")}`;let $=null;if(j.length>2)$=j.slice(0,j.length-2);return{signature:$,return_code:F,error_message:W}},M)}function i0(L){if(L.length!==65)throw new Error("decompressed public key length should be 65 bytes");let _=L.slice(33,65),O=Buffer.from([2+(_[_.length-1]&1)]);return Buffer.concat([O,L.slice(1,33)])}async function j0(L,_){return L.transport.send(E,z.INS_PUBLIC_KEY_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let G=O.slice(-2),B=G[0]*256+G[1],j=Buffer.from(O.slice(0,65));return{pk:j,compressed_pk:i0(j),return_code:B,error_message:U(B)}},M)}function F0(L){if(!L||L.length!==5)throw new Error("Invalid path.");let _=Buffer.alloc(20);return _.writeUInt32LE(2147483648+L[0],0),_.writeUInt32LE(2147483648+L[1],4),_.writeUInt32LE(2147483648+L[2],8),_.writeUInt32LE(L[3],12),_.writeUInt32LE(L[4],16),_}function X0(L,_,O,G,B=C.JSON){let j=k.ADD;if(_===1)j=k.INIT;if(_===O)j=k.LAST;return o(L,j,0,G,B)}async function J0(L,_){return L.transport.send(E,z.GET_ADDR_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let G=O.slice(-2),B=G[0]*256+G[1];return{pk:"OBSOLETE PROPERTY",compressed_pk:Buffer.from(O.slice(0,33)),return_code:B,error_message:U(B)}},M)}class l{transport;versionResponse;constructor(L){if(!L)throw new Error("Transport has not been defined");this.transport=L}static serializeHRP(L){if(L==null||L.length<3||L.length>83)throw new Error("Invalid HRP");let _=Buffer.alloc(1+L.length);return _.writeUInt8(L.length,0),_.write(L,1),_}async serializePath(L){if(this.versionResponse=await p(this.transport),this.versionResponse.return_code!==R.NoError)throw this.versionResponse;switch(this.versionResponse.major){case 1:return G0(L);case 2:return F0(L);default:return Buffer.alloc(0)}}async signGetChunks(L,_){let O=await this.serializePath(L),G=[];G.push(O);for(let B=0;B<_.length;B+=d){let j=B+d;if(B>_.length)j=_.length;G.push(_.slice(B,j))}return G}async getVersion(){try{return this.versionResponse=await p(this.transport),this.versionResponse}catch(L){return M(L)}}async appInfo(){return this.transport.send(176,1,0,0).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1],G="",B="",j=0,J=0;if(L[0]!==1)return{return_code:36865,error_message:"response format ID not recognized"};let F=L[1];G=L.slice(2,2+F).toString("ascii");let W=2+F,$=L[W];W+=1,B=L.slice(W,W+$).toString("ascii"),W+=$;let Q=L[W];return W+=1,j=Q,J=L[W],{return_code:O,error_message:U(O),appName:G,appVersion:B,flagLen:j,flagsValue:J,flag_recovery:(J&1)!==0,flag_signed_mcu_code:(J&2)!==0,flag_onboarded:(J&4)!==0,flag_pin_validated:(J&128)!==0}},M)}async deviceInfo(){return this.transport.send(224,1,0,0,Buffer.from([]),[R.NoError,28160]).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1];if(O===28160)return{return_code:O,error_message:"This command is only available in the Dashboard"};let G=L.slice(0,4).toString("hex"),B=4,j=L[B];B+=1;let J=L.slice(B,B+j).toString();B+=j;let F=L[B];B+=1;let W=L.slice(B,B+F).toString("hex");B+=F;let $=L[B];B+=1;let Q=L.slice(B,B+$);if(Q[$-1]===0)Q=L.slice(B,B+$-1);let T=Q.toString();return{return_code:O,error_message:U(O),targetId:G,seVersion:J,flag:W,mcuVersion:T}},M)}async publicKey(L){try{let _=await this.serializePath(L);switch(this.versionResponse.major){case 1:return j0(this,_);case 2:{let O=Buffer.concat([l.serializeHRP("thor"),_]);return J0(this,O)}default:return{return_code:25600,error_message:"App Version is not supported"}}}catch(_){return M(_)}}async getAddressAndPubKey(L,_,O=!1){return this.serializePath(L).then((G)=>{let B=Buffer.concat([l.serializeHRP(_),G]);return this.transport.send(E,z.GET_ADDR_SECP256K1,O?i.SHOW_ADDRESS_IN_DEVICE:i.ONLY_RETRIEVE,0,B,[R.NoError]).then((j)=>{let J=j.slice(-2),F=J[0]*256+J[1],W=Buffer.from(j.slice(0,33));return{bech32_address:Buffer.from(j.slice(33,-2)).toString(),compressed_pk:W,return_code:F,error_message:U(F)}},M)}).catch((G)=>M(G))}showAddressAndPubKey(L,_){return this.getAddressAndPubKey(L,_,!0)}signSendChunk(L,_,O,G=C.JSON){switch(this.versionResponse.major){case 1:return o(this,L,_,O,G);case 2:return X0(this,L,_,O,G);default:return{return_code:25600,error_message:"App Version is not supported"}}}async sign(L,_,O=C.JSON){let G=Buffer.from(_),B=[],j;try{B=await this.signGetChunks(L,G),j=await this.signSendChunk(1,B.length,B[0],O)}catch(F){M(F)}let J={return_code:j.return_code,error_message:j.error_message,signature:null};for(let F=1;F<B.length;F+=1)if(J=await this.signSendChunk(1+F,B.length,B[F],O),J.return_code!==R.NoError)break;return{return_code:J.return_code,error_message:J.error_message,signature:J.signature}}}var b=require("@swapkit/helpers"),t=()=>navigator?.usb,p0=async()=>{let L=t();if(typeof L?.getDevices!=="function")return[];let{ledgerUSBVendorId:_}=await import("@ledgerhq/devices"),G=(await L?.getDevices()).filter((B)=>B.vendorId===_);if(G.length>0)return G[0];return L?.requestDevice({filters:[{vendorId:_}]})},D=async()=>{let L=await p0();if(!L)throw new b.SwapKitError("wallet_ledger_device_not_found");if(await L.open(),L.configuration===null)await L.selectConfiguration(1);try{await L.reset()}catch{}let _=L.configurations[0].interfaces.find(({alternates:F})=>F.some(({interfaceClass:W})=>W===255));if(!_)throw await L.close(),new b.SwapKitError("wallet_ledger_connection_error");try{await L.claimInterface(_.interfaceNumber)}catch(F){throw await L.close(),new b.SwapKitError("wallet_ledger_connection_claimed",F)}let O=(await import("@ledgerhq/hw-transport-webusb")).default;if(!await O.isSupported())throw new Error("WebUSB not supported");let{DisconnectedDevice:B}=(await import("@ledgerhq/errors")).default,j=new O(L,_.interfaceNumber),J=(F)=>{if(L===F.device)t()?.removeEventListener("disconnect",J),j._emitDisconnect(new B)};return t()?.addEventListener("disconnect",J),j};class A{ledgerTimeout=50000;derivationPath=w.NetworkDerivationPath.GAIA;transport;ledgerApp;chain="thor";checkOrCreateTransportAndLedger=async(L=!1)=>{if(!L&&this.transport&&this.ledgerApp)return;try{switch(this.transport=L||!this.transport?await D():this.transport,this.chain){case"thor":{this.ledgerApp=L||!this.ledgerApp?new l(this.transport):this.ledgerApp;break}case"cosmos":{let _=(await import("@ledgerhq/hw-app-cosmos")).default;this.ledgerApp=L||!this.ledgerApp?new _(this.transport):this.ledgerApp}}return this.ledgerApp}catch(_){throw new w.SwapKitError("wallet_ledger_connection_error",_)}};validateResponse=(L,_)=>{switch(L){case w.LedgerErrorCode.NoError:return;case w.LedgerErrorCode.LockedDevice:throw new w.SwapKitError("wallet_ledger_device_locked",{message:`Ledger is locked: ${_}`});case w.LedgerErrorCode.TC_NotFound:throw new w.SwapKitError("wallet_ledger_device_not_found");default:{console.error(`Ledger error: ${L} ${_}`);break}}}}class n extends A{pubKey=null;derivationPath;constructor(L=x.NetworkDerivationPath.GAIA){super();this.chain="cosmos",this.derivationPath=x.derivationPathToString(L)}connect=async()=>{await this.checkOrCreateTransportAndLedger(!0);let{publicKey:L,address:_}=await this.getAddressAndPubKey();return this.pubKey=Buffer.from(L,"hex").toString("base64"),_};getAddressAndPubKey=async()=>{return await this.checkOrCreateTransportAndLedger(!0),await this.ledgerApp.getAddress(this.derivationPath,this.chain)};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:G,signature:B}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,G),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:B}]};signAmino=async(L,_)=>{await this.checkOrCreateTransportAndLedger(!0);let O=await this.getAccounts();if(O.findIndex((Q)=>Q.address===L)===-1)throw new Error(`Address ${L} not found in wallet`);let{encodeSecp256k1Signature:B,serializeSignDoc:j}=(await import("@cosmjs/amino")).default,{Secp256k1Signature:J}=(await import("@cosmjs/crypto")).default,F=j(_),W=await this.ledgerApp.sign(this.derivationPath,F);this.validateResponse(W.return_code,W.error_message);let $=J.fromDer(W.signature).toFixedLength();return{signed:_,signature:B(O[0].pubkey,$)}};getAccounts=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.getAddressAndPubKey();return[{address:L.address,algo:"secp256k1",pubkey:Buffer.from(L.publicKey,"hex")}]}}var m=require("@swapkit/helpers"),W0=require("ethers");class y extends W0.AbstractSigner{chainId=m.ChainId.Ethereum;derivationPath="";ledgerApp=null;ledgerTimeout=50000;constructor({provider:L,derivationPath:_=m.NetworkDerivationPath.OP,chainId:O=m.ChainId.Optimism}){super(L);this.chainId=O||m.ChainId.Ethereum,this.derivationPath=typeof _==="string"?_:m.derivationPathToString(_),Object.defineProperty(this,"provider",{enumerable:!0,value:L||null,writable:!1})}connect=(L)=>new y({provider:L,derivationPath:this.derivationPath,chainId:this.chainId});checkOrCreateTransportAndLedger=async()=>{if(this.ledgerApp)return;await this.createTransportAndLedger()};createTransportAndLedger=async()=>{let L=await D(),{default:_}=await import("@ledgerhq/hw-app-eth");this.ledgerApp=new _(L)};getAddress=async()=>{let L=await this.getAddressAndPubKey();if(!L)throw new Error("Could not get Address");return L.address};getAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath)};showAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath,!0)};signMessage=async(L)=>{let{Signature:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.ledgerApp?.signPersonalMessage(this.derivationPath,L);if(!O)throw new Error("Signing failed");return O.r=`0x${O.r}`,O.s=`0x${O.s}`,_.from(O).serialized};sendTransaction=async(L)=>{if(!this.provider)throw new Error("No provider set");let _=await this.signTransaction(L);return await this.provider.broadcastTransaction(_)};signTypedData(){throw new Error("Method not implemented.")}signTransaction=async(L)=>{let{Transaction:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.provider?.getTransactionCount(L.from||await this.getAddress()),G={chainId:L.chainId||this.chainId,data:L.data,gasLimit:L.gasLimit,...L.gasPrice&&{gasPrice:L.gasPrice},...!L.gasPrice&&L.maxFeePerGas&&{maxFeePerGas:L.maxFeePerGas,maxPriorityFeePerGas:L.maxPriorityFeePerGas},nonce:L.nonce!==void 0?Number((L.nonce||O||0).toString()):O,to:L.to?.toString(),value:L.value,type:L.type&&!Number.isNaN(L.type)?L.type:L.maxFeePerGas?2:0},B=_.from(G).unsignedSerialized.slice(2),{ledgerService:j}=await import("@ledgerhq/hw-app-eth"),J=await j.resolveTransaction(B,{},{externalPlugins:!0,erc20:!0}),F=await this.ledgerApp?.signTransaction(this.derivationPath,B,J);if(!F)throw new Error("Could not sign transaction");let{r:W,s:$,v:Q}=F;return _.from({...G,signature:{v:Number(BigInt(Q)),r:`0x${W}`,s:`0x${$}`}}).serialized}}var $0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Ethereum,provider:L,derivationPath:_}),Q0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Avalanche,provider:L,derivationPath:_}),Y0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.BinanceSmartChain,provider:L,derivationPath:_}),Z0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Arbitrum,provider:L,derivationPath:_}),H0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Polygon,provider:L,derivationPath:_}),m0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Optimism,provider:L,derivationPath:_}),M0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Base,provider:L,derivationPath:_});var U0=require("@scure/base"),w0=require("@swapkit/helpers");var T0=require("@scure/base"),a=(L)=>{if(L.length<64)throw new Error("Invalid Signature: Too short");if(L[0]!==48)throw new Error("Invalid Ledger Signature TLV encoding: expected first byte 0x30");if(L[1]+2!==L.length)throw new Error("Invalid Signature: signature length does not match TLV");if(L[2]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let _=L[3],O=L.slice(4,_+4);if(O.length===33&&O[0]===0)O=O.slice(1,33);else if(O.length===33)throw new Error('Invalid signature: "r" too long');while(O.length<32)O.unshift(0);if(L[_+4]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let G=L[_+5];if(4+_+2+G!==L.length)throw new Error("Invalid Ledger Signature: TLV byte lengths do not match message length");let B=L.slice(_+6,L.length);if(B.length===33&&B[0]===0)B=B.slice(1,33);else if(B.length===33)throw new Error('Invalid signature: "s" too long');while(B.length<32)B.unshift(0);if(O.length!==32||B.length!==32)throw new Error("Invalid signatures: must be 32 bytes each");return T0.base64.encode(Buffer.concat([O,B]))};class s extends A{pubKey=null;derivationPath;constructor(L=w0.NetworkDerivationPath.THOR){super();this.chain="thor",this.derivationPath=L}get pubkey(){return this.pubKey}connect=async()=>{await this.checkOrCreateTransportAndLedger();let{compressed_pk:L,bech32_address:_}=await this.getAddressAndPubKey();return this.pubKey=U0.base64.encode(L),_};getAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.getAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};showAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.showAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:G,signature:B}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,G),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:a(B)}]};sign=async(L)=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:_,error_message:O,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(_,O),a(G)}}var K=require("@swapkit/helpers"),R0=require("bitcoinjs-lib");var o0=async({psbt:L,inputUtxos:_,btcApp:O,derivationPath:G},B)=>{let j=_.map((Q)=>{let T=R0.Transaction.fromHex(Q.txHex||"");return[O.splitTransaction(T.toHex(),T.hasWitnesses()),Q.index,void 0,void 0]}),J=L.data.globalMap.unsignedTx.toBuffer().toString("hex"),F=O.splitTransaction(J,!0),W=O.serializeTransactionOutputs(F).toString("hex"),$={additionals:["bech32"],associatedKeysets:j.map(()=>G),inputs:j,outputScriptHex:W,segwit:!0,useTrustedInputForSegwit:!0};return O.createPaymentTransaction({...$,...B})},V=({chain:L,additionalSignParams:_})=>{let O,G=null;async function B(J=!0){if(J&&!O)new K.SwapKitError("wallet_ledger_connection_error",{message:`Ledger connection failed:
|
|
1
|
+
var L2={};n0(L2,{ledgerWallet:()=>q0,LEDGER_SUPPORTED_CHAINS:()=>a0});module.exports=t0(L2);var X=require("@swapkit/helpers");var H=require("@swapkit/helpers"),S=async({chain:L,ledgerClient:_})=>{if(!_)return"";switch(L){case H.Chain.Cosmos:case H.Chain.THORChain:return _.connect();case H.Chain.Ethereum:case H.Chain.BinanceSmartChain:case H.Chain.Avalanche:case H.Chain.Polygon:case H.Chain.Arbitrum:case H.Chain.Optimism:case H.Chain.Base:return _.getAddress();case H.Chain.Bitcoin:case H.Chain.BitcoinCash:case H.Chain.Dash:case H.Chain.Dogecoin:case H.Chain.Litecoin:{let O=_;await O.connect();let G=await O.getAddress();return L===H.Chain.BitcoinCash?G.replace("bitcoincash:",""):G}default:throw new H.SwapKitError("wallet_chain_not_supported",{wallet:H.WalletOption.LEDGER,chain:L})}};var Y=require("@swapkit/helpers");var x=require("@swapkit/helpers");var w=require("@swapkit/helpers");var E=85,d=250;var z={GET_VERSION:0,INS_PUBLIC_KEY_SECP256K1:1,SIGN_SECP256K1:2,GET_ADDR_SECP256K1:4},k={INIT:0,ADD:1,LAST:2},i={ONLY_RETRIEVE:0,SHOW_ADDRESS_IN_DEVICE:1},C={JSON:0},R={NoError:36864},B0={1:"U2F: Unknown",2:"U2F: Bad request",3:"U2F: Configuration unsupported",4:"U2F: Device Ineligible",5:"U2F: Timeout",14:"Timeout",36864:"No errors",36865:"Device is busy",26626:"Error deriving keys",25600:"Execution Error",26368:"Wrong Length",27010:"Empty Buffer",27011:"Output buffer too small",27012:"Data is invalid",27013:"Conditions not satisfied",27014:"Transaction rejected",27264:"Bad key handle",27392:"Invalid P1/P2",27904:"Instruction not supported",28160:"App does not seem to be open",28416:"Unknown error",28417:"Sign/verify error"};function U(L){if(L in B0)return B0[L];return`Unknown Status Code: ${L}`}function d0(L){return typeof L==="object"&&L!==null&&!Array.isArray(L)&&!(L instanceof Date)}function M(L){if(L){if(d0(L)){if(Object.prototype.hasOwnProperty.call(L,"statusCode"))return{return_code:L.statusCode,error_message:U(L.statusCode)};if(Object.prototype.hasOwnProperty.call(L,"return_code")&&Object.prototype.hasOwnProperty.call(L,"error_message"))return L}return{return_code:65535,error_message:L.toString()}}return{return_code:65535,error_message:L.toString()}}async function p(L){return L.send(85,z.GET_VERSION,0,0).then((_)=>{let O=_.slice(-2),G=O[0]*256+O[1],B=0;if(_.length>=9)B=(_[5]<<24)+(_[6]<<16)+(_[7]<<8)+(_[8]<<0);return{return_code:G,error_message:U(G),test_mode:_[0]!==0,major:_[1],minor:_[2],patch:_[3],device_locked:_[4]===1,target_id:B.toString(16)}},M)}function G0(L){if(L==null||L.length<3)throw new Error("Invalid path.");if(L.length>10)throw new Error("Invalid path. Length should be <= 10");let _=Buffer.alloc(1+4*L.length);_.writeUInt8(L.length,0);for(let O=0;O<L.length;O+=1){let G=L[O]||0;if(O<3)G|=2147483648;_.writeInt32LE(G,1+O*4)}return _}async function o(L,_,O,G,B=C.JSON){return L.transport.send(E,z.SIGN_SECP256K1,_,B,G,[R.NoError,27012,27264]).then((j)=>{let J=j.slice(-2),F=J[0]*256+J[1],W=U(F);if(F===27264||F===27012)W=`${W} : ${j.slice(0,j.length-2).toString("ascii")}`;let $=null;if(j.length>2)$=j.slice(0,j.length-2);return{signature:$,return_code:F,error_message:W}},M)}function i0(L){if(L.length!==65)throw new Error("decompressed public key length should be 65 bytes");let _=L.slice(33,65),O=Buffer.from([2+(_[_.length-1]&1)]);return Buffer.concat([O,L.slice(1,33)])}async function j0(L,_){return L.transport.send(E,z.INS_PUBLIC_KEY_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let G=O.slice(-2),B=G[0]*256+G[1],j=Buffer.from(O.slice(0,65));return{pk:j,compressed_pk:i0(j),return_code:B,error_message:U(B)}},M)}function F0(L){if(!L||L.length!==5)throw new Error("Invalid path.");let _=Buffer.alloc(20);return _.writeUInt32LE(2147483648+L[0],0),_.writeUInt32LE(2147483648+L[1],4),_.writeUInt32LE(2147483648+L[2],8),_.writeUInt32LE(L[3],12),_.writeUInt32LE(L[4],16),_}function X0(L,_,O,G,B=C.JSON){let j=k.ADD;if(_===1)j=k.INIT;if(_===O)j=k.LAST;return o(L,j,0,G,B)}async function J0(L,_){return L.transport.send(E,z.GET_ADDR_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let G=O.slice(-2),B=G[0]*256+G[1];return{pk:"OBSOLETE PROPERTY",compressed_pk:Buffer.from(O.slice(0,33)),return_code:B,error_message:U(B)}},M)}class l{transport;versionResponse;constructor(L){if(!L)throw new Error("Transport has not been defined");this.transport=L}static serializeHRP(L){if(L==null||L.length<3||L.length>83)throw new Error("Invalid HRP");let _=Buffer.alloc(1+L.length);return _.writeUInt8(L.length,0),_.write(L,1),_}async serializePath(L){if(this.versionResponse=await p(this.transport),this.versionResponse.return_code!==R.NoError)throw this.versionResponse;switch(this.versionResponse.major){case 1:return G0(L);case 2:return F0(L);default:return Buffer.alloc(0)}}async signGetChunks(L,_){let O=await this.serializePath(L),G=[];G.push(O);for(let B=0;B<_.length;B+=d){let j=B+d;if(B>_.length)j=_.length;G.push(_.slice(B,j))}return G}async getVersion(){try{return this.versionResponse=await p(this.transport),this.versionResponse}catch(L){return M(L)}}async appInfo(){return this.transport.send(176,1,0,0).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1],G="",B="",j=0,J=0;if(L[0]!==1)return{return_code:36865,error_message:"response format ID not recognized"};let F=L[1];G=L.slice(2,2+F).toString("ascii");let W=2+F,$=L[W];W+=1,B=L.slice(W,W+$).toString("ascii"),W+=$;let Q=L[W];return W+=1,j=Q,J=L[W],{return_code:O,error_message:U(O),appName:G,appVersion:B,flagLen:j,flagsValue:J,flag_recovery:(J&1)!==0,flag_signed_mcu_code:(J&2)!==0,flag_onboarded:(J&4)!==0,flag_pin_validated:(J&128)!==0}},M)}async deviceInfo(){return this.transport.send(224,1,0,0,Buffer.from([]),[R.NoError,28160]).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1];if(O===28160)return{return_code:O,error_message:"This command is only available in the Dashboard"};let G=L.slice(0,4).toString("hex"),B=4,j=L[B];B+=1;let J=L.slice(B,B+j).toString();B+=j;let F=L[B];B+=1;let W=L.slice(B,B+F).toString("hex");B+=F;let $=L[B];B+=1;let Q=L.slice(B,B+$);if(Q[$-1]===0)Q=L.slice(B,B+$-1);let T=Q.toString();return{return_code:O,error_message:U(O),targetId:G,seVersion:J,flag:W,mcuVersion:T}},M)}async publicKey(L){try{let _=await this.serializePath(L);switch(this.versionResponse.major){case 1:return j0(this,_);case 2:{let O=Buffer.concat([l.serializeHRP("thor"),_]);return J0(this,O)}default:return{return_code:25600,error_message:"App Version is not supported"}}}catch(_){return M(_)}}async getAddressAndPubKey(L,_,O=!1){return this.serializePath(L).then((G)=>{let B=Buffer.concat([l.serializeHRP(_),G]);return this.transport.send(E,z.GET_ADDR_SECP256K1,O?i.SHOW_ADDRESS_IN_DEVICE:i.ONLY_RETRIEVE,0,B,[R.NoError]).then((j)=>{let J=j.slice(-2),F=J[0]*256+J[1],W=Buffer.from(j.slice(0,33));return{bech32_address:Buffer.from(j.slice(33,-2)).toString(),compressed_pk:W,return_code:F,error_message:U(F)}},M)}).catch((G)=>M(G))}showAddressAndPubKey(L,_){return this.getAddressAndPubKey(L,_,!0)}signSendChunk(L,_,O,G=C.JSON){switch(this.versionResponse.major){case 1:return o(this,L,_,O,G);case 2:return X0(this,L,_,O,G);default:return{return_code:25600,error_message:"App Version is not supported"}}}async sign(L,_,O=C.JSON){let G=Buffer.from(_),B=[],j;try{B=await this.signGetChunks(L,G),j=await this.signSendChunk(1,B.length,B[0],O)}catch(F){M(F)}let J={return_code:j.return_code,error_message:j.error_message,signature:null};for(let F=1;F<B.length;F+=1)if(J=await this.signSendChunk(1+F,B.length,B[F],O),J.return_code!==R.NoError)break;return{return_code:J.return_code,error_message:J.error_message,signature:J.signature}}}var b=require("@swapkit/helpers"),t=()=>navigator?.usb,p0=async()=>{let L=t();if(typeof L?.getDevices!=="function")return[];let{ledgerUSBVendorId:_}=await import("@ledgerhq/devices"),G=(await L?.getDevices()).filter((B)=>B.vendorId===_);if(G.length>0)return G[0];return L?.requestDevice({filters:[{vendorId:_}]})},D=async()=>{let L=await p0();if(!L)throw new b.SwapKitError("wallet_ledger_device_not_found");if(await L.open(),L.configuration===null)await L.selectConfiguration(1);try{await L.reset()}catch{}let _=L.configurations[0].interfaces.find(({alternates:F})=>F.some(({interfaceClass:W})=>W===255));if(!_)throw await L.close(),new b.SwapKitError("wallet_ledger_connection_error");try{await L.claimInterface(_.interfaceNumber)}catch(F){throw await L.close(),new b.SwapKitError("wallet_ledger_connection_claimed",F)}let O=(await import("@ledgerhq/hw-transport-webusb")).default;if(!await O.isSupported())throw new Error("WebUSB not supported");let{DisconnectedDevice:B}=await import("@ledgerhq/errors"),j=new O(L,_.interfaceNumber),J=(F)=>{if(L===F.device)t()?.removeEventListener("disconnect",J),j._emitDisconnect(new B)};return t()?.addEventListener("disconnect",J),j};class A{ledgerTimeout=50000;derivationPath=w.NetworkDerivationPath.GAIA;transport;ledgerApp;chain="thor";checkOrCreateTransportAndLedger=async(L=!1)=>{if(!L&&this.transport&&this.ledgerApp)return;try{switch(this.transport=L||!this.transport?await D():this.transport,this.chain){case"thor":{this.ledgerApp=L||!this.ledgerApp?new l(this.transport):this.ledgerApp;break}case"cosmos":{let _=(await import("@ledgerhq/hw-app-cosmos")).default;this.ledgerApp=L||!this.ledgerApp?new _(this.transport):this.ledgerApp}}return this.ledgerApp}catch(_){throw new w.SwapKitError("wallet_ledger_connection_error",_)}};validateResponse=(L,_)=>{switch(L){case w.LedgerErrorCode.NoError:return;case w.LedgerErrorCode.LockedDevice:throw new w.SwapKitError("wallet_ledger_device_locked",{message:`Ledger is locked: ${_}`});case w.LedgerErrorCode.TC_NotFound:throw new w.SwapKitError("wallet_ledger_device_not_found");default:{console.error(`Ledger error: ${L} ${_}`);break}}}}class n extends A{pubKey=null;derivationPath;constructor(L=x.NetworkDerivationPath.GAIA){super();this.chain="cosmos",this.derivationPath=x.derivationPathToString(L)}connect=async()=>{await this.checkOrCreateTransportAndLedger(!0);let{publicKey:L,address:_}=await this.getAddressAndPubKey();return this.pubKey=Buffer.from(L,"hex").toString("base64"),_};getAddressAndPubKey=async()=>{return await this.checkOrCreateTransportAndLedger(!0),await this.ledgerApp.getAddress(this.derivationPath,this.chain)};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:G,signature:B}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,G),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:B}]};signAmino=async(L,_)=>{await this.checkOrCreateTransportAndLedger(!0);let O=await this.getAccounts();if(O.findIndex((Q)=>Q.address===L)===-1)throw new Error(`Address ${L} not found in wallet`);let{encodeSecp256k1Signature:B,serializeSignDoc:j}=(await import("@cosmjs/amino")).default,{Secp256k1Signature:J}=(await import("@cosmjs/crypto")).default,F=j(_),W=await this.ledgerApp.sign(this.derivationPath,F);this.validateResponse(W.return_code,W.error_message);let $=J.fromDer(W.signature).toFixedLength();return{signed:_,signature:B(O[0].pubkey,$)}};getAccounts=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.getAddressAndPubKey();return[{address:L.address,algo:"secp256k1",pubkey:Buffer.from(L.publicKey,"hex")}]}}var m=require("@swapkit/helpers"),W0=require("ethers");class y extends W0.AbstractSigner{chainId=m.ChainId.Ethereum;derivationPath="";ledgerApp=null;ledgerTimeout=50000;constructor({provider:L,derivationPath:_=m.NetworkDerivationPath.OP,chainId:O=m.ChainId.Optimism}){super(L);this.chainId=O||m.ChainId.Ethereum,this.derivationPath=typeof _==="string"?_:m.derivationPathToString(_),Object.defineProperty(this,"provider",{enumerable:!0,value:L||null,writable:!1})}connect=(L)=>new y({provider:L,derivationPath:this.derivationPath,chainId:this.chainId});checkOrCreateTransportAndLedger=async()=>{if(this.ledgerApp)return;await this.createTransportAndLedger()};createTransportAndLedger=async()=>{let L=await D(),_=(await import("@ledgerhq/hw-app-eth")).default;this.ledgerApp=new _(L)};getAddress=async()=>{let L=await this.getAddressAndPubKey();if(!L)throw new Error("Could not get Address");return L.address};getAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath)};showAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath,!0)};signMessage=async(L)=>{let{Signature:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.ledgerApp?.signPersonalMessage(this.derivationPath,L);if(!O)throw new Error("Signing failed");return O.r=`0x${O.r}`,O.s=`0x${O.s}`,_.from(O).serialized};sendTransaction=async(L)=>{if(!this.provider)throw new Error("No provider set");let _=await this.signTransaction(L);return await this.provider.broadcastTransaction(_)};signTypedData(){throw new Error("Method not implemented.")}signTransaction=async(L)=>{let{Transaction:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.provider?.getTransactionCount(L.from||await this.getAddress()),G={chainId:L.chainId||this.chainId,data:L.data,gasLimit:L.gasLimit,...L.gasPrice&&{gasPrice:L.gasPrice},...!L.gasPrice&&L.maxFeePerGas&&{maxFeePerGas:L.maxFeePerGas,maxPriorityFeePerGas:L.maxPriorityFeePerGas},nonce:L.nonce!==void 0?Number((L.nonce||O||0).toString()):O,to:L.to?.toString(),value:L.value,type:L.type&&!Number.isNaN(L.type)?L.type:L.maxFeePerGas?2:0},B=_.from(G).unsignedSerialized.slice(2),{ledgerService:j}=await import("@ledgerhq/hw-app-eth"),J=await j.resolveTransaction(B,{},{externalPlugins:!0,erc20:!0}),F=await this.ledgerApp?.signTransaction(this.derivationPath,B,J);if(!F)throw new Error("Could not sign transaction");let{r:W,s:$,v:Q}=F;return _.from({...G,signature:{v:Number(BigInt(Q)),r:`0x${W}`,s:`0x${$}`}}).serialized}}var $0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Ethereum,provider:L,derivationPath:_}),Q0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Avalanche,provider:L,derivationPath:_}),Y0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.BinanceSmartChain,provider:L,derivationPath:_}),Z0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Arbitrum,provider:L,derivationPath:_}),H0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Polygon,provider:L,derivationPath:_}),m0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Optimism,provider:L,derivationPath:_}),M0=({provider:L,derivationPath:_})=>new y({chainId:m.ChainId.Base,provider:L,derivationPath:_});var U0=require("@scure/base"),w0=require("@swapkit/helpers");var T0=require("@scure/base"),a=(L)=>{if(L.length<64)throw new Error("Invalid Signature: Too short");if(L[0]!==48)throw new Error("Invalid Ledger Signature TLV encoding: expected first byte 0x30");if(L[1]+2!==L.length)throw new Error("Invalid Signature: signature length does not match TLV");if(L[2]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let _=L[3],O=L.slice(4,_+4);if(O.length===33&&O[0]===0)O=O.slice(1,33);else if(O.length===33)throw new Error('Invalid signature: "r" too long');while(O.length<32)O.unshift(0);if(L[_+4]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let G=L[_+5];if(4+_+2+G!==L.length)throw new Error("Invalid Ledger Signature: TLV byte lengths do not match message length");let B=L.slice(_+6,L.length);if(B.length===33&&B[0]===0)B=B.slice(1,33);else if(B.length===33)throw new Error('Invalid signature: "s" too long');while(B.length<32)B.unshift(0);if(O.length!==32||B.length!==32)throw new Error("Invalid signatures: must be 32 bytes each");return T0.base64.encode(Buffer.concat([O,B]))};class s extends A{pubKey=null;derivationPath;constructor(L=w0.NetworkDerivationPath.THOR){super();this.chain="thor",this.derivationPath=L}get pubkey(){return this.pubKey}connect=async()=>{await this.checkOrCreateTransportAndLedger();let{compressed_pk:L,bech32_address:_}=await this.getAddressAndPubKey();return this.pubKey=U0.base64.encode(L),_};getAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.getAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};showAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.showAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:G,signature:B}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,G),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:a(B)}]};sign=async(L)=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:_,error_message:O,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(_,O),a(G)}}var K=require("@swapkit/helpers"),R0=require("bitcoinjs-lib");var o0=async({psbt:L,inputUtxos:_,btcApp:O,derivationPath:G},B)=>{let j=_.map((Q)=>{let T=R0.Transaction.fromHex(Q.txHex||"");return[O.splitTransaction(T.toHex(),T.hasWitnesses()),Q.index,void 0,void 0]}),J=L.data.globalMap.unsignedTx.toBuffer().toString("hex"),F=O.splitTransaction(J,!0),W=O.serializeTransactionOutputs(F).toString("hex"),$={additionals:["bech32"],associatedKeysets:j.map(()=>G),inputs:j,outputScriptHex:W,segwit:!0,useTrustedInputForSegwit:!0};return O.createPaymentTransaction({...$,...B})},V=({chain:L,additionalSignParams:_})=>{let O,G=null;async function B(J=!0){if(J&&!O)new K.SwapKitError("wallet_ledger_connection_error",{message:`Ledger connection failed:
|
|
2
2
|
${JSON.stringify({checkBtcApp:J,btcApp:O})}`});G||=await D()}async function j(){G=await D(),O=new(await import("@ledgerhq/hw-app-btc")).default({transport:G,currency:L})}return(J)=>{let F=typeof J==="string"?J:K.derivationPathToString(J),W=K.getWalletFormatFor(F);return{connect:async()=>{await B(!1),O=new(await import("@ledgerhq/hw-app-btc")).default({transport:G,currency:L})},getExtendedPublicKey:async($="84'/0'/0'",Q=76067358)=>{return await B(!1),O.getWalletXpub({path:$,xpubVersion:Q})},signTransaction:async($,Q)=>{return await j(),o0({psbt:$,derivationPath:F,btcApp:O,inputUtxos:Q},_)},getAddress:async()=>{let{toCashAddress:$}=await import("@swapkit/toolboxes/utxo");await B(!1);let{bitcoinAddress:Q}=await O.getWalletPublicKey(F,{format:W});if(!Q)throw new K.SwapKitError("wallet_ledger_get_address_error",{message:`Cannot get ${L} address from ledger derivation path: ${F}`});return L==="bitcoin-cash"&&W==="legacy"?$(Q).replace(/(bchtest:|bitcoincash:)/,""):Q}}}},y0=V({chain:"bitcoin"}),D0=V({chain:"litecoin"}),N0=V({chain:"bitcoin-cash",additionalSignParams:{segwit:!1,additionals:["abc"],sigHashType:65}}),z0=V({chain:"dogecoin",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}}),K0=V({chain:"dash",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}});var f=async({chain:L,derivationPath:_})=>{switch(L){case Y.Chain.THORChain:return new s(_);case Y.Chain.Cosmos:return new n(_);case Y.Chain.Bitcoin:return y0(_);case Y.Chain.BitcoinCash:return N0(_);case Y.Chain.Dash:return K0(_);case Y.Chain.Dogecoin:return z0(_);case Y.Chain.Litecoin:return D0(_);case Y.Chain.Arbitrum:case Y.Chain.Avalanche:case Y.Chain.BinanceSmartChain:case Y.Chain.Ethereum:case Y.Chain.Optimism:case Y.Chain.Polygon:case Y.Chain.Base:{let{getProvider:O}=await import("@swapkit/toolboxes/evm"),G={provider:await O(L),derivationPath:_};switch(L){case Y.Chain.BinanceSmartChain:return Y0(G);case Y.Chain.Avalanche:return Q0(G);case Y.Chain.Arbitrum:return Z0(G);case Y.Chain.Optimism:return m0(G);case Y.Chain.Polygon:return H0(G);case Y.Chain.Base:return M0(G);default:return $0(G)}}default:throw new Y.SwapKitError("wallet_chain_not_supported",{wallet:Y.WalletOption.LEDGER,chain:L})}};var q0=X.createWallet({name:"connectLedger",supportedChains:[X.Chain.Arbitrum,X.Chain.Avalanche,X.Chain.Base,X.Chain.BinanceSmartChain,X.Chain.Bitcoin,X.Chain.BitcoinCash,X.Chain.Cosmos,X.Chain.Dash,X.Chain.Dogecoin,X.Chain.Ethereum,X.Chain.Litecoin,X.Chain.Optimism,X.Chain.Polygon,X.Chain.THORChain],walletType:X.WalletOption.LEDGER,connect:({addChain:L,supportedChains:_,walletType:O})=>async function G(B,j){let[J]=X.filterSupportedChains({chains:B,supportedChains:_,walletType:O});if(!J)return!1;let F=await e0({chain:J,derivationPath:j});return L({...F,chain:J,walletType:X.WalletOption.LEDGER}),!0}}),a0=S0(q0);function s0(L,_="t"){if(!L?.includes("=:"))return L;let O=L.includes(`:${_}:`)?L.split(`:${_}:`)[0]:L;return O?.substring(0,O.lastIndexOf(":"))}function v(L){if(Array.isArray(L))return L.forEach((G,B)=>{L[B]=v(G)}),L;if(typeof L!=="object")return L;let _={},O=Object.keys(L).sort();for(let G of O)_[G]=v(L[G]);return _}function r0(L){return JSON.stringify(v(L))}async function e0({chain:L,derivationPath:_}){switch(L){case X.Chain.BitcoinCash:case X.Chain.Bitcoin:case X.Chain.Dash:case X.Chain.Dogecoin:case X.Chain.Litecoin:{let{getUtxoToolbox:O}=await import("@swapkit/toolboxes/utxo"),G=await O(L),B=await f({chain:L,derivationPath:_}),j=await S({chain:L,ledgerClient:B});return{...G,address:j,transfer:async(F)=>{let W=F.feeRate||(await G.getFeeRates())[X.FeeOption.Average],$=[X.Chain.Bitcoin].includes(L)?F.memo:s0(F.memo),{psbt:Q,inputs:T}=await G.createTransaction({...F,feeRate:W,memo:$,sender:j,fetchTxHex:!0}),q=await B.signTransaction(Q,T);return await G.broadcastTx(q)}}}case X.Chain.Ethereum:case X.Chain.Avalanche:case X.Chain.Arbitrum:case X.Chain.Optimism:case X.Chain.Polygon:case X.Chain.BinanceSmartChain:case X.Chain.Base:{let{getEvmToolbox:O}=await import("@swapkit/toolboxes/evm"),G=await f({chain:L,derivationPath:_}),B=await S({chain:L,ledgerClient:G});return{...await O(L,{signer:G}),address:B}}case X.Chain.Cosmos:{let{createSigningStargateClient:O,getMsgSendDenom:G,getCosmosToolbox:B}=await import("@swapkit/toolboxes/cosmos"),j=await B(X.Chain.Cosmos),J=await f({chain:L,derivationPath:_}),F=await S({chain:L,ledgerClient:J});return{...j,address:F,transfer:async({assetValue:$,recipient:Q,memo:T})=>{if(!$)throw new Error("invalid asset");let q={amount:[{amount:$.getBaseValue("string"),denom:G(`u${$.symbol}`).toLowerCase()}],fromAddress:F,toAddress:Q},I=await O(X.SKConfig.get("rpcUrls")[L],J,"0.007uatom"),{transactionHash:P}=await I.signAndBroadcast(F,[{typeUrl:"/cosmos.bank.v1beta1.MsgSend",value:q}],2,T);return P}}}case X.Chain.THORChain:{let{SignMode:O}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:G}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),{encodePubkey:B,makeAuthInfoBytes:j}=(await import("@cosmjs/proto-signing")).default,{createStargateClient:J,buildEncodedTxBody:F,getCosmosToolbox:W,buildAminoMsg:$,getDefaultChainFee:Q,fromBase64:T,parseAminoMessageForDirectSigning:q}=await import("@swapkit/toolboxes/cosmos"),I=await W(L),P=await f({chain:L,derivationPath:_}),g=await S({chain:L,ledgerClient:P}),c=Q(L),{pubkey:r,signTransaction:E0,sign:C0}=P,e=async({memo:N="",assetValue:L0,...f0})=>{let _0=await I.getAccount(g);if(!_0)throw new Error("invalid account");if(!L0)throw new Error("invalid asset");if(!r)throw new Error("Account pubkey not found");let{accountNumber:I0,sequence:l0}=_0,u=(l0||0).toString(),O0=v([$({sender:g,assetValue:L0,memo:N,...f0})]),A0=r0({account_number:I0?.toString(),chain_id:X.ChainId.THORChain,fee:c,memo:N,msgs:O0,sequence:u}),h=await E0(A0,u);if(!h)throw new Error("tx signing failed");let V0=B({type:"tendermint/PubKeySecp256k1",value:r}),P0=O0.map(q),k0=await F({msgs:P0,chain:L,memo:N}),b0=j([{pubkey:V0,sequence:Number(u)}],c.amount,Number.parseInt(c.gas),void 0,void 0,O.SIGN_MODE_LEGACY_AMINO_JSON),x0=h?.[0]?.signature?T(h[0].signature):Uint8Array.from([]),v0=G.fromPartial({bodyBytes:k0,authInfoBytes:b0,signatures:[x0]}),g0=G.encode(v0).finish(),{isStagenet:c0}=X.SKConfig.get("envs"),u0=await J(X.SKConfig.get("rpcUrls")[c0?X.StagenetChain.THORChain:X.Chain.THORChain]),{transactionHash:h0}=await u0.broadcastTx(g0);return h0};return{...I,address:g,deposit:(N)=>e(N),transfer:(N)=>e(N),signMessage:C0}}default:throw new Error("Unsupported chain")}}
|
|
3
3
|
|
|
4
|
-
//# debugId=
|
|
4
|
+
//# debugId=FB960900366564CD64756E2164756E21
|