У меня есть серверная часть Django для мобильного приложения.
Я использую django rest framework (django-rest-auth), но я все еще пишу свои собственные представления и логику, потому что конечные точки API не основаны на модели.
Отправленный мне запрос имеет секретный ключ в заголовках, который связан с отдельными зарегистрированными устройствами. Наряду с этим он имеет почтовые данные, состоящие из идентификатора устройства и других деталей.
Как только я получу этот заголовок, используя request.META, как сохранить его в пользовательской модели (он будет обновляться при каждом входе пользователя в систему), чтобы потом его можно было использовать в качестве внешнего ключа для получения всех деталей, таких как пользователь и связанное с ним устройство.
class CustomLoginView(LoginView):
def get_response_serializer(self):
if getattr(settings, 'REST_USE_JWT', False):
response_serializer = JWTSerializer
else:
# print(self.request.data)
response_serializer = serializers.TokenSerializer
# response_serializer = {'data':response_serializer}
return response_serializer
def get_response(self):
# raise APIException("There was a problem!")
serializer_class = self.get_response_serializer()
# print(serializer_class.data)
try:
if getattr(settings, 'REST_USE_JWT', False):
data = {
'user': self.user,
'token': self.token
}
serializer = serializer_class(instance=data,
context={'request': self.request})
else:
print("hello")
serializer = serializer_class(instance=self.token,
context={'request': self.request})
print("BYE")
print(serializer.data)
# print(self.request.data)
try:
# print(serializer.data)
if 'email' not in self.request.POST:
return Response({'data':'message'})
return Response({'data':serializer.data,'status':1,'message':'Success'}, status=status.HTTP_200_OK)
except ValidationError as exc:
raise ValidationError({
'field_val1': exc.detail,
})
except:
print("in except")
raise APIException("There was a problem!")
def post(self, request, *args, **kwargs):
self.request = request
self.serializer = self.get_serializer(data=self.request.data,
context={'request': request})
print(self.request.data)
if self.serializer.is_valid():
print(request.META)
self.login()
return self.get_response()
else:
return Response({"data":[],"message":"Credentials are wrong",'status':0})
Моя User_Model
class User(AbstractUser):
"""User model."""
username = None
email = models.EmailField(_('email address'), unique=True)
mobile_token = models.CharField(max_length=20,blank=True)
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = []
objects = UserManager()
Мой UserManage ()
Класс UserManager (BaseUserManager):
"" "Определите менеджер модели для модели пользователя без поля имени пользователя." ""
use_in_migrations = True
def _create_user(self, email, password, **extra_fields):
"""Create and save a User with the given email and password."""
if not email:
raise ValueError('The given email must be set')
email = self.normalize_email(email)
user = self.model(email=email, **extra_fields)
user.set_password(password)
user.save(using=self._db)
return user
def create_user(self, email, password=None, **extra_fields):
"""Create and save a regular User with the given email and password."""
extra_fields.setdefault('is_staff', False)
extra_fields.setdefault('is_superuser', False)
return self._create_user(email, password, **extra_fields)
def create_superuser(self, email, password, **extra_fields):
"""Create and save a SuperUser with the given email and password."""
extra_fields.setdefault('is_staff', True)
extra_fields.setdefault('is_superuser', 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(email, password, **extra_fields)