Skip to main content

FastAPI plugin to enable SSO to most common providers (such as Facebook login, Google login and login via Microsoft Office 365 Account)

Project description

FastAPI SSO

FastAPI plugin to enable SSO to most common providers (such as Facebook login, Google login and login via Microsoft Office 365 account).

This allows you to implement the famous Login with Google/Facebook/Microsoft buttons functionality on your backend very easily.

Installation

Install using pip

pip install fastapi-sso

Install using poetry

poetry add fastapi-sso

Example

example.py

"""This is an example usage of fastapi-sso.
"""

from fastapi import FastAPI
from starlette.requests import Request
from fastapi_sso.sso.google import GoogleSSO

app = FastAPI()

google_sso = GoogleSSO("my-client-id", "my-client-secret", "https://my.awesome-web.com/google/callback")


@app.get("/google/login")
async def google_login():
    """Generate login url and redirect"""
    return await google_sso.get_login_redirect()


@app.get("/google/callback")
async def google_callback(request: Request):
    """Process login response from Google and return user info"""
    user = await google_sso.verify_and_process(request)
    return {
        "id": user.id,
        "picture": user.picture,
        "display_name": user.display_name,
        "email": user.email,
        "provider": user.provider,
    }

Run using uvicorn example:app.

HTTP and development

You should always use https in production. But in case you need to test on localhost and do not want to use self-signed certificate, make sure you set up redirect uri within your SSO provider to http://localhost:{port} and then add this to your environment:

OAUTHLIB_INSECURE_TRANSPORT=1

And make sure you pass allow_insecure_http = True to SSO class' constructor, such as:

google_sso = GoogleSSO("client-id", "client-secret", "callback-url", allow_insecure_http=True)

See this issue for more information.

State

State is used in OAuth to make sure server is responding to the request we send. It may cause you trouble as fastsapi-sso actually saves the state content as a cookie and attempts reading upon callback and this may fail (e.g. when loging in from different domain then the callback is landing on). If this is your case, you may want to disable state checking by passing use_state = False in SSO class's constructor, such as:

google_sso = GoogleSSO("client-id", "client-secret", "callback-url", use_state=False)

See more on state here.

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

fastapi-sso-0.2.12.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

fastapi_sso-0.2.12-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file fastapi-sso-0.2.12.tar.gz.

File metadata

  • Download URL: fastapi-sso-0.2.12.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.11 CPython/3.10.0 Linux/5.10.71

File hashes

Hashes for fastapi-sso-0.2.12.tar.gz
Algorithm Hash digest
SHA256 671d00d0ee0630fccd9279f275d4f898c2012aa80354c8e86b33bd3dfe945387
MD5 26bad8fcb6ff340343d780ac7ab594bc
BLAKE2b-256 64905134d04a640f5ee4821856f2785057cc6d7964e45d1542705745c3932236

See more details on using hashes here.

File details

Details for the file fastapi_sso-0.2.12-py3-none-any.whl.

File metadata

  • Download URL: fastapi_sso-0.2.12-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.11 CPython/3.10.0 Linux/5.10.71

File hashes

Hashes for fastapi_sso-0.2.12-py3-none-any.whl
Algorithm Hash digest
SHA256 38da189b1bdacb06e9b08097bc560afbf2f7b87fbd620ca01a05a8039af1c99f
MD5 842dce2a167f295013449977550dbaaa
BLAKE2b-256 443fb8cb2cec0648ccddde8d47ddf625e4b20606ac818de5790c90f0c37f2be2

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