Skip to main content

Reusable auth + profiles foundations for Django/DRF projects

Project description

jb-drf-auth

Reusable authentication module for Django + Django REST Framework.

jb-drf-auth is a reusable foundation for authentication flows across projects, including:

  • User/profile base models (extensible)
  • OTP flows (email/SMS)
  • Login, registration, password reset, email confirmation
  • Multi-profile support
  • Provider-based SMS/email architecture
  • Configurable behavior via Django settings

Installation

pip install jb-drf-auth

Add jb_drf_auth and rest_framework to INSTALLED_APPS.

Documentation

  • Main docs index: docs/README.md
  • Getting started and configuration: docs/getting-started.md
  • API contract (endpoint by endpoint): docs/API_CONTRACT.md
  • Social authentication guide: docs/social-auth.md
  • Migration guide: docs/migration.md
  • i18n integration guide: docs/i18n.md
  • Release guide: docs/release.md
  • Roadmap: roadmap.md

Quick Start

  1. Configure concrete models in your project (User, Profile, Device, OtpCode, logs).
  2. Configure JB_DRF_AUTH settings (minimal real-world example):
JB_DRF_AUTH = {
    "PROFILE_MODEL": "authentication.Profile",
    "DEVICE_MODEL": "authentication.Device",
    "OTP_MODEL": "authentication.OtpCode",
    "SMS_LOG_MODEL": "authentication.SmsLog",
    "EMAIL_LOG_MODEL": "authentication.EmailLog",
    "FRONTEND_URL": env("FRONTEND_URL", default="http://localhost:3000"),
    "DEFAULT_FROM_EMAIL": "no-reply@your-domain.com",
    "AUTHENTICATION_TYPE": "both",  # "email", "username", "both"
    "AUTH_SINGLE_SESSION_ON_MOBILE": env.bool(
        "AUTH_SINGLE_SESSION_ON_MOBILE", default=False
    ),
    "ADMIN_BOOTSTRAP_TOKEN": env("ADMIN_BOOTSTRAP_TOKEN", default="super-secret-token"),
    "PROFILE_PICTURE_UPLOAD_TO": "uploads/users/profile-pictures",
    "PERSON_ID_DOCUMENTS_UPLOAD_TO": "uploads/people/id-documents",
    "PROFILE_ROLE_CHOICES": (
        ("PATIENT", "Patient"),
        ("DOCTOR", "Doctor"),
        ("ADMIN", "Admin"),
    ),
    "DEFAULT_PROFILE_ROLE": "PATIENT",
    "SMS_SENDER_ID": "YourBrand",
    "SMS_OTP_MESSAGE": "Tu codigo para acceder a Mentalysis es {code}. Expira en {minutes} minutos.",
}

If you use env(...)/env.bool(...), ensure environ.Env() is configured in your settings module. 3. Mount URLs:

from django.urls import include, path

urlpatterns = [
    path("auth/", include("jb_drf_auth.urls")),
]
  1. Run migrations in the integrator project.

For complete setup examples (including full JB_DRF_AUTH dict), see docs/getting-started.md.

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

jb_drf_auth-0.1.2.tar.gz (40.8 kB view details)

Uploaded Source

Built Distribution

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

jb_drf_auth-0.1.2-py3-none-any.whl (64.8 kB view details)

Uploaded Python 3

File details

Details for the file jb_drf_auth-0.1.2.tar.gz.

File metadata

  • Download URL: jb_drf_auth-0.1.2.tar.gz
  • Upload date:
  • Size: 40.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for jb_drf_auth-0.1.2.tar.gz
Algorithm Hash digest
SHA256 e2ba9fe5fc6c6cd02069534057b9fcc25d2431fce686e168b6fe36c27fec5748
MD5 72f098bfcfb3d2fc3f93677276256cf5
BLAKE2b-256 6b5b99e334f1e757fdc41318d24e64f9ab9e3c1e82a07b4ccab119a69808530d

See more details on using hashes here.

Provenance

The following attestation bundles were made for jb_drf_auth-0.1.2.tar.gz:

Publisher: pypi-publish.yml on joelbarron/jb-drf-auth

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jb_drf_auth-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: jb_drf_auth-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 64.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for jb_drf_auth-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8dff0db5aad7965087f16d4f9208c2983184c26d3ba759fe83b4e9cd6ee33478
MD5 758e8ae4c0612c3778134691aeb1456a
BLAKE2b-256 10172ed57d77f73a5c4bb19cf9d920e63707becaf4e82812827f3991f81d5812

See more details on using hashes here.

Provenance

The following attestation bundles were made for jb_drf_auth-0.1.2-py3-none-any.whl:

Publisher: pypi-publish.yml on joelbarron/jb-drf-auth

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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