DEV Community

Cover image for Secure and Simple: Integrating OAuth in Angular with Google Sign-In
chintanonweb
chintanonweb

Posted on

Secure and Simple: Integrating OAuth in Angular with Google Sign-In

Implement Google Sign-In (OAuth) in Your Angular App: A Step-by-Step Guide

Introduction:

In today's digital age, providing seamless authentication experiences is crucial for web applications. Google Sign-In, powered by OAuth, offers a secure and convenient way for users to access your Angular app with their Google credentials. In this comprehensive guide, we'll walk through the process of integrating Google Sign-In into your Angular application, covering all scenarios and providing detailed examples along the way.

Step 1: Set Up Google Developer Console

Before diving into Angular code, we need to set up our project in the Google Developer Console:

  1. Go to the Google Developer Console.
  2. Create a new project or select an existing one.
  3. Navigate to the "Credentials" tab.
  4. Click on "Create credentials" and select "OAuth client ID".
  5. Choose "Web application" as the application type.
  6. Add your Angular app's domain to the authorized JavaScript origins.
  7. Save your client ID for later use.

Step 2: Install Required Dependencies

Next, let's install the necessary packages for Google Sign-In integration in Angular:

npm install angularx-social-login
Enter fullscreen mode Exit fullscreen mode

Step 3: Configure Google Sign-In Service

Now, we'll create a service to handle Google Sign-In functionality:

// google-signin.service.ts

import { Injectable } from '@angular/core';
import { SocialAuthService, GoogleLoginProvider, SocialUser } from 'angularx-social-login';

@Injectable({
  providedIn: 'root'
})
export class GoogleSigninService {

  constructor(private authService: SocialAuthService) { }

  signInWithGoogle(): Promise<SocialUser> {
    return this.authService.signIn(GoogleLoginProvider.PROVIDER_ID);
  }

  signOut(): Promise<void> {
    return this.authService.signOut();
  }
}
Enter fullscreen mode Exit fullscreen mode

Step 4: Implement Sign-In Button

Now, let's add a sign-in button to our Angular component:

<!-- login.component.html -->

<button (click)="signInWithGoogle()">Sign in with Google</button>
Enter fullscreen mode Exit fullscreen mode

Step 5: Handle Sign-In Callback

In your Angular component, handle the sign-in callback and store user information:

// login.component.ts

import { Component } from '@angular/core';
import { GoogleSigninService } from './google-signin.service';

@Component({
  selector: 'app-login',
  templateUrl: './login.component.html',
  styleUrls: ['./login.component.css']
})
export class LoginComponent {

  constructor(private googleSigninService: GoogleSigninService) { }

  signInWithGoogle(): void {
    this.googleSigninService.signInWithGoogle()
      .then(user => {
        // Handle successful sign-in
        console.log(user);
      })
      .catch(error => {
        // Handle sign-in error
        console.error(error);
      });
  }
}
Enter fullscreen mode Exit fullscreen mode

Step 6: Add Sign-Out Option

To allow users to sign out, implement a sign-out button in your component:

<!-- login.component.html -->

<button (click)="signOut()">Sign out</button>
Enter fullscreen mode Exit fullscreen mode
// login.component.ts

import { Component } from '@angular/core';
import { GoogleSigninService } from './google-signin.service';

@Component({
  selector: 'app-login',
  templateUrl: './login.component.html',
  styleUrls: ['./login.component.css']
})
export class LoginComponent {

  constructor(private googleSigninService: GoogleSigninService) { }

  signInWithGoogle(): void {
    // Same as Step 5
  }

  signOut(): void {
    this.googleSigninService.signOut()
      .then(() => {
        // Handle sign-out success
        console.log('Signed out successfully');
      })
      .catch(error => {
        // Handle sign-out error
        console.error('Error signing out:', error);
      });
  }
}
Enter fullscreen mode Exit fullscreen mode

FAQ:

  1. Q: Can I customize the Google Sign-In button?
    A: Yes, you can customize the appearance of the button using CSS to match your app's design.

  2. Q: How can I access user information after sign-in?
    A: You can access user information through the SocialUser object returned by the sign-in method.

  3. Q: Is it possible to restrict access to certain users?
    A: Yes, you can restrict access based on the user's email or other criteria in your Angular application logic.

  4. Q: Can I integrate Google Sign-In with other authentication methods?
    A: Yes, you can integrate Google Sign-In with other authentication methods like JWT or Firebase Authentication for a comprehensive authentication solution.

  5. Q: Are there any security considerations to keep in mind?
    A: Ensure that your Angular app uses HTTPS to prevent man-in-the-middle attacks, and always validate user inputs and tokens on the server-side.

Conclusion:

Integrating Google Sign-In into your Angular application enhances user experience and security. By following the steps outlined in this guide, you can seamlessly implement OAuth-based authentication and provide your users with a convenient way to access your app. Remember to adhere to best practices and consider additional security measures to safeguard user data. Happy coding!

Top comments (0)