Skip to main content

Simple and opinionated OpenID-Connect relying party and resource server implementation

Project description

Simple OpenID

Simple and opinionated OpenID-Connect relying party and resource server implementation

Documentation Status

Quick Links

Development philosophy

  • Keep the API as simple as possible

    No **kwargs parameters, no function arguments called request_args, http_args or something_else_args

  • Fully typed API

    Python has type hints now, let's use them.

  • Support commonly used OpenID features and flows

    Commonly used flows will be supported but obscure and legacy or experimental mechanisms not so much.

  • Be just an OpenID library

    Tell the user about function requirements clearly but don't try any fancy internal persistence or caching mechanisms that will only fail in different usage scenarios. Instead, abstract the underlying OpenID protocol into usable, clear functions but nothing more.

Language & Framework Support

We aim to follow pythons officially supported versions. This is currently python v3.10, v3.11, v3.12, v3.13 and v3.14.

In addition to being an OpenID library from which one can build their own authentication solutaion, we also offer explicit integrations into the following frameworks and projects:

Name Package Feature Integration Docs Supported Versions
Django django Integration Docs v4.2, v5.2, v6.0
Django-Rest-Framework djangorestframework Integration Docs v3.15, v3.16, v3.17

Supported OpenID Specs

The list of OpenID specifications can be found on the official website.

  • (✔️) Partial OpenID Connect Core 1.0

    Only the following flows and features are implemented:

    • ✔️ Authorization Code Flow
    • ✔️ Direct Access Grant (or Resource Owner Password Credentials Grant)
    • ✔️ client_secret_basic client authentication
    • ✔️ none client authentication
    • ✔️ Query String serialization and parsing
    • ✔️ ID Token handling (parsing + validation)
    • ✔️ Using refresh tokens
    • ✔️ Retrieving userinfo
    • ❌ Implicit Flow
    • ❌ Hybrid Flow
    • ❌ Handling third party initiated login
    • ❌ Passing requests as JWTs (neither by value nor by reference)
    • ❌ Self-Issued OpenID Provider
    • client_secret_post client authentication
    • client_secret_jwt client authentication
    • private_key_jwt client authentication
  • (✔️) Partial OpenID Connect Discovery 1.0. Provider Configuration Discovery is implemented, Provider Issuer Discovery is not.

    This means that a known issuer can be introspected for its supported algorithms, endpoint locations and so forth but discovering that issuer in the first hand is not possible.

  • ✔️ Full OAuth 2.0 Multiple Response Type Encoding Practices

    Only the following features are implemented and supported:

    • ✔️ Response modes (fragment based response parsing)
    • ✔️ Multiple-Valued Response Types
      No explicit support, but it is possible to supply one of the multivalued response_type values to an authentication request and then parse multiple responses from the resulting response.
  • ✔️ Full OpenID Connect RP-Initiated Logout 1.0

  • ✔️ Full OpenID Connect Front-Channel Logout 1.0

  • ✔️ Full OpenID Connect Back-Channel Logout 1.0

  • ✔️ Full Proof Key for Code Exchange (PKCE)

  • ✔️ Full OAuth 2.0 Token Introspection

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

simple_openid_connect-2.4.0.tar.gz (100.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

simple_openid_connect-2.4.0-py3-none-any.whl (72.2 kB view details)

Uploaded Python 3

File details

Details for the file simple_openid_connect-2.4.0.tar.gz.

File metadata

  • Download URL: simple_openid_connect-2.4.0.tar.gz
  • Upload date:
  • Size: 100.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.33.1

File hashes

Hashes for simple_openid_connect-2.4.0.tar.gz
Algorithm Hash digest
SHA256 1077319c947f568e08d1d0788eb480e56205564950e4b48951b850f66c073b89
MD5 2e3349bd2b574e1b1a68f351c5d80d78
BLAKE2b-256 ed0305babd63b86de8cd5d230b5041b90222a28cf97a33658955465503ce5c18

See more details on using hashes here.

File details

Details for the file simple_openid_connect-2.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for simple_openid_connect-2.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 03ab140bb885974674df5494165b09d11a43ef99eb3a23ccd5d7909aad5703f2
MD5 df1555637b275730e904c1fe7c80cbb4
BLAKE2b-256 791c27d722e9883054aec169ae63019613e9a9c44449127a2fa4c8a24a7d1363

See more details on using hashes here.

Supported by

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