Skip to main content

Python Client Library for Supabase Auth

Project description

Auth-py

License: MIT CI Python Version Codecov Last commit GitHub commit activity Github Stars Github Forks Github Watchers GitHub contributors

This is a Python port of the supabase js gotrue client. The current state is that there is a features parity but with small differences that are mentioned in the section Differences to the JS client. As of December 14th, we renamed to repo from gotrue-py to auth-py to mirror the changes in the JavaScript library.

Installation

We are still working on making the supabase_auth python library more user-friendly. For now here are some sparse notes on how to install the module.

Poetry

poetry add supabase_auth

Pip

pip install supabase_auth

Differences to the JS client

It should be noted there are differences to the JS client. If you feel particulaly strongly about them and want to motivate a change, feel free to make a GitHub issue and we can discuss it there.

Firstly, feature pairity is not 100% with the JS client. In most cases we match the methods and attributes of the JS client and api classes, but is some places (e.g for browser specific code) it didn't make sense to port the code line for line.

There is also a divergence in terms of how errors are raised. In the JS client, the errors are returned as part of the object, which the user can choose to process in whatever way they see fit. In this Python client, we raise the errors directly where they originate, as it was felt this was more Pythonic and adhered to the idioms of the language more directly.

In JS we return the error, but in Python we just raise it.

const { data, error } = client.sign_up(...)

The other key difference is we do not use pascalCase to encode variable and method names. Instead we use the snake_case convention adopted in the Python language.

Also, the supabase_auth library for Python parses the date-time string into datetime Python objects. The JS client keeps the date-time as strings.

Usage (outdated)

Important: This section is outdated, you can be guided by the JS client documentation because this Python client has a lot of parity with the JS client.

To instantiate the client, you'll need the URL and any request headers at a minimum.

from supabase_auth import SyncGoTrueClient

headers = {
    "apiKey": "my-mega-awesome-api-key",
    # ... any other headers you might need.
}
client: SyncGoTrueClient = SyncGoTrueClient(url="www.genericauthwebsite.com", headers=headers)

To send a magic email link to the user, just provide the email kwarg to the sign_in method:

user: Dict[str, Any] = client.sign_up(email="example@gmail.com")

To login with email and password, provide both to the sign_in method:

user: Dict[str, Any] = client.sign_up(email="example@gmail.com", password="*********")

To sign out of the logged in user, call the sign_out method. We can then assert that the session and user are null values.

client.sign_out()
assert client.user() is None
assert client.session() is None

We can refesh a users session.

# The user should already be signed in at this stage.
user = client.refresh_session()
assert client.user() is not None
assert client.session() is not None

Contributions

We would be immensely grateful for any contributions to this project.

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

supabase_auth-2.10.0.tar.gz (41.5 kB view details)

Uploaded Source

Built Distribution

supabase_auth-2.10.0-py3-none-any.whl (49.0 kB view details)

Uploaded Python 3

File details

Details for the file supabase_auth-2.10.0.tar.gz.

File metadata

  • Download URL: supabase_auth-2.10.0.tar.gz
  • Upload date:
  • Size: 41.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for supabase_auth-2.10.0.tar.gz
Algorithm Hash digest
SHA256 252866bd312e52b2da6d73b37d1d3f0c675d99f6d5dab80dae9ec38d08c1a2ab
MD5 8c2a30d36278dab6dfb7d6883659d0fb
BLAKE2b-256 c851a8e0a6644acf35ebdfe225547789ca51d1610ee5c6fd3ea4112a7a06ce8e

See more details on using hashes here.

Provenance

The following attestation bundles were made for supabase_auth-2.10.0.tar.gz:

Publisher: ci.yml on supabase/auth-py

Attestations:

File details

Details for the file supabase_auth-2.10.0-py3-none-any.whl.

File metadata

File hashes

Hashes for supabase_auth-2.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c19b2b40ef1a2c12fe8bb7aff13ff309f9a5c5773e3ea78a78ec99ab98b126ee
MD5 4eb3ed91a85d3536716a7e7aa3e93d37
BLAKE2b-256 c20254c646abb6c1adf690d61e20727311b35d663540eca33665d3120953add4

See more details on using hashes here.

Provenance

The following attestation bundles were made for supabase_auth-2.10.0-py3-none-any.whl:

Publisher: ci.yml on supabase/auth-py

Attestations:

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