Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to determine if the user signed in to Firebase with email and password or with google sign in?

I am working on a log in for a web application, and I have made it so the user can sign in manually with their email and password or by using a google sign in. Is there a way to determine which method they used? Preferably by using the Firebase authentication state change function.

`firebase.auth().onAuthStateChanged(firebaseUser => {....`

I know you can tell how they signed in when you go into the Firebase console log but is there a way to determine it using JavaScript code?

When using firebase.auth().currentUser.providerData the following: enter image description here

like image 666
Evan Avatar asked Nov 10 '17 14:11

Evan


3 Answers

@mjrdnk's answer is correct, but there is a caveat, a user could have multiple providers linked. So using firebase.auth().currentUser.providerData[0].providerId will always yield the same provider even when another linked provider was used to sign in. The most accurate way to determine the current provider used to sign is by inspecting the ID token's field: firebase.sign_in_provider.

like image 68
bojeil Avatar answered Sep 25 '22 15:09

bojeil


You can determine by using currentUser https://firebase.google.com/docs/reference/js/firebase.UserInfo

Like this:

firebase.auth().currentUser.providerData[0].providerId

Hope this helps.

like image 21
mjrdnk Avatar answered Sep 23 '22 15:09

mjrdnk


Currently @mjdnk asnwer depracated, because it will gives always first provider not the last logged in.

So most recent solution is:

As noted here

var uiConfig = {
        callbacks: {
          signInSuccessWithAuthResult: function(authResult, redirectUrl) {
            var providerId = authResult.additionalUserInfo.providerId;
            localStorage.setItem("firebaseProviderId", providerId)
            //...
          },
          //..
       }

and for display in page

firebase.auth().onAuthStateChanged(function (user) {
      if (user) {
        user.getIdToken().then(function (idToken) {

          $('#user').text(welcomeName + "(" + localStorage.getItem("firebaseProviderId")+ ")");
          $('#logged-in').show();
        }
    }
});
like image 20
asdf_enel_hak Avatar answered Sep 25 '22 15:09

asdf_enel_hak