init commit

This commit is contained in:
2025-05-06 20:44:33 +09:00
commit 91f0d54563
5567 changed files with 948185 additions and 0 deletions

View File

@@ -0,0 +1,3 @@
from django.contrib import admin
# Register your models here.

View File

@@ -0,0 +1,19 @@
# backend/apps/users/admin.py
from django.contrib import admin
from django.contrib.auth.admin import UserAdmin as BaseUserAdmin
from .models import User
@admin.register(User)
class UserAdmin(BaseUserAdmin):
list_display = ('username', 'email', 'full_name', 'is_staff', 'is_active')
list_filter = ('is_staff', 'is_superuser', 'is_active', 'groups')
search_fields = ('username', 'email', 'full_name')
fieldsets = (
(None, {'fields': ('username', 'password')}),
('Персональное', {'fields': ('full_name', 'bio', 'avatar')}),
('Контакты', {'fields': ('email',)}),
('Права доступа', {'fields': ('is_active', 'is_staff', 'is_superuser', 'groups', 'user_permissions')}),
('Важные даты', {'fields': ('last_login', 'date_joined')}),
)

View File

@@ -0,0 +1,3 @@
from django.db import models
# Create your models here.

View File

@@ -0,0 +1,10 @@
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
full_name = models.CharField(max_length=150, blank=True)
bio = models.TextField(blank=True)
avatar = models.ImageField(upload_to='avatars/', null=True, blank=True)
def __str__(self):
return self.username

View File

