Appearance
Documentation / react-auth / PrivyInterface
Interface: PrivyInterface
Allows you to manage the user's current authentication state and access their linked accounts. You can access the fields and methods documented here via the usePrivy hook.
Properties
authenticated
authenticated:
boolean
True if the user is authenticated, false otherwise.
You should always check that ready
is true before using this value. Otherwise, the value may outdated while the Privy client fetches fresh tokens.
cancel
cancel: () =>
void
Cancel the MFA flow for the current user. If there is no pending MFA verification, this function is a no-op.
Call this method instead of submit
when a user has been prompted for MFA but decides to exit the flow.
Returns
void
void.
connectOrCreateWallet
connectOrCreateWallet: () =>
void
Opens the Privy login modal and prompts the user to login or connect a wallet.
Returns
void
connectWallet
connectWallet: (
options
?) =>void
Opens the Privy modal and prompts the user to connect a wallet.
Parameters
• options?: ExternalConnectWalletModalOptions
| MouseEvent
<any
, any
>
Returns
void
createWallet
createWallet: (
options
?) =>Promise
<Wallet
>
Creates an embedded wallet for the current user.
This method will error if the user already has an embedded wallet or if they exit in the middle of the flow.
If the config.embeddedWallets.requireUserOwnedRecoveryOnCreate
property is set to true, this will prompt the user to complete a recovery flow to secure the recovery share of their embedded wallet.
Otherwise (the default), Privy will secure the recovery share, and the embedded wallet will be created without showing any UIs to the user.
Parameters
• options?: MouseEvent
<any
, any
> | CreateWalletOptions
Returns
Promise
<Wallet
>
Promise for the Wallet object for the newly created embedded wallet
enrollInMfa
enrollInMfa: (
show
?) =>void
Function to control the visibility of the enrollment modal.
Parameters
• show?: boolean
{boolean} controls the visibility of the enrollment modal.
Returns
void
Promise for opening the enrollment modal.
exportWallet
exportWallet: (
options
?) =>Promise
<void
>
Shows the user a Privy modal, from which they can copy their embedded wallet's private key or seed phrase for easy export to another wallet client (e.g. MetaMask). The private key is loaded on an iframe running on a separate domain from your app, meaning your app cannot access it.
This method will error if the user is not authenticated or does not have an embedded wallet.
Parameters
• options?: MouseEvent
<any
, any
> | Object
{address: string} (optional) wallet address to export the private key for
Returns
Promise
<void
>
Promise that resolves once the user exits the modal
getAccessToken
getAccessToken: () =>
Promise
<null
|string
>
Get the Privy access token (JWT) for an authenticated user. Returns null for an unauthenticated user.
You may use this token to authorize requests sent from your frontend, and can validate it in your backend against your app's Privy verification key.
This will automatically attempt to refresh the session if the token is expired or about to expire.
Returns
Promise
<null
| string
>
Promise for the user's access token as a string if they are authenticated, null if they are unauthenticated.
init
init: (
mfaMethod
) =>Promise
<void
|PublicKeyCredentialRequestOptionsJSON
>
Initiate the MFA flow for the current user.
Parameters
• mfaMethod: "sms"
| "totp"
| "passkey"
MfaMethod The available MFA method to trigger for the current user.
Returns
Promise
<void
| PublicKeyCredentialRequestOptionsJSON
>
Promise for sending the MFA code to the user's device.
initEnrollmentWithPasskey
initEnrollmentWithPasskey: () =>
Promise
<void
>
Initiate the enrollment flow for Passkey MFA for the current user.
Returns
Promise
<void
>
void The TOTP Auth Url is used to encode into a QR Code for the user to scane.
initEnrollmentWithSms
initEnrollmentWithSms: (
meta
) =>Promise
<void
>
Initiate the enrollment flow for MFA for the current user.
Parameters
• meta: Object
{phoneNumber: string} The meta data needed to complete the MFA flow.
• meta.phoneNumber: string
Returns
Promise
<void
>
Promise for enrolling the current user with the chosen MFA method.
initEnrollmentWithTotp
initEnrollmentWithTotp: () =>
Promise
<Object
>
Initiate the enrollment flow for TOTP MFA for the current user.
Returns
Promise
<Object
>
{secret: string; authUrl: string} The TOTP Auth Url is used to encode into a QR Code for the user to scane.
authUrl
authUrl:
string
secret
secret:
string
isModalOpen
isModalOpen:
boolean
Check whether the Privy Modal is visible.
linkApple
linkApple: () =>
void
For users who are authenticated, prompts the user to link Apple OAuth account This will directly initiate the OAuth flow for Apple.
Returns
void
linkDiscord
linkDiscord: () =>
void
For users who are authenticated, prompts the user to link Discord OAuth account This will directly initiate the OAuth flow for Discord.
Returns
void
linkEmail
linkEmail: () =>
void
For users who are authenticated, opens the Privy modal and prompts the user to link an email. This will open the Privy Modal which will guide the user through this action.
Returns
void
linkFarcaster
linkFarcaster: () =>
void
For users who are authenticated, opens the Privy modal and prompts the user to link a Farcaster account. This will open the Privy Modal which will guide the user through this action.
Returns
void
linkGithub
linkGithub: () =>
void
For users who are authenticated, prompts the user to link Github OAuth account This will directly initiate the OAuth flow for Github.
Returns
void
linkGoogle
linkGoogle: () =>
void
For users who are authenticated, prompts the user to link a Google OAuth account. This will directly initiate the OAuth flow for Google.
Returns
void
linkInstagram
linkInstagram: () =>
void
For users who are authenticated, prompts the user to link Instagram OAuth account This will directly initiate the OAuth flow for Instagram.
Returns
void
linkLinkedIn
linkLinkedIn: () =>
void
For users who are authenticated, prompts the user to link LinkedIn OAuth account This will directly initiate the OAuth flow for LinkedIn.
Returns
void
linkPasskey
linkPasskey: () =>
void
For users who are authenticated, prompts the user to link a Passkey account This will open the Privy Modal which will guide the user through this action.
Returns
void
linkPhone
linkPhone: () =>
void
For users who are authenticated, opens the Privy modal and prompts the user to link a phone number. This will open the Privy Modal which will guide the user through this action.
Returns
void
linkSpotify
linkSpotify: () =>
void
For users who are authenticated, prompts the user to link Spotify OAuth account This will directly initiate the OAuth flow for Spotify.
Returns
void
linkTelegram
linkTelegram: (
options
?) =>void
For users who are authenticated, prompts the user to link a Telegram account This will directly initiate the auth flow for Telegram.
Parameters
• options?: Object
• options.launchParams?: Object
• options.launchParams.initDataRaw?: string
Returns
void
linkTiktok
linkTiktok: () =>
void
For users who are authenticated, prompts the user to link Tiktok OAuth account This will directly initiate the OAuth flow for Tiktok.
Returns
void
linkTwitter
linkTwitter: () =>
void
For users who are authenticated, prompts the user to link a Twitter OAuth account This will directly initiate the OAuth flow for Twitter.
Returns
void
linkWallet
linkWallet: () =>
void
For users who are authenticated, opens the Privy modal and prompts the user to link a wallet. This will open the Privy Modal which will guide the user through this action.
Returns
void
login
login: (
options
?) =>void
Opens the Privy login modal and prompts the user to login.
Parameters
• options?: MouseEvent
<any
, any
> | RuntimeLoginOverridableOptions
Returns
void
logout
logout: () =>
Promise
<void
>
Log the current user out and clears their authentication state. authenticated
will become false, user
will become null, and the Privy Auth tokens will be deleted from the browser's local storage.
You may await this call to take an action once logout is complete (e.g. redirecting to a specific page).
Returns
Promise
<void
>
mfaMethods
mfaMethods: (
"sms"
|"totp"
|"passkey"
)[]
The available mfa methods of this App
promptMfa
promptMfa: () =>
Promise
<void
>
Triggers the MFA verification flow if the user has an MFA method enrolled.
Returns
Promise
<void
>
Promise for triggering the MFA verification flow.
ready
ready:
boolean
Check whether the PrivyProvider
is ready to be used. You should wait for this to be true before using values such as authenticated
and user
.
sendTransaction
sendTransaction: (
input
,options
?) =>Promise
<Object
>
Prompts a user to send a transaction using their embedded wallet.
This method will error if the user is not authenticated or does not have an ethereum embedded wallet.
If no chainId
is specified as part of the UnsignedTransactionRequest, Privy will default to the embedded wallet's current chain ID.
If the config.embeddedWallets.showWalletUIs
property is set to false, the wallet will attempt to send the transaction without prompting the user. Otherwise (the default), Privy will show the user a modal to have them confirm the transaction. This can be customized via the SendTransactionModalUIOptions.
Parameters
• input: UnsignedTransactionRequest
UnsignedTransactionRequest transaction to be sent
• options?: Object
• options.address?: string
{optional} address for the embedded wallet signing the message. You should ONLY set this parameter if using imported embedded wallets or multiple HD embedded wallets for the same user. Defaults to the user's embedded wallet at HD index 0.
• options.fundWalletConfig?: FundWalletConfig
FundWalletConfig (optional) Funding configuration to specify chain and funding amount (if enabled), in the case of insufficient funds
• options.uiOptions?: SendTransactionModalUIOptions
SendTransactionModalUIOptions (optional) UI options to customize the transaction request modal
Returns
Promise
<Object
>
Promise for the transaction's hash as a hexadecimal string
hash
hash: `0x${string}`
setWalletPassword
setWalletPassword: () =>
Promise
<Wallet
>
@deprecated. Use setWalletRecovery
instead.
Set (or reset) a password on a wallet.
This method will error if the user does not have an embedded wallet or if the user exits in the middle of the flow.
Returns
Promise
<Wallet
>
Promise for the Wallet object for the updated embedded wallet
setWalletRecovery
setWalletRecovery: (
o
?) =>Promise
<Wallet
>
Prompt the user to enable wallet recovery. Current recovery options include password, Google Drive, and iCloud.
This method will error if the user does not have an embedded wallet, if the user's embedded wallet already has a cloud-based recovery set, or if the user exits in the middle of the flow.
Parameters
• o?: SetWalletRecoveryOptions
Returns
Promise
<Wallet
>
Promise for the Wallet object for the updated embedded wallet
signMessage
signMessage: (
input
,options
?) =>Promise
<Object
>
Prompts a user to sign a message using their embedded wallet using EIP-191's personal_sign
method (0x45).
This method will error if the user is not authenticated or does not have an embedded wallet.
If the config.embeddedWallets.showWalletUIs
property is set to false, the signature will be computed without prompting the user. Otherwise (the default), Privy will show the user a modal to prompt them for a signature. This can be customized via the SignMessageModalUIOptions.
Parameters
• input: Object
• input.message: string
{string} message to be signed
• options?: Object
• options.address?: string
{optional} address for the embedded wallet signing the message. You should ONLY set this parameter if using imported embedded wallets or multiple HD embedded wallets for the same user. Defaults to the user's embedded wallet at HD index 0.
• options.uiOptions?: SignMessageModalUIOptions
SignMessageModalUIOptions (optional) UI options to customize the signature prompt modal
Returns
Promise
<Object
>
Promise for the signature as a string
signature
signature:
string
signTransaction
signTransaction: (
input
,options
?) =>Promise
<Object
>
Prompts a user to sign a transaction using their embedded wallet.
This method will error if the user is not authenticated or does not have an ethereum embedded wallet.
If no chainId
is specified as part of the UnsignedTransactionRequest, Privy will default to the embedded wallet's current chain ID.
If the config.embeddedWallets.showWalletUIs
property is set to false, the wallet will attempt to sign the transaction without prompting the user. Otherwise (the default), Privy will show the user a modal to have them confirm the transaction. This can be customized via the SendTransactionModalUIOptions.
Parameters
• input: UnsignedTransactionRequest
UnsignedTransactionRequest transaction to be signed
• options?: Object
• options.address?: string
{optional} address for the embedded wallet signing the message. You should ONLY set this parameter if using imported embedded wallets or multiple HD embedded wallets for the same user. Defaults to the user's embedded wallet at HD index 0.
• options.uiOptions?: SendTransactionModalUIOptions
SendTransactionModalUIOptions (optional) UI options to customize the transaction request modal
Returns
Promise
<Object
>
Promise for the signature as a hexadecimal string
signature
signature: `0x${string}`
signTypedData
signTypedData: (
input
,options
?) =>Promise
<Object
>
Prompts a user to sign a message using their embedded wallet using EIP-712's eth_signTypedData_v4
.
This method will error if the user is not authenticated or does not have an embedded wallet.
Parameters
• input: SignTypedDataParams
{SignTypedDataParams} typed data payload to be signed
• options?: Object
• options.address?: string
{optional} address for the embedded wallet signing the message. You should ONLY set this parameter if using imported embedded wallets or multiple HD embedded wallets for the same user. Defaults to the user's embedded wallet at HD index 0.
• options.uiOptions?: SignMessageModalUIOptions
SignMessageModalUIOptions (optional) UI options to customize the signature prompt modal
Returns
Promise
<Object
>
Promise for the signature as a string
signature
signature:
string
submit
submit: (
mfaMethod
,mfaCode
) =>Promise
<void
>
Submit the MFA code for the current user. This will attempt to complete the MFA flow.
This will reject if:
- The verification attempt failed
- The max number of verification attempts has been reached
- The MFA attempt timed out
These errors can be caught and handled accordingly using the error helpers errorIndicatesMfaVerificationFailed
, errorIndicatesMaxMfaRetries
, errorIndicatesMfaTimeout
exported from 'react-auth'.
Parameters
• mfaMethod: "sms"
| "totp"
| "passkey"
• mfaCode: string
| PublicKeyCredentialRequestOptionsJSON
{string} The MFA code to submit.
Returns
Promise
<void
>
Promise for the MFA code submission.
submitEnrollmentWithPasskey
submitEnrollmentWithPasskey: (
meta
) =>Promise
<void
>
Submit the passkey to complete the enrollment process.
Parameters
• meta: Object
{credentialIds: string[]} The passkey credentialIds to enroll in MFA.
• meta.credentialIds: string
[]
Returns
Promise
<void
>
Promise for the MFA code submission.
submitEnrollmentWithSms
submitEnrollmentWithSms: (
meta
) =>Promise
<void
>
Submit the MFA code to complete SMS enrollment process.
Parameters
• meta: Object
{phoneNumber: string; mfaCode: string} The MFA code and phone number to submit.
• meta.mfaCode: string
• meta.phoneNumber: string
Returns
Promise
<void
>
Promise for the MFA code submission.
submitEnrollmentWithTotp
submitEnrollmentWithTotp: (
meta
) =>Promise
<void
>
Submit the MFA code to complete TOTP enrollment process.
Parameters
• meta: Object
{mfaCode: string} The MFA code.
• meta.mfaCode: string
Returns
Promise
<void
>
Promise for the MFA code submission.
unenroll
unenroll: (
method
) =>Promise
<void
>
Remove the MFA method for the current user.
Parameters
• method: "sms"
| "totp"
| "passkey"
MfaMethod The MFA method to remove for the current user.
Returns
Promise
<void
>
Promise for removing the MFA method for the current user.
unlinkApple
unlinkApple: (
subject
) =>Promise
<User
>
Unlink a Apple social account from a user, by passing the apple subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} apple account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Apple account has been unlinked
unlinkCrossAppAccount
unlinkCrossAppAccount: (
subject
) =>Promise
<User
>
Unlink a cross-app account from a user, by passing the apple subject ID. Note that you can only unlink this account if the user has at least one other account.
Parameters
• subject: Object
{string} apple account's subject ID
• subject.subject: string
Returns
Promise
<User
>
Promise for the User object after the provided cross-app account has been unlinked
unlinkDiscord
unlinkDiscord: (
subject
) =>Promise
<User
>
Unlink a Discord social account from a user, by passing the discord subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} discord account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Discord account has been unlinked
unlinkEmail
unlinkEmail: (
address
) =>Promise
<User
>
Unlink an email account from a user, by passing the email address. Note that you can only unlink an email account if the user has at least one other account.
Parameters
• address: string
{string} email address to be unlinked
Returns
Promise
<User
>
Promise for the User object after the provided email has been unlinked
unlinkFarcaster
unlinkFarcaster: (
fid
) =>Promise
<User
>
Unlink a Farcaster account from a user, by passing the FID. Note that you can only unlink a phone account if the user has at least one other account.
Parameters
• fid: number
{number} Farcaster ID
Returns
Promise
<User
>
Promise for the User object after the provided Farcaster account has been unlinked
unlinkGithub
unlinkGithub: (
subject
) =>Promise
<User
>
Unlink a Github social account from a user, by passing the github subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} github account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Github account has been unlinked
unlinkGoogle
unlinkGoogle: (
subject
) =>Promise
<User
>
Unlink a Google social account from a user, by passing the google subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} google account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Google account has been unlinked
unlinkInstagram
unlinkInstagram: (
subject
) =>Promise
<User
>
Unlink a Instagram social account from a user, by passing the instagram subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} instagram account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Instagram account has been unlinked
unlinkLinkedIn
unlinkLinkedIn: (
subject
) =>Promise
<User
>
Unlink a LinkedIn social account from a user, by passing the linkedin subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} linkedin account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided LinkedIn account has been unlinked
unlinkPasskey
unlinkPasskey: (
credentialId
) =>Promise
<User
>
Unlink a Passkey account from a user, by passing the credential ID. Note that you can only unlink a passkey account if the user has at least one other account.
Parameters
• credentialId: string
{string} Passkey Credential ID
Returns
Promise
<User
>
Promise for the User object after the provided passkey account has been unlinked
unlinkPhone
unlinkPhone: (
phoneNumber
) =>Promise
<User
>
Unlink a phone account from a user, by passing the phone number. Note that you can only unlink a phone account if the user has at least one other account.
Parameters
• phoneNumber: string
{string} phone number to be unlinked
Returns
Promise
<User
>
Promise for the User object after the provided phone number has been unlinked
unlinkSpotify
unlinkSpotify: (
subject
) =>Promise
<User
>
Unlink a Spotify social account from a user, by passing the spotify subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} spotify account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Spotify account has been unlinked
unlinkTelegram
unlinkTelegram: (
telegramUserId
) =>Promise
<User
>
Unlink a Telegram account from a user, by passing the Telegram subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• telegramUserId: string
{string} Telegram user ID of the linked account
Returns
Promise
<User
>
Promise for the User object after the provided Telegram account has been unlinked
unlinkTiktok
unlinkTiktok: (
subject
) =>Promise
<User
>
Unlink a Tiktok social account from a user, by passing the tiktok subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} tiktok account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Tiktok account has been unlinked
unlinkTwitter
unlinkTwitter: (
subject
) =>Promise
<User
>
Unlink a Twitter social account from a user, by passing the twitter subject ID. Note that you can only unlink a social account if the user has at least one other account.
Parameters
• subject: string
{string} twitter account's subject ID
Returns
Promise
<User
>
Promise for the User object after the provided Twitter account has been unlinked
unlinkWallet
unlinkWallet: (
address
) =>Promise
<User
>
Unlink a wallet account from a user, by passing the public address. Note that you can only unlink a wallet account if the user has at least one other account. If the unlinked wallet was the active one, and more wallets are linked to the user, then we attempt to make the most recently linked wallet active.
Parameters
• address: string
{string} wallet address to be unlinked
Returns
Promise
<User
>
Promise for the User object after the provided wallet has been unlinked
updateEmail
updateEmail: () =>
void
For users who are authenticated and have already linked an email address, prompts the user to update their email address. This will open the Privy Modal which will guide the user through this action.
Returns
void
updatePhone
updatePhone: () =>
void
For users who are authenticated and have already linked a phone number, prompts the user to update their phone number. This will open the Privy Modal which will guide the user through this action.
Returns
void
user
user:
null
|User
The user object, or null if the user is not authenticated.