Appearance
Quickstart
Get started with Privy's Expo SDK in the 5 quick steps below.
0. Prerequisites
In order to integrate the Privy Expo SDK, you must:
- Have an Expo project set up and running, using the latest version.
- Target the iOS and Android platforms. The Privy Expo SDK does not have Web support.
WARNING
If you are using a bare React Native project, you will need to install Expo modules.
1. Install the Privy Expo SDK and its dependencies
Core dependencies
Install the latest version of the Privy Expo SDK along with its peer dependencies using expo
:
sh
npx expo install expo-application expo-constants expo-web-browser expo-linking expo-secure-store react-native-webview expo-crypto @privy-io/expo-native-extensions @privy-io/expo
Polyfills
Install polyfills which account for APIs required by the Privy Expo SDK that are not available in the React Native environment.
sh
npm i fast-text-encoding react-native-get-random-values @ethersproject/shims
If your app uses the Expo bare workflow ("React Native without Expo"), the following must also be run.
sh
npx pod install
2. Import the required polyfills
Next, import the required polyfills that you installed above into your app. The placement of these imports depends on whether your app uses expo/router
or not; please make sure to follow the appropriate instructions below.
TIP
You must import polyfills in the exact order specified below to use them in your application.
If your app uses expo/router
, required polyfills must come before the Expo router entrypoint.
To do this, import the required polyfills into a new file called entrypoint.js
, and update your package.json
's main
property to point to entrypoint.js
:
js
// Import required polyfills first
import 'fast-text-encoding';
import 'react-native-get-random-values';
import '@ethersproject/shims';
// Then import the expo router
import 'expo-router/entry';
json
{
"name": "<your app name>",
"main": "expo-router/entry",
"main": "entrypoint.js"
}
INFO
If you're using the @solana/web3.js
package, please follow the Solana–RN guide.
In particular, make sure to add the buffer
dependency
sh
npm i buffer
and type the following right after the react-native-get-random-values
import:
js
import 'react-native-get-random-values';
import {Buffer} from 'buffer';
global.Buffer = Buffer;
3. Get your Privy app ID and client ID
Configure your Privy app and client IDs in the Privy Dashboard.
The app and client IDs serve as an API key used to initialize the Privy Expo SDK. These values can be safely exposed in a client-side environment.
4. Import Privy into your app
In your project, import the PrivyProvider
component and wrap your app with it. Set the appId
and clientId
props to the app ID and client ID you got from the Dashboard in step 3.
Concretely, the PrivyProvider
must wrap any component or page that will use the Privy Expo SDK. It is generally recommended to render it as close to the root of your application as possible. This should likely go either an App.tsx
or a _layout.tsx
file depending on your setup.
Wrap your app with the PrivyProvider
in the app/_layout.tsx
file.
tsx
import {PrivyProvider} from '@privy-io/expo';
import {Stack} from 'expo-router';
export default function RootLayout() {
return (
<PrivyProvider
// Render the PrivyProvider with your app ID and app client ID
appId={'insert-your-privy-app-id'}
clientId={'insert-your-privy-app-client-id'}
>
<Stack />
</PrivyProvider>
);
}
5. Just use Privy! 🎉
TIP
To see an example application that has the Privy Expo SDK configured, check out our Expo starter repo!
Once you've wrapped your app with the PrivyProvider
, you can now use the Privy Expo SDK throughout your components and screens via the provided hooks!
Check out our starter repo to see what a simple end-to-end integration looks like, or read on to learn how you can use Privy to:
and to do so much more!