Skip to main content

User registration REST API, based on django-rest-framework

Project description

Django REST Registration

CircleCI Build Status Codecov Coverage PyPi Version Documentation Status

User registration REST API, based on Django REST Framework.

Documentation

Full documentation for the project is available at https://django-rest-registration.readthedocs.io/.

Requirements

  • Django (2.0+, 3.0+, 4.0+, 5.0+) and Django-REST-Framework (3.3+)
  • Python 3.7 or higher (no Python 2 support!)

Features

  • Supported views:
    • registration (sign-up) with verification
    • login/logout (sign-in), session- or token-based
    • user profile (retrieving / updating)
    • reset password
    • change password
    • register (change) e-mail
  • Views are compatible with django-rest-swagger
  • Views can be authenticated via session or auth token
  • Modeless (uses the user defined by settings.AUTH_USER_MODEL and also uses cryptographic signing instead of profile models)
  • Uses password validation
  • Heavily tested (Above 98% code coverage)

Current limitations

Installation & Configuration

You can install Django REST Registration latest version via pip:

pip install django-rest-registration

Then, you should add it to the INSTALLED_APPS so the app templates for notification emails can be accessed:

INSTALLED_APPS=(
    ...

    'rest_registration',
)

After that, you can use the urls in your urlconfig, for instance:

api_urlpatterns = [
    ...

    path('accounts/', include('rest_registration.api.urls')),
]


urlpatterns = [
    ...

    path('api/v1/', include(api_urlpatterns)),
]

You can configure Django REST Registration using the REST_REGISTRATION setting in your Django settings (similarly to Django REST Framework).

Below is sample, minimal config you can provide in your django settings which will satisfy the system checks:

REST_REGISTRATION = {
    'REGISTER_VERIFICATION_ENABLED': False,
    'RESET_PASSWORD_VERIFICATION_ENABLED': False,
    'REGISTER_EMAIL_VERIFICATION_ENABLED': False,
}

However, the preferred base configuration would be:

REST_REGISTRATION = {
    'REGISTER_VERIFICATION_URL': 'https://frontend-host/verify-user/',
    'RESET_PASSWORD_VERIFICATION_URL': 'https://frontend-host/reset-password/',
    'REGISTER_EMAIL_VERIFICATION_URL': 'https://frontend-host/verify-email/',

    'VERIFICATION_FROM_EMAIL': 'no-reply@example.com',
}

The frontend urls are not provided by the library but should be provided by the user of the library, because Django REST Registration is frontend-agnostic. The frontend urls will receive parameters as GET query and should pass them to corresponding REST API views via HTTP POST request.

In case when any verification is enabled (which is the default!), your Django application needs to be properly configured so it can send e-mails.

You can read more about basic configuration here.

You can read more about detailed configuration here.

Configuration options

You can find all REST_REGISTRATION configuration options here.

Contributing

If you want to contribute, please refer to separate document CONTRIBUTING.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

django_rest_registration-0.9.0.tar.gz (39.1 kB view details)

Uploaded Source

Built Distribution

django_rest_registration-0.9.0-py3-none-any.whl (60.0 kB view details)

Uploaded Python 3

File details

Details for the file django_rest_registration-0.9.0.tar.gz.

File metadata

File hashes

Hashes for django_rest_registration-0.9.0.tar.gz
Algorithm Hash digest
SHA256 a8cb87b419cdafa434298c8fa492df81b26505412c50df43098bef8d16d0ad8a
MD5 eeab477ac2ffdc457ab35a25ebaf92e2
BLAKE2b-256 72e0bab3cacb76c12b0a6beae5d532cc5feb4ce7f54c14a144027b22724ef118

See more details on using hashes here.

File details

Details for the file django_rest_registration-0.9.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_rest_registration-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3260b0bc53246866dd857d577605b9fe6daf7890ed25fe7658d5885a602db110
MD5 e57dc63f36b5b219e41a539f854c0c8d
BLAKE2b-256 fffa265c5026e4a3a4d65a07e19d5e7ecc6970abe613ab3c946fde4e5e4a06a2

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