Skip to main content

OAuth 2.0 authentication for Google and Google Apps accounts

Project description

Simplified OAuth + OpenID Connect for authentication via Google.

googleauth used to be REALLY simple, but then Google decided to get rid of their OpenID service. Boooo Google. googleauth has been migrated to OAuth 2.0 + OpenID Connect, which isn’t quite as great because it takes a bit more configuration to get going.

googleauth was built to provide an easy way to add authentication against a Google Apps for Business domain, ideally for an individual organization. This package is not the best option if you are looking for a general social auth solution. Check out python-social-auth instead.

Getting things set up on Google

  1. Log in to the Google API Console.

  2. Open an existing project or create a new one if needed.

  3. Under the APIS & AUTH menu item, click APIs.

  4. Turn on the Google+ API.

  5. Under the APIS & AUTH menu item, click Credentials.

  6. Click the Create new Client ID button.

  7. Select Web application for application type, add your domain as the JavaScript origin, and add the full domain and path to the OAuth callback (see below for how to find this URL). Click the Create Client ID button to finish.

  8. You’re going to need the Client ID and Client secret values in Django settings, so keep this window open or copy them for later.

Callback URL

The callback URL is constructed from your preferred URL scheme, the domain at which your site is hosted, and the path where you mount the googleauth URL config in Django.

Let’s assume you are using HTTPS and have mounted the googleauth URL config at the root URL. Your callback URL would look something like:

https://<your-domain>/callback/

Okay, now let’s assume you are using HTTP and have mounted the googleauth URL config under /accounts/:

http://<your-domain>/accounts/callback/

Django Setup

Settings and configuration

The following settings should be placed in settings.py.

Add to INSTALLED_APPS:

INSTALLED_APPS = (
    ...
    'googleauth',
    ...
)

Add to AUTHENTICATION_BACKENDS:

AUTHENTICATION_BACKENDS = (
    'googleauth.backends.GoogleAuthBackend',
    ...
)

Required settings:

# client ID from the Google Developer Console
GOOGLEAUTH_CLIENT_ID = ''

# client secret from the Google Developer Console
GOOGLEAUTH_CLIENT_SECRET = ''

# your app's domain, used to construct callback URLs
GOOGLEAUTH_CALLBACK_DOMAIN = ''

Optional settings:

# callback URL uses HTTPS (your side, not Google), default True
GOOGLEAUTH_USE_HTTPS = True

# restrict to the given Google Apps domain, default None
GOOGLEAUTH_APPS_DOMAIN = ''

# get user's name, default True (extra HTTP request)
GOOGLEAUTH_GET_PROFILE = True

# sets value of user.is_staff for new users, default False
GOOGLEAUTH_IS_STAFF = False

# list of default group names to assign to new users
GOOGLEAUTH_GROUPS = []

URL routes

Add URL config:

urlpatterns = patterns('',
    ...
    (r'^auth/', include('googleauth.urls')),
    ...
)

googleauth doesn’t need to be mounted under /auth/, it can go anywhere. Place it where you see fit for your specific app.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

django_googleauth_ng-2.3-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file django-googleauth-ng-2.3.macosx-10.13-x86_64.tar.gz.

File metadata

File hashes

Hashes for django-googleauth-ng-2.3.macosx-10.13-x86_64.tar.gz
Algorithm Hash digest
SHA256 601e4f83f6071706f6b60c200202189f9dc7a298c184c0a99a5a89ac57c7d308
MD5 44404d396a46e66ff536391f6ff2f507
BLAKE2b-256 b77dfe45723a70ea82359d63eb49dcf76b820eef2c7b07b3196f413c5701be1d

See more details on using hashes here.

Provenance

File details

Details for the file django_googleauth_ng-2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for django_googleauth_ng-2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 b9669e6333523c2a1a1e5989697c29f9d3353708e86927af175e8768258c5898
MD5 500a8daefed90421d929f60c54c816ff
BLAKE2b-256 c3d7efed6bd5df76e1aaa3d3d173cbb10ec9a40ed5b6352e2eaca105188b13be

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page