Skip to main content

Django authentication middle ware using Firebase Authentication Service

Project description

Django Firebase Auth

Project provide Django authentication middle ware using Firebase Authentication Service

Requirements

Installation

pip install django-firebase-auth

Generate Firebase Credentials

Usage

Settings

1. Setting credentials

  • Credentials from file
FIREBASE_CREDENTIALS_FILE = '<YOUR FIREBASE CREDENTIALS PATH>'  # 'firebase-credentials.json'
  • or using credentials from json dict (where you can use as environment variables )
Using credentials from json dict
FIREBASE_CREDENTIALS_DICT = {
    "type": "service_account",
    "project_id": "<YOUR PROJECT ID>",
    "private_key_id": "<YOUR PRIVATE KEY ID>",
    "private_key": '<YOUR PRIVATE KEY>',
    "client_email": "<CLIENT EMAIL>",
    "client_id": "<CLIENT ID>",
    "auth_uri": "https://accounts.google.com/o/oauth2/auth",
    "token_uri": "https://oauth2.googleapis.com/token",
    "auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
    "client_x509_cert_url": "<CERT URL>"
}

2. Add installed apps:

INSTALLED_APPS = [
    "...",
    "django_firebase_auth",
]

3. Setting authentication backend

REST_FRAMEWORK = {
    "DEFAULT_AUTHENTICATION_CLASSES": (
        "django_firebase_auth.firebase_auth.FirebaseAuthentication",
    ),
}

Generate Firebase Credentials file

To generate a private key file for your service account:

  1. In the Firebase console, open Settings > Service Accounts.
  2. Click Generate New Private Key, then confirm by clicking Generate Key.
  3. Securely store the JSON file containing the key.

Add Firebase credentials to settings.py

Generate Firebase credentials from Firebase console img.png

TODO:

  • Support supabase
  • Optimize session management

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

django-firebase-auth-1.2.1.tar.gz (9.8 kB view details)

Uploaded Source

Built Distribution

django_firebase_auth-1.2.1-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file django-firebase-auth-1.2.1.tar.gz.

File metadata

  • Download URL: django-firebase-auth-1.2.1.tar.gz
  • Upload date:
  • Size: 9.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.18

File hashes

Hashes for django-firebase-auth-1.2.1.tar.gz
Algorithm Hash digest
SHA256 a48830c1b327bb11046a53514e7e4389fe88ceae3b1bb4dc05a2837c6acb3911
MD5 c53c2c567db235a390fcb66d0d37a596
BLAKE2b-256 e942a708c491bb2f765faed913745b53a5ba1ecc83742915ca0ae6208e3e539b

See more details on using hashes here.

File details

Details for the file django_firebase_auth-1.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for django_firebase_auth-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1ee6914d52602f734541b775e2d75e441ffcfa0802297487b687b686cf3cd56e
MD5 8623ad8d5b0930cb8804f53685113bcf
BLAKE2b-256 cb91666af417bacfd51a9e118b8e9bf4d6b883736f6278498eec4e5cc0f88ebe

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