Search code examples
firebaseangulargoogle-oauthgoogle-admin-sdkgoogle-directory-api

How to recognise an existing Google OAuth authentication made via Firebase and perform a Google Directory API request in Angular 2?


I want to use my existing authentication and be able to use that same authentication to perform a get request to the Google Directory API. Here's my current code:

login() {
    this.firebaseRef = new Firebase('https://xxx.firebaseio.com');
    this.firebaseRef.authWithOAuthPopup("google", (error, authData) => {
        if (error) {
            console.log("Login Failed!", error);
        } else {
            console.log("Authenticated successfully with payload:", authData);
        }
    }, {
            scope: "https://www.googleapis.com/auth/admin.directory.user.readonly"
    });
}

getData() {
    // TO-DO
    // Recognise existing OAuth and perform a GET request to
    // https://www.googleapis.com/admin/directory/v1/users?domain=nunoarruda.com
}

Solution

  • I've found the solution. I need to use the current access token in the http request headers for the GET request.

    import {Http, Headers} from 'angular2/http';

    getData() {
        // get access token
        let authData = this.firebaseRef.getAuth();
        let oauthToken = authData.google.accessToken;
        console.log(oauthToken);
    
        // set authorization on request headers
        let headers = new Headers();
        headers.append('Authorization', 'Bearer ' + oauthToken);
    
        // api request
        this.http.get('https://www.googleapis.com/admin/directory/v1/users?domain=nunoarruda.com',{headers: headers}).subscribe((res) => {
            console.log(res.json());
        });
    }