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

Uploaded Source

Built Distribution

django_email_accounts-0.7.0-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: django-email-accounts-0.7.0.tar.gz
  • Upload date:
  • Size: 21.9 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.7.0.tar.gz
Algorithm Hash digest
SHA256 36d34a252fd4652219833fa0a2fe478e7d3fd38cba72d658737421a2f79287b9
MD5 762bd380430f3fca1fe6f8912a6299d9
BLAKE2b-256 9f00375ed3985a32520e976d5a86129ff09cec48109eaca849d8b658305af19c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_email_accounts-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bfee98551d2cef00e19238000c9c2830816ae491f251f4d80f14c242c00a888f
MD5 959706a1001e97f7902822f4f0e81106
BLAKE2b-256 866601e6cc9def2abe8357360ad8dee6488703014e5990460d7174d54a32543f

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