SIWN: React Native
In this guide, we’ll take a look at how to add sign-in with neynar to a React native application!
Setting up your application
Prerequisites
- Node.js: A JavaScript runtime built on Chrome’s V8 JavaScript engine. Ensure you have Node.js installed on your system.
- Expo Go: Install Expo Go on your phone
Cloning the repo
Clone the repo from GitHub using the following command and open it up in your favourite code editor using the following commands:
Once you’ve cloned your repo we can start installing the packages and setting up the env variables!
Server
Navigate to server directory
Navigate to the server directory
Install Project Dependencies
Based on the package manager run one of the following commands to install all required dependencies:
Configure Environment Variables
Copy the example environment file:
Edit .env
to add your NEYNAR_API_KEY
and NEYNAR_CLIENT_ID
. You can find them in your dashboard
Start the server
Start the server:
Client
Open new terminal
Navigate to client directory
Navigate to the client directory
Install Project Dependencies
Based on the package manager run one of the following commands to install all required dependencies:
For yarn
For npm
Configure Environment Variables
Copy the example environment file:
- Edit
.env
to add yourCOMPUTER_IP_ADDRESS
. Refer find-IP-address article to get the IP address of your Computer.
Start the app
Make sure your phone and computer is connected to the same network
For yarn
For npm
you’ll see a QR Code
Run App
Open the Expo Go app on your phone and scan the QR Code. You should now be able to see a button to sign in with neynar in your app!
How does it work?
You’re probably wondering how it all works, so let’s break it down!
Server
In our server, we have 3 API routes, you can take a look at them in server/index.js
:
/get-auth-url
(GET): This API route gets the authorization URL using thefetchAuthorizationUrl
function from the neynar client./user
(GET): This API route takes in the fid as a query parameter and returns the user data like display name and pfp url using thefetchBulkUsers
function./cast
(POST): This API route takes in the signer UUID and text in the body and publishes the cast on behalf of the user using thepublishCast
function.
Client
On the client side, we use the NeynarSigninButton
component from the @neynar/react-native-signin
package and pass in a bunch of props like fetchAuthorizationUrl
, successCallback
, errorCallback
, and redirectUrl
.
- For
fetchAuthorizationUrl
we fetch the url from our server and then pass it. - For
successCallback
we are creating a functionContext/AppContext.ts
that fetches the user info from the backend and safely stores it. - For
errorCallBack
we simply just console log the error. - For
redirectURL
we are using a URL of the formatexp://${COMPUTER_IP_ADDRESS}:8081
. TheCOMPUTER_IP_ADDRESS
is the one you added in your.env
file - There are also a lot of customisation options that you can find commented out in the
Signin.tsx
file.
Conclusion
This guide taught us how to add sign-in with neynar to a React native app, check out the GitHub repository.
Lastly, make sure to sure what you built with us on Farcaster by tagging @neynar and if you have any questions, reach out to us on warpcast or Telegram!
Was this page helpful?