Skip to main content

No project description provided

Project description

Starlette OAuth2

A Startlette middleware for authentication through oauth2.

This middleware is intented to be used when the application relies on an external tenant (e.g. Microsoft AD) for authentication.

It assumes that a user that is not authenticated is not authorized to do anything.

Check example/ for a concrete implementation.

How to run the example against Microsoft AD

Note: the values in capital such as CLIENT_ID are to be replaced in example/.venv.

  1. Generate a secret and write its value on SECRET_KEY

  2. Go to Azure AD, create an app registration (app registrations), give it a name, and add http://localhost:5001/authorized as a Redirect URI.

    • replace the value on CLIENT_ID by the value on Application (client) ID
    • replace the value on TENANT_ID by the value on Directory (tenant) ID
  3. In Certificates & secrets, create a new client secret.

    • replace the value on CLIENT_SECRET by the value of the key you just created under Client secrets
  4. Install dependencies and run:

cd examples
python -m venv venv
venv/bin/pip install -r requirements.txt
python -m app

When you visit http://localhost:5001/public, you will see that you are not authenticated. When you visit http://localhost:5001, you will be redirected to your tenant, to authenticate. Once authenticated, you will be redirected back to http://localhost:5001, and your email will appear.

Public endpoints are optional. They are useful e.g. for healthchecks.

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

starlette-oauth2-0.2.0.tar.gz (3.6 kB view details)

Uploaded Source

File details

Details for the file starlette-oauth2-0.2.0.tar.gz.

File metadata

  • Download URL: starlette-oauth2-0.2.0.tar.gz
  • Upload date:
  • Size: 3.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.40.0 CPython/3.7.3

File hashes

Hashes for starlette-oauth2-0.2.0.tar.gz
Algorithm Hash digest
SHA256 e67e9f285ce078a8b96e3aca5aa2174a1b8b56607e6fd5f0130ef6dde02be1dd
MD5 b1ac459712105a2527f0f517414d0d94
BLAKE2b-256 1af803449428516e11ee6614b1b7ee0dfd63829eaf50cfb9b23c4551e8174c0e

See more details on using hashes here.

Supported by

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