Skip to content

Documentation / react-auth / PrivyEvents

Interface: PrivyEvents ​

Properties ​

accessToken ​

accessToken: Object

Type declaration ​

onAccessTokenGranted ​

onAccessTokenGranted: (params) => void

Callback that will execute when a user's access token is granted.

Parameters ​

• params: Object

• params.accessToken: string

The user's access token

Returns ​

void

onAccessTokenRemoved ​

onAccessTokenRemoved: () => void

Callback that will execute when a user's access token is removed.

Returns ​

void


configureMfa ​

configureMfa: Object

Type declaration ​

onMfaRequired ​

onMfaRequired: (params) => void

Callback that will execute when MFA is required to complete a given action.

Parameters ​

• params: Object

• params.mfaMethods: ("sms" | "totp" | "passkey")[]

[] - List of MFA methods that the user can choose from

Returns ​

void


connectOrCreateWallet ​

connectOrCreateWallet: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful wallet connection.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful connectWallet completes. This will not run in the case of a wallet-based authentication or link flow.

Parameters ​

• params: Object

• params.wallet: BaseConnectedEthereumWallet | BaseConnectedSolanaWallet

[BaseConnectedEthereumWallet | BaseConnectedSolanaWallet]([object Object]) the wallet object correspending to the connection

Returns ​

void


connectWallet ​

connectWallet: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful wallet connection.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful connectWallet completes. This will not run in the case of a wallet-based authentication or link flow.

Parameters ​

• params: Object

• params.wallet: BaseConnectedEthereumWallet | BaseConnectedSolanaWallet

[BaseConnectedEthereumWallet | BaseConnectedSolanaWallet]([object Object]) the wallet object correspending to the connection

Returns ​

void


createWallet ​

createWallet: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful wallet creation.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once on a successful embedded wallet creation. This will run when createWallet is called manually, or when config.embeddedWallets.createOnLogin triggers an automatic wallet creation.

Parameters ​

• params: Object

• params.wallet: Wallet

BaseConnectedWallet- the created wallet object

Returns ​

void


customAuth ​

customAuth: Object

Type declaration ​

onAuthenticated ​

onAuthenticated: (params) => void

Callback that will execute when Privy successfully exchanges a custom auth JWT for a Privy JWT

Parameters ​

• params: Object

• params.user: User

The Privy user

Returns ​

void

onUnauthenticated ​

onUnauthenticated: () => void

Callback that will execute when Privy detects a user is logged out from the third-party auth system, and correspondingly logs the user out.

Returns ​

void


fundSolanaWallet ​

fundSolanaWallet: Object

Type declaration ​

onUserExited? ​

onUserExited?: (params) => void

Callback that will execute when a funding flow is exited. This fires when a user closes a funding flow modal, for any reason.

Parameters ​

• params: Object

• params.address: string

{string} The address of the wallet being funded

• params.balance: undefined | bigint

{bigint} The value for the funded wallet at the point of user exit.

• params.cluster: SolanaCluster

{SolanaCluster} The Solana cluster of the wallet being funded

• params.fundingMethod: null | FundingMethod | "manual"

[FundingMethod]([object Object]) The funding method associated with the flow at time of exit. If the user had not yet selected a recovery method, this will be null.

Returns ​

void


fundWallet ​

fundWallet: Object

Type declaration ​

onUserExited? ​

onUserExited?: (params) => void

Callback that will execute when a funding flow is exited. This fires when a user closes a funding flow modal, for any reason.

Parameters ​

• params: Object

• params.address: string

{string} The address of the wallet being funded

• params.balance: undefined | bigint

{bigint} The value for the funded wallet at the point of user exit.

• params.chain: Chain

{Chain} The chain of the wallet being funded

• params.fundingMethod: null | FundingMethod | "manual"

[FundingMethod]([object Object]) The funding method associated with the flow at time of exit. If the user had not yet selected a recovery method, this will be null.

Returns ​

void


linkAccount ​

linkAccount: Object

Type declaration ​

onError? ​

onError?: (error, details) => void

Callback that will execute in the case of a non-successful account linking.

Parameters ​

• error: PrivyErrorCode

{PrivyErrorCode} - the corresponding error code

• details: Object

• details.linkMethod: LoginMethod

{LoginMethod} - the type of (attempted) linked account

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once on a successful linking of a new account/login method. This will run when any of the 'link' methods are called manually.

Parameters ​

• params: Object

• params.linkMethod: LoginMethod

[LoginMethod]([object Object])- the type of linked account

• params.linkedAccount: LinkedAccountWithMetadata

the newly linked account

• params.user: User

User- the user the account was linked to

Returns ​

void


login ​

login: Object

Type declaration ​

onComplete? ​

onComplete?: (params) => void

