Reading time: 5 minutes
Today, we are going to learn how to implement Google authentication in our React Native app.
data:image/s3,"s3://crabby-images/b3864/b3864fd2ec6cc8d3645ea144439d3ccb0252c729" alt=""
Once we have our initialized React Native project, we will use the library (https://docs.expo.dev/versions/latest/sdk/auth-session/).
First of all, open app.json and add the fields “name” and “slug“:
"expo": { "name": "App_name", "slug": "App_name",
And within app.json, in the iOS section:
"ios": { "bundleIdentifier": "com.app_name",
We also need to add the package in Android:
"android": { "package": "com.app_name",
Now, we need to sign in to the Google Developer Center (https://cloud.google.com/developers?hl=en):
data:image/s3,"s3://crabby-images/dac5e/dac5ea4c32b374e781dfee683837ef87de26828b" alt=""
Click on > Get Started for Free and join.
Once inside, click on Console.
Within the console, you need to create a new project. Click on the box that appears at the top left corner, where it says Google Cloud (in my case, there is already a project):
data:image/s3,"s3://crabby-images/9b41b/9b41b714cb1c82301dde0a8dbb71d26d65888787" alt=""
A new window will open, and you can choose “New Project”:
data:image/s3,"s3://crabby-images/337bd/337bd74d0cae3fff6df751ac30f33b02bac5524d" alt=""
Now, add the desired name and click on Create.
Once created, select your project.
Now click on the navigation menu:
data:image/s3,"s3://crabby-images/7c94c/7c94c98836addc5fa0a7082aff7a92860168e7fc" alt=""
Today we are going to see how we can implement Google authentication in our React Native app.
data:image/s3,"s3://crabby-images/b3864/b3864fd2ec6cc8d3645ea144439d3ccb0252c729" alt=""
Assuming our React Native project is initialized, we’re going to use the library (https://docs.expo.dev/versions/latest/sdk/auth-session/ ).
First, open app.json and add the fields ““name” and ““slug”:
"expo": { "name": "App_Name", "slug": "App_Name",
And inside app.json in the iOS section:
"ios": { "bundleIdentifier": "com.app_name",
You also need to add the package in Android:
"android": { "package": "com.app_name",
Now, you need to sign in to the Google Developer Console (https://cloud.google.com/developers?hl=en):
data:image/s3,"s3://crabby-images/dac5e/dac5ea4c32b374e781dfee683837ef87de26828b" alt=""
Click on > Get Started for Free and join.
Once inside, click on Console.
Inside the console, you need to create a new project. Click on the drawer that appears in the top left corner of the title where it says Google Cloud (in my case, there is already a project):
data:image/s3,"s3://crabby-images/9b41b/9b41b714cb1c82301dde0a8dbb71d26d65888787" alt=""
A new window will open, and you can choose “New Project”:
data:image/s3,"s3://crabby-images/337bd/337bd74d0cae3fff6df751ac30f33b02bac5524d" alt=""
Now add the desired name and click on Create.
Once created, select your project.
Now click on the navigation menu:
data:image/s3,"s3://crabby-images/7c94c/7c94c98836addc5fa0a7082aff7a92860168e7fc" alt=""
Choose APIs & Services and then Credentials.
data:image/s3,"s3://crabby-images/9196c/9196c23f12117079f1ab521f308c1611ad85a5ff" alt=""
Click on Create Credentials and choose OAuth client ID.
Choose Android or iOS, depending on your needs.
Enter the name of your app and the package name (com.app_name):
data:image/s3,"s3://crabby-images/74d2d/74d2d04fc95aff06e738879d1bd5039b46822335" alt=""
Click on Create.
You will receive your Client ID and Client Secret. Save them for later use.
data:image/s3,"s3://crabby-images/cc6f4/cc6f43be3c16cd9b36f21548ceda50646e23207a" alt=""
Now let’s install the necessary packages:
expo install expo-google-app-auth expo-constants
Open the file where you want to implement the authentication (for example, App.js) and import the necessary packages:
import * as Google from 'expo-google-app-auth'; import Constants from 'expo-constants';
Now we will create a function for Google authentication:
const signInWithGoogleAsync = async () => { try { const config = { iosClientId: Constants.manifest.extra.iosClientId, androidClientId: Constants.manifest.extra.androidClientId, scopes: ['profile', 'email'], }; const { type, accessToken, user } = await Google.logInAsync(config); if (type === 'success') { // User successfully authenticated console.log('User authenticated!', user); // You can now do something with the user data } else { // Authentication failed console.log('Authentication failed!'); } } catch (error) { console.log('Error: ', error.message); } };
Add a button or any other UI element to trigger the authentication process:
That’s it! Now you have implemented Google authentication in your React Native app.
Remember to replace App_Name
with the actual name of your app and com.app_name
with the appropriate package name.
PIPE
data:image/s3,"s3://crabby-images/dcda1/dcda1869d3b0ea466fe645d8fc18f277ea25d855" alt=""