Skip to main content

Default EVM Adapter

The @web3auth/default-evm-adapter package enables seamless detection of injected EVM wallets and WalletConnect-supported wallets, allowing interaction with just a single line of code.

Installation

npm install --save @web3auth/default-evm-adapter

Injected Wallets

To automatically fetch all the available EVM wallets in browser context, you should use the getInjectedAdapters function. This function uses MIPD (EIP6163) so all available wallets in the browser will automatically be detected.

In case of PnP Modal SDK, if no wallets are available, prompts users with an option to install one. Refer to the image below for details:

getInjectedAdapters image

Parameter

ParameterDescription
optionsAccepts IWeb3AuthCoreOptions used to initialize the Web3Auth SDK.

Usage

import { getInjectedAdapters } from "@web3auth/default-evm-adapter";
import { EthereumPrivateKeyProvider } from "@web3auth/ethereum-provider";

const chainConfig = {
chainId: "0xaa36a7",
displayName: "Ethereum Sepolia",
chainNamespace: CHAIN_NAMESPACES.EIP155,
tickerName: "Ethereum Sepolia",
ticker: "ETH",
rpcTarget: "https://rpc.ankr.com/eth_sepolia",
blockExplorerUrl: "https://sepolia.etherscan.io",
logo: "https://cryptologos.cc/logos/ethereum-eth-logo.png",
};

const privateKeyProvider = new EthereumPrivateKeyProvider({ config: { chainConfig } });

const web3AuthOptions: Web3AuthOptions = {
clientId,
chainConfig
web3AuthNetwork: WEB3AUTH_NETWORK.SAPPHIRE_MAINNET,
privateKeyProvider: privateKeyProvider,
};

const adapters = await getInjectedAdapters({ options: web3AuthOptions });

adapters.forEach((adapter) => {
web3auth.configureAdapter(adapter);
});

WalletConnect-supported Wallets

To list all the wallets supported by the WalletConnect list, you can use the getDefaultExternalAdapters function.

In case of PnP Modal SDK, if no wallets are available, it provides an option to use the WalletConnect v2 to connect the wallet. Refer to the image below for details:

getDefaultExternalAdapters image

Parameter

ParameterDescription
optionsAccepts IWeb3AuthCoreOptions used to initialize the Web3Auth SDK.

Usage

import { getDefaultExternalAdapters } from "@web3auth/default-evm-adapter";
import { EthereumPrivateKeyProvider } from "@web3auth/ethereum-provider";

const chainConfig = {
chainId: "0xaa36a7",
displayName: "Ethereum Sepolia",
chainNamespace: CHAIN_NAMESPACES.EIP155,
tickerName: "Ethereum Sepolia",
ticker: "ETH",
rpcTarget: "https://rpc.ankr.com/eth_sepolia",
blockExplorerUrl: "https://sepolia.etherscan.io",
logo: "https://cryptologos.cc/logos/ethereum-eth-logo.png",
};

const privateKeyProvider = new EthereumPrivateKeyProvider({ config: { chainConfig } });

const web3AuthOptions: Web3AuthOptions = {
clientId,
chainConfig
web3AuthNetwork: WEB3AUTH_NETWORK.SAPPHIRE_MAINNET,
privateKeyProvider: privateKeyProvider,
};

const adapters = await getDefaultExternalAdapters({ options: web3AuthOptions });

adapters.forEach((adapter) => {
web3auth.configureAdapter(adapter);
});