Skip to main content

No project description provided

Project description

Starlette OAuth2

A Startlette middleware for authentication through oauth2's via a secret key, which is often used to add authentication and authorization to a web application that interacts with an API on behalf of the user.

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

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 added to example/.venv.

  1. Generate a secret (e.g. openssl rand -base64 32) 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.

    • add the value on Application (client) ID to CLIENT_ID
    • add the value on Endpoints > OpenID Connect metadata document to SERVER_METADATA_URL
  3. In Certificates & secrets tab, create a new client secret.

    • add the value of the key you just created under Client secrets to CLIENT_SECRET
  4. Install dependencies and run:

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

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

Public endpoints are optional. They are useful for e.g. health checks.

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.3.4.tar.gz (3.3 kB view details)

Uploaded Source

File details

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

File metadata

  • Download URL: starlette-oauth2-0.3.4.tar.gz
  • Upload date:
  • Size: 3.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.4

File hashes

Hashes for starlette-oauth2-0.3.4.tar.gz
Algorithm Hash digest
SHA256 ff270a0e1e9127c0e49976f3e5844406acf8c8097b5c84eb82e7757fdda2a4bc
MD5 af8154064b18c7a2bdcb8a8b8ef9fa0b
BLAKE2b-256 f83b347a8c36d2288984aab228d4ae1c4ee42fb0d555d90e8d341e8179ebbb77

See more details on using hashes here.

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