Privy is a simple toolkit for progressive authentication in web3. With a single library, you can easily onboard both expert users and newcomers alike, through Privy's powerful wallet connectors and delightful embedded wallets.

Privy makes it easy to integrate every major wallet into your app without having to wrangle the connectors individually. You can check out Privy in action here.

Privy comes pre-packaged with Phantom so you can support your Phantom users right out of the box. Here’s how.


The Privy React Auth SDK allows you to authenticate your users with Privy in your React app in minutes. You can follow the standard guide here.

Building a new app? Check out these starter templates for integrating Privy into:

1. Get a Privy account

Request access to Privy and get keys in minutes. Retrieve your Privy app ID from the developer console at

2. Install the Privy npm package

Install the Privy React Auth SDK using npm:

npm install @privy-io/react-auth

3. Configure Privy

Once you have your app ID, in your React project, wrap your components with a PrivyProvider. The PrivyProvider should wrap any component that will use the Privy SDK.

If you're starting from scratch, we recommend using one of these templates to integrate Privy:

For example, in a NextJS or Create React App project, you may wrap your components like so:

import type {AppProps} from 'next/app';
import Head from 'next/head';
import {PrivyProvider} from '@privy-io/react-auth';

// This method will be passed to the PrivyProvider as a callback
// that runs after successful login.
const handleLogin = (user) => {
  console.log(`User ${} logged in!`)

function MyApp({Component, pageProps}: AppProps) {
  return (
        {/* Edit your HTML header */}
        <Component {...pageProps} />

The PrivyProvider takes the following properties:

4. Just usePrivy! πŸŽ‰

You can now use the Privy SDK throughout your app via the usePrivy hook with Phantom working right out of the box.

Check it out live

See Privy run live in a CodeSandbox environment and check out the starter repo for more reference.

Next Steps

Customize Privy to match your brand and explore how your users are connecting to your app.

From here, you can easily use Privy to:

Last updated