Django использует otp (одноразовый пароль) для входа вместо пароля - PullRequest
1 голос
/ 26 мая 2019

Я использую django-rest-framework для создания логина для веб-приложения (веб-интерфейс находится в React), но мне нужно использовать только номер телефона и otp для входа в систему, без пароля.Отп отправляется на номер телефона пользователя.Я использую пользовательскую модель пользователя.Я просто не могу понять, как переопределить встроенный вид входа в систему.Я также пытаюсь использовать аутентификацию токена jwt с помощью djangorestframework-simplejwt.

Пожалуйста, помогите мне написать это.models.py

from django.db import models
from django.contrib.auth.models import AbstractBaseUser
from django.contrib.auth.models import PermissionsMixin
from django.utils import timezone

from .managers import UserManager


class User(AbstractBaseUser, PermissionsMixin):
    phone = models.CharField(max_length=10, unique=True)
    full_name = models.CharField(max_length=30)
    business_name = models.CharField(max_length=30)
    is_fos = models.BooleanField(default=False)
    is_staff = models.BooleanField(default=False)
    is_active = models.BooleanField(default=True)
    date_joined = models.DateTimeField(default=timezone.now)

    USERNAME_FIELD = 'phone'
    REQUIRED_FIELDS = ['full_name', 'business_name']

    objects = UserManager()

    def __str__(self):
        return self.full_name

Manager.py

from django.contrib.auth.base_user import BaseUserManager
from django.utils.translation import ugettext_lazy as _


class UserManager(BaseUserManager):
    """
    Custom user model manager where phone number is the unique identifiers
    for authentication instead of usernames.
    """
    def create_user(self, phone, full_name, business_name, **extra_fields):
        """
        Create and save a User with the given phone number.
        """
        if not phone:
            raise ValueError(_('Phone must be set'))
        user = self.model(phone=phone, full_name=full_name, business_name=business_name, **extra_fields)
        user.save()
        return user

    def create_superuser(self, phone, full_name, business_name, **extra_fields):
        """
        Create and save a SuperUser with the given phone number, name and buisness name.
        """
        extra_fields.setdefault('is_staff', True)
        extra_fields.setdefault('is_superuser', True)
        extra_fields.setdefault('is_active', True)

        if extra_fields.get('is_staff') is not True:
            raise ValueError(_('Superuser must have is_staff=True.'))
        if extra_fields.get('is_superuser') is not True:
            raise ValueError(_('Superuser must have is_superuser=True.'))
        return self.create_user(phone, full_name, business_name, **extra_fields)
...