Use Starknet
Starknet is a non-EVM Layer 2 network. To interact with Starknet accounts in MetaMask, you need to use the Starknet Snap.
You can use the get-starknet
library or the wallet_invokeSnap
JSON-RPC method to connect to the Starknet Snap.
The choice depends on your specific use case and development preferences.
get-starknet
:
- Provides a high-level API that abstracts complex operations.
- Offers standardized error handling.
- Supports multiple wallets, not limited to MetaMask.
- Manages wallet connections and Starknet interactions.
- Results are in more readable code.
wallet_invokeSnap
:
- Requires precise method names and parameter structures.
- Handles both MetaMask-specific and Starknet-specific errors.
- Is designed for operating within the MetaMask framework.
- Manages lower-level Starknet interactions directly.
- Provides results in more detailed, lower-level code.
We recommend using the get-starknet
library for a most use cases.
The choice between the two connection methods depends on the specific needs of the project, the desired level of control, and familiarity with Starknet and Snaps.
About get-starknet
get-starknet
is a library that simplifies Starknet network interactions.
It works with the Starknet Snap to extend the functionality of MetaMask and enable dapps to interact with users' Starknet accounts in MetaMask.
When you integrate get-starknet
into your dapp, it creates a WalletAccount
object. WalletAccount
acts as a connection between dapps and MetaMask and provides a way to manage Starknet interactions.
This allows users to send Starknet transactions, sign Starknet messages, and manage Starknet accounts within MetaMask, and this functionality can be extended to multiple wallets.
How get-starknet
and MetaMask interact
A dapp with get-starknet
installed interacts with MetaMask as follows:
-
The dapp uses
get-starknet
to request the user connect to MetaMask. If the user doesn't have the Starknet Snap installed, MetaMask automatically prompts the user to connect and approve the addition. -
After the dapp is connected to MetaMask and the Starknet Snap,
get-starknet
receives a Starknet Windows Object (SWO), which represents the MetaMask wallet with Starknet functionality. -
get-starknet
creates aWalletAccount
instance. This instance manages the Starknet account within MetaMask.
The get-starknet
library offers several key features that improve how dapps interact with the StarkNet network through MetaMask."
- The
WalletAccount
uses a specified provider to access data from the StarkNet network. - For transactions,
get-starknet
prepares the data and sends it to MetaMask for signing via StarkNet Snap. get-starknet
enables the dapp to create contract instances connected to theWalletAccount
, allowing smart contract functions to be invoked, with MetaMask handling the signatures.- It sets up listeners for account and network changes in MetaMask, so the dapp can subscribe and update its state accordingly.
get-starknet
can request network changes through MetaMask, allowing users to switch between StarkNet networks, such as Mainnet or Sepolia testnet.- It can also request MetaMask to display specific tokens, improving the user experience.