In this guide, you will learn how to use Privy to easily onboard your users and create transactions without the need for any Web3 wallet.
What is Privy?
Privy is a simple tool to easily onboard all your users to web3, regardless of whether they already have a wallet, across mobile and desktop.
Terminology
Before we dive into the guide, let's first understand the terminology.
Term | Meaning |
---|---|
Social Login | Social Login is a form of single sign-on (SSO) that allows users to log into a third-party website or app using their existing credentials from a social media platform, such as Google, X (formerly Twitter), or Apple. Instead of creating a new username and password, users can authenticate themselves through their social media accounts, streamlining the login process. |
Magic Link | A Magic Link is a form of passwordless authentication where users can log into an application or website by clicking a unique, time-sensitive link sent to their email address. This method eliminates the need for a traditional username and password combination, making the login process simpler and more user-friendly. |
Next.js | Next.js’ Pages Router is a full-stack React framework. It’s versatile and lets you create React apps of any size—from a mostly static blog to a complex dynamic application. |
Prerequisites and Recommended Knowledge
- Privy account
- Basic understanding of EVM, and transaction data
- Basic understanding of frontend development
Preparation
Create Application and Retrieve API Keys
- Log in to Privy Dashboard
- Click on
New App
on the Applications page. - Click on the Settings button on the left pane. Under the Basic tab, you'll find the API keys.
Start a New React Project with Next.js
To create a new Next.js project, run in your terminal:
Install Dependencies
After the React project is created, we need to install some dependencies: to use Privy (its own package), to add a custom chain, to create and use an HTTP client (viem), and to include utilities (ethers).
Define Your Avalanche L1
In this guide, we are using the Echo L1
as an example Avalanche L1. However, you can use any Avalanche L1 that has a public RPC URL. If the L1 has an explorer page, you can see better what is happening, but it is not required.
Import Privy into Your App
After the React project is created, navigate to page.tsx
. Inside the Home
function, wrap your content with PrivyProvider
.
Walkthrough
So far in the guide, we have installed the necessary dependencies, created our Privy application, and obtained our API key. Now, we are ready to use Privy.
Here is our walkthrough:
- We will create a simple login flow.
- We will create a welcome page for users who have logged in, showing their embedded wallet address and balance.
- We will trigger a test transfer of the
ECH
token via Privy.
Login Flow
To onboard your users into your application, you just need to know the following hooks:
It's really that simple!
ready
: Checks whether thePrivyProvider
isready
to be used.authenticated
: Returnstrue
if the user isauthenticated
,false
otherwise.login
: Opens the Privy login modal and prompts the user to log in.
We've only added a button to trigger login
function, and Privy handles the rest.
When we click on the Login via Privy
button, this modal appears.
You can choose any login method to log in. We’ve already defined these options in the PrivyProvider
when we wrapped our content.
Welcome Page
After checking whether the user is authenticated or not, we display the following information to the user who has logged in.
As you can see, Privy has generated an embedded wallet for our user. We’ve displayed the following properties on the screen: Privy ID, embedded wallet address, and embedded wallet balance.
We’ve used the user object of Privy to retrieve the user ID and wallet address. To fetch the user’s balance, we need to create an HTTP client for our Avalanche L1, which we’ve already defined earlier.
We can allow users to log out using the following hook:
Fund the New Wallet Using the Faucet
We’ve funded the new wallet that was generated for our user with some ECH tokens from the Echo AWM Testnet Faucet.
After the ECH tokens were sent, our balance updated accordingly.
Send Test Transfer via Privy
Now that we have a balance, we can send some ECH tokens to another recipient via Privy to test Privy's sendTransaction
flow. Privy provides the following hook for this:
We’ve already added the following button to trigger the transfer
function, which will, in turn, trigger the sendTransaction
function provided by Privy.
We have built a simple transaction that sends some ECH tokens to another recipient.
When we click on the Send Test Transfer via Privy
button, this modal appears. Users can see the following details related to the transaction.
Conclusion
What we achieved is the creation of a simple React project that integrates Privy. Our application can now easily onboard new users to our Web3 application without needing them to install a Web3 wallet extension, regardless of which chain they are on.
Written by
On
Fri Aug 23 2024
Topics