Skip to main content

A Django app for user management with email-based authentication.

Project description

Django Email Accounts

Django Email Accounts is a Django app for user management with email-based authentication. It provides a customizable User model and registration view for handling user registration and authentication using email and password.

Installation

Install the package using pip:

pip install django-email-accounts

Usage

  1. Add 'email_accounts' to the INSTALLED_APPS list in your Django project's settings.py file:
INSTALLED_APPS = [
   ...
   'email_accounts',
   ...
]
  1. Change the default authentication user model by adding this line of code in your Django project's settings.py file:
AUTH_USER_MODEL = 'email_accounts.User'
  1. Update your project's urls.py file to include the email-accounts URLs:
from django.urls import path, include

urlpatterns = [
    ...
    path('accounts/', include('email_accounts.urls')),
    ...
]

Note : If you want to use the restfull api instead, then here is a propre update for urls.py:

from django.urls import path, include
from rest_framework.routers import DefaultRouter

from email_accounts.views import UserViewSet

router = DefaultRouter()
router.register('users', UserViewSet)

urlpatterns = [
    ...
    path('api/', include(router.urls)),
    path('api/accounts/', include('email_accounts.api_urls')),
    ...
]
  1. Run migrations to create the necessary database tables:
python manage.py makemigrations email_accounts
python manage.py migrate
  1. You can now use the email-accounts functionality in your Django project.

Note : If you want custom authentication templates, then, in your templates folder, create a email_accounts subdirectory in templates directory and create all authentication templates on it like this.

├── templates
│   └── email_accounts
│       ├── login.html
│       ├── register.html
│       └── password
│           ├── change
│           ├── ├── 1.html
│           ├── └── 2.html
│           └── reset
│               ├── 1.html
│               ├── 2.html
│               ├── 3.html
│               └── 4.html

Contributing

Contributions are welcome! If you find any issues or have suggestions for improvements, please feel free to open an issue or submit a pull request on the GitHub repository.

To contribute to the project, follow these steps:

  1. Fork the repository on GitHub.
  2. Clone your forked repository to your local machine.
  3. Create a new branch for your feature or bug fix.
  4. Make the necessary changes and commit them.
  5. Push the changes to your forked repository.
  6. Submit a pull request to the main repository.

Please ensure that your code adheres to the project's coding conventions and includes appropriate tests. Also, provide a clear description of the changes you have made in the pull request.

Thank you for your contributions!

License

This project is licensed under the GNU General Public License v3.0. See the LICENSE file for more details.

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-email-accounts-0.5.0.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

django_email_accounts-0.5.0-py3-none-any.whl (26.7 kB view details)

Uploaded Python 3

File details

Details for the file django-email-accounts-0.5.0.tar.gz.

File metadata

  • Download URL: django-email-accounts-0.5.0.tar.gz
  • Upload date:
  • Size: 21.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.4

File hashes

Hashes for django-email-accounts-0.5.0.tar.gz
Algorithm Hash digest
SHA256 537131d46f135f8ba9c27db2e58b82aded05a43c8ff61cd8ebf7d3d9637c9d2c
MD5 33127ff2b29e71d9ee32e9196ba477c5
BLAKE2b-256 f6e0db7d4c48800a6b9f85398e052c9c872769c1dfee4d06812f2ff98f29de76

See more details on using hashes here.

File details

Details for the file django_email_accounts-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_email_accounts-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 377c7cbcebfc4730b4c8021a394566ee3e40536c00d446f94854cc35705bc29f
MD5 0e24abc8240e9197d52ef76544c5cadc
BLAKE2b-256 27d5789089995def85f82e960be84027a234f8fe3b49b9c5cd91087166abd0e9

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