123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- import os
- from django.contrib.auth.models import Group
- from django.dispatch import receiver
- from django.db.models.signals import post_migrate
- from django.contrib.auth import get_user_model
- from django.contrib.auth.hashers import make_password
- from django.conf import settings
- from tickets.models import TicketList
- User = get_user_model()
- @receiver(post_migrate)
- def create_initial_groups(sender, **kwargs):
- Group.objects.get_or_create(pk=21, name='METASERVICE-ADMIN')
- Group.objects.get_or_create(pk=22, name='METASERVICE-SUPERVISOR')
- Group.objects.get_or_create(pk=23, name='METASERVICE-SUPPORT')
- Group.objects.get_or_create(pk=24, name='METASERVICE-TECHSUPPORT')
- Group.objects.get_or_create(pk=31, name='PARTNER-ADMIN')
- Group.objects.get_or_create(pk=32, name='PARTNER-SUPERVISOR')
- Group.objects.get_or_create(pk=33, name='PARTNER-SUPPORT')
- Group.objects.get_or_create(pk=34, name='PARTNER-TECHSUPPORT')
- Group.objects.get_or_create(pk=41, name='PROVIDER')
- Group.objects.get_or_create(pk=51, name='CLIENT')
- Group.objects.get_or_create(pk=61, name='GUEST')
- Group.objects.get_or_create(pk=99, name='TEST')
- @receiver(post_migrate)
- def create_test_users(sender, **kwargs):
- """
- Создает тестовых пользователей, но только если установочный скрипт был запущен с параметром --test-users
- или была задана переменная окружения TEST_USERS=true.
- """
- if os.getenv('TEST_USERS') == 'true':
- password = make_password("sharix-open-test")
- test_group = Group.objects.get(pk=99)
- # Группа, в которой надо создать пользователя и их количество
- test_users = [
- ('METASERVICE-ADMIN', 1),
- ('METASERVICE-SUPERVISOR', 3),
- ('METASERVICE-SUPPORT', 3),
- ('METASERVICE-TECHSUPPORT', 3),
- ('PARTNER-ADMIN', 1),
- ('PARTNER-SUPERVISOR', 3),
- ('PARTNER-SUPPORT', 3),
- ('PARTNER-TECHSUPPORT', 3),
- ('PROVIDER', 3),
- ('CLIENT', 3),
- ('GUEST', 3)
- ]
- for test_user in test_users:
- group_name = test_user[0]
- group = Group.objects.get(name=group_name)
- for i in range(1, test_user[1] + 1):
- user, created = User.objects.get_or_create(
- phone_number=f"{group.pk}0{i}",
- defaults={
- 'last_name': i,
- 'first_name': group_name,
- 'email': f"test-{group_name.lower()}-{i}@domain.org",
- 'username': f"test-{group_name.lower()}-{i}",
- 'middle_name': "Test",
- 'password': password
- }
- )
- if created:
- user.groups.add(
- test_group,
- group
- )
- print(f"Test user created: {user}")
- @receiver(post_migrate)
- def create_initial_ticket_lists(sender, **kwargs):
- if sender.name == 'tickets':
- # METASERVICE
- ## ADMIN
- TicketList.objects.get_or_create(pk=2101, name='Активация партнеров (NEG_REQUEST)', group=Group.objects.get(name='METASERVICE-ADMIN'))
- TicketList.objects.get_or_create(pk=2102, name='Права в сервисе (ACCESS_REQUEST)', group=Group.objects.get(name='METASERVICE-ADMIN'))
- TicketList.objects.get_or_create(pk=2103, name='Проверка документов (ST_REQUEST)', group=Group.objects.get(name='METASERVICE-ADMIN'))
- ## SUPERVISOR
- TicketList.objects.get_or_create(pk=2201, name='Активность пользователей (ST_REQUEST)', group=Group.objects.get(name='METASERVICE-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=2202, name='Оперативный доступ (ST_REQUEST)', group=Group.objects.get(name='METASERVICE-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=2203, name='Оперативный доступ экстра (ACCESS_REQUEST)', group=Group.objects.get(name='METASERVICE-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=2204, name='Права сервиса (ST_REQUEST)', group=Group.objects.get(name='METASERVICE-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=2205, name='Проверка документов (ST_REQUEST)', group=Group.objects.get(name='METASERVICE-SUPERVISOR'))
- ## SUPPORT
- TicketList.objects.get_or_create(pk=2301, name='Входящие обычные заявки (ST_REQUEST)', group=Group.objects.get(name='METASERVICE-SUPPORT'))
- TicketList.objects.get_or_create(pk=2302, name='Заявки на услуги сервиса (SERVICE_REQUEST)', group=Group.objects.get(name='METASERVICE-SUPPORT'))
- ## TECHSUPPORT
- TicketList.objects.get_or_create(pk=2401, name='Входящие технические заявки (ST_REQUEST)', group=Group.objects.get(name='METASERVICE-TECHSUPPORT'))
- # PARTNER
- ## ADMIN
- TicketList.objects.get_or_create(pk=3101, name='Документы исполнителей (ST_REQUEST)', group=Group.objects.get(name='PARTNER-ADMIN'))
- TicketList.objects.get_or_create(pk=3102, name='Документы ресурсов (ST_REQUEST)', group=Group.objects.get(name='PARTNER-ADMIN'))
- TicketList.objects.get_or_create(pk=3103, name='Права в партнерке (ACCESS_REQUEST)', group=Group.objects.get(name='PARTNER-ADMIN'))
-
- ## SUPERVISOR
- TicketList.objects.get_or_create(pk=3201, name='Активность внутри партнера (ST_REQUEST)', group=Group.objects.get(name='PARTNER-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=3202, name='Документы исполнителей (ST_REQUEST)', group=Group.objects.get(name='PARTNER-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=3203, name='Документы ресурсов (ST_REQUEST)', group=Group.objects.get(name='PARTNER-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=3204, name='Доступ внутри партнера (ST_REQUEST)', group=Group.objects.get(name='PARTNER-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=3205, name='Оперативный доступ (ST_REQUEST)', group=Group.objects.get(name='PARTNER-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=3206, name='Оперативный доступ экстра (ST_REQUEST)', group=Group.objects.get(name='PARTNER-SUPERVISOR'))
- TicketList.objects.get_or_create(pk=3207, name='Ручное подтверждение заявок (ACCESS-REQUEST)', group=Group.objects.get(name='PARTNER-SUPERVISOR'))
-
- ## TECHSUPPORT
- TicketList.objects.get_or_create(pk=3401, name='Входящие технические заявки (ST_REQUEST)', group=Group.objects.get(name='PARTNER-TECHSUPPORT'))
- # Откючаем тестовых пользователей (если такие есть), если DEBUG=False и наоброт
- try:
- if Group.objects.filter(name="TEST").exists():
- test_group = Group.objects.get(name="TEST")
- users_in_test_group = User.objects.filter(groups=test_group)
- if users_in_test_group:
- users_in_test_group.update(is_active=settings.DEBUG)
- except:
- print("Test user validation is not available. Models have not been created yet")
|