через форму (дефолтная UserCreationForm) и через приложение (Unity, но это не важно). Хочу, чтобы допустимые юзернеймы и пароли при регистрации через приложение были такими же, как и через форму. Сейчас код выглядит так, и все вроде работает, но можно ли сделать лучше? import re
from django.contrib.auth.models import User
from django.http import JsonResponse
from django.views.generic.base import View
from django.contrib.auth import password_validation
from django.core.exceptions import ValidationError
class RegisterView(View):
usernameregex = re.compile(r'^[\w.@+-]+$')
def get(self, request):
if ('HTTP_USER_AGENT' in request.META and
request.META['HTTP_USER_AGENT'] == 'Unity'):
username = request.GET.get('username', '')
password = request.GET.get('password', '')
errors = []
if len(username) > 150:
errors.append('too long')
if not self.usernameregex.match(username):
errors.append('invalid characters')
if User.objects.filter(username=username).exists():
errors.append('already exists')
if not errors:
user = User.objects.create_user(username)
try:
password_validation.validate_password(password, user=user)
except ValidationError as e:
user.delete()
errors.extend(list(e))
if not errors:
user.set_password(password)
user.save()
return JsonResponse({'status' : 'success'})
return JsonResponse({'status' : 'error', 'errors' : errors})
Не увидел в примере, что если UA != Unity, то есть, рега через форму. Значит, это другая вюха. Если это чекается и там и там, то будет иметь смысл проводить валидацию просто на уровне полей модели. Если речь идёт о реге, то так или иначе это что то от AbstractUser, какие то наследники. Ну и пилить валидацию на поля.
Обсуждают сегодня