mirror of
https://gitlab.com/megazordpobeda/DataRush.git
synced 2026-05-23 20:17:10 +00:00
add simple user admin and hash password
This commit is contained in:
@@ -27,6 +27,7 @@ router = Router(tags=["user"])
|
|||||||
)
|
)
|
||||||
def sign_up(request, data: RegisterSchema):
|
def sign_up(request, data: RegisterSchema):
|
||||||
user = User(**data.dict())
|
user = User(**data.dict())
|
||||||
|
user.password = user.make_password()
|
||||||
user.full_clean()
|
user.full_clean()
|
||||||
user.save()
|
user.save()
|
||||||
|
|
||||||
@@ -47,7 +48,7 @@ def sign_in(request, data: LoginSchema):
|
|||||||
user = User.objects.filter(email=data.email).first()
|
user = User.objects.filter(email=data.email).first()
|
||||||
if not user:
|
if not user:
|
||||||
raise AuthenticationError
|
raise AuthenticationError
|
||||||
if user.password != data.password:
|
if not user.check_password(data.password):
|
||||||
raise AuthenticationError
|
raise AuthenticationError
|
||||||
|
|
||||||
token = BearerAuth.generate_jwt(user)
|
token = BearerAuth.generate_jwt(user)
|
||||||
|
|||||||
@@ -0,0 +1,9 @@
|
|||||||
|
from django.contrib import admin
|
||||||
|
|
||||||
|
from apps.user.models import User
|
||||||
|
|
||||||
|
|
||||||
|
@admin.register(User)
|
||||||
|
class UserAdmin(admin.ModelAdmin):
|
||||||
|
list_display = ("email", "username")
|
||||||
|
search_fields = ("id", "email", "username")
|
||||||
@@ -5,3 +5,4 @@ class UsersConfig(AppConfig):
|
|||||||
default_auto_field = "django.db.models.BigAutoField"
|
default_auto_field = "django.db.models.BigAutoField"
|
||||||
name = "apps.user"
|
name = "apps.user"
|
||||||
label = "user"
|
label = "user"
|
||||||
|
verbose_name = "Пользователи"
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.contrib.auth.hashers import check_password, make_password
|
||||||
|
|
||||||
from apps.core.models import BaseModel
|
from apps.core.models import BaseModel
|
||||||
|
|
||||||
@@ -11,7 +12,13 @@ class UserRole(models.Choices):
|
|||||||
class User(BaseModel):
|
class User(BaseModel):
|
||||||
email = models.EmailField(unique=True, verbose_name="почта")
|
email = models.EmailField(unique=True, verbose_name="почта")
|
||||||
username = models.SlugField(unique=True, verbose_name="юзернейм")
|
username = models.SlugField(unique=True, verbose_name="юзернейм")
|
||||||
password = models.TextField(verbose_name="пароль")
|
password = models.TextField(verbose_name="пароль", editable=False)
|
||||||
|
|
||||||
|
def make_password(self):
|
||||||
|
return make_password(self.password)
|
||||||
|
|
||||||
|
def check_password(self, password):
|
||||||
|
return check_password(self.password, password)
|
||||||
|
|
||||||
status = models.CharField(
|
status = models.CharField(
|
||||||
max_length=10, choices=UserRole, default="student"
|
max_length=10, choices=UserRole, default="student"
|
||||||
|
|||||||
@@ -483,6 +483,10 @@ DJANGO_GUID = {
|
|||||||
|
|
||||||
LANGUAGE_COOKIE_AGE = 31449600
|
LANGUAGE_COOKIE_AGE = 31449600
|
||||||
|
|
||||||
|
PASSWORD_HASHERS = [
|
||||||
|
"django.contrib.auth.hashers.Argon2PasswordHasher",
|
||||||
|
]
|
||||||
|
|
||||||
LANGUAGE_COOKIE_DOMAIN = None
|
LANGUAGE_COOKIE_DOMAIN = None
|
||||||
|
|
||||||
LANGUAGE_COOKIE_HTTPONLY = False
|
LANGUAGE_COOKIE_HTTPONLY = False
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ version = "0.1.0"
|
|||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
requires-python = ">=3.10,<3.12"
|
requires-python = ">=3.10,<3.12"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
|
"argon2-cffi>=23.1.0",
|
||||||
"celery>=5.4.0",
|
"celery>=5.4.0",
|
||||||
"colorlog>=6.9.0",
|
"colorlog>=6.9.0",
|
||||||
"django-cors-headers>=4.6.0",
|
"django-cors-headers>=4.6.0",
|
||||||
|
|||||||
Reference in New Issue
Block a user