Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

TypeError: gapi.auth2 undefined

I went exactly by the instructions for integrating google sign-in:

https://developers.google.com/identity/sign-in/web/sign-in#specify_your_apps_client_id

sign-in works, but sign-out gives a javascript error in the line:

var auth2 = gapi.auth2.getAuthInstance();

The error is:

gapi.auth2 undefined

I include the google platform library as instructed:

    <script type='text/javascript' src='https://apis.google.com/js/platform.js' async defer></script> 

Why does it not work?

like image 755
Erel Segal-Halevi Avatar asked Apr 23 '15 06:04

Erel Segal-Halevi


1 Answers

Are signIn and signOut used on the same page? Div g-signin2 loads and inits gapi.auth2 so it should work as long as those are on the same page.

In case signOut is on separate page, you should manually load and init gapi.auth2 library.

Full example (you have to replace YOUR_CLIENT_ID with your actual client_id):

<html> <head>    <meta name="google-signin-client_id" content="YOUR_CLIENT_ID"> </head> <body>   <script>     function signOut() {       var auth2 = gapi.auth2.getAuthInstance();       auth2.signOut().then(function () {         console.log('User signed out.');       });     }      function onLoad() {       gapi.load('auth2', function() {         gapi.auth2.init();       });     }   </script>   <a href="#" onclick="signOut();">Sign out</a>    <script src="https://apis.google.com/js/platform.js?onload=onLoad" async defer></script> </body> </html> 
like image 113
Jarosław Gomułka Avatar answered Oct 04 '22 20:10

Jarosław Gomułka