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.3.1.tar.gz (18.3 kB view details)

Uploaded Source

Built Distribution

django_email_accounts-0.3.1-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: django-email-accounts-0.3.1.tar.gz
  • Upload date:
  • Size: 18.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for django-email-accounts-0.3.1.tar.gz
Algorithm Hash digest
SHA256 d0fac832787135c77e8e592cd8d74b630e64d2f188a56b29fe1cf08c4c0fd838
MD5 1a5f4460d9941b2c86ce7737d34b4abf
BLAKE2b-256 8b555703ca2fda216fc127200a3340edb5c1e31f18ac0336a33cb1a5391c1a6d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_email_accounts-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ef49aae3821c4ce75c244e1fa7316ae98fae40bfd492f21162d50f23119ee58e
MD5 11d0c849a2e9ab3a04ddcea8276ec844
BLAKE2b-256 d654f4c8a7cf648a70a328f4bbb545ecc0872427582fbad7e625e22943899902

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