Callback that will execute once a login flow successfully completes.

  • If config.embeddedWallets.createOnLogin is set to 'off' or a wallet creation flow is not applicable, this will run after the user successfully authenticates.
  • If config.embeddedWallets.createOnLogin is set to 'users-without-wallets' or 'all-users', this will run after the user successfully authenticates and creates their wallet (if applicable).
  • If a user is already authenticated, this will run immediately and the wasAlreadyAuthenticated flag will be set to true.
Parameters ​

• params: Object

• params.isNewUser: boolean

{boolean} boolean flag indicating if this is the user's first time logging in to your app

• params.loginAccount: null | LinkedAccountWithMetadata

the account corresponding to the loginMethod used

• params.loginMethod: null | LoginMethod

{string} - the method used by the user to login

• params.user: User

User the user oject corresponding to the authenticated user

• params.wasAlreadyAuthenticated: boolean

{boolean} - boolean flag indicating whether the user entered the application already authenticated

Returns ​

void

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful login.

Parameters ​

• error: PrivyErrorCode

PrivyErrorCode - the corresponding error code

Returns ​

void


logout ​

logout: Object

Type declaration ​

onSuccess? ​

onSuccess?: () => void

Callback that will execute when a user successfully logs out.

Returns ​

void


oAuthAuthorization ​

oAuthAuthorization: Object

Type declaration ​

onOAuthTokenGrant ​

onOAuthTokenGrant: (params) => void

Callback that will execute when a user successfully authorizes an OAuth flow.

Parameters ​

• params: Object

• params.oAuthTokens: OAuthTokens

OAuthTokens - the OAuth tokens returned from the OAuth provider:

• params.user: User

User The authenticated user

Returns ​

void


sendSolanaTransaction ​

sendSolanaTransaction: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful sendTransaction.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful sendSolanaTransaction completes. This will not run in the case of a wallet-based authentication or link flow.

Parameters ​

• params: Object

• params.response: SolanaTransactionReceipt

the response SolanaTransactionReceipt from the successful transaction

Returns ​

void


sendTransaction ​

sendTransaction: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful sendTransaction.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful sendTransaction completes. This will not run for transactions with external wallets.

Parameters ​

• params: Object

• params.hash: `0x${string}`

Returns ​

void


setWalletPassword ​

setWalletPassword: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful setWalletPassword.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful setWalletPassword completes.

Parameters ​

• params: Object

• params.wallet: Wallet

Wallet- the wallet object that the password was set for

Returns ​

void


setWalletRecovery ​

setWalletRecovery: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful setWalletRecovery.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful setWalletRecovery completes.

Parameters ​

• params: Object

• params.method: UserRecoveryMethod

[UserRecoveryMethod]([object Object]) - the recovery method that was set

• params.wallet: Wallet

Wallet- the wallet object that the recovery was set for

Returns ​

void


signMessage ​

signMessage: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful signMessage.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful signMessage completes. This will not run in the case of a wallet-based authentication or link flow.

Parameters ​

• params: Object

• params.signature: string

the signature (type string) of the embedded wallet used to sign message

Returns ​

void


signSolanaMessage ​

signSolanaMessage: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful signSolanaMessage.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful signSolanaMessage completes. This will not run in the case of a wallet-based authentication or link flow.

Parameters ​

• params: Object

• params.signature: Uint8Array

Returns ​

void


signSolanaTransaction ​

signSolanaTransaction: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful sendTransaction.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful signSolanaTransaction completes. This will not run in the case of a wallet-based authentication or link flow.

Parameters ​

• params: Object

• params.signedTransaction: SupportedSolanaTransaction

Returns ​

void


signTransaction ​

signTransaction: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful signTransaction.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful signTransaction completes. This will not run for transactions with external wallets.

Parameters ​

• params: Object

• params.signature: `0x${string}`

Returns ​

void


signTypedData ​

signTypedData: Object

Type declaration ​

onError? ​

onError?: (error) => void

Callback that will execute in the case of a non-successful signTypedData.

Parameters ​

• error: PrivyErrorCode

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once a successful signTypedData completes.

Parameters ​

• params: Object

• params.signature: string

the signature (type string) of the embedded wallet used to sign

Returns ​

void


update ​

update: Object

Type declaration ​

onError? ​

onError?: (error, details) => void

Callback that will execute in the case of a non-successful account linking.

Parameters ​

• error: PrivyErrorCode

{PrivyErrorCode} - the corresponding error code

• details: Object

• details.linkMethod: LoginMethod

{LoginMethod} - the type of (attempted) linked account

Returns ​

void

onSuccess? ​

onSuccess?: (params) => void

Callback that will execute once on a successful updating of an account. This will run when any of the 'updateAccount' methods are called manually.

Parameters ​

• params: Object

• params.updateMethod: LoginMethod

[LoginMethod]([object Object])- the type of updated account

• params.updatedAccount: LinkedAccountWithMetadata

the newly updated account

• params.user: User

User- the user the account was linked to

Returns ​

void