DEV Community

Cover image for Adding 'Sign in with Google' to your site with vanilla JS
Michael Marcoux
Michael Marcoux

Posted on

Adding 'Sign in with Google' to your site with vanilla JS

This blog is going to be a step-by-step guide on how to quickly add a 'Sign in with Google' button to your website. You won't need to install any modules for this to work. At the end, you'll be able to sign in with your Google account and use the data returned from the Google OAuth API to run conditional JS functions on your website.

I decided to put this together because I believe that a Google login is slicker and more functional than a bootstrapped HTML form, but I couldn't find a step-by-step resource oriented toward beginners. Please comment below your thoughts and any questions/issues you have while following these instructions. Happy coding!

Please note that this guide will feature macOS/Linux terminal commands. If you are running Windows, you will have to research the corresponding command prompt syntax.

Prerequisites:

  • A HTML & JS file open in your code editor of choice
  • A Google account
  • Python installed (installation guide)

Links you'll need:

Step 1: Get your site running on a localhost server

This step with require the use of a Python command. If you do not have Python installed, follow the guide provided under 'Prerequisites'.

Navigate to the working directory in which your website lives. Make sure you have created HTML & JS files there. Your HTML file should contain at least one line of code.

working directory

Run the following Python command in your terminal.



python3 -m http.server


Enter fullscreen mode Exit fullscreen mode

You should see the following output.

terminal output

Navigate to http://localhost:8000 in your browser. You should see your site! When you are done working, you can use 'Ctrl + c' in the same terminal to terminate the server.

Having issues? If you are getting a different output, try the following steps.

Verify you have Python installed by running this command in a new terminal.



python3 -v


Enter fullscreen mode Exit fullscreen mode

If you see a version number in the output, go ahead and terminate that terminal and check to see which ports are open with this command in a new terminal.



lsof -i -P | grep -i "listen"


Enter fullscreen mode Exit fullscreen mode

In the image below, you can see that Python is running on port :8000 with the portID 30098.

terminal output

If something else is running on port 8000, use the following command to terminate the port. Use the value found in the previous command for 'portID'.



kill portID


Enter fullscreen mode Exit fullscreen mode

Step 2: Create a Google Cloud project

Navigate to the Credentials API Dashboard and click to create a new project.

Creating a project in Google Cloud

Once you have followed all of the prompts, navigate back to the dashboard if you are not automatically directed there.

Step 3: Create your OAuth consent screen

Click 'OAuth consent screen' in the left-side navigation and enter an app name, user support email, and developer contact information. The rest of the fields can be left blank.

Creating OAuth consent screen

Creating OAuth consent screen

Continue clicking 'SAVE AND CONTINUE' until you are at the summary page and then navigate back to the dashboard. You do not need to fill out the 'Scope' or 'Optional Information' prompts.

Step 4: Create your OAuth 2.0 Client ID

Click 'Credentials' in the left-side navigation, click 'CREATE CREDENTIALS' at the top of the page, and then click 'OAuth client ID'.

Creating client ID

Add a client name, and then add http://localhost:8000 and http://localhost under both the 'Authorized JavaScript origins' and 'Authorized redirect URIs' sections.

Configuring client ID

Note that this screen is where you can find your 'Client ID'. Click 'SAVE' and navigate back to the dashboard.

Client ID

If anything from steps 3 & 4 was confusing, checking out the Google authentication docs may be helpful.

Step 5: Configure your HTML headers

Per the docs linked above, you'll need to add two headers to your HTML document so that your login works with a localhost server.



<meta name="referrer" content="no-referrer-when-downgrade">
<meta name="Cross-Origin-Opener-Policy" content="same-origin-allow-popups">


Enter fullscreen mode Exit fullscreen mode

While we're here, check that your JS document is linked to your HTML document. If you choose to link it in the header as I have done, it is best practice to include the defer keyword.

HTML header

Step 6: Generate your button code

Follow this link to the HTML code generator.

Add your Client ID, choose 'Swap to JavaScript callback', and then enter a name for your callback function.

Code configuration

In this example, we have to use a JS callback rather than a Login URI because we are using a localhost server.

Toggle the 'Enable Sign in with Google button', and make sure 'In a popup' is selected under the 'Behavior' dropdown.

Code configuration

Edit the styling options as you wish, and then click 'Get code'. Copy the code output to your clipboard.

In this example, we have not enabled OneTap as that requires additional configuration not covered in this blog.

Step 7: Add the button to your HTML

Paste the code in your HTML document nested somewhere between your <body> tags. I recommend creating a parent <div> around the login button code for styling purposes.

Resulting HTML code

Hint: You can use Cmd + k then Cmd + f on a selection in VS Code to automatically format it.

Step 8: Add OAuth scripts to the bottom of your HTML doc

Add the following scripts to the bottom of the <body> section in your HTML document. The first script loads the Google client library and the second is the callback function that will handle the API response.



<script src="https://accounts.google.com/gsi/client" async defer></script>
<script>
    function handleCredentialResponse(response) {
        decodeJwtResponse(response.credential);
    }
</script>


Enter fullscreen mode Exit fullscreen mode

In the callback function you'll notice I invoke another function called decodeJwtResponse. This function parses the JSON web token (JWT) that is returned from the Google API upon sign in. This JWT contains account information from the Google user that signed in via your button. Once parsed, you can store this information in different variables to supplement functionality on your webpage.

If this step is confusing, check out Google's documentation on loading the client library and handling the credential response.

Step 9: Parsing the JWT in your JS file

Parsing the JSON web token (JWT) can be accomplished several ways. In this example, I'm going to use a solution from Stack Overflow that doesn't require a library. If you would like to experiment with libraries, check them out here.

Navigate to your JS file and add the following function.



function parseJwt (token) {
    var base64Url = token.split('.')[1];
    var base64 = base64Url.replace(/-/g, '+').replace(/_/g, '/');
    var jsonPayload = decodeURIComponent(window.atob(base64).split('').map(function(c) {
        return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
    }).join(''));

    return JSON.parse(jsonPayload);
}


Enter fullscreen mode Exit fullscreen mode

Now pass it the JWT by adding a second function.



function decodeJwtResponse(data){
    signIn(parseJwt(data))
}


Enter fullscreen mode Exit fullscreen mode

This second function is invoked in the handleCredentialResponse callback and is where you can invoke other functionality related to signing in for your website. In the above example, I chose to invoke a function called signIn that takes the parsed JWT from the parseJWT function. If you would like to simply see the parsed JWT in your console log, replace signIn(parseJwt(data)) with console.log(parseJwt(data)).

That's all there is to this blog! Thank you for following along. Feel free to comment below with your thoughts/questions.

Top comments (2)

Collapse
 
vijay_iyer_645b65ede919f8 profile image
Vijay Iyer

Genuine question, why is running the app on a server required? I was trying with vanilla js but just by opening an index.html with a script.

Collapse
 
zackzhong profile image
zack

Thank you for sharing.