@@ -0,0 +1,37 @@
from django.contrib.auth.models import AbstractUser, Group, Permission
from django.db import models
class User(AbstractUser):
full_name = models.CharField(max_length=150, blank=True)
bio = models.TextField(blank=True)
avatar = models.ImageField(upload_to='avatars/', null=True, blank=True)
# Переопределяем поля групп и разрешений, чтобы избежать конфликтов обратных связей
groups = models.ManyToManyField(
Group,
related_name='custom_user_set',
blank=True,
help_text='The groups this user belongs to.',
verbose_name='groups',
)
user_permissions = models.ManyToManyField(
Permission,
related_name='custom_user_set',
blank=True,
help_text='Specific permissions for this user.',
verbose_name='user permissions',
)
def __str__(self):
return self.username
```python
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
full_name = models.CharField(max_length=150, blank=True)
bio = models.TextField(blank=True)
avatar = models.ImageField(upload_to='avatars/', null=True, blank=True)
def __str__(self):
return self.username

View File

@@ -0,0 +1,38 @@
from django.contrib.auth.models import AbstractUser, Group, Permission
from django.db import models
class User(AbstractUser):
full_name = models.CharField(max_length=150, blank=True)
bio = models.TextField(blank=True)
avatar = models.ImageField(upload_to='avatars/', null=True, blank=True)
# Переопределяем поля групп и разрешений, чтобы избежать конфликтов обратных связей
groups = models.ManyToManyField(
Group,
related_name='custom_user_set',
blank=True,
help_text='The groups this user belongs to.',
verbose_name='groups',
)
user_permissions = models.ManyToManyField(
Permission,
related_name='custom_user_set',
blank=True,
help_text='Specific permissions for this user.',
verbose_name='user permissions',
)
def __str__(self):
return self.username
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
full_name = models.CharField(max_length=150, blank=True)
bio = models.TextField(blank=True)
avatar = models.ImageField(upload_to='avatars/', null=True, blank=True)
def __str__(self):
return self.username

View File

@@ -0,0 +1,104 @@
# users/models.py
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
"""
Пользовательская модель, расширяющая стандартную AbstractUser.
"""
full_name = models.CharField(
max_length=150,
blank=True,
help_text='Полное имя пользователя'
)
bio = models.TextField(
blank=True,
help_text='Краткая биография пользователя'
)
avatar = models.ImageField(
upload_to='avatars/',
null=True,
blank=True,
help_text='Аватар пользователя'
)
def __str__(self):
return self.username
def get_full_name(self):
"""
Возвращает полное имя пользователя.
"""
return self.full_name if self.full_name else self.username
def get_short_name(self):
"""
Возвращает короткое имя пользователя.
"""
return self.username
def get_bio(self):
"""
Возвращает биографию пользователя.
"""
return self.bio if self.bio else "Нет информации о пользователе"
def get_avatar(self):
"""
Возвращает URL аватара пользователя.
"""
return self.avatar.url if self.avatar else None
def get_user_info(self):
"""
Возвращает словарь с информацией о пользователе.
"""
return {
'username': self.username,
'full_name': self.get_full_name(),
'bio': self.get_bio(),
'avatar': self.get_avatar()
}
def get_user_links(self):
"""
Возвращает список ссылок пользователя.
"""
from links.models import Link
return Link.objects.filter(owner=self).values('title', 'url')
def get_user_design(self):
"""
Возвращает настройки дизайна пользователя.
"""
from customization.models import DesignSettings
try:
design = DesignSettings.objects.get(user=self)
return {
'theme_color': design.theme_color,
'background_image': design.background_image.url if design.background_image else None,
'font_family': design.font_family,
'custom_css': design.custom_css
}
except DesignSettings.DoesNotExist:
return None
def get_user_groups(self):
"""
Возвращает группы пользователя.
"""
return self.groups.all().values('name')
def get_user_permissions(self):
"""
Возвращает разрешения пользователя.
"""
return self.user_permissions.all().values('codename')
def get_user_permissions_list(self):
"""
Возвращает список разрешений пользователя.
"""
return list(self.get_user_permissions().values_list('codename', flat=True))
def get_user_permissions_dict(self):
"""
Возвращает словарь с разрешениями пользователя.
"""
return {perm.codename: perm.name for perm in self.user_permissions.all()}
def get_user_permissions_dict_list(self):
"""
Возвращает список словарей с разрешениями пользователя.
"""
return [{'codename': perm.codename, 'name': perm.name} for perm in self.user_permissions.all()]

View File

@@ -0,0 +1,97 @@
# users/models.py
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
"""
Пользовательская модель, расширяющая стандартную AbstractUser.
"""
full_name = models.CharField(
max_length=150,
blank=True,
help_text='Полное имя пользователя'
)
bio = models.TextField(
blank=True,
help_text='Краткая биография пользователя'
)
avatar = models.ImageField(
upload_to='avatars/',
null=True,
blank=True,
help_text='Аватар пользователя'
)
def __str__(self):
return self.username
def get_full_name(self):
"""
Возвращает полное имя пользователя.
"""
return self.full_name if self.full_name else self.username
def get_short_name(self):
"""
Возвращает короткое имя пользователя.
"""
return self.username
def get_bio(self):
"""
Возвращает биографию пользователя.
"""
return self.bio if self.bio else "Нет информации о пользователе"
def get_avatar(self):
"""
Возвращает URL аватара пользователя.
"""
return self.avatar.url if self.avatar else None
def get_user_info(self):
"""
Возвращает словарь с информацией о пользователе.
"""
return {
'username': self.username,
'full_name': self.get_full_name(),
'bio': self.get_bio(),
'avatar': self.get_avatar()
}
def get_user_links(self):
"""
Возвращает список ссылок пользователя.
"""
from links.models import Link
return Link.objects.filter(group__owner=self).values('title', 'url')
def get_user_design(self):
"""
Возвращает настройки дизайна пользователя.
"""
from customization.models import DesignSettings
try:
design = DesignSettings.objects.get(user=self)
return {
'theme_color': design.theme_color,
'background_image': design.background_image.url if design.background_image else None,
'font_family': design.font_family,
'custom_css': design.custom_css
}
except DesignSettings.DoesNotExist:
return None
def get_user_groups(self):
"""
Возвращает группы пользователя.
"""
return list(self.link_groups.values('title', 'order'))
def get_user_permissions(self):
"""
Возвращает разрешения пользователя.
"""
return list(self.user_permissions.values_list('codename', flat=True))

View File

@@ -0,0 +1,97 @@
# users/models.py
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
"""
Пользовательская модель, расширяющая стандартную AbstractUser.
"""
full_name = models.CharField(
max_length=150,
blank=True,
help_text='Полное имя пользователя'
)
bio = models.TextField(
blank=True,
help_text='Краткая биография пользователя'
)
avatar = models.ImageField(
upload_to='frontend/assets/img/avatars/',
null=True,
blank=True,
help_text='Аватар пользователя'
)
def __str__(self):
return self.username
def get_full_name(self):
"""
Возвращает полное имя пользователя.
"""
return self.full_name if self.full_name else self.username
def get_short_name(self):
"""
Возвращает короткое имя пользователя.
"""
return self.username
def get_bio(self):
"""
Возвращает биографию пользователя.
"""
return self.bio if self.bio else "Нет информации о пользователе"
def get_avatar(self):
"""
Возвращает URL аватара пользователя.
"""
return self.avatar.url if self.avatar else None
def get_user_info(self):
"""
Возвращает словарь с информацией о пользователе.
"""
return {
'username': self.username,
'full_name': self.get_full_name(),
'bio': self.get_bio(),
'avatar': self.get_avatar()
}
def get_user_links(self):
"""
Возвращает список ссылок пользователя.
"""
from links.models import Link
return Link.objects.filter(group__owner=self).values('title', 'url')
def get_user_design(self):
"""
Возвращает настройки дизайна пользователя.
"""
from customization.models import DesignSettings
try:
design = DesignSettings.objects.get(user=self)
return {
'theme_color': design.theme_color,
'background_image': design.background_image.url if design.background_image else None,
'font_family': design.font_family,
'custom_css': design.custom_css
}
except DesignSettings.DoesNotExist:
return None
def get_user_groups(self):
"""
Возвращает группы пользователя.
"""
return list(self.link_groups.values('title', 'order'))
def get_user_permissions(self):
"""
Возвращает разрешения пользователя.
"""
return list(self.user_permissions.values_list('codename', flat=True))

View File

@@ -0,0 +1,97 @@
# users/models.py
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
"""
Пользовательская модель, расширяющая стандартную AbstractUser.
"""
full_name = models.CharField(
max_length=150,
blank=True,
help_text='Полное имя пользователя'
)
bio = models.TextField(
blank=True,
help_text='Краткая биография пользователя'
)
avatar = models.ImageField(
upload_to='avatars/',
null=True,
blank=True,
help_text='Аватар пользователя'
)
def __str__(self):
return self.username
def get_full_name(self):
"""
Возвращает полное имя пользователя.
"""
return self.full_name if self.full_name else self.username
def get_short_name(self):
"""
Возвращает короткое имя пользователя.
"""
return self.username
def get_bio(self):
"""
Возвращает биографию пользователя.
"""
return self.bio if self.bio else "Нет информации о пользователе"
def get_avatar(self):
"""
Возвращает URL аватара пользователя.
"""
return self.avatar.url if self.avatar else None
def get_user_info(self):
"""
Возвращает словарь с информацией о пользователе.
"""
return {
'username': self.username,
'full_name': self.get_full_name(),
'bio': self.get_bio(),
'avatar': self.get_avatar()
}
def get_user_links(self):
"""
Возвращает список ссылок пользователя.
"""
from links.models import Link
return Link.objects.filter(group__owner=self).values('title', 'url')
def get_user_design(self):
"""
Возвращает настройки дизайна пользователя.
"""
from customization.models import DesignSettings
try:
design = DesignSettings.objects.get(user=self)
return {
'theme_color': design.theme_color,
'background_image': design.background_image.url if design.background_image else None,
'font_family': design.font_family,
'custom_css': design.custom_css
}
except DesignSettings.DoesNotExist:
return None
def get_user_groups(self):
"""
Возвращает группы пользователя.
"""
return list(self.link_groups.values('title', 'order'))
def get_user_permissions(self):
"""
Возвращает разрешения пользователя.
"""
return list(self.user_permissions.values_list('codename', flat=True))

View File

@@ -0,0 +1,101 @@
# users/models.py
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
"""
Пользовательская модель, расширяющая стандартную AbstractUser.
"""
full_name = models.CharField(
max_length=150,
blank=True,
help_text='Полное имя пользователя'
)
bio = models.TextField(
blank=True,
help_text='Краткая биография пользователя'
)
avatar = models.ImageField(
upload_to='avatars/',
null=True,
blank=True,
help_text='Аватар пользователя'
)
cover = models.ImageField(
upload_to='avatars/covers/',
null=True,
blank=True,
)
def __str__(self):
return self.username
def get_full_name(self):
"""
Возвращает полное имя пользователя.
"""
return self.full_name if self.full_name else self.username
def get_short_name(self):
"""
Возвращает короткое имя пользователя.
"""
return self.username
def get_bio(self):
"""
Возвращает биографию пользователя.
"""
return self.bio if self.bio else "Нет информации о пользователе"
def get_avatar(self):
"""
Возвращает URL аватара пользователя.
"""
return self.avatar.url if self.avatar else None
def get_user_info(self):
"""
Возвращает словарь с информацией о пользователе.
"""
return {
'username': self.username,
'full_name': self.get_full_name(),
'bio': self.get_bio(),
'avatar': self.get_avatar()
}
def get_user_links(self):
"""
Возвращает список ссылок пользователя.
"""
from links.models import Link
return Link.objects.filter(group__owner=self).values('title', 'url')
def get_user_design(self):
"""
Возвращает настройки дизайна пользователя.
"""
from customization.models import DesignSettings
try:
design = DesignSettings.objects.get(user=self)
return {
'theme_color': design.theme_color,
'background_image': design.background_image.url if design.background_image else None,
'font_family': design.font_family,
'custom_css': design.custom_css
}
except DesignSettings.DoesNotExist:
return None
def get_user_groups(self):
"""
Возвращает группы пользователя.
"""
return list(self.link_groups.values('title', 'order'))
def get_user_permissions(self):
"""
Возвращает разрешения пользователя.
"""
return list(self.user_permissions.values_list('codename', flat=True))

View File

@@ -0,0 +1,5 @@
from django.urls import path
urlpatterns = [
# дополнительные эндпоинты по ссылкам
]