@swapkit/wallets 3.0.0-beta.13 → 3.0.0-beta.15
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.cjs +2 -2
- package/dist/src/bitget/index.cjs.map +3 -3
- package/dist/src/bitget/index.js +2 -2
- package/dist/src/bitget/index.js.map +3 -3
- package/dist/src/coinbase/index.js +1 -1
- package/dist/src/ctrl/index.js +1 -1
- package/dist/src/evm-extensions/index.js +1 -1
- package/dist/src/exodus/index.cjs +2 -2
- package/dist/src/exodus/index.cjs.map +3 -3
- package/dist/src/exodus/index.js +2 -2
- package/dist/src/exodus/index.js.map +3 -3
- 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 +3 -3
- package/dist/src/ledger/index.cjs.map +4 -4
- package/dist/src/ledger/index.js +3 -3
- package/dist/src/ledger/index.js.map +4 -4
- package/dist/src/okx/index.cjs +2 -2
- package/dist/src/okx/index.cjs.map +3 -3
- package/dist/src/okx/index.js +2 -2
- package/dist/src/okx/index.js.map +3 -3
- package/dist/src/onekey/index.cjs +2 -2
- package/dist/src/onekey/index.cjs.map +3 -3
- package/dist/src/onekey/index.js +2 -2
- package/dist/src/onekey/index.js.map +3 -3
- 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 +2 -2
- package/src/bitget/helpers.ts +1 -2
- package/src/exodus/index.ts +1 -2
- package/src/ledger/clients/utxo.ts +1 -3
- package/src/ledger/helpers/getLedgerTransport.ts +4 -2
- package/src/okx/helpers.ts +2 -1
- package/src/onekey/index.ts +1 -1
- /package/dist/{chunk-9cnrfb9p.js → chunk-0vabeczs.js} +0 -0
- /package/dist/{chunk-9cnrfb9p.js.map → chunk-0vabeczs.js.map} +0 -0
- /package/dist/{chunk-bw2b8py6.js → chunk-95tkswae.js} +0 -0
- /package/dist/{chunk-bw2b8py6.js.map → chunk-95tkswae.js.map} +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
var
|
|
1
|
+
var x={};C(x,{bitgetWallet:()=>u,BITGET_SUPPORTED_CHAINS:()=>_});module.exports=b(x);var a=require("@swapkit/helpers");var t=require("@swapkit/helpers"),p=require("bitcoinjs-lib");async function m(i){let o=window.bitkeep;switch(i){case t.Chain.Ethereum:case t.Chain.Base:case t.Chain.Avalanche:case t.Chain.Arbitrum:case t.Chain.Optimism:case t.Chain.Polygon:case t.Chain.BinanceSmartChain:{if(!(o&&("ethereum"in o)))throw new t.SwapKitError("wallet_bitkeep_not_found");let n=o.ethereum,[r]=await n.send("eth_requestAccounts",[]);return{...await f({chain:i,walletProvider:n}),address:r}}case t.Chain.Bitcoin:{if(!(o&&("unisat"in o)))throw new t.SwapKitError("wallet_bitkeep_not_found");let{unisat:n}=o,{getUtxoToolbox:r}=await import("@swapkit/toolboxes/utxo"),[e]=await n.requestAccounts();async function c(d){let h=await n.signPsbt(d.toHex(),{autoFinalized:!1});return p.Psbt.fromHex(h)}let s={getAddress:()=>Promise.resolve(e),signTransaction:c};return{...await r(t.Chain.Bitcoin,{signer:s}),address:e}}case t.Chain.Cosmos:{if(!(o&&("keplr"in o)))throw new t.SwapKitError("wallet_bitkeep_not_found");let{keplr:n}=o;await n.enable(t.ChainId.Cosmos);let r=n.getOfflineSignerOnlyAmino(t.ChainId.Cosmos),e=await r.getAccounts();if(!e?.[0])throw new Error("No cosmos account found");let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),[{address:s}]=e,l={...r,getAddress:()=>Promise.resolve(s),signTransaction:async()=>Promise.resolve({})};return{...c(t.Chain.Cosmos,{signer:l}),address:s}}case t.Chain.Solana:{if(!(o&&("solana"in o)))throw new t.SwapKitError("wallet_bitkeep_not_found");let{getSolanaToolbox:n}=await import("@swapkit/toolboxes/solana"),r=o?.solana,e=n({signer:r}),s=(await r.connect()).publicKey.toString();return{...e,address:s}}default:throw new t.SwapKitError("wallet_chain_not_supported")}}var f=async({chain:i,walletProvider:o})=>{let{getEvmToolbox:n}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:r}=await import("ethers");if(!o)throw new t.SwapKitError("wallet_provider_not_found");let e=new r(o,"any"),c=await e.getSigner(),s=await n(i,{provider:e,signer:c});try{if(i!==t.Chain.Ethereum&&"getNetworkParams"in s)await t.switchEVMWalletNetwork(e,i,s.getNetworkParams())}catch(l){throw new Error(`Failed to add/switch ${i} network: ${i}`)}return t.prepareNetworkSwitch({chain:i,toolbox:s,provider:e})};var u=a.createWallet({name:"connectBitget",walletType:a.WalletOption.BITGET,supportedChains:[...a.EVMChains,a.Chain.Cosmos,a.Chain.Bitcoin,a.Chain.Solana],connect:({addChain:i,walletType:o,supportedChains:n})=>async function r(e){let c=a.filterSupportedChains({chains:e,supportedChains:n,walletType:o});return await Promise.all(c.map(async(s)=>{let l=await m(s),d=await l.getAddress()||"";i({...l,address:d,chain:s,walletType:o})})),!0}}),_=g(u);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=DADAB989D1BBF10664756E2164756E21
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/bitget/index.ts", "../src/bitget/helpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import {\n Chain,\n EVMChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
|
|
6
|
-
"import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport
|
|
6
|
+
"import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const bitget = window.bitkeep;\n\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Base:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({ chain, walletProvider: wallet });\n\n return { ...evmWallet, address };\n }\n\n case Chain.Bitcoin: {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction,\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n }\n\n case Chain.Cosmos: {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0]) throw new Error(\"No cosmos account found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = getCosmosToolbox(Chain.Cosmos, {\n signer,\n });\n\n return { ...toolbox, address };\n }\n\n case Chain.Solana: {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n const toolbox = getSolanaToolbox({ signer: provider });\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n return { ...toolbox, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_chain_not_supported\");\n }\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return prepareNetworkSwitch({ chain, toolbox, provider });\n};\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "qFAMO,IANP,8BCOO,IAPP,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "DADAB989D1BBF10664756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
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-0vabeczs.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
|
-
//# debugId=
|
|
3
|
+
//# debugId=39BB292BD7B8372B64756E2164756E21
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/bitget/index.ts", "../src/bitget/helpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import {\n Chain,\n EVMChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
|
|
6
|
-
"import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport
|
|
6
|
+
"import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const bitget = window.bitkeep;\n\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Base:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({ chain, walletProvider: wallet });\n\n return { ...evmWallet, address };\n }\n\n case Chain.Bitcoin: {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction,\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n }\n\n case Chain.Cosmos: {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0]) throw new Error(\"No cosmos account found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = getCosmosToolbox(Chain.Cosmos, {\n signer,\n });\n\n return { ...toolbox, address };\n }\n\n case Chain.Solana: {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n const toolbox = getSolanaToolbox({ signer: provider });\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n return { ...toolbox, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_chain_not_supported\");\n }\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return prepareNetworkSwitch({ chain, toolbox, provider });\n};\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "4FAAA,cACE,eACA,kBACA,kBACA,2BACA,yBCLF,gBACE,aACA,kBAEA,0BACA,4BACA,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "39BB292BD7B8372B64756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as g}from"../../chunk-
|
|
1
|
+
import{a as g}from"../../chunk-0vabeczs.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.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as m}from"../../chunk-
|
|
1
|
+
import{a as m}from"../../chunk-0vabeczs.js";import{c as R,d as g}from"../../chunk-p1kdg37m.js";import{Chain as w,ChainToChainId as $,SwapKitError as U,WalletOption as k,createWallet as c,filterSupportedChains as q}from"@swapkit/helpers";import{Chain as f,ChainToChainId as J,EVMChains as N,SwapKitError as b,WalletOption as P}from"@swapkit/helpers";import{erc20ABI as Q}from"@swapkit/helpers/contracts";async function S(o){if(!window.xfi)throw new b("wallet_ctrl_not_found");let{match:y}=await import("ts-pattern");return y(o).with(f.Arbitrum,f.Avalanche,f.Base,f.BinanceSmartChain,f.Ethereum,f.Optimism,f.Polygon,()=>window.xfi?.ethereum).with(f.Cosmos,f.Kujira,f.Maya,f.THORChain,()=>window.xfi?.keplr).with(f.Bitcoin,()=>window.xfi?.bitcoin).with(f.BitcoinCash,()=>window.xfi?.bitcoincash).with(f.Dogecoin,()=>window.xfi?.dogecoin).with(f.Litecoin,()=>window.xfi?.litecoin).with(f.Solana,()=>window.xfi?.solana).otherwise(()=>{return})}async function Z({method:o,params:y,chain:t}){let l=await S(t);return new Promise((_,T)=>{if(l&&"request"in l)l.request({method:o,params:y},(n,B)=>{n?T(n):_(B)})})}async function E(o){let y=await S(o);if(!y)throw new b({errorKey:"wallet_provider_not_found",info:{wallet:P.CTRL,chain:o}});if([f.Cosmos,f.Kujira].includes(o)){let t=await S(f.Cosmos);if(!t||"request"in t)throw new b({errorKey:"wallet_provider_not_found",info:{wallet:P.CTRL,chain:o}});let l=J[o];await t.enable(l);let _=t.getOfflineSigner(l),[T]=await _.getAccounts();return T?.address}if(N.includes(o)){let[t]=await y.request({method:"eth_requestAccounts",params:[]});return t}if(o===f.Solana)return(await(await S(f.Solana)).connect()).publicKey.toString();return new Promise((t,l)=>y.request({method:"request_accounts",params:[]},(_,[T])=>_?l(_):t(T)))}async function D({assetValue:o,recipient:y,memo:t,gasLimit:l},_="transfer"){if(!o)throw new b("wallet_ctrl_asset_not_defined");let T=await E(o.chain),n=[{amount:{amount:o.getBaseValue("number"),decimals:o.decimal},asset:{chain:o.chain,symbol:o.symbol.toUpperCase(),ticker:o.symbol.toUpperCase()},memo:t||"",from:T,recipient:y,gasLimit:l}];return Z({method:_,params:n,chain:o.chain})}function Y(o,y){return{call:async({contractAddress:t,abi:l,funcName:_,funcParams:T=[],txOverrides:n})=>{if(!t)throw new b("wallet_ctrl_contract_address_not_provided");let{createContract:B,getCreateContractTxObject:L,isStateChangingCall:M,toHexString:G}=await import("@swapkit/toolboxes/evm");if(M({abi:l,funcName:_})){let x=L({provider:o,chain:y}),{value:H,from:z,to:A,data:F}=await x({contractAddress:t,abi:l,funcName:_,funcParams:T,txOverrides:n});return o.send("eth_sendTransaction",[{value:G(BigInt(H||0)),from:z,to:A,data:F||"0x"}])}let W=await B(t,l,o)[_]?.(...T);return typeof W?.hash==="string"?W?.hash:W},approve:async({assetAddress:t,spenderAddress:l,amount:_,from:T})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:B,toHexString:L}=await import("@swapkit/toolboxes/evm"),M=[l,BigInt(_||n)],O={contractAddress:t,abi:Q,funcName:"approve",funcParams:M,txOverrides:{from:T}},I=B({provider:o,chain:y}),{value:W,to:x,data:H}=await I(O);return o.send("eth_sendTransaction",[{value:L(BigInt(W||0)),from:T,to:x,data:H||"0x"}])},sendTransaction:async(t)=>{let{from:l,to:_,data:T,value:n}=t;if(!_)throw new b("wallet_ctrl_send_transaction_no_address");let{toHexString:B}=await import("@swapkit/toolboxes/evm");return o.send("eth_sendTransaction",[{value:B(BigInt(n||0)),from:l,to:_,data:T||"0x"}])}}}var K=c({name:"connectCtrl",walletType:k.CTRL,supportedChains:[w.Arbitrum,w.Avalanche,w.Base,w.BinanceSmartChain,w.Bitcoin,w.BitcoinCash,w.Cosmos,w.Dogecoin,w.Ethereum,w.Kujira,w.Litecoin,w.Maya,w.Optimism,w.Polygon,w.Solana,w.THORChain],connect:({addChain:o,walletType:y,supportedChains:t})=>async function l(_){let n=q({chains:_,supportedChains:t,walletType:y}).map(async(B)=>{let L=await E(B),M=await X(B);o({...M,address:L,chain:B,walletType:y})});return await Promise.all(n),!0}}),i=m(K);async function X(o){switch(o){case w.Solana:{let{getSolanaToolbox:y}=await import("@swapkit/toolboxes/solana"),t=window.xfi?.solana;if(!t)throw new U("wallet_ctrl_not_found");return{...y({signer:t})}}case w.Maya:case w.THORChain:{let{getCosmosToolbox:y,THORCHAIN_GAS_VALUE:t,MAYA_GAS_VALUE:l}=await import("@swapkit/toolboxes/cosmos"),_=o===w.Maya?l:t;return{...await y(o),deposit:(n)=>D({...n,recipient:""},"deposit"),transfer:(n)=>D({...n,gasLimit:_},"transfer")}}case w.Cosmos:case w.Kujira:{let{getCosmosToolbox:y}=await import("@swapkit/toolboxes/cosmos"),t=$[o],l=await S(o);await l?.enable(t);let _=l?.getOfflineSignerOnlyAmino(t);if(!_)throw new U("wallet_ctrl_not_found");return y(o,{signer:_})}case w.Bitcoin:case w.BitcoinCash:case w.Dogecoin:case w.Litecoin:{let{getUtxoToolbox:y}=await import("@swapkit/toolboxes/utxo");return{...await y(o),transfer:D}}case w.Arbitrum:case w.Avalanche:case w.Base:case w.BinanceSmartChain:case w.Ethereum:case w.Optimism:case w.Polygon:{let{prepareNetworkSwitch:y,switchEVMWalletNetwork:t}=await import("@swapkit/helpers"),{getEvmToolbox:l}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:_}=await import("ethers"),T=await S(o);if(!T)throw new U("wallet_ctrl_not_found");let n=new _(T,"any"),B=await n.getSigner(),L=await l(o,{provider:n,signer:B}),M=Y(n,o);try{if(o!==w.Ethereum){let G=L.getNetworkParams();await t(n,o,G)}}catch(G){throw new U({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:k.CTRL,chain:o}})}return y({provider:window.xfi?.ethereum,chain:o,toolbox:{...L,...M}})}default:return null}}export{K as ctrlWallet,i as CTRL_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=A42F7E7517D14D9064756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as M}from"../../chunk-
|
|
1
|
+
import{a as M}from"../../chunk-0vabeczs.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
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
var z={};E(z,{exodusWallet:()=>V,EXODUS_SUPPORTED_CHAINS:()=>N});module.exports=B(z);var q=require("@swapkit/helpers"),
|
|
1
|
+
var z={};E(z,{exodusWallet:()=>V,EXODUS_SUPPORTED_CHAINS:()=>N});module.exports=B(z);var q=require("@swapkit/helpers"),j=require("bitcoinjs-lib"),I=require("sats-connect");F(z,require("@passkeys/react"),module.exports);F(z,require("@passkeys/core"),module.exports);async function M({walletProvider:K,provider:$,chain:H}){switch(H){case q.Chain.Bitcoin:{let{getUtxoToolbox:D}=await import("@swapkit/toolboxes/utxo"),J="",Q=()=>new Promise((G)=>G($)),L={getProvider:Q,payload:{purposes:[I.AddressPurpose.Payment],message:"Address for receiving and sending payments",network:{type:I.BitcoinNetworkType.Mainnet}},onFinish:(G)=>{if(!G.addresses[0])throw new Error("No address found");J=G.addresses[0].address},onCancel:()=>{throw new Error("Request canceled")}};await I.getAddress(L);async function Y(G){let _,R={getProvider:Q,payload:{message:"Sign transaction",network:{type:I.BitcoinNetworkType.Mainnet},psbtBase64:G.toBase64(),broadcast:!1,inputsToSign:[{address:J,signingIndexes:G.txInputs.map((U,A)=>A)}]},onFinish:(U)=>{_=j.Psbt.fromBase64(U.psbtBase64)},onCancel:()=>{throw new Error("Signature canceled")}};if(await I.signTransaction(R),!_)throw new q.SwapKitError("wallet_exodus_sign_transaction_error");return _}return{...await D(H,{signer:{signTransaction:Y,getAddress:()=>Promise.resolve(J)}}),address:J}}case q.Chain.Arbitrum:case q.Chain.Avalanche:case q.Chain.Base:case q.Chain.BinanceSmartChain:case q.Chain.Ethereum:case q.Chain.Optimism:case q.Chain.Polygon:{if(!K)throw new Error("Requested web3 wallet is not installed");let{getProvider:D,getEvmToolbox:J}=await import("@swapkit/toolboxes/evm"),Q=await D(H),L=$;await L.send("eth_requestAccounts",[]);let Y=await L.getSigner(),Z=await Y.getAddress(),X=await J(H,{provider:Q,signer:Y});try{if(H!==q.Chain.Ethereum){let G=X.getNetworkParams();await q.switchEVMWalletNetwork(L,H,G)}}catch(G){throw new Error(`Failed to add/switch ${H} network: ${H}`)}return{...q.prepareNetworkSwitch({toolbox:X,chain:H,provider:L}),address:Z}}default:throw new Error(`Unsupported chain: ${H}`)}}var V=q.createWallet({name:"connectExodusWallet",walletType:q.WalletOption.EXODUS,supportedChains:[...q.EVMChains,q.Chain.Bitcoin],connect:({addChain:K,walletType:$,supportedChains:H})=>async function D(J,Q){if(!Q)throw new Error("Missing Exodus Wallet instance");let L=q.filterSupportedChains({chains:J,supportedChains:H,walletType:$}),{BrowserProvider:Y}=await import("ethers"),{providers:Z}=Q;return await Promise.all(L.map(async(X)=>{let G=X===q.Chain.Bitcoin?Z.bitcoin:new Y(Z.ethereum,"any"),{address:_,...R}=await M({chain:X,provider:G,walletProvider:Z.ethereum});K({...R,disconnect:()=>G.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:X,address:_,walletType:q.WalletOption.EXODUS})})),!0}}),N=m(V);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=6F698290BCD1C48C64756E2164756E21
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/exodus/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport
|
|
5
|
+
"import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport {\n AddressPurpose,\n BitcoinNetworkType,\n type BitcoinProvider,\n type GetAddressOptions,\n type GetAddressResponse,\n type SignTransactionOptions,\n getAddress,\n signTransaction as satsSignTransaction,\n} from \"sats-connect\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nasync function getWalletMethods({\n walletProvider,\n provider,\n chain,\n}: {\n walletProvider?: Eip1193Provider;\n provider: BrowserProvider | BitcoinProvider;\n chain: Chain;\n}) {\n switch (chain) {\n case Chain.Bitcoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n let address = \"\";\n\n const getProvider: () => Promise<BitcoinProvider | undefined> = () =>\n new Promise((res) => res(provider as BitcoinProvider));\n\n const getAddressOptions: GetAddressOptions = {\n getProvider,\n payload: {\n purposes: [AddressPurpose.Payment],\n message: \"Address for receiving and sending payments\",\n network: { type: BitcoinNetworkType.Mainnet },\n },\n onFinish: (response: GetAddressResponse) => {\n if (!response.addresses[0]) throw new Error(\"No address found\");\n address = response.addresses[0].address;\n },\n onCancel: () => {\n throw new Error(\"Request canceled\");\n },\n };\n\n // TODO: Towan - probably not needed ?\n await getAddress(getAddressOptions);\n\n async function signTransaction(psbt: Psbt) {\n let signedPsbt: Psbt | undefined;\n const signPsbtOptions: SignTransactionOptions = {\n getProvider,\n payload: {\n message: \"Sign transaction\",\n network: {\n type: BitcoinNetworkType.Mainnet,\n },\n psbtBase64: psbt.toBase64(),\n broadcast: false,\n inputsToSign: [\n { address: address, signingIndexes: psbt.txInputs.map((_, index) => index) },\n ],\n },\n onFinish: (response) => {\n signedPsbt = Psbt.fromBase64(response.psbtBase64);\n },\n onCancel: () => {\n throw new Error(\"Signature canceled\");\n },\n };\n\n await satsSignTransaction(signPsbtOptions);\n if (!signedPsbt) throw new SwapKitError(\"wallet_exodus_sign_transaction_error\");\n return signedPsbt;\n }\n\n const signer = {\n signTransaction,\n getAddress: () => Promise.resolve(address),\n };\n const toolbox = await getUtxoToolbox(chain, { signer });\n\n return { ...toolbox, address };\n }\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n if (!walletProvider) throw new Error(\"Requested web3 wallet is not installed\");\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const jsonRpcProvider = await getProvider(chain);\n const browserProvider = provider as BrowserProvider;\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider: jsonRpcProvider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(browserProvider, chain, networkParams);\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return { ...prepareNetworkSwitch({ toolbox, chain, provider: browserProvider }), address };\n }\n default:\n throw new Error(`Unsupported chain: ${chain}`);\n }\n}\n\nexport const exodusWallet = createWallet({\n name: \"connectExodusWallet\",\n walletType: WalletOption.EXODUS,\n supportedChains: [...EVMChains, Chain.Bitcoin],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectExodusWallet(chains: Chain[], wallet: Wallet) {\n if (!wallet) throw new Error(\"Missing Exodus Wallet instance\");\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n const { providers } = wallet;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const provider =\n chain === Chain.Bitcoin\n ? providers.bitcoin\n : new BrowserProvider(providers.ethereum, \"any\");\n\n const { address, ...walletMethods } = await getWalletMethods({\n chain,\n provider,\n walletProvider: providers.ethereum,\n });\n\n const disconnect = () =>\n provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({\n ...walletMethods,\n disconnect,\n chain,\n address,\n walletType: WalletOption.EXODUS,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const EXODUS_SUPPORTED_CHAINS = getWalletSupportedChains(exodusWallet);\nexport * from \"@passkeys/react\";\nexport * from \"@passkeys/core\";\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "qFAUO,IATP,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "qFAUO,IATP,8BAUA,2BAEA,0BAmKA,+CACA,8CAxJA,eAAe,CAAgB,EAC7B,iBACA,WACA,SAKC,CACD,OAAQ,QACD,QAAM,QAAS,CAClB,IAAQ,kBAAmB,KAAa,mCAEpC,EAAU,GAER,EAA0D,IAC9D,IAAI,QAAQ,CAAC,IAAQ,EAAI,CAA2B,CAAC,EAEjD,EAAuC,CAC3C,cACA,QAAS,CACP,SAAU,CAAC,iBAAe,OAAO,EACjC,QAAS,6CACT,QAAS,CAAE,KAAM,qBAAmB,OAAQ,CAC9C,EACA,SAAU,CAAC,IAAiC,CAC1C,IAAK,EAAS,UAAU,GAAI,MAAM,IAAI,MAAM,kBAAkB,EAC9D,EAAU,EAAS,UAAU,GAAG,SAElC,SAAU,IAAM,CACd,MAAM,IAAI,MAAM,kBAAkB,EAEtC,EAGA,MAAM,aAAW,CAAiB,EAElC,eAAe,CAAe,CAAC,EAAY,CACzC,IAAI,EACE,EAA0C,CAC9C,cACA,QAAS,CACP,QAAS,mBACT,QAAS,CACP,KAAM,qBAAmB,OAC3B,EACA,WAAY,EAAK,SAAS,EAC1B,UAAW,GACX,aAAc,CACZ,CAAE,QAAS,EAAS,eAAgB,EAAK,SAAS,IAAI,CAAC,EAAG,IAAU,CAAK,CAAE,CAC7E,CACF,EACA,SAAU,CAAC,IAAa,CACtB,EAAa,OAAK,WAAW,EAAS,UAAU,GAElD,SAAU,IAAM,CACd,MAAM,IAAI,MAAM,oBAAoB,EAExC,EAGA,GADA,MAAM,kBAAoB,CAAe,GACpC,EAAY,MAAM,IAAI,eAAa,sCAAsC,EAC9E,OAAO,EAST,MAAO,IAFS,MAAM,EAAe,EAAO,CAAE,OAJ/B,CACb,kBACA,WAAY,IAAM,QAAQ,QAAQ,CAAO,CAC3C,CACqD,CAAC,EAEjC,SAAQ,CAC/B,MACK,QAAM,cACN,QAAM,eACN,QAAM,UACN,QAAM,uBACN,QAAM,cACN,QAAM,cACN,QAAM,QAAS,CAClB,IAAK,EAAgB,MAAM,IAAI,MAAM,wCAAwC,EAC7E,IAAQ,cAAa,iBAAkB,KAAa,kCAE9C,EAAkB,MAAM,EAAY,CAAK,EACzC,EAAkB,EAExB,MAAM,EAAgB,KAAK,sBAAuB,CAAC,CAAC,EAEpD,IAAM,EAAS,MAAM,EAAgB,UAAU,EACzC,EAAU,MAAM,EAAO,WAAW,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,SAAU,EAAiB,QAAO,CAAC,EAEhF,GAAI,CACF,GAAI,IAAU,QAAM,SAAU,CAC5B,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,yBAAuB,EAAiB,EAAO,CAAa,GAEpE,MAAO,EAAQ,CACf,MAAM,IAAI,MAAM,wBAAwB,cAAkB,GAAO,EAGnE,MAAO,IAAK,uBAAqB,CAAE,UAAS,QAAO,SAAU,CAAgB,CAAC,EAAG,SAAQ,CAC3F,SAEE,MAAM,IAAI,MAAM,sBAAsB,GAAO,GAI5C,IAAM,EAAe,eAAa,CACvC,KAAM,sBACN,WAAY,eAAa,OACzB,gBAAiB,CAAC,GAAG,YAAW,QAAM,OAAO,EAC7C,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAmB,CAAC,EAAiB,EAAgB,CAClE,IAAK,EAAQ,MAAM,IAAI,MAAM,gCAAgC,EAC7D,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,mBAAoB,KAAa,mBAEjC,aAAc,EA4BtB,OA1BA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EACJ,IAAU,QAAM,QACZ,EAAU,QACV,IAAI,EAAgB,EAAU,SAAU,KAAK,GAE3C,aAAY,GAAkB,MAAM,EAAiB,CAC3D,QACA,WACA,eAAgB,EAAU,QAC5B,CAAC,EAKD,EAAS,IACJ,EACH,WALiB,IACjB,EAAS,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EAKhE,QACA,UACA,WAAY,eAAa,MAC3B,CAAC,EACF,CACH,EAEO,GAEb,CAAC,EAEY,EAA0B,EAAyB,CAAY",
|
|
8
|
+
"debugId": "6F698290BCD1C48C64756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
package/dist/src/exodus/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as j}from"../../chunk-0vabeczs.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
|
-
//# debugId=
|
|
3
|
+
//# debugId=3A555307E01DF90164756E2164756E21
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/exodus/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport
|
|
5
|
+
"import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport {\n AddressPurpose,\n BitcoinNetworkType,\n type BitcoinProvider,\n type GetAddressOptions,\n type GetAddressResponse,\n type SignTransactionOptions,\n getAddress,\n signTransaction as satsSignTransaction,\n} from \"sats-connect\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nasync function getWalletMethods({\n walletProvider,\n provider,\n chain,\n}: {\n walletProvider?: Eip1193Provider;\n provider: BrowserProvider | BitcoinProvider;\n chain: Chain;\n}) {\n switch (chain) {\n case Chain.Bitcoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n let address = \"\";\n\n const getProvider: () => Promise<BitcoinProvider | undefined> = () =>\n new Promise((res) => res(provider as BitcoinProvider));\n\n const getAddressOptions: GetAddressOptions = {\n getProvider,\n payload: {\n purposes: [AddressPurpose.Payment],\n message: \"Address for receiving and sending payments\",\n network: { type: BitcoinNetworkType.Mainnet },\n },\n onFinish: (response: GetAddressResponse) => {\n if (!response.addresses[0]) throw new Error(\"No address found\");\n address = response.addresses[0].address;\n },\n onCancel: () => {\n throw new Error(\"Request canceled\");\n },\n };\n\n // TODO: Towan - probably not needed ?\n await getAddress(getAddressOptions);\n\n async function signTransaction(psbt: Psbt) {\n let signedPsbt: Psbt | undefined;\n const signPsbtOptions: SignTransactionOptions = {\n getProvider,\n payload: {\n message: \"Sign transaction\",\n network: {\n type: BitcoinNetworkType.Mainnet,\n },\n psbtBase64: psbt.toBase64(),\n broadcast: false,\n inputsToSign: [\n { address: address, signingIndexes: psbt.txInputs.map((_, index) => index) },\n ],\n },\n onFinish: (response) => {\n signedPsbt = Psbt.fromBase64(response.psbtBase64);\n },\n onCancel: () => {\n throw new Error(\"Signature canceled\");\n },\n };\n\n await satsSignTransaction(signPsbtOptions);\n if (!signedPsbt) throw new SwapKitError(\"wallet_exodus_sign_transaction_error\");\n return signedPsbt;\n }\n\n const signer = {\n signTransaction,\n getAddress: () => Promise.resolve(address),\n };\n const toolbox = await getUtxoToolbox(chain, { signer });\n\n return { ...toolbox, address };\n }\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n if (!walletProvider) throw new Error(\"Requested web3 wallet is not installed\");\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const jsonRpcProvider = await getProvider(chain);\n const browserProvider = provider as BrowserProvider;\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider: jsonRpcProvider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(browserProvider, chain, networkParams);\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return { ...prepareNetworkSwitch({ toolbox, chain, provider: browserProvider }), address };\n }\n default:\n throw new Error(`Unsupported chain: ${chain}`);\n }\n}\n\nexport const exodusWallet = createWallet({\n name: \"connectExodusWallet\",\n walletType: WalletOption.EXODUS,\n supportedChains: [...EVMChains, Chain.Bitcoin],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectExodusWallet(chains: Chain[], wallet: Wallet) {\n if (!wallet) throw new Error(\"Missing Exodus Wallet instance\");\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n const { providers } = wallet;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const provider =\n chain === Chain.Bitcoin\n ? providers.bitcoin\n : new BrowserProvider(providers.ethereum, \"any\");\n\n const { address, ...walletMethods } = await getWalletMethods({\n chain,\n provider,\n walletProvider: providers.ethereum,\n });\n\n const disconnect = () =>\n provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({\n ...walletMethods,\n disconnect,\n chain,\n address,\n walletType: WalletOption.EXODUS,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const EXODUS_SUPPORTED_CHAINS = getWalletSupportedChains(exodusWallet);\nexport * from \"@passkeys/react\";\nexport * from \"@passkeys/core\";\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "iGACA,cACE,eACA,kBACA,kBACA,kBACA,2BACA,0BACA,4BACA,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "iGACA,cACE,eACA,kBACA,kBACA,kBACA,2BACA,0BACA,4BACA,yBAEF,eAAS,sBAET,yBACE,wBACA,gBAKA,qBACA,qBA2JF,6BACA,4BAxJA,eAAe,CAAgB,EAC7B,iBACA,WACA,SAKC,CACD,OAAQ,QACD,EAAM,QAAS,CAClB,IAAQ,kBAAmB,KAAa,mCAEpC,EAAU,GAER,EAA0D,IAC9D,IAAI,QAAQ,CAAC,IAAQ,EAAI,CAA2B,CAAC,EAEjD,EAAuC,CAC3C,cACA,QAAS,CACP,SAAU,CAAC,EAAe,OAAO,EACjC,QAAS,6CACT,QAAS,CAAE,KAAM,EAAmB,OAAQ,CAC9C,EACA,SAAU,CAAC,IAAiC,CAC1C,IAAK,EAAS,UAAU,GAAI,MAAM,IAAI,MAAM,kBAAkB,EAC9D,EAAU,EAAS,UAAU,GAAG,SAElC,SAAU,IAAM,CACd,MAAM,IAAI,MAAM,kBAAkB,EAEtC,EAGA,MAAM,EAAW,CAAiB,EAElC,eAAe,CAAe,CAAC,EAAY,CACzC,IAAI,EACE,EAA0C,CAC9C,cACA,QAAS,CACP,QAAS,mBACT,QAAS,CACP,KAAM,EAAmB,OAC3B,EACA,WAAY,EAAK,SAAS,EAC1B,UAAW,GACX,aAAc,CACZ,CAAE,QAAS,EAAS,eAAgB,EAAK,SAAS,IAAI,CAAC,EAAG,IAAU,CAAK,CAAE,CAC7E,CACF,EACA,SAAU,CAAC,IAAa,CACtB,EAAa,EAAK,WAAW,EAAS,UAAU,GAElD,SAAU,IAAM,CACd,MAAM,IAAI,MAAM,oBAAoB,EAExC,EAGA,GADA,MAAM,EAAoB,CAAe,GACpC,EAAY,MAAM,IAAI,EAAa,sCAAsC,EAC9E,OAAO,EAST,MAAO,IAFS,MAAM,EAAe,EAAO,CAAE,OAJ/B,CACb,kBACA,WAAY,IAAM,QAAQ,QAAQ,CAAO,CAC3C,CACqD,CAAC,EAEjC,SAAQ,CAC/B,MACK,EAAM,cACN,EAAM,eACN,EAAM,UACN,EAAM,uBACN,EAAM,cACN,EAAM,cACN,EAAM,QAAS,CAClB,IAAK,EAAgB,MAAM,IAAI,MAAM,wCAAwC,EAC7E,IAAQ,cAAa,iBAAkB,KAAa,kCAE9C,EAAkB,MAAM,EAAY,CAAK,EACzC,EAAkB,EAExB,MAAM,EAAgB,KAAK,sBAAuB,CAAC,CAAC,EAEpD,IAAM,EAAS,MAAM,EAAgB,UAAU,EACzC,EAAU,MAAM,EAAO,WAAW,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,SAAU,EAAiB,QAAO,CAAC,EAEhF,GAAI,CACF,GAAI,IAAU,EAAM,SAAU,CAC5B,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,EAAuB,EAAiB,EAAO,CAAa,GAEpE,MAAO,EAAQ,CACf,MAAM,IAAI,MAAM,wBAAwB,cAAkB,GAAO,EAGnE,MAAO,IAAK,EAAqB,CAAE,UAAS,QAAO,SAAU,CAAgB,CAAC,EAAG,SAAQ,CAC3F,SAEE,MAAM,IAAI,MAAM,sBAAsB,GAAO,GAI5C,IAAM,EAAe,EAAa,CACvC,KAAM,sBACN,WAAY,EAAa,OACzB,gBAAiB,CAAC,GAAG,EAAW,EAAM,OAAO,EAC7C,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAmB,CAAC,EAAiB,EAAgB,CAClE,IAAK,EAAQ,MAAM,IAAI,MAAM,gCAAgC,EAC7D,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,mBAAoB,KAAa,mBAEjC,aAAc,EA4BtB,OA1BA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EACJ,IAAU,EAAM,QACZ,EAAU,QACV,IAAI,EAAgB,EAAU,SAAU,KAAK,GAE3C,aAAY,GAAkB,MAAM,EAAiB,CAC3D,QACA,WACA,eAAgB,EAAU,QAC5B,CAAC,EAKD,EAAS,IACJ,EACH,WALiB,IACjB,EAAS,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EAKhE,QACA,UACA,WAAY,EAAa,MAC3B,CAAC,EACF,CACH,EAEO,GAEb,CAAC,EAEY,EAA0B,EAAyB,CAAY",
|
|
8
|
+
"debugId": "3A555307E01DF90164756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
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-0vabeczs.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-9cnrfb9p.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-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};
|
|
2
2
|
|
|
3
3
|
//# debugId=C1A7C5EC6AF41DFF64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as l}from"../../chunk-
|
|
1
|
+
import{a as l}from"../../chunk-0vabeczs.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-0vabeczs.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
|