Skip to main content

Authentication and registration with django graphene and JWT

Project description

https://badge.fury.io/py/graphene-jwt-auth-registration.svg https://travis-ci.org/fivethreeo/graphene-jwt-auth-registration.svg?branch=master https://codecov.io/gh/fivethreeo/graphene-jwt-auth-registration/branch/master/graph/badge.svg

Authentication and registration using graphene and JWT

Documentation

Quickstart

Install Graphene JWT Auth Registration:

pip install graphene-jwt-auth-registration

Add it to your INSTALLED_APPS:

INSTALLED_APPS = [
    "django.contrib.auth",
    "django.contrib.contenttypes",
    "django.contrib.sites",

    ...

    "rest_framework",
    "rest_framework_jwt",
    "djoser",
    "graphene_django",

    "gjwt_auth",
]

Set AUTH_USER_MODEL:

AUTH_USER_MODEL = "gjwt_auth.User"

Add the JWTAuthenticationMiddleware:

MIDDLEWARE = [
    ...

    'gjwt_auth.middleware.JWTAuthenticationMiddleware',
]

Create graphene schema in yourproject/schema.py:

import graphene

from gjwt_auth.mutations import (
    Activate,
    DeleteAccount,
    Login,
    RefreshToken,
    Register,
    ResetPassword,
    ResetPasswordConfirm,
)

from gjwt_auth.schema import User, Viewer


class RootQuery(graphene.ObjectType):
    viewer = graphene.Field(Viewer)

    def resolve_viewer(self, info, **kwargs):
        if info.context.user.is_authenticated:
            return info.context.user
        return None


class Mutation(graphene.ObjectType):
    activate = Activate.Field()
    login = Login.Field()
    register = Register.Field()
    deleteAccount = DeleteAccount.Field()
    refreshToken = RefreshToken.Field()
    resetPassword = ResetPassword.Field()
    resetPasswordConfirm = ResetPasswordConfirm.Field()


schema = graphene.Schema(query=RootQuery, mutation=Mutation)

Set the graphene schema:

GRAPHENE = {
    'SCHEMA': 'yourproject.schema.schema'
}

Set djoser setttings:

DJOSER = {
    'DOMAIN': os.environ.get('DJANGO_DJOSER_DOMAIN', 'localhost:3000'),
    'SITE_NAME': os.environ.get('DJANGO_DJOSER_SITE_NAME', 'my site'),
    'PASSWORD_RESET_CONFIRM_URL': '?action=set-new-password&uid={uid}&token={token}',
    'ACTIVATION_URL': 'activate?uid={uid}&token={token}',
    'SEND_ACTIVATION_EMAIL': True,
}

Set jwt auth settings:

JWT_AUTH = {
    'JWT_ALLOW_REFRESH': True,
}

Add Graphene JWT Auth’s URL patterns:

from django.conf.urls import url
from django.views.decorators.csrf import csrf_exempt

from graphene_django.views import GraphQLView

...

urlpatterns = [
    ...
    url(r'^graphql', csrf_exempt(GraphQLView.as_view(graphiql=True))),
    ...
]

Running Tests

Does the code actually work?

source <YOURVIRTUALENV>/bin/activate
(myenv) $ pip install tox
(myenv) $ tox

Credits

Tools used in rendering this package:

History

0.1.0 (2019-06-04)

  • First release on PyPI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for graphene-jwt-auth-registration, version 0.3.2
Filename, size & hash File type Python version Upload date
graphene_jwt_auth_registration-0.3.2-py2.py3-none-any.whl (12.8 kB) View hashes Wheel py2.py3
graphene-jwt-auth-registration-0.3.2.tar.gz (11.9 kB) View hashes Source None

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page