Django Allauth (6) – Social Login with Google
data:image/s3,"s3://crabby-images/237e5/237e5bc7689bd5e956daa72d6e45872fc9bc102c" alt="Setting Up Social Login with Google via Django Allauth"
This lesson will explain how to set up a social login with Google.
Note: The approach can change depending on Google's policy.
1. Register a new OAuth app in the GCP(Google Cloud Platform) console
Go to the GCP (Google Cloud Platform). Click on the Console button on the top bar.
data:image/s3,"s3://crabby-images/b0250/b02509f466ad6ab009b29ee44d5468058b2c31ab" alt="Register a new OAuth app in GCP: Step 1 Register a new OAuth app in GCP: Step 1"
Click on Select a project. And press the NEW PROJECT button.
data:image/s3,"s3://crabby-images/6721a/6721a6dac0e66ba850bbe1b0091a7ba4ede9e319" alt="Register a new OAuth app in GCP: Step 2 Register a new OAuth app in GCP: Step 2"
Add a project name (e.g., Employee Learning) and press the CREATE button.
data:image/s3,"s3://crabby-images/f01b1/f01b124bca8c2443dc33a24fd872272480cc5de1" alt="Register a new OAuth app in GCP: Step 3 Register a new OAuth app in GCP: Step 3"
In the created project (Employee Learning), select API and services. Click on OAuth consent screen.
data:image/s3,"s3://crabby-images/9188e/9188e4856fbfbfa156feb14057e0f0a61a0f2e20" alt="Register a new OAuth app in GCP: Step 4 Register a new OAuth app in GCP: Step 4"
On the OAuth consent screen, select External and press the CREATE button.
data:image/s3,"s3://crabby-images/6aad3/6aad38afb78f4ae53076176fbddcafacdc270414" alt="Register a new OAuth app in GCP: Step 5 Register a new OAuth app in GCP: Step 5"
Add App name, User support email, and Developer contact information at the bottom.
data:image/s3,"s3://crabby-images/5c198/5c198bd0101e02469b4fc3ee83017d317e1d54d7" alt="Register a new OAuth app in GCP: Step 6 Register a new OAuth app in GCP: Step 6"
There is no need to add other information. Click on Save And Continue in the rest of the steps.
Once the OAuth consent part is done, select Credentials on the left sidebar. And click on + CREATE CREDENTIALS. Select OAuth client ID from the dropdown menu.
data:image/s3,"s3://crabby-images/fc6be/fc6be0c61dd64e692e1ab78536e2807ffe6caa0a" alt="Register a new OAuth app in GCP: Step 7 Register a new OAuth app in GCP: Step 7"
Add the following information.
- Application Type: Web application
- Name: Any name (e.g., Employee Learning)
- Authorized JavaScript origins: http://localhost:8000
- Authorized redirect URIs: http://localhost:8000/accounts/google/login/callback/
Carefully type, especially for Authorized JavaScript origins and Authorized redirect URIs.
- Authorized JavaScript origins is the Homepage URL in GitHub.
- Authorized redirect URIs is Authorization callback URL in GitHub.
data:image/s3,"s3://crabby-images/4933d/4933d4b8aba2ab0034c78d0bcf508927840aa945" alt="Google and GitHub Social Login URL setting comparison Google and GitHub Social Login URL setting comparison"
Often, error come from this setting. If you are using 127.0.0.1 for the runserver
command, use 127.0.0.1 here as well. Another point you need to be careful about is the accounts part. Don't forget to put s at the end.
data:image/s3,"s3://crabby-images/78fbe/78fbe4fa84824d91458588972db810ed49886aed" alt="Register a new OAuth app in GCP: Step 8 Register a new OAuth app in GCP: Step 8"
Once you have filled in all the required data, click on CREATE. You can see a pop-up with the Client ID and Client secret and save them somewhere in a safe place. We'll use them later.
data:image/s3,"s3://crabby-images/757ee/757ee6015527db29cf0c9081985031c9c189fc3b" alt="Register a new OAuth app in GCP: Step 9 Register a new OAuth app in GCP: Step 9"
2. Edit settings.py
To add the Google social login feature, you need to edit settings.py.
- Add
allauth google app
in theINSTALLED_APPS
section - Add
SCOPE
and other settings underSOCIALACCOUNT_PROVIDERS
INSTALLED_APPS = [
:
'allauth.socialaccount.providers.github',
'allauth.socialaccount.providers.google',
]
###Social Login###
SOCIALACCOUNT_PROVIDERS = {
'github': {
'SCOPE': [
'user',
'repo',
'read:org',
],
},
'google': {
'SCOPE': [
'profile',
'email',
],
'AUTH_PARAMS': {
'access_type': 'online',
},
'OAUTH_PKCE_ENABLED': True,
},
}
Check the allauth official document for details.
3. Register in Django Admin
As the last step, you need to add your domain on the Site page and Google social login settings on the Social applications page in the Django admin site.
Update the domain information on the Site page
You can skip this step if you have done this in the previous GitHub section.
Click on the Site link on the left sidebar. As a default, example.com is registered on the Site page.
data:image/s3,"s3://crabby-images/4dd53/4dd53970e86e43c3ff294ddf587674c4390f2805" alt="Register Google Social Login in Django Admin: Step 1 Register Google Social Login in Django Admin: Step 1"
Change it to localhost:8000.
data:image/s3,"s3://crabby-images/cf40f/cf40fd967bae1595d7e5c834244177321315d6da" alt="Register Google Social Login in Django Admin: Step 2 Register Google Social Login in Django Admin: Step 2"
Add Google social login settings on the Social applications page
Click on the +Add button beside the Social applications link on the left sidebar.
Add the following settings:
- Provider: GitHub
- Name: Any name
- Client ID: Client ID obtained from GitHub website
- Secret Key: Client secret obtained from GitHub website
- Sites: localhost:8000
Once it's done, save the record.
data:image/s3,"s3://crabby-images/d81ac/d81acfa8cf706141e20de79f65f439d9d127ad13" alt="Register Google Social Login in Django Admin: Step 3 Register Google Social Login in Django Admin: Step 3"
Once it's done, save the record.
4. Check the results
Go to the Sign In (Login) page (not the Sign Up page!) to check the results.
You can see the link named Google.
data:image/s3,"s3://crabby-images/d7056/d705629a4680417422ca235a2dbe0889b3bb3fa3" alt="Django Allauth Sign In Page UI with Google Social Login Django Allauth Sign In Page UI with Google Social Login"
Click on the link. And then click on the continue button.
data:image/s3,"s3://crabby-images/ee279/ee279a2e4da703d2ed31c0da4f0cbce9f4e7deac" alt="Django Allauth Google Social Login Page Django Allauth Google Social Login Page"
You'll be redirected to the Google's site. Select an account you want to use for the social login.
data:image/s3,"s3://crabby-images/45ec9/45ec94d7ac146c165d4fd0418dda902772b306fd" alt="Google Social Login Account Selection Google Social Login Account Selection"
Once you select an account, you'll jump to the landing page (You are successfully logged in to the app).
data:image/s3,"s3://crabby-images/c6ee8/c6ee8ce8bebbdcdb8c084c5f9ab2594c3a9982a3" alt="Index page UI example (After login) Index page UI example (After login)"
Unlike with the GitHub social login setting, you don't need to verify your email again.