Firebase/React: currentUser is null after Sign In with Google redirect and reload












0















I'm using the Google's pre-build firebaseui to do authentication in create-react-app.



I have the onAuthStateChanged function set up in componentDidMount.



componentDidMount() {
firebase.auth().onAuthStateChanged((user) => {
console.log('Auth state changed');
console.log('user: ',user);
if (user) {
this.setState({user: user});
} else {
this.setState({user: null});
}
});


}



I use this.state.user in render to show different UI elements depending on whether or not they're logged in. I also log the currentUser:



render() {
console.log('render currentUser: ',firebase.auth().currentUser);
...


Here's what happens when I try to log in with firebaseui:



1) Click the Log In button which displays FirebaseUI.



2) Select Sign In with Google



enter image description here



3) The page is redirected to a Google auth page, then redirects back to my app



4) After the reload I see these console logs:



render currentUser: null
Auth state changed
user: null
render currentUser: null


5) Click the Log In button again



6) FirebaseUI shows a blank window with a loading indicator at the top, then closes. There is no redirect.



enter image description here



7) Console output:



render currentUser: null
Auth state change
user: {firebase user object...}
render currentUser: {firebase user object...}


It's like Firebase has the auth information stored somewhere, but it isn't being pulled up when the app loads. How can I get Firebase to recognize the user is logged in when the page first reloads?










share|improve this question





























    0















    I'm using the Google's pre-build firebaseui to do authentication in create-react-app.



    I have the onAuthStateChanged function set up in componentDidMount.



    componentDidMount() {
    firebase.auth().onAuthStateChanged((user) => {
    console.log('Auth state changed');
    console.log('user: ',user);
    if (user) {
    this.setState({user: user});
    } else {
    this.setState({user: null});
    }
    });


    }



    I use this.state.user in render to show different UI elements depending on whether or not they're logged in. I also log the currentUser:



    render() {
    console.log('render currentUser: ',firebase.auth().currentUser);
    ...


    Here's what happens when I try to log in with firebaseui:



    1) Click the Log In button which displays FirebaseUI.



    2) Select Sign In with Google



    enter image description here



    3) The page is redirected to a Google auth page, then redirects back to my app



    4) After the reload I see these console logs:



    render currentUser: null
    Auth state changed
    user: null
    render currentUser: null


    5) Click the Log In button again



    6) FirebaseUI shows a blank window with a loading indicator at the top, then closes. There is no redirect.



    enter image description here



    7) Console output:



    render currentUser: null
    Auth state change
    user: {firebase user object...}
    render currentUser: {firebase user object...}


    It's like Firebase has the auth information stored somewhere, but it isn't being pulled up when the app loads. How can I get Firebase to recognize the user is logged in when the page first reloads?










    share|improve this question



























      0












      0








      0








      I'm using the Google's pre-build firebaseui to do authentication in create-react-app.



      I have the onAuthStateChanged function set up in componentDidMount.



      componentDidMount() {
      firebase.auth().onAuthStateChanged((user) => {
      console.log('Auth state changed');
      console.log('user: ',user);
      if (user) {
      this.setState({user: user});
      } else {
      this.setState({user: null});
      }
      });


      }



      I use this.state.user in render to show different UI elements depending on whether or not they're logged in. I also log the currentUser:



      render() {
      console.log('render currentUser: ',firebase.auth().currentUser);
      ...


      Here's what happens when I try to log in with firebaseui:



      1) Click the Log In button which displays FirebaseUI.



      2) Select Sign In with Google



      enter image description here



      3) The page is redirected to a Google auth page, then redirects back to my app



      4) After the reload I see these console logs:



      render currentUser: null
      Auth state changed
      user: null
      render currentUser: null


      5) Click the Log In button again



      6) FirebaseUI shows a blank window with a loading indicator at the top, then closes. There is no redirect.



      enter image description here



      7) Console output:



      render currentUser: null
      Auth state change
      user: {firebase user object...}
      render currentUser: {firebase user object...}


      It's like Firebase has the auth information stored somewhere, but it isn't being pulled up when the app loads. How can I get Firebase to recognize the user is logged in when the page first reloads?










      share|improve this question
















      I'm using the Google's pre-build firebaseui to do authentication in create-react-app.



      I have the onAuthStateChanged function set up in componentDidMount.



      componentDidMount() {
      firebase.auth().onAuthStateChanged((user) => {
      console.log('Auth state changed');
      console.log('user: ',user);
      if (user) {
      this.setState({user: user});
      } else {
      this.setState({user: null});
      }
      });


      }



      I use this.state.user in render to show different UI elements depending on whether or not they're logged in. I also log the currentUser:



      render() {
      console.log('render currentUser: ',firebase.auth().currentUser);
      ...


      Here's what happens when I try to log in with firebaseui:



      1) Click the Log In button which displays FirebaseUI.



      2) Select Sign In with Google



      enter image description here



      3) The page is redirected to a Google auth page, then redirects back to my app



      4) After the reload I see these console logs:



      render currentUser: null
      Auth state changed
      user: null
      render currentUser: null


      5) Click the Log In button again



      6) FirebaseUI shows a blank window with a loading indicator at the top, then closes. There is no redirect.



      enter image description here



      7) Console output:



      render currentUser: null
      Auth state change
      user: {firebase user object...}
      render currentUser: {firebase user object...}


      It's like Firebase has the auth information stored somewhere, but it isn't being pulled up when the app loads. How can I get Firebase to recognize the user is logged in when the page first reloads?







      reactjs firebase firebase-authentication firebaseui






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 16 '18 at 0:42









      Doug Stevenson

      81.4k997115




      81.4k997115










      asked Nov 16 '18 at 0:25









      Josh M.Josh M.

      6928




      6928
























          0






          active

          oldest

          votes











          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53329724%2ffirebase-react-currentuser-is-null-after-sign-in-with-google-redirect-and-reloa%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes
















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53329724%2ffirebase-react-currentuser-is-null-after-sign-in-with-google-redirect-and-reloa%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Xamarin.iOS Cant Deploy on Iphone

          Glorious Revolution

          Dulmage-Mendelsohn matrix decomposition in Python