[init] Initial commit
This commit is contained in:
@@ -0,0 +1,5 @@
|
||||
from django.contrib import admin
|
||||
|
||||
from users.models import User
|
||||
|
||||
admin.site.register(User)
|
||||
@@ -0,0 +1,6 @@
|
||||
from django.apps import AppConfig
|
||||
|
||||
|
||||
class UsersConfig(AppConfig):
|
||||
default_auto_field = "django.db.models.BigAutoField"
|
||||
name = "users"
|
||||
@@ -0,0 +1,97 @@
|
||||
# Generated by Django 5.0.3 on 2024-03-31 12:22
|
||||
|
||||
import django.contrib.auth.models
|
||||
import django.contrib.auth.validators
|
||||
import django.core.validators
|
||||
import django.db.models.deletion
|
||||
import django.utils.timezone
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
||||
dependencies = [
|
||||
('auth', '0012_alter_user_first_name_max_length'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='Achievements',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('name', models.CharField(max_length=255, verbose_name='Название достижения')),
|
||||
('info', models.TextField(max_length=255, verbose_name='Информация про достижение')),
|
||||
('file', models.FileField(upload_to='achievements', verbose_name='Файл достижения')),
|
||||
],
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='Skill',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('name', models.CharField(max_length=255, unique=True)),
|
||||
('level', models.IntegerField(validators=[django.core.validators.MinValueValidator(1), django.core.validators.MaxValueValidator(10)], verbose_name='уровень навыка')),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='Specialization',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('name', models.CharField(max_length=255, unique=True)),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='Tag',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('name', models.CharField(max_length=255, unique=True)),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='User',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('password', models.CharField(max_length=128, verbose_name='password')),
|
||||
('last_login', models.DateTimeField(blank=True, null=True, verbose_name='last login')),
|
||||
('is_superuser', models.BooleanField(default=False, help_text='Designates that this user has all permissions without explicitly assigning them.', verbose_name='superuser status')),
|
||||
('username', models.CharField(error_messages={'unique': 'A user with that username already exists.'}, help_text='Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.', max_length=150, unique=True, validators=[django.contrib.auth.validators.UnicodeUsernameValidator()], verbose_name='username')),
|
||||
('first_name', models.CharField(blank=True, max_length=150, verbose_name='first name')),
|
||||
('last_name', models.CharField(blank=True, max_length=150, verbose_name='last name')),
|
||||
('is_staff', models.BooleanField(default=False, help_text='Designates whether the user can log into this admin site.', verbose_name='staff status')),
|
||||
('is_active', models.BooleanField(default=True, help_text='Designates whether this user should be treated as active. Unselect this instead of deleting accounts.', verbose_name='active')),
|
||||
('date_joined', models.DateTimeField(default=django.utils.timezone.now, verbose_name='date joined')),
|
||||
('email', models.EmailField(max_length=254, unique=True, verbose_name='электронная почта')),
|
||||
('birthday', models.DateField(blank=True, help_text='Введите дату рождения', null=True, verbose_name='дата рождения')),
|
||||
('avatar', models.ImageField(blank=True, upload_to='avatars', verbose_name='Аватарка')),
|
||||
('country', models.CharField(blank=True, max_length=255, verbose_name='страна')),
|
||||
('city', models.CharField(blank=True, max_length=255, verbose_name='город')),
|
||||
('bio', models.TextField(blank=True, validators=[django.core.validators.MaxLengthValidator(512)], verbose_name='обо мне')),
|
||||
('experience', models.IntegerField(null=True, validators=[django.core.validators.MinValueValidator(0), django.core.validators.MinValueValidator(100)], verbose_name='опыт работы')),
|
||||
('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.group', verbose_name='groups')),
|
||||
('user_permissions', models.ManyToManyField(blank=True, help_text='Specific permissions for this user.', related_name='user_set', related_query_name='user', to='auth.permission', verbose_name='user permissions')),
|
||||
('achievements', models.ManyToManyField(blank=True, to='users.achievements', verbose_name='достижения')),
|
||||
('technologies', models.ManyToManyField(blank=True, to='users.skill', verbose_name='технологии')),
|
||||
('specialization', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='users.specialization', verbose_name='специализация')),
|
||||
('tag', models.ManyToManyField(blank=True, to='users.tag', verbose_name='теги')),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'user',
|
||||
'verbose_name_plural': 'users',
|
||||
'abstract': False,
|
||||
'swappable': 'AUTH_USER_MODEL',
|
||||
},
|
||||
managers=[
|
||||
('objects', django.contrib.auth.models.UserManager()),
|
||||
],
|
||||
),
|
||||
]
|
||||
@@ -0,0 +1,18 @@
|
||||
# Generated by Django 5.0.3 on 2024-03-31 13:48
|
||||
|
||||
from django.db import migrations
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('users', '0001_initial'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.RenameField(
|
||||
model_name='user',
|
||||
old_name='technologies',
|
||||
new_name='skills',
|
||||
),
|
||||
]
|
||||
@@ -0,0 +1,128 @@
|
||||
from django.contrib.auth.models import AbstractUser
|
||||
from django.core import validators
|
||||
from django.db import models
|
||||
|
||||
|
||||
class AbstractTag(models.Model):
|
||||
name = models.CharField(
|
||||
max_length=255,
|
||||
unique=True,
|
||||
)
|
||||
|
||||
class Meta:
|
||||
abstract = True
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
||||
|
||||
class Tag(AbstractTag):
|
||||
pass
|
||||
|
||||
|
||||
class Skill(AbstractTag):
|
||||
level = models.IntegerField(
|
||||
validators=[
|
||||
validators.MinValueValidator(1),
|
||||
validators.MaxValueValidator(10),
|
||||
],
|
||||
verbose_name="уровень навыка",
|
||||
)
|
||||
|
||||
|
||||
class Specialization(AbstractTag):
|
||||
pass
|
||||
|
||||
|
||||
class Achievements(models.Model):
|
||||
name = models.CharField(
|
||||
max_length=255,
|
||||
verbose_name="Название достижения",
|
||||
)
|
||||
|
||||
info = models.TextField(
|
||||
max_length=255,
|
||||
verbose_name="Информация про достижение",
|
||||
)
|
||||
|
||||
file = models.FileField(
|
||||
upload_to="achievements",
|
||||
verbose_name="Файл достижения",
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
||||
|
||||
class User(AbstractUser):
|
||||
email = models.EmailField("электронная почта", unique=True)
|
||||
|
||||
birthday = models.DateField(
|
||||
verbose_name="дата рождения",
|
||||
help_text="Введите дату рождения",
|
||||
blank=True,
|
||||
null=True,
|
||||
)
|
||||
|
||||
avatar = models.ImageField(
|
||||
upload_to="avatars",
|
||||
blank=True,
|
||||
verbose_name="Аватарка",
|
||||
)
|
||||
|
||||
country = models.CharField(
|
||||
blank=True,
|
||||
max_length=255,
|
||||
verbose_name="страна",
|
||||
)
|
||||
|
||||
city = models.CharField(
|
||||
blank=True,
|
||||
max_length=255,
|
||||
verbose_name="город",
|
||||
)
|
||||
|
||||
bio = models.TextField(
|
||||
blank=True,
|
||||
validators=[
|
||||
validators.MaxLengthValidator(
|
||||
512,
|
||||
),
|
||||
],
|
||||
verbose_name="обо мне",
|
||||
)
|
||||
|
||||
skills = models.ManyToManyField(
|
||||
Skill,
|
||||
blank=True,
|
||||
verbose_name="технологии",
|
||||
)
|
||||
|
||||
tag = models.ManyToManyField(
|
||||
Tag,
|
||||
blank=True,
|
||||
verbose_name="теги",
|
||||
)
|
||||
|
||||
experience = models.IntegerField(
|
||||
validators=[
|
||||
validators.MinValueValidator(0),
|
||||
validators.MinValueValidator(100),
|
||||
],
|
||||
verbose_name="опыт работы",
|
||||
null=True,
|
||||
)
|
||||
|
||||
achievements = models.ManyToManyField(
|
||||
Achievements,
|
||||
blank=True,
|
||||
verbose_name="достижения",
|
||||
)
|
||||
|
||||
specialization = models.ForeignKey(
|
||||
Specialization,
|
||||
on_delete=models.CASCADE,
|
||||
blank=True,
|
||||
verbose_name="специализация",
|
||||
null=True,
|
||||
)
|
||||
@@ -0,0 +1,26 @@
|
||||
import rest_framework.serializers
|
||||
|
||||
import users.models
|
||||
|
||||
|
||||
class UserSerializer(rest_framework.serializers.ModelSerializer):
|
||||
class Meta:
|
||||
model = users.models.User
|
||||
fields = (
|
||||
"email",
|
||||
"birthday",
|
||||
"country",
|
||||
"city",
|
||||
"bio",
|
||||
"avatar",
|
||||
"password",
|
||||
"first_name",
|
||||
"last_name",
|
||||
"tag",
|
||||
"specialization",
|
||||
"experience",
|
||||
"achievements",
|
||||
"username",
|
||||
)
|
||||
|
||||
extra_kwargs = {"password": {"write_only": True}}
|
||||
@@ -0,0 +1,47 @@
|
||||
import rest_framework.generics
|
||||
import rest_framework.permissions
|
||||
import rest_framework.response
|
||||
import rest_framework.viewsets
|
||||
|
||||
import users.models
|
||||
import users.serializers
|
||||
|
||||
|
||||
class UserViewSet(rest_framework.viewsets.ModelViewSet):
|
||||
http_method_names = ("get",)
|
||||
|
||||
queryset = users.models.User.objects.all()
|
||||
serializer_class = users.serializers.UserSerializer
|
||||
permission_classes = [rest_framework.permissions.IsAuthenticated]
|
||||
|
||||
|
||||
class RegisterView(rest_framework.generics.CreateAPIView):
|
||||
http_method_names = ("post",)
|
||||
serializer_class = users.serializers.UserSerializer
|
||||
|
||||
def post(self, request):
|
||||
if users.models.User.objects.filter(
|
||||
username=request.data.get("username"),
|
||||
).exists():
|
||||
return rest_framework.response.Response(
|
||||
{
|
||||
"username": [
|
||||
"пользователь с таким именем уже существует.",
|
||||
],
|
||||
},
|
||||
status=rest_framework.status.HTTP_409_CONFLICT,
|
||||
)
|
||||
|
||||
serializer = self.get_serializer(data=request.data)
|
||||
if serializer.is_valid():
|
||||
serializer.save()
|
||||
|
||||
return rest_framework.response.Response(
|
||||
serializer.data,
|
||||
status=rest_framework.status.HTTP_201_CREATED,
|
||||
)
|
||||
|
||||
return rest_framework.response.Response(
|
||||
serializer.errors,
|
||||
status=rest_framework.status.HTTP_400_BAD_REQUEST,
|
||||
)
|
||||
Reference in New Issue
Block a user