@swapkit/wallets 4.2.10 → 4.3.3
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.cjs +4 -0
- package/dist/src/bitget.cjs.map +10 -0
- package/dist/src/bitget.js +4 -0
- package/dist/src/bitget.js.map +10 -0
- package/dist/src/cosmostation.cjs +4 -0
- package/dist/src/cosmostation.cjs.map +10 -0
- package/dist/src/cosmostation.js +4 -0
- package/dist/src/cosmostation.js.map +10 -0
- package/dist/src/ctrl.cjs +4 -0
- package/dist/src/ctrl.cjs.map +10 -0
- package/dist/src/ctrl.js +4 -0
- package/dist/src/ctrl.js.map +10 -0
- package/dist/src/evm-extensions.cjs +4 -0
- package/dist/src/evm-extensions.cjs.map +10 -0
- package/dist/src/evm-extensions.js +4 -0
- package/dist/src/evm-extensions.js.map +10 -0
- package/dist/src/index.cjs +2 -2
- package/dist/src/index.cjs.map +3 -3
- package/dist/src/index.js +2 -2
- package/dist/src/index.js.map +3 -3
- package/dist/src/keepkey-bex.cjs +4 -0
- package/dist/src/keepkey-bex.cjs.map +10 -0
- package/dist/src/keepkey-bex.js +4 -0
- package/dist/src/keepkey-bex.js.map +10 -0
- package/dist/src/keplr.cjs +4 -0
- package/dist/src/keplr.cjs.map +10 -0
- package/dist/src/keplr.js +4 -0
- package/dist/src/keplr.js.map +10 -0
- package/dist/src/okx.cjs +4 -0
- package/dist/src/okx.cjs.map +10 -0
- package/dist/src/okx.js +4 -0
- package/dist/src/okx.js.map +10 -0
- package/dist/src/onekey.cjs +4 -0
- package/dist/src/onekey.cjs.map +10 -0
- package/dist/src/onekey.js +4 -0
- package/dist/src/onekey.js.map +10 -0
- package/dist/src/passkeys/index.cjs +4 -0
- package/dist/src/passkeys/index.cjs.map +10 -0
- package/dist/src/passkeys/index.js +4 -0
- package/dist/src/passkeys/index.js.map +10 -0
- package/dist/src/phantom.cjs +4 -0
- package/dist/src/phantom.cjs.map +10 -0
- package/dist/src/phantom.js +4 -0
- package/dist/src/phantom.js.map +10 -0
- package/dist/src/polkadotjs.cjs +4 -0
- package/dist/src/polkadotjs.cjs.map +10 -0
- package/dist/src/polkadotjs.js +4 -0
- package/dist/src/polkadotjs.js.map +10 -0
- package/dist/src/talisman.cjs +4 -0
- package/dist/src/talisman.cjs.map +10 -0
- package/dist/src/talisman.js +4 -0
- package/dist/src/talisman.js.map +10 -0
- package/dist/src/tronlink.cjs +4 -0
- package/dist/src/tronlink.cjs.map +10 -0
- package/dist/src/tronlink.js +4 -0
- package/dist/src/tronlink.js.map +10 -0
- package/dist/src/vultisig.cjs +4 -0
- package/dist/src/vultisig.cjs.map +10 -0
- package/dist/src/vultisig.js +4 -0
- package/dist/src/vultisig.js.map +10 -0
- package/dist/types/bitget.d.ts +2 -0
- package/dist/types/bitget.d.ts.map +1 -0
- package/dist/types/coinbase/index.d.ts +2 -2
- package/dist/types/coinbase/signer.d.ts +7 -7
- package/dist/types/coinbase/signer.d.ts.map +1 -1
- package/dist/types/cosmostation.d.ts +2 -0
- package/dist/types/cosmostation.d.ts.map +1 -0
- package/dist/types/ctrl.d.ts +2 -0
- package/dist/types/ctrl.d.ts.map +1 -0
- package/dist/types/evm-extensions.d.ts +2 -0
- package/dist/types/evm-extensions.d.ts.map +1 -0
- package/dist/types/keepkey-bex.d.ts +2 -0
- package/dist/types/keepkey-bex.d.ts.map +1 -0
- package/dist/types/keplr.d.ts +2 -0
- package/dist/types/keplr.d.ts.map +1 -0
- package/dist/types/okx.d.ts +2 -0
- package/dist/types/okx.d.ts.map +1 -0
- package/dist/types/onekey.d.ts +2 -0
- package/dist/types/onekey.d.ts.map +1 -0
- package/dist/types/passkeys/index.d.ts +14 -0
- package/dist/types/passkeys/index.d.ts.map +1 -0
- package/dist/types/phantom.d.ts +2 -0
- package/dist/types/phantom.d.ts.map +1 -0
- package/dist/types/polkadotjs.d.ts +2 -0
- package/dist/types/polkadotjs.d.ts.map +1 -0
- package/dist/types/talisman.d.ts +2 -0
- package/dist/types/talisman.d.ts.map +1 -0
- package/dist/types/tronlink.d.ts +2 -0
- package/dist/types/tronlink.d.ts.map +1 -0
- package/dist/types/types.d.ts +19 -180
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/utils.d.ts.map +1 -1
- package/dist/types/vultisig.d.ts +2 -0
- package/dist/types/vultisig.d.ts.map +1 -0
- package/dist/types/walletconnect/helpers.d.ts +1 -1
- package/dist/types/walletconnect/index.d.ts +2 -2
- package/package.json +112 -89
- package/src/bitget.ts +1 -0
- package/src/coinbase/index.ts +44 -0
- package/src/coinbase/signer.ts +77 -0
- package/src/cosmostation.ts +1 -0
- package/src/ctrl.ts +1 -0
- package/src/evm-extensions.ts +1 -0
- package/src/index.ts +3 -0
- package/src/keepkey-bex.ts +1 -0
- package/src/keepkey.ts +1 -0
- package/src/keplr.ts +1 -0
- package/src/keystore.ts +1 -0
- package/src/ledger.ts +1 -0
- package/src/near-wallet-selector/index.ts +115 -0
- package/src/okx.ts +1 -0
- package/src/onekey.ts +1 -0
- package/src/passkeys/index.ts +183 -0
- package/src/phantom.ts +1 -0
- package/src/polkadotjs.ts +1 -0
- package/src/radix/index.ts +189 -0
- package/src/talisman.ts +1 -0
- package/src/trezor.ts +1 -0
- package/src/tronlink.ts +1 -0
- package/src/types.ts +94 -0
- package/src/utils.ts +59 -0
- package/src/vultisig.ts +1 -0
- package/src/walletconnect/constants.ts +102 -0
- package/src/walletconnect/evmSigner.ts +125 -0
- package/src/walletconnect/helpers.ts +70 -0
- package/src/walletconnect/index.ts +390 -0
- package/src/walletconnect/namespaces.ts +80 -0
- package/src/walletconnect/types.ts +6 -0
- package/src/xaman/helpers.ts +54 -0
- package/src/xaman/index.ts +62 -0
- package/src/xaman/types.ts +26 -0
- package/src/xaman/walletMethods.ts +110 -0
- package/dist/chunk-rx1jg8mz.js +0 -4
- package/dist/chunk-rx1jg8mz.js.map +0 -10
- package/dist/chunk-sg1ppebr.js +0 -4
- package/dist/chunk-sg1ppebr.js.map +0 -10
- package/dist/src/bitget/index.cjs +0 -4
- package/dist/src/bitget/index.cjs.map +0 -11
- package/dist/src/bitget/index.js +0 -4
- package/dist/src/bitget/index.js.map +0 -11
- package/dist/src/cosmostation/index.cjs +0 -4
- package/dist/src/cosmostation/index.cjs.map +0 -10
- package/dist/src/cosmostation/index.js +0 -4
- package/dist/src/cosmostation/index.js.map +0 -10
- package/dist/src/ctrl/index.cjs +0 -4
- package/dist/src/ctrl/index.cjs.map +0 -11
- package/dist/src/ctrl/index.js +0 -4
- package/dist/src/ctrl/index.js.map +0 -11
- package/dist/src/evm-extensions/index.cjs +0 -4
- package/dist/src/evm-extensions/index.cjs.map +0 -10
- package/dist/src/evm-extensions/index.js +0 -4
- package/dist/src/evm-extensions/index.js.map +0 -10
- package/dist/src/exodus/index.cjs +0 -4
- package/dist/src/exodus/index.cjs.map +0 -10
- package/dist/src/exodus/index.js +0 -4
- package/dist/src/exodus/index.js.map +0 -10
- package/dist/src/keepkey-bex/index.cjs +0 -4
- package/dist/src/keepkey-bex/index.cjs.map +0 -11
- package/dist/src/keepkey-bex/index.js +0 -4
- package/dist/src/keepkey-bex/index.js.map +0 -11
- package/dist/src/keplr/index.cjs +0 -4
- package/dist/src/keplr/index.cjs.map +0 -11
- package/dist/src/keplr/index.js +0 -4
- package/dist/src/keplr/index.js.map +0 -11
- package/dist/src/okx/index.cjs +0 -4
- package/dist/src/okx/index.cjs.map +0 -11
- package/dist/src/okx/index.js +0 -4
- package/dist/src/okx/index.js.map +0 -11
- package/dist/src/onekey/index.cjs +0 -4
- package/dist/src/onekey/index.cjs.map +0 -10
- package/dist/src/onekey/index.js +0 -4
- package/dist/src/onekey/index.js.map +0 -10
- package/dist/src/phantom/index.cjs +0 -4
- package/dist/src/phantom/index.cjs.map +0 -10
- package/dist/src/phantom/index.js +0 -4
- package/dist/src/phantom/index.js.map +0 -10
- package/dist/src/polkadotjs/index.cjs +0 -4
- package/dist/src/polkadotjs/index.cjs.map +0 -10
- package/dist/src/polkadotjs/index.js +0 -4
- package/dist/src/polkadotjs/index.js.map +0 -10
- package/dist/src/talisman/index.cjs +0 -4
- package/dist/src/talisman/index.cjs.map +0 -10
- package/dist/src/talisman/index.js +0 -4
- package/dist/src/talisman/index.js.map +0 -10
- package/dist/src/tronlink/index.cjs +0 -4
- package/dist/src/tronlink/index.cjs.map +0 -12
- package/dist/src/tronlink/index.js +0 -4
- package/dist/src/tronlink/index.js.map +0 -12
- package/dist/src/vultisig/index.cjs +0 -4
- package/dist/src/vultisig/index.cjs.map +0 -11
- package/dist/src/vultisig/index.js +0 -4
- package/dist/src/vultisig/index.js.map +0 -11
- package/dist/types/bitget/helpers.d.ts +0 -1545
- package/dist/types/bitget/helpers.d.ts.map +0 -1
- package/dist/types/bitget/index.d.ts +0 -11
- package/dist/types/bitget/index.d.ts.map +0 -1
- package/dist/types/cosmostation/index.d.ts +0 -21
- package/dist/types/cosmostation/index.d.ts.map +0 -1
- package/dist/types/ctrl/index.d.ts +0 -11
- package/dist/types/ctrl/index.d.ts.map +0 -1
- package/dist/types/ctrl/walletHelpers.d.ts +0 -18
- package/dist/types/ctrl/walletHelpers.d.ts.map +0 -1
- package/dist/types/evm-extensions/index.d.ts +0 -715
- package/dist/types/evm-extensions/index.d.ts.map +0 -1
- package/dist/types/evm-extensions/types.d.ts +0 -18
- package/dist/types/evm-extensions/types.d.ts.map +0 -1
- package/dist/types/exodus/index.d.ts +0 -14
- package/dist/types/exodus/index.d.ts.map +0 -1
- package/dist/types/helpers/near.d.ts +0 -57
- package/dist/types/helpers/near.d.ts.map +0 -1
- package/dist/types/keepkey-bex/index.d.ts +0 -11
- package/dist/types/keepkey-bex/index.d.ts.map +0 -1
- package/dist/types/keepkey-bex/walletHelpers.d.ts +0 -45
- package/dist/types/keepkey-bex/walletHelpers.d.ts.map +0 -1
- package/dist/types/keplr/chainRegistry.d.ts +0 -4
- package/dist/types/keplr/chainRegistry.d.ts.map +0 -1
- package/dist/types/keplr/index.d.ts +0 -11
- package/dist/types/keplr/index.d.ts.map +0 -1
- package/dist/types/okx/helpers.d.ts +0 -822
- package/dist/types/okx/helpers.d.ts.map +0 -1
- package/dist/types/okx/index.d.ts +0 -11
- package/dist/types/okx/index.d.ts.map +0 -1
- package/dist/types/okx/types.d.ts +0 -104
- package/dist/types/okx/types.d.ts.map +0 -1
- package/dist/types/onekey/evmSigner.d.ts +0 -29
- package/dist/types/onekey/evmSigner.d.ts.map +0 -1
- package/dist/types/onekey/index.d.ts +0 -11
- package/dist/types/onekey/index.d.ts.map +0 -1
- package/dist/types/phantom/index.d.ts +0 -12
- package/dist/types/phantom/index.d.ts.map +0 -1
- package/dist/types/polkadotjs/index.d.ts +0 -11
- package/dist/types/polkadotjs/index.d.ts.map +0 -1
- package/dist/types/talisman/index.d.ts +0 -11
- package/dist/types/talisman/index.d.ts.map +0 -1
- package/dist/types/tronlink/helpers.d.ts +0 -26
- package/dist/types/tronlink/helpers.d.ts.map +0 -1
- package/dist/types/tronlink/index.d.ts +0 -13
- package/dist/types/tronlink/index.d.ts.map +0 -1
- package/dist/types/tronlink/types.d.ts +0 -55
- package/dist/types/tronlink/types.d.ts.map +0 -1
- package/dist/types/vultisig/index.d.ts +0 -11
- package/dist/types/vultisig/index.d.ts.map +0 -1
- package/dist/types/vultisig/walletHelpers.d.ts +0 -34
- package/dist/types/vultisig/walletHelpers.d.ts.map +0 -1
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\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 name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n Chain.XLayer,\n ],\n walletType: WalletOption.CTRL,\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 = await 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(\"@swapkit/toolboxes/cosmos\");\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 case Chain.Noble: {\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, { preferNoSetFee: true });\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await 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.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.XLayer: {\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\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n const transfer = async (params: GenericTransferParams) => {\n const { actionCreators } = await import(\"@near-js/transactions\");\n\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = actionCreators.transfer(BigInt(amountInYocto));\n\n const transaction = { actions: [action], receiverId: params.recipient, signerId: accountId };\n\n const txHash: string = await provider.request({ method: \"signAndSendTransaction\", params: { transaction } });\n\n return txHash;\n };\n\n return { ...toolbox, transfer };\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 CosmosChain,\n type EVMChain,\n EVMChains,\n type FeeOption,\n providerRequest,\n SwapKitError,\n type TCLikeChain,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { 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 typeof Chain.Solana\n ? SolanaProvider\n : T extends Exclude<CosmosChain, TCLikeChain>\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.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => 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 .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\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-expect-error\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 try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain as Exclude<CosmosChain, TCLikeChain>)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\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 // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\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 if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({ method: \"connect\" });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\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: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo: memo || \"\",\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n"
|
|
7
|
-
],
|
|
8
|
-
"mappings": "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",
|
|
9
|
-
"debugId": "B70ECE16CB00A3AA64756E2164756E21",
|
|
10
|
-
"names": []
|
|
11
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var S={};m(S,{getWeb3WalletMethods:()=>O,evmWallet:()=>_,EVM_EXTENSIONS_SUPPORTED_CHAINS:()=>M});module.exports=g(S);var t=require("@swapkit/helpers"),c=require("@swapkit/wallet-core"),u=(r)=>{switch(r){case t.WalletOption.COINBASE_WEB:return window.coinbaseWalletExtension;case t.WalletOption.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},O=async({address:r,walletProvider:w,chain:o,provider:e})=>{if(!w)throw new t.SwapKitError("wallet_evm_extensions_not_found");let{getEvmToolbox:n}=await import("@swapkit/toolboxes/evm"),i=await e.getSigner(),a=await n(o,{provider:e,signer:i}),{chainIdHex:E}=t.getChainConfig(o);if((await e.getNetwork()).chainId.toString()!==E)try{let s=a.getNetworkParams();await t.switchEVMWalletNetwork(e,o,s)}catch{throw new t.SwapKitError("wallet_evm_extensions_failed_to_switch_network",{chain:o})}return t.prepareNetworkSwitch({chain:o,provider:e,toolbox:{...a,getBalance:()=>a.getBalance(r)}})},_=c.createWallet({connect:({addChain:r,supportedChains:w})=>async function(e,n=t.WalletOption.METAMASK,i){let a=t.filterSupportedChains({chains:e,supportedChains:w,walletType:n}),{BrowserProvider:E}=await import("ethers");return await Promise.all(a.map(async(p)=>{if(n===t.WalletOption.EIP6963&&!i)throw new t.SwapKitError("wallet_evm_extensions_no_provider");let s=i||u(n),l=new E(s,"any");await l.send("eth_requestAccounts",[]);let W=await(await l.getSigner()).getAddress(),h=await O({address:W,chain:p,provider:l,walletProvider:s});r({...h,address:W,chain:p,disconnect:()=>l.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:n});return})),!0},name:"connectEVMWallet",supportedChains:[...t.EVMChains]}),M=c.getWalletSupportedChains(_);
|
|
2
|
-
|
|
3
|
-
//# debugId=49F7207C18AA525C64756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/evm-extensions/index.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import {\n type Chain,\n type EVMChain,\n EVMChains,\n filterSupportedChains,\n getChainConfig,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\nexport type EVMWalletOptions =\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963;\n\nconst getWalletForType = (\n walletType:\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963,\n) => {\n switch (walletType) {\n case WalletOption.COINBASE_WEB:\n return window.coinbaseWalletExtension;\n case WalletOption.TRUSTWALLET_WEB:\n return window.trustwallet;\n default:\n return window.ethereum;\n }\n};\n\nexport const getWeb3WalletMethods = async ({\n address,\n walletProvider,\n chain,\n provider,\n}: {\n address: string;\n walletProvider?: Eip1193Provider;\n chain: EVMChain;\n provider: BrowserProvider;\n}) => {\n if (!walletProvider) throw new SwapKitError(\"wallet_evm_extensions_not_found\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const { chainIdHex } = getChainConfig(chain);\n\n const currentNetwork = await provider.getNetwork();\n if (currentNetwork.chainId.toString() !== chainIdHex) {\n try {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n } catch {\n throw new SwapKitError(\"wallet_evm_extensions_failed_to_switch_network\", { chain });\n }\n }\n\n return prepareNetworkSwitch({\n chain,\n provider,\n toolbox: { ...toolbox, getBalance: () => toolbox.getBalance(address) },\n });\n};\n\nexport const evmWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectEVMWallet(\n chains: Chain[],\n walletType: EVMWalletOptions = WalletOption.METAMASK,\n eip1193Provider?: Eip1193Provider,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n if (walletType === WalletOption.EIP6963 && !eip1193Provider)\n throw new SwapKitError(\"wallet_evm_extensions_no_provider\");\n\n const windowProvider = eip1193Provider || getWalletForType(walletType);\n const browserProvider = new BrowserProvider(windowProvider, \"any\");\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n address,\n chain,\n provider: browserProvider,\n walletProvider: windowProvider,\n });\n\n const disconnect = () => browserProvider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n addChain({ ...walletMethods, address, chain, disconnect, walletType });\n return;\n }),\n );\n\n return true;\n },\n name: \"connectEVMWallet\",\n supportedChains: [...EVMChains] as EVMChain[],\n});\n\nexport const EVM_EXTENSIONS_SUPPORTED_CHAINS = getWalletSupportedChains(evmWallet);\n"
|
|
6
|
-
],
|
|
7
|
-
"mappings": "qHAUO,IAVP,8BAWA,kCAWM,EAAmB,CACvB,IAOG,CACH,OAAQ,QACD,eAAa,aAChB,OAAO,OAAO,6BACX,eAAa,gBAChB,OAAO,OAAO,oBAEd,OAAO,OAAO,WAIP,EAAuB,OAClC,UACA,iBACA,QACA,cAMI,CACJ,GAAI,CAAC,EAAgB,MAAM,IAAI,eAAa,iCAAiC,EAC7E,IAAQ,iBAAkB,KAAa,kCAEjC,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,GACvD,cAAe,iBAAe,CAAK,EAG3C,IADuB,MAAM,EAAS,WAAW,GAC9B,QAAQ,SAAS,IAAM,EACxC,GAAI,CACF,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,yBAAuB,EAAU,EAAO,CAAa,EAC3D,KAAM,CACN,MAAM,IAAI,eAAa,iDAAkD,CAAE,OAAM,CAAC,EAItF,OAAO,uBAAqB,CAC1B,QACA,WACA,QAAS,IAAK,EAAS,WAAY,IAAM,EAAQ,WAAW,CAAO,CAAE,CACvE,CAAC,GAGU,EAAY,eAAa,CACpC,QAAS,EAAG,WAAU,qBACpB,cAA+B,CAC7B,EACA,EAA+B,eAAa,SAC5C,EACA,CACA,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,mBAAoB,KAAa,kBA2BzC,OAzBA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,GAAI,IAAe,eAAa,SAAW,CAAC,EAC1C,MAAM,IAAI,eAAa,mCAAmC,EAE5D,IAAM,EAAiB,GAAmB,EAAiB,CAAU,EAC/D,EAAkB,IAAI,EAAgB,EAAgB,KAAK,EAEjE,MAAM,EAAgB,KAAK,sBAAuB,CAAC,CAAC,EAEpD,IAAM,EAAU,MADD,MAAM,EAAgB,UAAU,GAClB,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,UACA,QACA,SAAU,EACV,eAAgB,CAClB,CAAC,EAGD,EAAS,IAAK,EAAe,UAAS,QAAO,WAD1B,IAAM,EAAgB,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EACvC,YAAW,CAAC,EACrE,OACD,CACH,EAEO,IAEX,KAAM,mBACN,gBAAiB,CAAC,GAAG,WAAS,CAChC,CAAC,EAEY,EAAkC,2BAAyB,CAAS",
|
|
8
|
-
"debugId": "49F7207C18AA525C64756E2164756E21",
|
|
9
|
-
"names": []
|
|
10
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import{F as d,G as O}from"../../chunk-jgq4njag.js";import{EVMChains as h,filterSupportedChains as g,getChainConfig as m,prepareNetworkSwitch as u,SwapKitError as p,switchEVMWalletNetwork as M,WalletOption as l}from"@swapkit/helpers";import{createWallet as S,getWalletSupportedChains as B}from"@swapkit/wallet-core";var P=(n)=>{switch(n){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},A=async({address:n,walletProvider:c,chain:e,provider:t})=>{if(!c)throw new p("wallet_evm_extensions_not_found");let{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),a=await t.getSigner(),r=await o(e,{provider:t,signer:a}),{chainIdHex:w}=m(e);if((await t.getNetwork()).chainId.toString()!==w)try{let i=r.getNetworkParams();await M(t,e,i)}catch{throw new p("wallet_evm_extensions_failed_to_switch_network",{chain:e})}return u({chain:e,provider:t,toolbox:{...r,getBalance:()=>r.getBalance(n)}})},C=S({connect:({addChain:n,supportedChains:c})=>async function(t,o=l.METAMASK,a){let r=g({chains:t,supportedChains:c,walletType:o}),{BrowserProvider:w}=await import("ethers");return await Promise.all(r.map(async(E)=>{if(o===l.EIP6963&&!a)throw new p("wallet_evm_extensions_no_provider");let i=a||P(o),s=new w(i,"any");await s.send("eth_requestAccounts",[]);let W=await(await s.getSigner()).getAddress(),_=await A({address:W,chain:E,provider:s,walletProvider:i});n({..._,address:W,chain:E,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:o});return})),!0},name:"connectEVMWallet",supportedChains:[...h]}),I=B(C);export{A as getWeb3WalletMethods,C as evmWallet,I as EVM_EXTENSIONS_SUPPORTED_CHAINS};
|
|
2
|
-
|
|
3
|
-
//# debugId=A7EDD9E7E3CCE11264756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/evm-extensions/index.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import {\n type Chain,\n type EVMChain,\n EVMChains,\n filterSupportedChains,\n getChainConfig,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\nexport type EVMWalletOptions =\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963;\n\nconst getWalletForType = (\n walletType:\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963,\n) => {\n switch (walletType) {\n case WalletOption.COINBASE_WEB:\n return window.coinbaseWalletExtension;\n case WalletOption.TRUSTWALLET_WEB:\n return window.trustwallet;\n default:\n return window.ethereum;\n }\n};\n\nexport const getWeb3WalletMethods = async ({\n address,\n walletProvider,\n chain,\n provider,\n}: {\n address: string;\n walletProvider?: Eip1193Provider;\n chain: EVMChain;\n provider: BrowserProvider;\n}) => {\n if (!walletProvider) throw new SwapKitError(\"wallet_evm_extensions_not_found\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const { chainIdHex } = getChainConfig(chain);\n\n const currentNetwork = await provider.getNetwork();\n if (currentNetwork.chainId.toString() !== chainIdHex) {\n try {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n } catch {\n throw new SwapKitError(\"wallet_evm_extensions_failed_to_switch_network\", { chain });\n }\n }\n\n return prepareNetworkSwitch({\n chain,\n provider,\n toolbox: { ...toolbox, getBalance: () => toolbox.getBalance(address) },\n });\n};\n\nexport const evmWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectEVMWallet(\n chains: Chain[],\n walletType: EVMWalletOptions = WalletOption.METAMASK,\n eip1193Provider?: Eip1193Provider,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n if (walletType === WalletOption.EIP6963 && !eip1193Provider)\n throw new SwapKitError(\"wallet_evm_extensions_no_provider\");\n\n const windowProvider = eip1193Provider || getWalletForType(walletType);\n const browserProvider = new BrowserProvider(windowProvider, \"any\");\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n address,\n chain,\n provider: browserProvider,\n walletProvider: windowProvider,\n });\n\n const disconnect = () => browserProvider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n addChain({ ...walletMethods, address, chain, disconnect, walletType });\n return;\n }),\n );\n\n return true;\n },\n name: \"connectEVMWallet\",\n supportedChains: [...EVMChains] as EVMChain[],\n});\n\nexport const EVM_EXTENSIONS_SUPPORTED_CHAINS = getWalletSupportedChains(evmWallet);\n"
|
|
6
|
-
],
|
|
7
|
-
"mappings": "mDAAA,oBAGE,2BACA,oBACA,0BACA,kBACA,4BACA,kBACA,yBAEF,uBAAS,8BAAc,6BAWvB,IAAM,EAAmB,CACvB,IAOG,CACH,OAAQ,QACD,EAAa,aAChB,OAAO,OAAO,6BACX,EAAa,gBAChB,OAAO,OAAO,oBAEd,OAAO,OAAO,WAIP,EAAuB,OAClC,UACA,iBACA,QACA,cAMI,CACJ,GAAI,CAAC,EAAgB,MAAM,IAAI,EAAa,iCAAiC,EAC7E,IAAQ,iBAAkB,KAAa,kCAEjC,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,GACvD,cAAe,EAAe,CAAK,EAG3C,IADuB,MAAM,EAAS,WAAW,GAC9B,QAAQ,SAAS,IAAM,EACxC,GAAI,CACF,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,EAAuB,EAAU,EAAO,CAAa,EAC3D,KAAM,CACN,MAAM,IAAI,EAAa,iDAAkD,CAAE,OAAM,CAAC,EAItF,OAAO,EAAqB,CAC1B,QACA,WACA,QAAS,IAAK,EAAS,WAAY,IAAM,EAAQ,WAAW,CAAO,CAAE,CACvE,CAAC,GAGU,EAAY,EAAa,CACpC,QAAS,EAAG,WAAU,qBACpB,cAA+B,CAC7B,EACA,EAA+B,EAAa,SAC5C,EACA,CACA,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,mBAAoB,KAAa,kBA2BzC,OAzBA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,GAAI,IAAe,EAAa,SAAW,CAAC,EAC1C,MAAM,IAAI,EAAa,mCAAmC,EAE5D,IAAM,EAAiB,GAAmB,EAAiB,CAAU,EAC/D,EAAkB,IAAI,EAAgB,EAAgB,KAAK,EAEjE,MAAM,EAAgB,KAAK,sBAAuB,CAAC,CAAC,EAEpD,IAAM,EAAU,MADD,MAAM,EAAgB,UAAU,GAClB,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,UACA,QACA,SAAU,EACV,eAAgB,CAClB,CAAC,EAGD,EAAS,IAAK,EAAe,UAAS,QAAO,WAD1B,IAAM,EAAgB,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EACvC,YAAW,CAAC,EACrE,OACD,CACH,EAEO,IAEX,KAAM,mBACN,gBAAiB,CAAC,GAAG,CAAS,CAChC,CAAC,EAEY,EAAkC,EAAyB,CAAS",
|
|
8
|
-
"debugId": "A7EDD9E7E3CCE11264756E2164756E21",
|
|
9
|
-
"names": []
|
|
10
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var z={};N(z,{exodusWallet:()=>B,EXODUS_SUPPORTED_CHAINS:()=>u});module.exports=M(z);var q=require("@swapkit/helpers"),V=require("@swapkit/wallet-core"),A=require("bitcoinjs-lib"),X=require("sats-connect");F(z,require("@passkeys/core"),module.exports);F(z,require("@passkeys/react"),module.exports);async function O({wallet:R,chain:H}){switch(H){case q.Chain.Bitcoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo"),I=await R.getProvider("bitcoin");if(!I)throw new q.SwapKitError("wallet_exodus_not_found");let Q="",G=()=>Promise.resolve(I),_={getProvider:G,onCancel:()=>{throw new q.SwapKitError("wallet_exodus_request_canceled")},onFinish:(L)=>{if(!L.addresses[0])throw new q.SwapKitError("wallet_exodus_no_address");Q=L.addresses[0].address},payload:{message:"Address for receiving and sending payments",network:{type:X.BitcoinNetworkType.Mainnet},purposes:[X.AddressPurpose.Payment]}};await X.getAddress(_);async function J(L){let $,f={getProvider:G,onCancel:()=>{throw new q.SwapKitError("wallet_exodus_signature_canceled")},onFinish:(m)=>{$=A.Psbt.fromBase64(m.psbtBase64)},payload:{broadcast:!1,inputsToSign:[{address:Q,signingIndexes:L.txInputs.map((m,D)=>D)}],message:"Sign transaction",network:{type:X.BitcoinNetworkType.Mainnet},psbtBase64:L.toBase64()}};if(await X.signTransaction(f),!$)throw new q.SwapKitError("wallet_exodus_sign_transaction_error");return $}return{...await Z(H,{signer:{getAddress:()=>Promise.resolve(Q),signTransaction:J}}),address:Q}}case q.Chain.Arbitrum:case q.Chain.Aurora:case q.Chain.Avalanche:case q.Chain.Base:case q.Chain.BinanceSmartChain:case q.Chain.Ethereum:case q.Chain.Optimism:case q.Chain.Polygon:case q.Chain.XLayer:{let{getProvider:Z,getEvmToolbox:I}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Q}=await import("ethers"),G=await R.getProvider("ethereum");if(!G)throw new q.SwapKitError("wallet_exodus_not_found");let _=await Z(H),J=new Q(G,"any");await J.send("eth_requestAccounts",[]);let Y=await J.getSigner(),U=await Y.getAddress(),L=await I(H,{provider:_,signer:Y});try{if(H!==q.Chain.Ethereum){let $=L.getNetworkParams();await q.switchEVMWalletNetwork(J,H,$)}}catch{throw new q.SwapKitError("wallet_exodus_failed_to_switch_network",{chain:H})}return{...q.prepareNetworkSwitch({chain:H,provider:J,toolbox:L}),address:U}}case q.Chain.Solana:{let{getSolanaToolbox:Z}=await import("@swapkit/toolboxes/solana"),I=await R.getProvider("solana");if(I?.publicKey,!I)throw new q.SwapKitError("wallet_exodus_not_found");let G=(await I.connect()).publicKey.toString();return{...await Z({signer:I}),address:G,disconnect:async()=>{await I.disconnect()}}}default:throw new q.SwapKitError("wallet_exodus_chain_not_supported",{chain:H})}}var B=V.createWallet({connect:({addChain:R,walletType:H,supportedChains:Z})=>async function(Q,G){if(!G)throw new q.SwapKitError("wallet_exodus_instance_missing");let _=q.filterSupportedChains({chains:Q,supportedChains:Z,walletType:H});return await Promise.all(_.map(async(J)=>{try{let Y=await O({chain:J,wallet:G}),{address:U,...L}=Y,f=G.disconnect||(async()=>{if(G.disconnect)await G.disconnect()});R({...L,address:U,chain:J,disconnect:f,walletType:q.WalletOption.EXODUS})}catch(Y){throw console.error(`Failed to connect ${J} wallet:`,Y),Y}})),!0},name:"connectExodusWallet",supportedChains:[...q.EVMChains,q.Chain.Bitcoin,q.Chain.Solana],walletType:q.WalletOption.EXODUS}),u=V.getWalletSupportedChains(B);
|
|
2
|
-
|
|
3
|
-
//# debugId=A77887EDE81A382764756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/exodus/index.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n filterSupportedChains,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport {\n AddressPurpose,\n BitcoinNetworkType,\n type GetAddressOptions,\n type GetAddressResponse,\n getAddress,\n type SignTransactionOptions,\n signTransaction as satsSignTransaction,\n} from \"sats-connect\";\n\nasync function getWalletMethods({ wallet, chain }: { wallet: Wallet; chain: Chain }) {\n switch (chain) {\n case Chain.Bitcoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const provider = await wallet.getProvider(\"bitcoin\");\n\n if (!provider) {\n throw new SwapKitError(\"wallet_exodus_not_found\");\n }\n\n let address = \"\";\n\n const getProvider = () => Promise.resolve(provider);\n\n const getAddressOptions: GetAddressOptions = {\n getProvider,\n onCancel: () => {\n throw new SwapKitError(\"wallet_exodus_request_canceled\");\n },\n onFinish: (response: GetAddressResponse) => {\n if (!response.addresses[0]) throw new SwapKitError(\"wallet_exodus_no_address\");\n address = response.addresses[0].address;\n },\n payload: {\n message: \"Address for receiving and sending payments\",\n network: { type: BitcoinNetworkType.Mainnet },\n purposes: [AddressPurpose.Payment],\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 onCancel: () => {\n throw new SwapKitError(\"wallet_exodus_signature_canceled\");\n },\n onFinish: (response) => {\n signedPsbt = Psbt.fromBase64(response.psbtBase64);\n },\n payload: {\n broadcast: false,\n inputsToSign: [{ address: address, signingIndexes: psbt.txInputs.map((_, index) => index) }],\n message: \"Sign transaction\",\n network: { type: BitcoinNetworkType.Mainnet },\n psbtBase64: psbt.toBase64(),\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 = { getAddress: () => Promise.resolve(address), signTransaction };\n const toolbox = await getUtxoToolbox(chain, { signer });\n\n return { ...toolbox, address };\n }\n case Chain.Arbitrum:\n case Chain.Aurora:\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 case Chain.XLayer: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n\n const walletProvider = await wallet.getProvider(\"ethereum\");\n if (!walletProvider) {\n throw new SwapKitError(\"wallet_exodus_not_found\");\n }\n\n const jsonRpcProvider = await getProvider(chain);\n const browserProvider = new BrowserProvider(walletProvider, \"any\");\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 {\n throw new SwapKitError(\"wallet_exodus_failed_to_switch_network\", { chain });\n }\n\n return { ...prepareNetworkSwitch({ chain, provider: browserProvider, toolbox }), address };\n }\n\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = (await wallet.getProvider(\"solana\")) as any as SolanaProvider;\n\n provider?.publicKey;\n\n if (!provider) {\n throw new SwapKitError(\"wallet_exodus_not_found\");\n }\n\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n const toolbox = await getSolanaToolbox({ signer: provider });\n\n const disconnect = async () => {\n await provider.disconnect();\n };\n\n return { ...toolbox, address, disconnect };\n }\n\n default:\n throw new SwapKitError(\"wallet_exodus_chain_not_supported\", { chain });\n }\n}\n\nexport const exodusWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectExodusWallet(chains: Chain[], wallet: Wallet) {\n if (!wallet) throw new SwapKitError(\"wallet_exodus_instance_missing\");\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n try {\n const walletData = await getWalletMethods({ chain, wallet });\n\n const { address, ...walletMethods } = walletData;\n const disconnect = wallet.disconnect;\n\n const finalDisconnect =\n disconnect ||\n (async () => {\n if (wallet.disconnect) {\n await wallet.disconnect();\n }\n });\n\n addChain({\n ...walletMethods,\n address,\n chain,\n disconnect: finalDisconnect,\n walletType: WalletOption.EXODUS,\n });\n } catch (error) {\n console.error(`Failed to connect ${chain} wallet:`, error);\n throw error;\n }\n }),\n );\n\n return true;\n },\n name: \"connectExodusWallet\",\n supportedChains: [...EVMChains, Chain.Bitcoin, Chain.Solana],\n walletType: WalletOption.EXODUS,\n});\n\nexport const EXODUS_SUPPORTED_CHAINS = getWalletSupportedChains(exodusWallet);\nexport * from \"@passkeys/core\";\nexport * from \"@passkeys/react\";\n"
|
|
6
|
-
],
|
|
7
|
-
"mappings": "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",
|
|
8
|
-
"debugId": "A77887EDE81A382764756E2164756E21",
|
|
9
|
-
"names": []
|
|
10
|
-
}
|
package/dist/src/exodus/index.js
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import{F as R,G as U}from"../../chunk-jgq4njag.js";import{Chain as q,EVMChains as B,filterSupportedChains as D,prepareNetworkSwitch as M,SwapKitError as J,switchEVMWalletNetwork as N,WalletOption as f}from"@swapkit/helpers";import{createWallet as O,getWalletSupportedChains as u}from"@swapkit/wallet-core";import{Psbt as y}from"bitcoinjs-lib";import{AddressPurpose as W,BitcoinNetworkType as m,getAddress as K,signTransaction as T}from"sats-connect";export*from"@passkeys/core";export*from"@passkeys/react";async function k({wallet:_,chain:F}){switch(F){case q.Bitcoin:{let{getUtxoToolbox:X}=await import("@swapkit/toolboxes/utxo"),G=await _.getProvider("bitcoin");if(!G)throw new J("wallet_exodus_not_found");let L="",z=()=>Promise.resolve(G),Y={getProvider:z,onCancel:()=>{throw new J("wallet_exodus_request_canceled")},onFinish:(I)=>{if(!I.addresses[0])throw new J("wallet_exodus_no_address");L=I.addresses[0].address},payload:{message:"Address for receiving and sending payments",network:{type:m.Mainnet},purposes:[W.Payment]}};await K(Y);async function H(I){let Z,j={getProvider:z,onCancel:()=>{throw new J("wallet_exodus_signature_canceled")},onFinish:(V)=>{Z=y.fromBase64(V.psbtBase64)},payload:{broadcast:!1,inputsToSign:[{address:L,signingIndexes:I.txInputs.map((V,A)=>A)}],message:"Sign transaction",network:{type:m.Mainnet},psbtBase64:I.toBase64()}};if(await T(j),!Z)throw new J("wallet_exodus_sign_transaction_error");return Z}return{...await X(F,{signer:{getAddress:()=>Promise.resolve(L),signTransaction:H}}),address:L}}case q.Arbitrum:case q.Aurora:case q.Avalanche:case q.Base:case q.BinanceSmartChain:case q.Ethereum:case q.Optimism:case q.Polygon:case q.XLayer:{let{getProvider:X,getEvmToolbox:G}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:L}=await import("ethers"),z=await _.getProvider("ethereum");if(!z)throw new J("wallet_exodus_not_found");let Y=await X(F),H=new L(z,"any");await H.send("eth_requestAccounts",[]);let Q=await H.getSigner(),$=await Q.getAddress(),I=await G(F,{provider:Y,signer:Q});try{if(F!==q.Ethereum){let Z=I.getNetworkParams();await N(H,F,Z)}}catch{throw new J("wallet_exodus_failed_to_switch_network",{chain:F})}return{...M({chain:F,provider:H,toolbox:I}),address:$}}case q.Solana:{let{getSolanaToolbox:X}=await import("@swapkit/toolboxes/solana"),G=await _.getProvider("solana");if(G?.publicKey,!G)throw new J("wallet_exodus_not_found");let z=(await G.connect()).publicKey.toString();return{...await X({signer:G}),address:z,disconnect:async()=>{await G.disconnect()}}}default:throw new J("wallet_exodus_chain_not_supported",{chain:F})}}var x=O({connect:({addChain:_,walletType:F,supportedChains:X})=>async function(L,z){if(!z)throw new J("wallet_exodus_instance_missing");let Y=D({chains:L,supportedChains:X,walletType:F});return await Promise.all(Y.map(async(H)=>{try{let Q=await k({chain:H,wallet:z}),{address:$,...I}=Q,j=z.disconnect||(async()=>{if(z.disconnect)await z.disconnect()});_({...I,address:$,chain:H,disconnect:j,walletType:f.EXODUS})}catch(Q){throw console.error(`Failed to connect ${H} wallet:`,Q),Q}})),!0},name:"connectExodusWallet",supportedChains:[...B,q.Bitcoin,q.Solana],walletType:f.EXODUS}),v=u(x);export{x as exodusWallet,v as EXODUS_SUPPORTED_CHAINS};
|
|
2
|
-
|
|
3
|
-
//# debugId=1BECA51C57A0D93A64756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/exodus/index.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n filterSupportedChains,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport {\n AddressPurpose,\n BitcoinNetworkType,\n type GetAddressOptions,\n type GetAddressResponse,\n getAddress,\n type SignTransactionOptions,\n signTransaction as satsSignTransaction,\n} from \"sats-connect\";\n\nasync function getWalletMethods({ wallet, chain }: { wallet: Wallet; chain: Chain }) {\n switch (chain) {\n case Chain.Bitcoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const provider = await wallet.getProvider(\"bitcoin\");\n\n if (!provider) {\n throw new SwapKitError(\"wallet_exodus_not_found\");\n }\n\n let address = \"\";\n\n const getProvider = () => Promise.resolve(provider);\n\n const getAddressOptions: GetAddressOptions = {\n getProvider,\n onCancel: () => {\n throw new SwapKitError(\"wallet_exodus_request_canceled\");\n },\n onFinish: (response: GetAddressResponse) => {\n if (!response.addresses[0]) throw new SwapKitError(\"wallet_exodus_no_address\");\n address = response.addresses[0].address;\n },\n payload: {\n message: \"Address for receiving and sending payments\",\n network: { type: BitcoinNetworkType.Mainnet },\n purposes: [AddressPurpose.Payment],\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 onCancel: () => {\n throw new SwapKitError(\"wallet_exodus_signature_canceled\");\n },\n onFinish: (response) => {\n signedPsbt = Psbt.fromBase64(response.psbtBase64);\n },\n payload: {\n broadcast: false,\n inputsToSign: [{ address: address, signingIndexes: psbt.txInputs.map((_, index) => index) }],\n message: \"Sign transaction\",\n network: { type: BitcoinNetworkType.Mainnet },\n psbtBase64: psbt.toBase64(),\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 = { getAddress: () => Promise.resolve(address), signTransaction };\n const toolbox = await getUtxoToolbox(chain, { signer });\n\n return { ...toolbox, address };\n }\n case Chain.Arbitrum:\n case Chain.Aurora:\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 case Chain.XLayer: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n\n const walletProvider = await wallet.getProvider(\"ethereum\");\n if (!walletProvider) {\n throw new SwapKitError(\"wallet_exodus_not_found\");\n }\n\n const jsonRpcProvider = await getProvider(chain);\n const browserProvider = new BrowserProvider(walletProvider, \"any\");\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 {\n throw new SwapKitError(\"wallet_exodus_failed_to_switch_network\", { chain });\n }\n\n return { ...prepareNetworkSwitch({ chain, provider: browserProvider, toolbox }), address };\n }\n\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = (await wallet.getProvider(\"solana\")) as any as SolanaProvider;\n\n provider?.publicKey;\n\n if (!provider) {\n throw new SwapKitError(\"wallet_exodus_not_found\");\n }\n\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n const toolbox = await getSolanaToolbox({ signer: provider });\n\n const disconnect = async () => {\n await provider.disconnect();\n };\n\n return { ...toolbox, address, disconnect };\n }\n\n default:\n throw new SwapKitError(\"wallet_exodus_chain_not_supported\", { chain });\n }\n}\n\nexport const exodusWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectExodusWallet(chains: Chain[], wallet: Wallet) {\n if (!wallet) throw new SwapKitError(\"wallet_exodus_instance_missing\");\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n try {\n const walletData = await getWalletMethods({ chain, wallet });\n\n const { address, ...walletMethods } = walletData;\n const disconnect = wallet.disconnect;\n\n const finalDisconnect =\n disconnect ||\n (async () => {\n if (wallet.disconnect) {\n await wallet.disconnect();\n }\n });\n\n addChain({\n ...walletMethods,\n address,\n chain,\n disconnect: finalDisconnect,\n walletType: WalletOption.EXODUS,\n });\n } catch (error) {\n console.error(`Failed to connect ${chain} wallet:`, error);\n throw error;\n }\n }),\n );\n\n return true;\n },\n name: \"connectExodusWallet\",\n supportedChains: [...EVMChains, Chain.Bitcoin, Chain.Solana],\n walletType: WalletOption.EXODUS,\n});\n\nexport const EXODUS_SUPPORTED_CHAINS = getWalletSupportedChains(exodusWallet);\nexport * from \"@passkeys/core\";\nexport * from \"@passkeys/react\";\n"
|
|
6
|
-
],
|
|
7
|
-
"mappings": "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",
|
|
8
|
-
"debugId": "1BECA51C57A0D93A64756E2164756E21",
|
|
9
|
-
"names": []
|
|
10
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var L={};D(L,{keepkeyBexWallet:()=>b,KEEPKEY_BEX_SUPPORTED_CHAINS:()=>A});module.exports=x(L);var e=require("@swapkit/helpers"),f=require("@swapkit/wallet-core");var r=require("@swapkit/helpers"),T=require("@swapkit/helpers/contracts"),E=(t)=>{switch(t){case r.Chain.Bitcoin:return"bitcoin";case r.Chain.BitcoinCash:return"bitcoincash";case r.Chain.Dash:return"dash";case r.Chain.Dogecoin:return"dogecoin";case r.Chain.Litecoin:return"litecoin";default:throw new r.SwapKitError("wallet_keepkey_chain_not_supported",{chain:t})}};function P(t){if(!window.keepkey)throw new r.SwapKitError("wallet_keepkey_not_found");switch(t){case r.Chain.Ethereum:case r.Chain.Base:case r.Chain.Avalanche:case r.Chain.BinanceSmartChain:case r.Chain.Arbitrum:case r.Chain.Optimism:case r.Chain.Polygon:case r.Chain.XLayer:return window.keepkey.ethereum;case r.Chain.Cosmos:return window.keepkey.cosmos;case r.Chain.Bitcoin:return window.keepkey.bitcoin;case r.Chain.BitcoinCash:return window.keepkey.bitcoincash;case r.Chain.Dogecoin:return window.keepkey.dogecoin;case r.Chain.Litecoin:return window.keepkey.litecoin;case r.Chain.Dash:return window.keepkey.dash;case r.Chain.THORChain:return window.keepkey.thorchain;case r.Chain.Maya:return window.keepkey.mayachain;default:return}}function M({method:t,params:c,chain:n}){let o=P(n);return new Promise((i,a)=>{if(o&&"request"in o)o.request({method:t,params:c},(s,m)=>{s?a(s):i(m)});else a(new r.SwapKitError("wallet_provider_not_found"))})}async function _(t){let c=P(t);if(!c)throw new r.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:r.WalletOption.KEEPKEY}});let n="request_accounts";if(r.EVMChains.includes(t))n="eth_requestAccounts";let[o]=await c.request({method:n,params:[]});return o}async function y({assetValue:t,recipient:c,memo:n,gasLimit:o},i="transfer"){if(!t)throw new r.SwapKitError("wallet_keepkey_asset_not_defined");let a=await _(t.chain),s=[{amount:{amount:t.getValue("string"),decimals:t.decimal},asset:{chain:t.chain,symbol:t.symbol.toUpperCase(),ticker:t.symbol.toUpperCase()},from:a,gasLimit:o,memo:n,recipient:c}];return M({chain:t.chain,method:i,params:s})}function O(t,c){return{approve:async({assetAddress:n,spenderAddress:o,amount:i,from:a})=>{let{MAX_APPROVAL:s,getCreateContractTxObject:m,toHexString:u}=await import("@swapkit/toolboxes/evm"),g=m({chain:c,provider:t}),{value:p,to:v,data:k}=await g({abi:T.erc20ABI,contractAddress:n,funcName:"approve",funcParams:[o,BigInt(i||s)],txOverrides:{from:a}});return t.send("eth_sendTransaction",[{data:k||"0x",from:a,to:v,value:u(BigInt(p||0))}])},call:async({contractAddress:n,abi:o,funcName:i,funcParams:a=[],txOverrides:s})=>{if(!n)throw new r.SwapKitError("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:u,isStateChangingCall:g,toHexString:p}=await import("@swapkit/toolboxes/evm");if(g({abi:o,funcName:i})){let l=u({chain:c,provider:t}),{value:B,from:X,to:U,data:q}=await l({abi:o,contractAddress:n,funcName:i,funcParams:a,txOverrides:s});return t.send("eth_sendTransaction",[{data:q||"0x",from:X,to:U,value:p(BigInt(B||0))}])}let w=await m(n,o,t)[i]?.(...a);return typeof w?.hash==="string"?w?.hash:w},sendTransaction:async(n)=>{let{from:o,to:i,data:a,value:s}=n;if(!i)throw new r.SwapKitError("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return t.send("eth_sendTransaction",[{data:a||"0x",from:o,to:i,value:m(BigInt(s||0))}])}}}var b=f.createWallet({connect:({addChain:t,supportedChains:c,walletType:n})=>async function(i){let a=e.filterSupportedChains({chains:i,supportedChains:c,walletType:n});return await Promise.all(a.map(async(s)=>{let m=await _(s),u=await I(s);t({...u,address:m,chain:s,walletType:n})})),!0},name:"connectKeepkeyBex",supportedChains:[e.Chain.Arbitrum,e.Chain.Avalanche,e.Chain.BinanceSmartChain,e.Chain.Bitcoin,e.Chain.BitcoinCash,e.Chain.Base,e.Chain.Cosmos,e.Chain.Dash,e.Chain.Dogecoin,e.Chain.Ethereum,e.Chain.Kujira,e.Chain.Litecoin,e.Chain.Maya,e.Chain.Optimism,e.Chain.Polygon,e.Chain.Ripple,e.Chain.Solana,e.Chain.THORChain,e.Chain.XLayer],walletType:e.WalletOption.KEEPKEY_BEX}),A=f.getWalletSupportedChains(b);async function I(t){switch(t){case e.Chain.Maya:case e.Chain.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:n,MAYA_GAS_VALUE:o}=await import("@swapkit/toolboxes/cosmos"),i=t===e.Chain.Maya?o:n;return{...await c(t),deposit:(s)=>y({...s,recipient:""},"deposit"),transfer:(s)=>y({...s,gasLimit:i},"transfer")}}case e.Chain.Cosmos:case e.Chain.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),n=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(e.ChainId[t]);if(!n)throw new e.SwapKitError("wallet_keepkey_signer_not_found");let o=await c(t,{signer:n}),i=await n.getAccounts();if(!i?.[0]?.address)throw new e.SwapKitError("wallet_keepkey_no_accounts");let[{address:a}]=i;return{...o,address:a}}case e.Chain.Dash:case e.Chain.Bitcoin:case e.Chain.BitcoinCash:case e.Chain.Dogecoin:case e.Chain.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(t),getBalance:async()=>{let i=E(t),a=await window?.keepkey?.[i]?.request({method:"request_balance"});return[e.AssetValue.from({chain:t,value:a[0].balance})]},transfer:y}}case e.Chain.Ethereum:case e.Chain.BinanceSmartChain:case e.Chain.Base:case e.Chain.Arbitrum:case e.Chain.Optimism:case e.Chain.Polygon:case e.Chain.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:n}=await import("@swapkit/helpers"),{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:i}=await import("ethers"),a=P(t);if(!a)throw new e.SwapKitError("wallet_keepkey_not_found");let s=new i(a,"any"),m=await s.getSigner(),u=await o(t,{provider:s,signer:m}),g=O(s,t);try{if(t!==e.Chain.Ethereum){let p=u.getNetworkParams();await n(s,t,p)}}catch{throw new e.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:t,wallet:e.WalletOption.KEEPKEY}})}return c({chain:t,provider:s,toolbox:{...u,...g}})}default:return null}}
|
|
2
|
-
|
|
3
|
-
//# debugId=1B2335DE04A09BB064756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/keepkey-bex/index.ts", "../src/keepkey-bex/walletHelpers.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import { AssetValue, Chain, ChainId, filterSupportedChains, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { Eip1193Provider } from \"ethers\";\nimport {\n getKEEPKEYAddress,\n getKEEPKEYMethods,\n getKEEPKEYProvider,\n getProviderNameFromChain,\n type WalletTxParams,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const keepkeyBexWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeepkeyBex(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const address = await getKEEPKEYAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectKeepkeyBex\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Base,\n Chain.Cosmos,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Ripple,\n Chain.Solana,\n Chain.THORChain,\n Chain.XLayer,\n ],\n walletType: WalletOption.KEEPKEY_BEX,\n});\n\nexport const KEEPKEY_BEX_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyBexWallet);\n\nasync function getWalletMethods(chain: (typeof KEEPKEY_BEX_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\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: WalletTxParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: WalletTxParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n // @ts-expect-error assumed available connection\n const signer = window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(ChainId[chain]);\n if (!signer) throw new SwapKitError(\"wallet_keepkey_signer_not_found\");\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_keepkey_no_accounts\");\n\n const [{ address }] = accounts;\n\n return { ...toolbox, address };\n }\n\n case Chain.Dash:\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 const getBalance = async () => {\n const providerChain = getProviderNameFromChain(chain);\n // @ts-expect-error We assuming there chains via switch\n const balance = await window?.keepkey?.[providerChain]?.request({ method: \"request_balance\" });\n const assetValue = AssetValue.from({ chain, value: balance[0].balance });\n return [assetValue];\n };\n\n return { ...toolbox, getBalance, transfer: walletTransfer };\n }\n\n case Chain.Ethereum:\n case Chain.BinanceSmartChain:\n case Chain.Base:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche: {\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 = getKEEPKEYProvider(chain) as Eip1193Provider;\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_keepkey_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 keepkeyMethods = getKEEPKEYMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.KEEPKEY },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox: { ...toolbox, ...keepkeyMethods } });\n }\n\n default:\n return null;\n }\n}\n",
|
|
6
|
-
"import {\n type AssetValue,\n Chain,\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 { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ninterface UTXOProvider {\n request: (\n args: {\n method: string;\n params?: {\n amount: { amount: string; decimals?: number };\n asset: { chain: Chain; symbol: string; ticker: string };\n memo: string | undefined;\n from?: string;\n recipient: string;\n gasLimit?: string | bigint;\n }[];\n },\n callback: (err: string, tx: string) => void,\n ) => void;\n}\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: string | 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 | undefined;\n};\n\nexport const getProviderNameFromChain = (chain: Chain): string => {\n switch (chain) {\n case Chain.Bitcoin:\n return \"bitcoin\";\n case Chain.BitcoinCash:\n return \"bitcoincash\";\n case Chain.Dash:\n return \"dash\";\n case Chain.Dogecoin:\n return \"dogecoin\";\n case Chain.Litecoin:\n return \"litecoin\";\n default:\n throw new SwapKitError(\"wallet_keepkey_chain_not_supported\", { chain });\n }\n};\n\ndeclare const window: {\n keepkey?: {\n binance: Eip1193Provider;\n bitcoin: Eip1193Provider;\n bitcoincash: Eip1193Provider;\n dogecoin: Eip1193Provider;\n ethereum: Eip1193Provider;\n cosmos: Eip1193Provider;\n dash: Eip1193Provider;\n litecoin: Eip1193Provider;\n thorchain: Eip1193Provider;\n mayachain: Eip1193Provider;\n };\n} & Window;\n\nexport function getKEEPKEYProvider<T extends Chain>(chain: T) {\n if (!window.keepkey) throw new SwapKitError(\"wallet_keepkey_not_found\");\n\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Base:\n case Chain.Avalanche:\n case Chain.BinanceSmartChain:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.XLayer:\n return window.keepkey.ethereum as Eip1193Provider;\n case Chain.Cosmos:\n return window.keepkey.cosmos as Eip1193Provider;\n case Chain.Bitcoin:\n return window.keepkey.bitcoin as UTXOProvider;\n case Chain.BitcoinCash:\n return window.keepkey.bitcoincash as UTXOProvider;\n case Chain.Dogecoin:\n return window.keepkey.dogecoin as UTXOProvider;\n case Chain.Litecoin:\n return window.keepkey.litecoin as UTXOProvider;\n case Chain.Dash:\n return window.keepkey.dash as UTXOProvider;\n case Chain.THORChain:\n return window.keepkey.thorchain as UTXOProvider;\n case Chain.Maya:\n return window.keepkey.mayachain as UTXOProvider;\n\n default:\n return undefined;\n }\n}\n\nfunction transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = getKEEPKEYProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n } else {\n reject(new SwapKitError(\"wallet_provider_not_found\"));\n }\n });\n}\n\nexport async function getKEEPKEYAddress(chain: Chain) {\n const eipProvider = getKEEPKEYProvider(chain) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.KEEPKEY } });\n }\n\n let method = \"request_accounts\";\n if (EVMChains.includes(chain as EVMChain)) {\n method = \"eth_requestAccounts\";\n }\n\n const [response] = await eipProvider.request({ method, params: [] });\n return response;\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams & { assetValue: AssetValue },\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_keepkey_asset_not_defined\");\n }\n\n const from = await getKEEPKEYAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getValue(\"string\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo,\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n\nexport function getKEEPKEYMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject, toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, to, data } = await createTx({\n abi: erc20ABI,\n contractAddress: assetAddress,\n funcName: \"approve\",\n funcParams: [spenderAddress, BigInt(amount || MAX_APPROVAL)],\n txOverrides: { from },\n });\n\n return provider.send(\"eth_sendTransaction\", [\n { data: data || \"0x\", from, to, value: toHexString(BigInt(value || 0)) },\n ]);\n },\n call: async <T>({ contractAddress, abi, funcName, funcParams = [], txOverrides }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_keepkey_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall, toHexString } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, from, to, data } = await createTx({ abi, contractAddress, funcName, funcParams, txOverrides });\n\n return provider.send(\"eth_sendTransaction\", [\n { data: data || \"0x\", from, to, value: toHexString(BigInt(value || 0)) },\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 sendTransaction: async (tx: EVMTxParams) => {\n const { from, to, data, value } = tx;\n if (!to) {\n throw new SwapKitError(\"wallet_keepkey_send_transaction_no_address\");\n }\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n return provider.send(\"eth_sendTransaction\", [\n { data: data || \"0x\", from, to, value: toHexString(BigInt(value || 0)) },\n ]);\n },\n };\n}\n"
|
|
7
|
-
],
|
|
8
|
-
"mappings": "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",
|
|
9
|
-
"debugId": "1B2335DE04A09BB064756E2164756E21",
|
|
10
|
-
"names": []
|
|
11
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import{F as d,G as u}from"../../chunk-jgq4njag.js";import{AssetValue as L,Chain as t,ChainId as F,filterSupportedChains as V,SwapKitError as _,WalletOption as l}from"@swapkit/helpers";import{createWallet as j,getWalletSupportedChains as H}from"@swapkit/wallet-core";import{Chain as a,EVMChains as x,SwapKitError as p,WalletOption as D}from"@swapkit/helpers";import{erc20ABI as A}from"@swapkit/helpers/contracts";var O=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new p("wallet_keepkey_chain_not_supported",{chain:e})}};function f(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:case a.XLayer: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}}function I({method:e,params:c,chain:r}){let s=f(r);return new Promise((o,i)=>{if(s&&"request"in s)s.request({method:e,params:c},(n,m)=>{n?i(n):o(m)});else i(new p("wallet_provider_not_found"))})}async function k(e){let c=f(e);if(!c)throw new p({errorKey:"wallet_provider_not_found",info:{chain:e,wallet:D.KEEPKEY}});let r="request_accounts";if(x.includes(e))r="eth_requestAccounts";let[s]=await c.request({method:r,params:[]});return s}async function w({assetValue:e,recipient:c,memo:r,gasLimit:s},o="transfer"){if(!e)throw new p("wallet_keepkey_asset_not_defined");let i=await k(e.chain),n=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},from:i,gasLimit:s,memo:r,recipient:c}];return I({chain:e.chain,method:o,params:n})}function b(e,c){return{approve:async({assetAddress:r,spenderAddress:s,amount:o,from:i})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),P=m({chain:c,provider:e}),{value:y,to:T,data:E}=await P({abi:A,contractAddress:r,funcName:"approve",funcParams:[s,BigInt(o||n)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{data:E||"0x",from:i,to:T,value:g(BigInt(y||0))}])},call:async({contractAddress:r,abi:s,funcName:o,funcParams:i=[],txOverrides:n})=>{if(!r)throw new p("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:P,toHexString:y}=await import("@swapkit/toolboxes/evm");if(P({abi:s,funcName:o})){let B=g({chain:c,provider:e}),{value:X,from:U,to:q,data:M}=await B({abi:s,contractAddress:r,funcName:o,funcParams:i,txOverrides:n});return e.send("eth_sendTransaction",[{data:M||"0x",from:U,to:q,value:y(BigInt(X||0))}])}let v=await m(r,s,e)[o]?.(...i);return typeof v?.hash==="string"?v?.hash:v},sendTransaction:async(r)=>{let{from:s,to:o,data:i,value:n}=r;if(!o)throw new p("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{data:i||"0x",from:s,to:o,value:m(BigInt(n||0))}])}}}var K=j({connect:({addChain:e,supportedChains:c,walletType:r})=>async function(o){let i=V({chains:o,supportedChains:c,walletType:r});return await Promise.all(i.map(async(n)=>{let m=await k(n),g=await R(n);e({...g,address:m,chain:n,walletType:r})})),!0},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.Ripple,t.Solana,t.THORChain,t.XLayer],walletType:l.KEEPKEY_BEX}),S=H(K);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:s}=await import("@swapkit/toolboxes/cosmos"),o=e===t.Maya?s:r;return{...await c(e),deposit:(n)=>w({...n,recipient:""},"deposit"),transfer:(n)=>w({...n,gasLimit:o},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(F[e]);if(!r)throw new _("wallet_keepkey_signer_not_found");let s=await c(e,{signer:r}),o=await r.getAccounts();if(!o?.[0]?.address)throw new _("wallet_keepkey_no_accounts");let[{address:i}]=o;return{...s,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{let o=O(e),i=await window?.keepkey?.[o]?.request({method:"request_balance"});return[L.from({chain:e,value:i[0].balance})]},transfer:w}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:s}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:o}=await import("ethers"),i=f(e);if(!i)throw new _("wallet_keepkey_not_found");let n=new o(i,"any"),m=await n.getSigner(),g=await s(e,{provider:n,signer:m}),P=b(n,e);try{if(e!==t.Ethereum){let y=g.getNetworkParams();await r(n,e,y)}}catch{throw new _({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:e,wallet:l.KEEPKEY}})}return c({chain:e,provider:n,toolbox:{...g,...P}})}default:return null}}export{K as keepkeyBexWallet,S as KEEPKEY_BEX_SUPPORTED_CHAINS};
|
|
2
|
-
|
|
3
|
-
//# debugId=64DA7A9D2C97C21164756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/keepkey-bex/index.ts", "../src/keepkey-bex/walletHelpers.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import { AssetValue, Chain, ChainId, filterSupportedChains, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { Eip1193Provider } from \"ethers\";\nimport {\n getKEEPKEYAddress,\n getKEEPKEYMethods,\n getKEEPKEYProvider,\n getProviderNameFromChain,\n type WalletTxParams,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const keepkeyBexWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeepkeyBex(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const address = await getKEEPKEYAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectKeepkeyBex\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Base,\n Chain.Cosmos,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Ripple,\n Chain.Solana,\n Chain.THORChain,\n Chain.XLayer,\n ],\n walletType: WalletOption.KEEPKEY_BEX,\n});\n\nexport const KEEPKEY_BEX_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyBexWallet);\n\nasync function getWalletMethods(chain: (typeof KEEPKEY_BEX_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\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: WalletTxParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: WalletTxParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n // @ts-expect-error assumed available connection\n const signer = window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(ChainId[chain]);\n if (!signer) throw new SwapKitError(\"wallet_keepkey_signer_not_found\");\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_keepkey_no_accounts\");\n\n const [{ address }] = accounts;\n\n return { ...toolbox, address };\n }\n\n case Chain.Dash:\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 const getBalance = async () => {\n const providerChain = getProviderNameFromChain(chain);\n // @ts-expect-error We assuming there chains via switch\n const balance = await window?.keepkey?.[providerChain]?.request({ method: \"request_balance\" });\n const assetValue = AssetValue.from({ chain, value: balance[0].balance });\n return [assetValue];\n };\n\n return { ...toolbox, getBalance, transfer: walletTransfer };\n }\n\n case Chain.Ethereum:\n case Chain.BinanceSmartChain:\n case Chain.Base:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche: {\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 = getKEEPKEYProvider(chain) as Eip1193Provider;\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_keepkey_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 keepkeyMethods = getKEEPKEYMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.KEEPKEY },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox: { ...toolbox, ...keepkeyMethods } });\n }\n\n default:\n return null;\n }\n}\n",
|
|
6
|
-
"import {\n type AssetValue,\n Chain,\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 { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ninterface UTXOProvider {\n request: (\n args: {\n method: string;\n params?: {\n amount: { amount: string; decimals?: number };\n asset: { chain: Chain; symbol: string; ticker: string };\n memo: string | undefined;\n from?: string;\n recipient: string;\n gasLimit?: string | bigint;\n }[];\n },\n callback: (err: string, tx: string) => void,\n ) => void;\n}\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: string | 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 | undefined;\n};\n\nexport const getProviderNameFromChain = (chain: Chain): string => {\n switch (chain) {\n case Chain.Bitcoin:\n return \"bitcoin\";\n case Chain.BitcoinCash:\n return \"bitcoincash\";\n case Chain.Dash:\n return \"dash\";\n case Chain.Dogecoin:\n return \"dogecoin\";\n case Chain.Litecoin:\n return \"litecoin\";\n default:\n throw new SwapKitError(\"wallet_keepkey_chain_not_supported\", { chain });\n }\n};\n\ndeclare const window: {\n keepkey?: {\n binance: Eip1193Provider;\n bitcoin: Eip1193Provider;\n bitcoincash: Eip1193Provider;\n dogecoin: Eip1193Provider;\n ethereum: Eip1193Provider;\n cosmos: Eip1193Provider;\n dash: Eip1193Provider;\n litecoin: Eip1193Provider;\n thorchain: Eip1193Provider;\n mayachain: Eip1193Provider;\n };\n} & Window;\n\nexport function getKEEPKEYProvider<T extends Chain>(chain: T) {\n if (!window.keepkey) throw new SwapKitError(\"wallet_keepkey_not_found\");\n\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Base:\n case Chain.Avalanche:\n case Chain.BinanceSmartChain:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.XLayer:\n return window.keepkey.ethereum as Eip1193Provider;\n case Chain.Cosmos:\n return window.keepkey.cosmos as Eip1193Provider;\n case Chain.Bitcoin:\n return window.keepkey.bitcoin as UTXOProvider;\n case Chain.BitcoinCash:\n return window.keepkey.bitcoincash as UTXOProvider;\n case Chain.Dogecoin:\n return window.keepkey.dogecoin as UTXOProvider;\n case Chain.Litecoin:\n return window.keepkey.litecoin as UTXOProvider;\n case Chain.Dash:\n return window.keepkey.dash as UTXOProvider;\n case Chain.THORChain:\n return window.keepkey.thorchain as UTXOProvider;\n case Chain.Maya:\n return window.keepkey.mayachain as UTXOProvider;\n\n default:\n return undefined;\n }\n}\n\nfunction transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = getKEEPKEYProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n } else {\n reject(new SwapKitError(\"wallet_provider_not_found\"));\n }\n });\n}\n\nexport async function getKEEPKEYAddress(chain: Chain) {\n const eipProvider = getKEEPKEYProvider(chain) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.KEEPKEY } });\n }\n\n let method = \"request_accounts\";\n if (EVMChains.includes(chain as EVMChain)) {\n method = \"eth_requestAccounts\";\n }\n\n const [response] = await eipProvider.request({ method, params: [] });\n return response;\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams & { assetValue: AssetValue },\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_keepkey_asset_not_defined\");\n }\n\n const from = await getKEEPKEYAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getValue(\"string\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo,\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n\nexport function getKEEPKEYMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject, toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, to, data } = await createTx({\n abi: erc20ABI,\n contractAddress: assetAddress,\n funcName: \"approve\",\n funcParams: [spenderAddress, BigInt(amount || MAX_APPROVAL)],\n txOverrides: { from },\n });\n\n return provider.send(\"eth_sendTransaction\", [\n { data: data || \"0x\", from, to, value: toHexString(BigInt(value || 0)) },\n ]);\n },\n call: async <T>({ contractAddress, abi, funcName, funcParams = [], txOverrides }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_keepkey_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall, toHexString } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, from, to, data } = await createTx({ abi, contractAddress, funcName, funcParams, txOverrides });\n\n return provider.send(\"eth_sendTransaction\", [\n { data: data || \"0x\", from, to, value: toHexString(BigInt(value || 0)) },\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 sendTransaction: async (tx: EVMTxParams) => {\n const { from, to, data, value } = tx;\n if (!to) {\n throw new SwapKitError(\"wallet_keepkey_send_transaction_no_address\");\n }\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n return provider.send(\"eth_sendTransaction\", [\n { data: data || \"0x\", from, to, value: toHexString(BigInt(value || 0)) },\n ]);\n },\n };\n}\n"
|
|
7
|
-
],
|
|
8
|
-
"mappings": "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",
|
|
9
|
-
"debugId": "64DA7A9D2C97C21164756E2164756E21",
|
|
10
|
-
"names": []
|
|
11
|
-
}
|
package/dist/src/keplr/index.cjs
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var x={};E(x,{keplrWallet:()=>p,KEPLR_SUPPORTED_CHAINS:()=>y});module.exports=f(x);var i=require("@swapkit/helpers"),c=require("@swapkit/wallet-core");var o=require("@swapkit/helpers"),l=new Map([[o.ChainId.Kujira,{bech32Config:{bech32PrefixAccAddr:"kujira",bech32PrefixAccPub:"kujirapub",bech32PrefixConsAddr:"kujiravalcons",bech32PrefixConsPub:"kujiravalconspub",bech32PrefixValAddr:"kujiravaloper",bech32PrefixValPub:"kujiravaloperpub"},bip44:{coinType:118},chainId:"kaiyo-1",chainName:"Kujira",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png",currencies:[{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"},{coinDecimals:6,coinDenom:"USK",coinGeckoId:"usk",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk"},{coinDecimals:6,coinDenom:"MNTA",coinGeckoId:"mantadao",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta"},{coinDecimals:6,coinDenom:"bKUJI",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png",coinMinimalDenom:"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji"},{coinDecimals:6,coinDenom:"AQLA",coinGeckoId:"aqualibre",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png",coinMinimalDenom:"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla"}],features:["cosmwasm"],feeCurrencies:[{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"},{coinDecimals:6,coinDenom:"USK",coinGeckoId:"usk",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk"},{coinDecimals:6,coinDenom:"axlUSDC",coinGeckoId:"usd-coin",coinMinimalDenom:"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F"},{coinDecimals:6,coinDenom:"ATOM",coinGeckoId:"cosmos",coinMinimalDenom:"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2"},{coinDecimals:6,coinDenom:"OSMO",coinGeckoId:"osmosis",coinMinimalDenom:"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23"},{coinDecimals:6,coinDenom:"CMDX",coinGeckoId:"comdex",coinMinimalDenom:"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07"},{coinDecimals:6,coinDenom:"EVMOS",coinGeckoId:"evmos",coinMinimalDenom:"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10"},{coinDecimals:6,coinDenom:"JUNO",coinGeckoId:"juno-network",coinMinimalDenom:"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5"},{coinDecimals:6,coinDenom:"MNTA",coinGeckoId:"mantadao",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta"},{coinDecimals:6,coinDenom:"SCRT",coinGeckoId:"secret",coinMinimalDenom:"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5"},{coinDecimals:6,coinDenom:"STARS",coinGeckoId:"stargaze",coinMinimalDenom:"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602"},{coinDecimals:18,coinDenom:"wAVAX",coinGeckoId:"avalanche-2",coinMinimalDenom:"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2"},{coinDecimals:18,coinDenom:"wETH",coinGeckoId:"ethereum",coinMinimalDenom:"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7"}],nodeProvider:{email:"pfc-validator@protonmail.com",name:"PFC",website:"https://pfc.zone/"},rest:"https://rest.cosmos.directory/kujira/",rpc:"https://kujira-rpc.nodes.defiantlabs.net",stakeCurrency:{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"}}],[o.ChainId.Noble,{bech32Config:{bech32PrefixAccAddr:"noble",bech32PrefixAccPub:"noblepub",bech32PrefixConsAddr:"noblevalcons",bech32PrefixConsPub:"noblevalconspub",bech32PrefixValAddr:"noblevaloper",bech32PrefixValPub:"noblevaloperpub"},bip44:{coinType:118},chainId:"noble-1",chainName:"Noble",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/chain.png",currencies:[{coinDecimals:6,coinDenom:"USDC",coinGeckoId:"usd-coin",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png",coinMinimalDenom:"uusdc"},{coinDecimals:6,coinDenom:"USDN",coinGeckoId:"usd-coin",coinMinimalDenom:"uusdn"}],features:["cosmwasm"],feeCurrencies:[{coinDecimals:6,coinDenom:"USDC",coinGeckoId:"usd-coin",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png",coinMinimalDenom:"uusdc"},{coinDecimals:6,coinDenom:"USDN",coinGeckoId:"usd-coin",coinMinimalDenom:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdn.png"}],rest:"https://lcd-noble.keplr.app",rpc:"https://rpc-noble.keplr.app"}],[o.ChainId.THORChain,{bech32Config:{bech32PrefixAccAddr:"thor",bech32PrefixAccPub:"thorpub",bech32PrefixConsAddr:"thorvalcons",bech32PrefixConsPub:"thorvalconspub",bech32PrefixValAddr:"thorvaloper",bech32PrefixValPub:"thorvaloperpub"},bip44:{coinType:931},chainId:"thorchain-1",chainName:"THORChain",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png",currencies:[{coinDecimals:8,coinDenom:"RUNE",coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",coinMinimalDenom:"rune"}],features:[],feeCurrencies:[{coinDecimals:8,coinDenom:"RUNE",coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",coinMinimalDenom:"rune",gasPriceStep:{average:0.02,high:0.03,low:0.02}}],rest:"https://lcd-thorchain.keplr.app",rpc:"https://rpc-thorchain.keplr.app"}]]);var I=[i.ChainId.Cosmos,i.ChainId.Kujira,i.ChainId.Noble,i.ChainId.THORChain],p=c.createWallet({connect:({addChain:h,supportedChains:u})=>async function(D,a=i.WalletOption.KEPLR){let d=a===i.WalletOption.LEAP?"leap":"keplr",k=i.filterSupportedChains({chains:D,supportedChains:u,walletType:a}),r=window[d];return await Promise.all(k.map(async(n)=>{let e=i.ChainToChainId[n];if(!I.includes(e)){let m=l.get(e);if(!m)throw new i.SwapKitError("wallet_keplr_chain_not_supported",{chain:n});await r.experimentalSuggestChain(m)}r?.enable(e);let s=r?.getOfflineSignerOnlyAmino(e);if(!s)throw new i.SwapKitError("wallet_keplr_signer_not_found");let{getCosmosToolbox:g}=await import("@swapkit/toolboxes/cosmos"),t=await s.getAccounts();if(!t?.[0]?.address)throw new i.SwapKitError("wallet_keplr_no_accounts");let[{address:b}]=t,C=await g(n,{signer:s});h({...C,address:b,chain:n,walletType:a})})),!0},name:"connectKeplr",supportedChains:[i.Chain.Cosmos,i.Chain.Kujira,i.Chain.Noble,i.Chain.THORChain]}),y=c.getWalletSupportedChains(p);
|
|
2
|
-
|
|
3
|
-
//# debugId=8118FB8ACFC5472064756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/keplr/index.ts", "../src/keplr/chainRegistry.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import { Chain, ChainId, ChainToChainId, filterSupportedChains, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { chainRegistry } from \"./chainRegistry\";\n\nconst keplrSupportedChainIds = [ChainId.Cosmos, ChainId.Kujira, ChainId.Noble, ChainId.THORChain] as const;\n\nexport const keplrWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectKeplr(\n chains: Chain[],\n walletType: WalletOption.KEPLR | WalletOption.LEAP = WalletOption.KEPLR,\n ) {\n const extensionKey = walletType === WalletOption.LEAP ? \"leap\" : \"keplr\";\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const keplrClient = window[extensionKey];\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof keplrSupportedChainIds)[number];\n\n if (!keplrSupportedChainIds.includes(chainId)) {\n const chainConfig = chainRegistry.get(chainId);\n if (!chainConfig) throw new SwapKitError(\"wallet_keplr_chain_not_supported\", { chain });\n\n await keplrClient.experimentalSuggestChain(chainConfig);\n }\n\n keplrClient?.enable(chainId);\n const signer = keplrClient?.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new SwapKitError(\"wallet_keplr_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_keplr_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n addChain({ ...toolbox, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectKeplr\",\n supportedChains: [Chain.Cosmos, Chain.Kujira, Chain.Noble, Chain.THORChain],\n});\n\nexport const KEPLR_SUPPORTED_CHAINS = getWalletSupportedChains(keplrWallet);\n",
|
|
6
|
-
"import type { ChainInfo } from \"@keplr-wallet/types\";\nimport { ChainId } from \"@swapkit/helpers\";\n\nexport const chainRegistry = new Map<ChainId, ChainInfo>([\n [\n ChainId.Kujira,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"kujira\",\n bech32PrefixAccPub: \"kujirapub\",\n bech32PrefixConsAddr: \"kujiravalcons\",\n bech32PrefixConsPub: \"kujiravalconspub\",\n bech32PrefixValAddr: \"kujiravaloper\",\n bech32PrefixValPub: \"kujiravaloperpub\",\n },\n bip44: { coinType: 118 },\n chainId: \"kaiyo-1\",\n chainName: \"Kujira\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png\",\n currencies: [\n {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USK\",\n coinGeckoId: \"usk\",\n coinMinimalDenom: \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"MNTA\",\n coinGeckoId: \"mantadao\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"bKUJI\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png\",\n coinMinimalDenom: \"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"AQLA\",\n coinGeckoId: \"aqualibre\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png\",\n coinMinimalDenom: \"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla\",\n },\n ],\n features: [\"cosmwasm\"],\n feeCurrencies: [\n {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USK\",\n coinGeckoId: \"usk\",\n coinMinimalDenom: \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"axlUSDC\",\n coinGeckoId: \"usd-coin\",\n coinMinimalDenom: \"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"ATOM\",\n coinGeckoId: \"cosmos\",\n coinMinimalDenom: \"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"OSMO\",\n coinGeckoId: \"osmosis\",\n coinMinimalDenom: \"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"CMDX\",\n coinGeckoId: \"comdex\",\n coinMinimalDenom: \"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"EVMOS\",\n coinGeckoId: \"evmos\",\n coinMinimalDenom: \"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"JUNO\",\n coinGeckoId: \"juno-network\",\n coinMinimalDenom: \"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"MNTA\",\n coinGeckoId: \"mantadao\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"SCRT\",\n coinGeckoId: \"secret\",\n coinMinimalDenom: \"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"STARS\",\n coinGeckoId: \"stargaze\",\n coinMinimalDenom: \"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602\",\n },\n {\n coinDecimals: 18,\n coinDenom: \"wAVAX\",\n coinGeckoId: \"avalanche-2\",\n coinMinimalDenom: \"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2\",\n },\n {\n coinDecimals: 18,\n coinDenom: \"wETH\",\n coinGeckoId: \"ethereum\",\n coinMinimalDenom: \"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7\",\n },\n ],\n nodeProvider: { email: \"pfc-validator@protonmail.com\", name: \"PFC\", website: \"https://pfc.zone/\" },\n rest: \"https://rest.cosmos.directory/kujira/\",\n rpc: \"https://kujira-rpc.nodes.defiantlabs.net\",\n stakeCurrency: {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n },\n ],\n [\n ChainId.Noble,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"noble\",\n bech32PrefixAccPub: \"noblepub\",\n bech32PrefixConsAddr: \"noblevalcons\",\n bech32PrefixConsPub: \"noblevalconspub\",\n bech32PrefixValAddr: \"noblevaloper\",\n bech32PrefixValPub: \"noblevaloperpub\",\n },\n bip44: { coinType: 118 },\n chainId: \"noble-1\",\n chainName: \"Noble\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/chain.png\",\n currencies: [\n {\n coinDecimals: 6,\n coinDenom: \"USDC\",\n coinGeckoId: \"usd-coin\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png\",\n coinMinimalDenom: \"uusdc\",\n },\n { coinDecimals: 6, coinDenom: \"USDN\", coinGeckoId: \"usd-coin\", coinMinimalDenom: \"uusdn\" },\n ],\n features: [\"cosmwasm\"],\n feeCurrencies: [\n {\n coinDecimals: 6,\n coinDenom: \"USDC\",\n coinGeckoId: \"usd-coin\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png\",\n coinMinimalDenom: \"uusdc\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USDN\",\n coinGeckoId: \"usd-coin\",\n coinMinimalDenom:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdn.png\",\n },\n ],\n rest: \"https://lcd-noble.keplr.app\",\n rpc: \"https://rpc-noble.keplr.app\",\n },\n ],\n [\n ChainId.THORChain,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"thor\",\n bech32PrefixAccPub: \"thorpub\",\n bech32PrefixConsAddr: \"thorvalcons\",\n bech32PrefixConsPub: \"thorvalconspub\",\n bech32PrefixValAddr: \"thorvaloper\",\n bech32PrefixValPub: \"thorvaloperpub\",\n },\n bip44: { coinType: 931 },\n chainId: \"thorchain-1\",\n chainName: \"THORChain\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png\",\n currencies: [\n {\n coinDecimals: 8,\n coinDenom: \"RUNE\",\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n coinMinimalDenom: \"rune\",\n },\n ],\n features: [],\n feeCurrencies: [\n {\n coinDecimals: 8,\n coinDenom: \"RUNE\",\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n coinMinimalDenom: \"rune\",\n gasPriceStep: { average: 0.02, high: 0.03, low: 0.02 },\n },\n ],\n rest: \"https://lcd-thorchain.keplr.app\",\n rpc: \"https://rpc-thorchain.keplr.app\",\n },\n ],\n]);\n"
|
|
7
|
-
],
|
|
8
|
-
"mappings": "mFAAkG,IAAlG,8BACA,kCCAwB,IAAxB,8BAEa,EAAgB,IAAI,IAAwB,CACvD,CACE,UAAQ,OACR,CACE,aAAc,CACZ,oBAAqB,SACrB,mBAAoB,YACpB,qBAAsB,gBACtB,oBAAqB,mBACrB,oBAAqB,gBACrB,mBAAoB,kBACtB,EACA,MAAO,CAAE,SAAU,GAAI,EACvB,QAAS,UACT,UAAW,SACX,oBACE,gGACF,WAAY,CACV,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,aAAc,gGACd,iBAAkB,OACpB,EACA,CACE,aAAc,EACd,UAAW,MACX,YAAa,MACb,iBAAkB,gFACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,WACb,iBAAkB,6DACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,aACE,0KACF,iBAAkB,oFACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,YACb,aACE,qJACF,iBAAkB,6DACpB,CACF,EACA,SAAU,CAAC,UAAU,EACrB,cAAe,CACb,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,aAAc,gGACd,iBAAkB,OACpB,EACA,CACE,aAAc,EACd,UAAW,MACX,YAAa,MACb,iBAAkB,gFACpB,EACA,CACE,aAAc,EACd,UAAW,UACX,YAAa,WACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,UACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,YAAa,QACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,eACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,WACb,iBAAkB,6DACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,YAAa,WACb,iBAAkB,sEACpB,EACA,CACE,aAAc,GACd,UAAW,QA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",
|
|
9
|
-
"debugId": "8118FB8ACFC5472064756E2164756E21",
|
|
10
|
-
"names": []
|
|
11
|
-
}
|
package/dist/src/keplr/index.js
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import{F as f,G as E}from"../../chunk-jgq4njag.js";import{Chain as e,ChainId as o,ChainToChainId as I,filterSupportedChains as y,SwapKitError as t,WalletOption as h}from"@swapkit/helpers";import{createWallet as x,getWalletSupportedChains as F}from"@swapkit/wallet-core";import{ChainId as s}from"@swapkit/helpers";var p=new Map([[s.Kujira,{bech32Config:{bech32PrefixAccAddr:"kujira",bech32PrefixAccPub:"kujirapub",bech32PrefixConsAddr:"kujiravalcons",bech32PrefixConsPub:"kujiravalconspub",bech32PrefixValAddr:"kujiravaloper",bech32PrefixValPub:"kujiravaloperpub"},bip44:{coinType:118},chainId:"kaiyo-1",chainName:"Kujira",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png",currencies:[{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"},{coinDecimals:6,coinDenom:"USK",coinGeckoId:"usk",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk"},{coinDecimals:6,coinDenom:"MNTA",coinGeckoId:"mantadao",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta"},{coinDecimals:6,coinDenom:"bKUJI",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png",coinMinimalDenom:"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji"},{coinDecimals:6,coinDenom:"AQLA",coinGeckoId:"aqualibre",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png",coinMinimalDenom:"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla"}],features:["cosmwasm"],feeCurrencies:[{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"},{coinDecimals:6,coinDenom:"USK",coinGeckoId:"usk",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk"},{coinDecimals:6,coinDenom:"axlUSDC",coinGeckoId:"usd-coin",coinMinimalDenom:"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F"},{coinDecimals:6,coinDenom:"ATOM",coinGeckoId:"cosmos",coinMinimalDenom:"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2"},{coinDecimals:6,coinDenom:"OSMO",coinGeckoId:"osmosis",coinMinimalDenom:"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23"},{coinDecimals:6,coinDenom:"CMDX",coinGeckoId:"comdex",coinMinimalDenom:"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07"},{coinDecimals:6,coinDenom:"EVMOS",coinGeckoId:"evmos",coinMinimalDenom:"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10"},{coinDecimals:6,coinDenom:"JUNO",coinGeckoId:"juno-network",coinMinimalDenom:"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5"},{coinDecimals:6,coinDenom:"MNTA",coinGeckoId:"mantadao",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta"},{coinDecimals:6,coinDenom:"SCRT",coinGeckoId:"secret",coinMinimalDenom:"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5"},{coinDecimals:6,coinDenom:"STARS",coinGeckoId:"stargaze",coinMinimalDenom:"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602"},{coinDecimals:18,coinDenom:"wAVAX",coinGeckoId:"avalanche-2",coinMinimalDenom:"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2"},{coinDecimals:18,coinDenom:"wETH",coinGeckoId:"ethereum",coinMinimalDenom:"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7"}],nodeProvider:{email:"pfc-validator@protonmail.com",name:"PFC",website:"https://pfc.zone/"},rest:"https://rest.cosmos.directory/kujira/",rpc:"https://kujira-rpc.nodes.defiantlabs.net",stakeCurrency:{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"}}],[s.Noble,{bech32Config:{bech32PrefixAccAddr:"noble",bech32PrefixAccPub:"noblepub",bech32PrefixConsAddr:"noblevalcons",bech32PrefixConsPub:"noblevalconspub",bech32PrefixValAddr:"noblevaloper",bech32PrefixValPub:"noblevaloperpub"},bip44:{coinType:118},chainId:"noble-1",chainName:"Noble",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/chain.png",currencies:[{coinDecimals:6,coinDenom:"USDC",coinGeckoId:"usd-coin",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png",coinMinimalDenom:"uusdc"},{coinDecimals:6,coinDenom:"USDN",coinGeckoId:"usd-coin",coinMinimalDenom:"uusdn"}],features:["cosmwasm"],feeCurrencies:[{coinDecimals:6,coinDenom:"USDC",coinGeckoId:"usd-coin",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png",coinMinimalDenom:"uusdc"},{coinDecimals:6,coinDenom:"USDN",coinGeckoId:"usd-coin",coinMinimalDenom:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdn.png"}],rest:"https://lcd-noble.keplr.app",rpc:"https://rpc-noble.keplr.app"}],[s.THORChain,{bech32Config:{bech32PrefixAccAddr:"thor",bech32PrefixAccPub:"thorpub",bech32PrefixConsAddr:"thorvalcons",bech32PrefixConsPub:"thorvalconspub",bech32PrefixValAddr:"thorvaloper",bech32PrefixValPub:"thorvaloperpub"},bip44:{coinType:931},chainId:"thorchain-1",chainName:"THORChain",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png",currencies:[{coinDecimals:8,coinDenom:"RUNE",coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",coinMinimalDenom:"rune"}],features:[],feeCurrencies:[{coinDecimals:8,coinDenom:"RUNE",coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",coinMinimalDenom:"rune",gasPriceStep:{average:0.02,high:0.03,low:0.02}}],rest:"https://lcd-thorchain.keplr.app",rpc:"https://rpc-thorchain.keplr.app"}]]);var w=[o.Cosmos,o.Kujira,o.Noble,o.THORChain],j=x({connect:({addChain:u,supportedChains:D})=>async function(d,c=h.KEPLR){let k=c===h.LEAP?"leap":"keplr",g=y({chains:d,supportedChains:D,walletType:c}),a=window[k];return await Promise.all(g.map(async(i)=>{let n=I[i];if(!w.includes(n)){let l=p.get(n);if(!l)throw new t("wallet_keplr_chain_not_supported",{chain:i});await a.experimentalSuggestChain(l)}a?.enable(n);let r=a?.getOfflineSignerOnlyAmino(n);if(!r)throw new t("wallet_keplr_signer_not_found");let{getCosmosToolbox:b}=await import("@swapkit/toolboxes/cosmos"),m=await r.getAccounts();if(!m?.[0]?.address)throw new t("wallet_keplr_no_accounts");let[{address:C}]=m,A=await b(i,{signer:r});u({...A,address:C,chain:i,walletType:c})})),!0},name:"connectKeplr",supportedChains:[e.Cosmos,e.Kujira,e.Noble,e.THORChain]}),G=F(j);export{j as keplrWallet,G as KEPLR_SUPPORTED_CHAINS};
|
|
2
|
-
|
|
3
|
-
//# debugId=1DCBCD86B9D49B8C64756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/keplr/index.ts", "../src/keplr/chainRegistry.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import { Chain, ChainId, ChainToChainId, filterSupportedChains, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { chainRegistry } from \"./chainRegistry\";\n\nconst keplrSupportedChainIds = [ChainId.Cosmos, ChainId.Kujira, ChainId.Noble, ChainId.THORChain] as const;\n\nexport const keplrWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectKeplr(\n chains: Chain[],\n walletType: WalletOption.KEPLR | WalletOption.LEAP = WalletOption.KEPLR,\n ) {\n const extensionKey = walletType === WalletOption.LEAP ? \"leap\" : \"keplr\";\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const keplrClient = window[extensionKey];\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof keplrSupportedChainIds)[number];\n\n if (!keplrSupportedChainIds.includes(chainId)) {\n const chainConfig = chainRegistry.get(chainId);\n if (!chainConfig) throw new SwapKitError(\"wallet_keplr_chain_not_supported\", { chain });\n\n await keplrClient.experimentalSuggestChain(chainConfig);\n }\n\n keplrClient?.enable(chainId);\n const signer = keplrClient?.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new SwapKitError(\"wallet_keplr_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_keplr_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n addChain({ ...toolbox, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectKeplr\",\n supportedChains: [Chain.Cosmos, Chain.Kujira, Chain.Noble, Chain.THORChain],\n});\n\nexport const KEPLR_SUPPORTED_CHAINS = getWalletSupportedChains(keplrWallet);\n",
|
|
6
|
-
"import type { ChainInfo } from \"@keplr-wallet/types\";\nimport { ChainId } from \"@swapkit/helpers\";\n\nexport const chainRegistry = new Map<ChainId, ChainInfo>([\n [\n ChainId.Kujira,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"kujira\",\n bech32PrefixAccPub: \"kujirapub\",\n bech32PrefixConsAddr: \"kujiravalcons\",\n bech32PrefixConsPub: \"kujiravalconspub\",\n bech32PrefixValAddr: \"kujiravaloper\",\n bech32PrefixValPub: \"kujiravaloperpub\",\n },\n bip44: { coinType: 118 },\n chainId: \"kaiyo-1\",\n chainName: \"Kujira\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png\",\n currencies: [\n {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USK\",\n coinGeckoId: \"usk\",\n coinMinimalDenom: \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"MNTA\",\n coinGeckoId: \"mantadao\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"bKUJI\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png\",\n coinMinimalDenom: \"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"AQLA\",\n coinGeckoId: \"aqualibre\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png\",\n coinMinimalDenom: \"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla\",\n },\n ],\n features: [\"cosmwasm\"],\n feeCurrencies: [\n {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USK\",\n coinGeckoId: \"usk\",\n coinMinimalDenom: \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"axlUSDC\",\n coinGeckoId: \"usd-coin\",\n coinMinimalDenom: \"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"ATOM\",\n coinGeckoId: \"cosmos\",\n coinMinimalDenom: \"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"OSMO\",\n coinGeckoId: \"osmosis\",\n coinMinimalDenom: \"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"CMDX\",\n coinGeckoId: \"comdex\",\n coinMinimalDenom: \"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"EVMOS\",\n coinGeckoId: \"evmos\",\n coinMinimalDenom: \"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"JUNO\",\n coinGeckoId: \"juno-network\",\n coinMinimalDenom: \"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"MNTA\",\n coinGeckoId: \"mantadao\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"SCRT\",\n coinGeckoId: \"secret\",\n coinMinimalDenom: \"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"STARS\",\n coinGeckoId: \"stargaze\",\n coinMinimalDenom: \"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602\",\n },\n {\n coinDecimals: 18,\n coinDenom: \"wAVAX\",\n coinGeckoId: \"avalanche-2\",\n coinMinimalDenom: \"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2\",\n },\n {\n coinDecimals: 18,\n coinDenom: \"wETH\",\n coinGeckoId: \"ethereum\",\n coinMinimalDenom: \"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7\",\n },\n ],\n nodeProvider: { email: \"pfc-validator@protonmail.com\", name: \"PFC\", website: \"https://pfc.zone/\" },\n rest: \"https://rest.cosmos.directory/kujira/\",\n rpc: \"https://kujira-rpc.nodes.defiantlabs.net\",\n stakeCurrency: {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n },\n ],\n [\n ChainId.Noble,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"noble\",\n bech32PrefixAccPub: \"noblepub\",\n bech32PrefixConsAddr: \"noblevalcons\",\n bech32PrefixConsPub: \"noblevalconspub\",\n bech32PrefixValAddr: \"noblevaloper\",\n bech32PrefixValPub: \"noblevaloperpub\",\n },\n bip44: { coinType: 118 },\n chainId: \"noble-1\",\n chainName: \"Noble\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/chain.png\",\n currencies: [\n {\n coinDecimals: 6,\n coinDenom: \"USDC\",\n coinGeckoId: \"usd-coin\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png\",\n coinMinimalDenom: \"uusdc\",\n },\n { coinDecimals: 6, coinDenom: \"USDN\", coinGeckoId: \"usd-coin\", coinMinimalDenom: \"uusdn\" },\n ],\n features: [\"cosmwasm\"],\n feeCurrencies: [\n {\n coinDecimals: 6,\n coinDenom: \"USDC\",\n coinGeckoId: \"usd-coin\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png\",\n coinMinimalDenom: \"uusdc\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USDN\",\n coinGeckoId: \"usd-coin\",\n coinMinimalDenom:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdn.png\",\n },\n ],\n rest: \"https://lcd-noble.keplr.app\",\n rpc: \"https://rpc-noble.keplr.app\",\n },\n ],\n [\n ChainId.THORChain,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"thor\",\n bech32PrefixAccPub: \"thorpub\",\n bech32PrefixConsAddr: \"thorvalcons\",\n bech32PrefixConsPub: \"thorvalconspub\",\n bech32PrefixValAddr: \"thorvaloper\",\n bech32PrefixValPub: \"thorvaloperpub\",\n },\n bip44: { coinType: 931 },\n chainId: \"thorchain-1\",\n chainName: \"THORChain\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png\",\n currencies: [\n {\n coinDecimals: 8,\n coinDenom: \"RUNE\",\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n coinMinimalDenom: \"rune\",\n },\n ],\n features: [],\n feeCurrencies: [\n {\n coinDecimals: 8,\n coinDenom: \"RUNE\",\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n coinMinimalDenom: \"rune\",\n gasPriceStep: { average: 0.02, high: 0.03, low: 0.02 },\n },\n ],\n rest: \"https://lcd-thorchain.keplr.app\",\n rpc: \"https://rpc-thorchain.keplr.app\",\n },\n ],\n]);\n"
|
|
7
|
-
],
|
|
8
|
-
"mappings": "mDAAA,gBAAS,aAAO,oBAAS,2BAAgB,kBAAuB,kBAAc,yBAC9E,uBAAS,8BAAc,6BCAvB,kBAAS,yBAEF,IAAM,EAAgB,IAAI,IAAwB,CACvD,CACE,EAAQ,OACR,CACE,aAAc,CACZ,oBAAqB,SACrB,mBAAoB,YACpB,qBAAsB,gBACtB,oBAAqB,mBACrB,oBAAqB,gBACrB,mBAAoB,kBACtB,EACA,MAAO,CAAE,SAAU,GAAI,EACvB,QAAS,UACT,UAAW,SACX,oBACE,gGACF,WAAY,CACV,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,aAAc,gGACd,iBAAkB,OACpB,EACA,CACE,aAAc,EACd,UAAW,MACX,YAAa,MACb,iBAAkB,gFACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,WACb,iBAAkB,6DACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,aACE,0KACF,iBAAkB,oFACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,YACb,aACE,qJACF,iBAAkB,6DACpB,CACF,EACA,SAAU,CAAC,UAAU,EACrB,cAAe,CACb,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,aAAc,gGACd,iBAAkB,OACpB,EACA,CACE,aAAc,EACd,UAAW,MACX,YAAa,MACb,iBAAkB,gFACpB,EACA,CACE,aAAc,EACd,UAAW,UACX,YAAa,WACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,UACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,YAAa,QACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,eACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,WACb,iBAAkB,6DACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,YAA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",
|
|
9
|
-
"debugId": "1DCBCD86B9D49B8C64756E2164756E21",
|
|
10
|
-
"names": []
|
|
11
|
-
}
|
package/dist/src/okx/index.cjs
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var V={};y(V,{okxWallet:()=>X,OKX_SUPPORTED_CHAINS:()=>N});module.exports=M(V);var D=require("@swapkit/helpers"),H=require("@swapkit/wallet-core");var z=require("@swapkit/helpers"),I=require("bitcoinjs-lib"),R=(Y)=>async({recipient:_,assetValue:$,memo:Z})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Cosmos});let{createSigningStargateClient:F}=await import("@swapkit/toolboxes/cosmos"),{keplr:G}=window.okxwallet,Q=G?.getOfflineSignerOnlyAmino(z.getChainConfig(z.Chain.Cosmos).chainId),j=await z.getRPCUrl(z.Chain.Cosmos),A=await F(j,Q),B=$?.symbol==="MUON"?"umuon":"uatom",O=[{amount:$.getBaseValue("string"),denom:B}],{transactionHash:L}=await A.sendTokens(Y,_,O,1.6,Z);return L};async function U({walletProvider:Y,chain:_}){let{getEvmToolbox:$}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Z}=await import("ethers");if(!Y)throw new z.SwapKitError("wallet_okx_not_found");let F=new Z(Y,"any"),G=await F.getSigner(),Q=await $(_,{provider:F,signer:G});try{if(_!==z.Chain.Ethereum&&"getNetworkParams"in Q)await z.switchEVMWalletNetwork(F,_,Q.getNetworkParams())}catch{throw new z.SwapKitError("wallet_okx_failed_to_switch_network",{chain:_})}return z.prepareNetworkSwitch({chain:_,provider:F,toolbox:Q})}async function J(Y){let{match:_,P:$}=await import("ts-pattern");return _(Y).with($.union(z.Chain.Arbitrum,z.Chain.Aurora,z.Chain.Avalanche,z.Chain.Base,z.Chain.Berachain,z.Chain.BinanceSmartChain,z.Chain.Ethereum,z.Chain.XLayer,z.Chain.Gnosis,z.Chain.Optimism,z.Chain.Polygon),async()=>{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:Y});let Z=await U({chain:Y,walletProvider:window.okxwallet}),F=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{...Z,address:F}}).with(z.Chain.Bitcoin,async()=>{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Bitcoin});let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo"),{bitcoin:F}=window.okxwallet,G=(await F.connect()).address,Q={getAddress:async()=>Promise.resolve(G),signTransaction:async(A)=>{let B=await F.signPsbt(A.toHex(),{from:G,type:"list"});return I.Psbt.fromHex(B)}};return{...await Z(z.Chain.Bitcoin,{signer:Q}),address:G}}).with(z.Chain.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Cosmos});let{keplr:Z}=window.okxwallet;await Z.enable(z.getChainConfig(Y).chainId);let G=await Z.getOfflineSignerOnlyAmino(z.getChainConfig(Y).chainId).getAccounts();if(!(G&&Array.isArray(G))||G.length===0)throw new z.SwapKitError("wallet_okx_no_accounts",{chain:z.Chain.Cosmos,message:"No Cosmos accounts returned from OKX Wallet"});let{getCosmosToolbox:Q}=await import("@swapkit/toolboxes/cosmos"),[{address:j}]=G;return{...await Q(z.Chain.Cosmos),address:j,transfer:R(j)}}).with(z.Chain.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Tron});let{createTronToolbox:Z}=await import("@swapkit/toolboxes/tron"),F=window.okxwallet.tronLink,G=await F.request({method:"tron_requestAccounts"});if(!G||G.length===0)throw new z.SwapKitError("wallet_okx_no_accounts",{chain:z.Chain.Tron});let Q=F.tronWeb.defaultAddress.base58;return{...await Z({signer:{getAddress:async()=>Q,signTransaction:async(B)=>{return await F.tronWeb.trx.sign(B)}}}),address:Q}}).otherwise(()=>{throw new z.SwapKitError("wallet_okx_chain_not_supported",{chain:Y})})}var X=H.createWallet({connect:({addChain:Y,supportedChains:_,walletType:$})=>async function(F){let G=D.filterSupportedChains({chains:F,supportedChains:_,walletType:$});return await Promise.all(G.map(async(Q)=>{let j=await J(Q);Y({...j,chain:Q,walletType:$})})),!0},name:"connectOkx",supportedChains:[D.Chain.Arbitrum,D.Chain.Aurora,D.Chain.Avalanche,D.Chain.Base,D.Chain.Berachain,D.Chain.BinanceSmartChain,D.Chain.Bitcoin,D.Chain.Cosmos,D.Chain.Ethereum,D.Chain.Gnosis,D.Chain.Optimism,D.Chain.Polygon,D.Chain.XLayer,D.Chain.Tron],walletType:D.WalletOption.OKX}),N=H.getWalletSupportedChains(X);
|
|
2
|
-
|
|
3
|
-
//# debugId=B05096128AAE55BD64756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/okx/index.ts", "../src/okx/helpers.ts"],
|
|
4
|
-
"sourcesContent": [
|
|
5
|
-
"import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectOkx(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 addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectOkx\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.Cosmos,\n Chain.Ethereum,\n Chain.Gnosis,\n // NEAR transfer is not yet supported in OKX Wallet\n // Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.XLayer,\n Chain.Tron,\n ],\n walletType: WalletOption.OKX,\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
|
|
6
|
-
"import {\n Chain,\n type EVMChain,\n type GenericTransferParams,\n getChainConfig,\n getRPCUrl,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nconst cosmosTransfer =\n (sender: string) =>\n async ({ recipient, assetValue, memo }: GenericTransferParams) => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { createSigningStargateClient } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const { keplr: wallet } = window.okxwallet;\n const offlineSigner = wallet?.getOfflineSignerOnlyAmino(getChainConfig(Chain.Cosmos).chainId);\n\n const rpcUrl = await getRPCUrl(Chain.Cosmos);\n const cosmJS = await createSigningStargateClient(rpcUrl, offlineSigner);\n\n const denom = assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\";\n const coins = [{ amount: assetValue.getBaseValue(\"string\"), denom }];\n\n const { transactionHash } = await cosmJS.sendTokens(sender, recipient, coins, 1.6, memo);\n return transactionHash;\n };\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: {\n walletProvider: Eip1193Provider | undefined;\n chain: EVMChain;\n}) {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_okx_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 {\n throw new SwapKitError(\"wallet_okx_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n\n return (\n match(chain)\n .with(\n P.union(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.XLayer,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n ),\n async () => {\n if (!(window.okxwallet && \"send\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain });\n }\n\n const evmWallet = await getWeb3WalletMethods({ chain: chain as EVMChain, walletProvider: window.okxwallet });\n const address: string = (await window.okxwallet.send(\"eth_requestAccounts\", [])).result[0];\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(window.okxwallet && \"bitcoin\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Bitcoin });\n }\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const { bitcoin: wallet } = window.okxwallet;\n const address = (await wallet.connect()).address;\n\n const signer = {\n getAddress: async () => Promise.resolve(address),\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { from: address, type: \"list\" });\n\n return Psbt.fromHex(signedPsbt);\n },\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { keplr: wallet } = window.okxwallet;\n\n await wallet.enable(getChainConfig(chain).chainId);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(getChainConfig(chain).chainId);\n const accounts = await offlineSigner.getAccounts();\n\n // Add defensive check for accounts array\n if (!(accounts && Array.isArray(accounts)) || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", {\n chain: Chain.Cosmos,\n message: \"No Cosmos accounts returned from OKX Wallet\",\n });\n }\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(Chain.Cosmos);\n\n return { ...toolbox, address, transfer: cosmosTransfer(address) };\n })\n // INFO: OK wallet near is broken\n // .with(Chain.Near, async () => {\n // if (!(window.okxwallet && \"near\" in window.okxwallet)) {\n // throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Near });\n // }\n\n // const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n // const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n // const provider = window.okxwallet.near;\n // const signer = await createNearSignerFromProvider(provider, \"OKX\");\n // const accountId = await signer.getAddress();\n // const toolbox = await getNearToolbox({ signer });\n\n // return { ...toolbox, address: accountId } as NearToolbox & { address: string };\n // })\n .with(Chain.Tron, async () => {\n if (!(window.okxwallet && \"tronLink\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Tron });\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n\n const tronLink = window.okxwallet.tronLink;\n\n // Request account access\n const accounts = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = tronLink.tronWeb.defaultAddress.base58;\n\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_okx_chain_not_supported\", { chain });\n })\n );\n}\n"
|
|
7
|
-
],
|
|
8
|
-
"mappings": "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",
|
|
9
|
-
"debugId": "B05096128AAE55BD64756E2164756E21",
|
|
10
|
-
"names": []
|
|
11
|
-
}
|
package/dist/src/okx/index.js
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import{F as A,G as B}from"../../chunk-jgq4njag.js";import{Chain as Q,filterSupportedChains as f,WalletOption as P}from"@swapkit/helpers";import{createWallet as W,getWalletSupportedChains as K}from"@swapkit/wallet-core";import{Chain as z,getChainConfig as J,getRPCUrl as R,prepareNetworkSwitch as U,SwapKitError as $,switchEVMWalletNetwork as M}from"@swapkit/helpers";import{Psbt as y}from"bitcoinjs-lib";var N=(Y)=>async({recipient:_,assetValue:j,memo:Z})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new $("wallet_okx_not_found",{chain:z.Cosmos});let{createSigningStargateClient:D}=await import("@swapkit/toolboxes/cosmos"),{keplr:F}=window.okxwallet,G=F?.getOfflineSignerOnlyAmino(J(z.Cosmos).chainId),q=await R(z.Cosmos),H=await D(q,G),I=j?.symbol==="MUON"?"umuon":"uatom",O=[{amount:j.getBaseValue("string"),denom:I}],{transactionHash:L}=await H.sendTokens(Y,_,O,1.6,Z);return L};async function V({walletProvider:Y,chain:_}){let{getEvmToolbox:j}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Z}=await import("ethers");if(!Y)throw new $("wallet_okx_not_found");let D=new Z(Y,"any"),F=await D.getSigner(),G=await j(_,{provider:D,signer:F});try{if(_!==z.Ethereum&&"getNetworkParams"in G)await M(D,_,G.getNetworkParams())}catch{throw new $("wallet_okx_failed_to_switch_network",{chain:_})}return U({chain:_,provider:D,toolbox:G})}async function X(Y){let{match:_,P:j}=await import("ts-pattern");return _(Y).with(j.union(z.Arbitrum,z.Aurora,z.Avalanche,z.Base,z.Berachain,z.BinanceSmartChain,z.Ethereum,z.XLayer,z.Gnosis,z.Optimism,z.Polygon),async()=>{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new $("wallet_okx_not_found",{chain:Y});let Z=await V({chain:Y,walletProvider:window.okxwallet}),D=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{...Z,address:D}}).with(z.Bitcoin,async()=>{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new $("wallet_okx_not_found",{chain:z.Bitcoin});let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo"),{bitcoin:D}=window.okxwallet,F=(await D.connect()).address,G={getAddress:async()=>Promise.resolve(F),signTransaction:async(H)=>{let I=await D.signPsbt(H.toHex(),{from:F,type:"list"});return y.fromHex(I)}};return{...await Z(z.Bitcoin,{signer:G}),address:F}}).with(z.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new $("wallet_okx_not_found",{chain:z.Cosmos});let{keplr:Z}=window.okxwallet;await Z.enable(J(Y).chainId);let F=await Z.getOfflineSignerOnlyAmino(J(Y).chainId).getAccounts();if(!(F&&Array.isArray(F))||F.length===0)throw new $("wallet_okx_no_accounts",{chain:z.Cosmos,message:"No Cosmos accounts returned from OKX Wallet"});let{getCosmosToolbox:G}=await import("@swapkit/toolboxes/cosmos"),[{address:q}]=F;return{...await G(z.Cosmos),address:q,transfer:N(q)}}).with(z.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new $("wallet_okx_not_found",{chain:z.Tron});let{createTronToolbox:Z}=await import("@swapkit/toolboxes/tron"),D=window.okxwallet.tronLink,F=await D.request({method:"tron_requestAccounts"});if(!F||F.length===0)throw new $("wallet_okx_no_accounts",{chain:z.Tron});let G=D.tronWeb.defaultAddress.base58;return{...await Z({signer:{getAddress:async()=>G,signTransaction:async(I)=>{return await D.tronWeb.trx.sign(I)}}}),address:G}}).otherwise(()=>{throw new $("wallet_okx_chain_not_supported",{chain:Y})})}var T=W({connect:({addChain:Y,supportedChains:_,walletType:j})=>async function(D){let F=f({chains:D,supportedChains:_,walletType:j});return await Promise.all(F.map(async(G)=>{let q=await X(G);Y({...q,chain:G,walletType:j})})),!0},name:"connectOkx",supportedChains:[Q.Arbitrum,Q.Aurora,Q.Avalanche,Q.Base,Q.Berachain,Q.BinanceSmartChain,Q.Bitcoin,Q.Cosmos,Q.Ethereum,Q.Gnosis,Q.Optimism,Q.Polygon,Q.XLayer,Q.Tron],walletType:P.OKX}),u=K(T);export{T as okxWallet,u as OKX_SUPPORTED_CHAINS};
|
|
2
|
-
|
|
3
|
-
//# debugId=9AE8A6C20638101664756E2164756E21
|
|
4
|
-
//# sourceMappingURL=index.js.map
|