From 9b430c7eb0328ab25d47e8e2653eeef28f1ffc05 Mon Sep 17 00:00:00 2001 From: Andrey Smakotin Date: Mon, 22 Dec 2025 10:44:42 +0300 Subject: [PATCH] =?UTF-8?q?=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=20=D0=BF=D0=BE=D1=80=D1=8F=D0=B4=D0=BE=D0=BA=20?= =?UTF-8?q?=D1=81=D0=BE=D0=B7=D0=B4=D0=B0=D0=BD=D0=B8=D1=8F=20=D1=80=D0=BE?= =?UTF-8?q?=D0=BB=D0=B5=D0=B9=20=D0=BF=D1=80=D0=B8=20=D0=BE=D0=B4=D0=BE?= =?UTF-8?q?=D0=B1=D1=80=D0=B5=D0=BD=D0=B8=D0=B8=20=D0=B7=D0=B0=D1=8F=D0=B2?= =?UTF-8?q?=D0=BA=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Перемещено создание системных ролей перед назначением роли владельцу - Теперь UserRole создается автоматически для владельца при одобрении заявки - Исправлена ошибка: роль назначалась до создания ролей в БД --- myproject/tenants/admin.py | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-) diff --git a/myproject/tenants/admin.py b/myproject/tenants/admin.py index b97cb34..3051120 100644 --- a/myproject/tenants/admin.py +++ b/myproject/tenants/admin.py @@ -355,10 +355,20 @@ class TenantRegistrationAdmin(admin.ModelAdmin): owner.save() logger.info(f"Аккаунт владельца создан: {owner.id} ({owner.email})") + # Создаем системные роли пользователей (ПЕРЕД назначением роли владельцу) + logger.info(f"Создание системных ролей для тенанта: {client.id}") + from user_roles.services import RoleService + + try: + RoleService.create_default_roles() + logger.info("Системные роли успешно созданы") + except Exception as e: + logger.error(f"Ошибка при создании ролей: {e}", exc_info=True) + # Не прерываем процесс, т.к. это не критично + # Назначаем роль owner владельцу try: from user_roles.models import Role - from user_roles.services import RoleService RoleService.assign_role_to_user(owner, Role.OWNER, created_by=None) logger.info(f"Роль owner назначена владельцу {owner.email}") except Exception as e: @@ -392,17 +402,6 @@ class TenantRegistrationAdmin(admin.ModelAdmin): logger.error(f"Ошибка при создании статусов заказов: {e}", exc_info=True) # Не прерываем процесс, т.к. это не критично - # Создаем системные роли пользователей - logger.info(f"Создание системных ролей для тенанта: {client.id}") - from user_roles.services import RoleService - - try: - RoleService.create_default_roles() - logger.info("Системные роли успешно созданы") - except Exception as e: - logger.error(f"Ошибка при создании ролей: {e}", exc_info=True) - # Не прерываем процесс, т.к. это не критично - # Создаем системные способы оплаты logger.info(f"Создание системных способов оплаты для тенанта: {client.id}") from django.core.management import call_command