Privy provides authentication and wallet infrastructure for apps built on crypto rails. Embed self-custodial wallets, authenticate users via email/SMS/socials/passkeys/wallets, and transact on EVM and Solana chains. Also supports agent payment protocols (x402, MPP) and autonomous agentic wallets.
Key packages:
@privy-io/react-auth - React SDK (auth + wallets + x402)@privy-io/react-auth/solana - Solana wallet hooks@privy-io/react-auth/smart-wallets - Smart wallets (ERC-4337)@privy-io/wagmi - wagmi v2 connector@privy-io/node - Server-side SDK (replaces deprecated @privy-io/server-auth)mppx - MPP client/server SDK (settles on Tempo)Docs: Privy ships an official agent skill - npx skills add https://docs.privy.io (or fetch https://docs.privy.io/skill.md). The machine-readable doc index is https://docs.privy.io/llms-full.txt (plus sitemap.xml); llms.txt now only points to the skill installer. Privy restructures docs often - do not guess URLs, they 404.
Setting up Privy auth in a React app? -> Quick Start below, then references/react-sdk.md
Adding wagmi/viem to a Privy app? -> Wagmi Integration below, then references/react-sdk.md
Working server-side (Node.js)? -> Server-Side section below, then references/server-sdk.md
Adding x402 or MPP payments? -> x402/MPP sections below, then references/agent-payments.md
Building agentic wallets or agent auth? -> Agentic Wallets below, then references/agent-auth.md
Solana-specific integration? -> references/solana.md
Wallet management (smart wallets, policies, funding)? -> references/wallets.md
Wallet actions (DeFi earn, swap, cross-chain transfer/bridge)? -> Wallet Actions in references/wallets.md
npm i @privy-io/react-auth
'use client';
import {PrivyProvider} from '@privy-io/react-auth';
export default function Providers({children}: {children: React.ReactNode}) {
return (
<PrivyProvider
appId={process.env.NEXT_PUBLIC_PRIVY_APP_ID!}
config={{
embeddedWallets: {
ethereum: {createOnLogin: 'users-without-wallets'}
}
}}
>
{children}
</PrivyProvider>
);
}
import {usePrivy} from '@privy-io/react-auth';
function App() {
const {ready, authenticated, user} = usePrivy();
if (!ready) return <div>Loading...</div>;
// Safe to use Privy hooks now
}
import {useLoginWithEmail} from '@privy-io/react-auth';
function LoginForm() {
const {sendCode, loginWithCode} = useLoginWithEmail();
// sendCode({email}) then loginWithCode({code})
}
import {useSendTransaction} from '@privy-io/react-auth';
function SendButton() {
const {sendTransaction} = useSendTransaction();
return (
<button onClick={() => sendTransaction({to: '0x...', value: 100000})}>
Send
</button>
);
}
config={{
// Auth methods enabled for login
loginMethods: ['email', 'sms', 'wallet', 'google', 'apple', 'twitter',
'github', 'discord', 'farcaster', 'telegram', 'passkey'],
// Embedded wallet creation
embeddedWallets: {
ethereum: {createOnLogin: 'users-without-wallets'}, // or 'all-users' | 'off'
solana: {createOnLogin: 'users-without-wallets'}
},
// UI appearance
appearance: {
showWalletLoginFirst: false,
walletChainType: 'ethereum-and-solana', // or 'ethereum-only' | 'solana-only'
theme: 'light', // or 'dark'
accentColor: '#6A6FF5',
logo: 'https://your-logo.png'
},
// External wallet connectors (Solana)
externalWallets: {
solana: {connectors: toSolanaWalletConnectors()}
},
// Solana RPC config (required for embedded wallet UIs)
solana: {
rpcs: {
'solana:mainnet': {
rpc: createSolanaRpc('https://api.mainnet-beta.solana.com'),
rpcSubscriptions: createSolanaRpcSubscriptions('wss://api.mainnet-beta.solana.com')
}
}
}
}}
Import createConfig and WagmiProvider from @privy-io/wagmi (NOT from wagmi).
npm i @privy-io/react-auth @privy-io/wagmi wagmi @tanstack/react-query
import {PrivyProvider} from '@privy-io/react-auth';
import {WagmiProvider, createConfig} from '@privy-io/wagmi';
import {QueryClient, QueryClientProvider} from '@tanstack/react-query';
import {mainnet, base} from 'viem/chains';
import {http} from 'wagmi';
const queryClient = new QueryClient();
const wagmiConfig = createConfig({
chains: [mainnet, base],
transports: {[mainnet.id]: http(), [base.id]: http()}
});
// Nesting order: PrivyProvider > QueryClientProvider > WagmiProvider
export default function Providers({children}: {children: React.ReactNode}) {
return (
<PrivyProvider appId="your-app-id" config={privyConfig}>
<QueryClientProvider client={queryClient}>
<WagmiProvider config={wagmiConfig}>{children}</WagmiProvider>
</QueryClientProvider>
</PrivyProvider>
);
}
Use wagmi hooks (useAccount, useSendTransaction, etc.) for read/write actions. Use Privy hooks for wallet connection/creation.
npm i @privy-io/node
import {PrivyClient} from '@privy-io/node';
const privy = new PrivyClient({
appId: process.env.PRIVY_APP_ID!,
appSecret: process.env.PRIVY_APP_SECRET!
});
// Verify access token from Authorization header
// (top-level privy.verifyAuthToken is deprecated - use utils().auth())
const {userId} = await privy.utils().auth().verifyAccessToken(accessToken);
All auth flows can be fully whitelabeled with custom UI. Key hooks:
| Hook | Auth method |
|---|---|
| ------ | ------------ |
useLoginWithEmail | Email OTP (sendCode, loginWithCode) |
useLoginWithSms | SMS OTP |
useLoginWithOAuth | Social logins (initOAuth({provider: 'google'})) |
useLoginWithPasskey | Passkeys |
useSignupWithPasskey | Passkey signup |
useLoginWithTelegram | Telegram |
useLogin | General login with callbacks |
Footgun: whitelabel flows (useLoginWithEmail, etc.) call Privy directly from the app domain, so they silently fail if that domain is not in the Dashboard's Allowed Origins/Domains - the hosted modal (usePrivy().login()) still works, masking the issue. Add every local dev port (e.g. localhost:5173) too. useLoginWithEmail's onError returns a rich object, not {message} - log the whole thing to see the real rejection.
Built into @privy-io/react-auth since v3.7.0. Handles HTTP 402 payment flows automatically using USDC.
import {useX402Fetch, useWallets} from '@privy-io/react-auth';
function PaidContent() {
const {wallets} = useWallets();
const {wrapFetchWithPayment} = useX402Fetch();
const fetchContent = async () => {
const fetchWithPayment = wrapFetchWithPayment({
walletAddress: wallets[0]?.address,
fetch,
maxValue: BigInt(1000000) // Max 1 USDC
});
const res = await fetchWithPayment('https://api.example.com/premium');
return res.json();
};
}
Server-side (Node.js):
import {createX402Client} from '@privy-io/node/x402';
import {wrapFetchWithPayment} from '@x402/fetch';
const x402client = createX402Client(privy, {walletId: wallet.id, address: wallet.address});
const fetchWithPayment = wrapFetchWithPayment(fetch, x402client);
const response = await fetchWithPayment('https://api.example.com/premium');
MPP (Machine Payments Protocol) settles on Tempo using stablecoins (PathUSD, USDC, or others). Supports sessions for high-frequency payments.
import {Mppx, tempo} from 'mppx/client';
// Create Privy-backed viem account (see references/agent-payments.md for full pattern)
const account = createPrivyAccount(wallet.id, wallet.address);
const mppx = Mppx.create({polyfill: false, methods: [tempo({account})]});
const response = await mppx.fetch('https://api.example.com/weather');
Server-controlled wallets with policy-based constraints for autonomous agents.
// Create agent wallet
const wallet = await privy.wallets().create({chain_type: 'ethereum'});
// Execute transactions - validated against attached policies
const {hash} = await privy.wallets().ethereum().sendTransaction(wallet.id, {
caip2: 'eip155:8453',
params: {transaction: {to: '0x...', value: '0x1', chain_id: 8453}}
});
Two control models: agent-controlled (fully autonomous, developer-owned) and user-owned with agent signers (user retains revocation authority). See references/agent-auth.md for policy examples and setup.
Read the appropriate reference file for detailed integration guides:
@privy-io/node), token types and verification, user management API, REST API, webhooks| Topic | URL |
|---|---|
| ------- | ----- |
| Full docs index (LLM-friendly) | https://docs.privy.io/llms.txt |
| React setup | https://docs.privy.io/basics/react/setup |
| React quickstart | https://docs.privy.io/basics/react/quickstart |
| Auth overview | https://docs.privy.io/authentication/overview |
| Whitelabel auth | https://docs.privy.io/authentication/user-authentication/whitelabel |
| Tokens (access/refresh/identity) | https://docs.privy.io/authentication/user-authentication/tokens |
| Wallets overview | https://docs.privy.io/wallets/overview |
| Wagmi integration | https://docs.privy.io/wallets/connectors/ethereum/integrations/wagmi |
| Viem integration | https://docs.privy.io/wallets/connectors/ethereum/integrations/viem |
| Smart wallets | https://docs.privy.io/wallets/using-wallets/evm-smart-wallets/overview |
| Smart wallets SDK config | https://docs.privy.io/wallets/using-wallets/evm-smart-wallets/setup/configuring-sdk |
| Gas sponsorship | https://docs.privy.io/wallets/gas-and-asset-management/gas/overview |
| Gas on Ethereum | https://docs.privy.io/wallets/gas-and-asset-management/gas/ethereum |
| Gas on Solana | https://docs.privy.io/wallets/gas-and-asset-management/gas/solana |
| Node.js SDK quickstart | https://docs.privy.io/basics/nodeJS/quickstart |
| Solana recipe | https://docs.privy.io/recipes/solana/getting-started-with-privy-and-solana |
| Connectors overview | https://docs.privy.io/wallets/connectors/overview |
| Custom auth provider (JWT) | https://docs.privy.io/authentication/user-authentication/jwt-based-auth/overview |
| Webhooks | https://docs.privy.io/wallets/actions/webhooks |
| x402 integration | https://docs.privy.io/recipes/agent-integrations/x402 |
| MPP integration | https://docs.privy.io/recipes/agent-integrations/mpp |
| Agentic wallets | https://docs.privy.io/recipes/agent-integrations/agentic-wallets |
| OpenClaw integration | https://docs.privy.io/recipes/agent-integrations/openclaw-agentic-wallets |
| Tempo chain | https://docs.privy.io/recipes/tempo/send-transactions |
| Wallet policies | https://docs.privy.io/controls/policies/overview |
| Wallet actions (earn/swap/transfer) | https://docs.privy.io/wallets/actions/overview |
| Wallet signers | https://docs.privy.io/wallets/using-wallets/signers/overview |
| x402 protocol | https://x402.org |
| MPP protocol | https://mpp.dev |
| Agent Auth Protocol | https://agentauthprotocol.com |
| MCP auth spec | https://modelcontextprotocol.io/specification/2025-11-25/basic/authorization |
共 1 个版本