Skip to content
Merged
7 changes: 2 additions & 5 deletions taccsite_cms/__init__.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,3 @@
# from django.conf import settings
#
# if settings.CONSOLE_LOG_ENABLED:
# print("--> Parsing FILE: cms-template-setup01/taccsite_cms/__init__.py")
from .apps import TaccsiteCmsConfig

# print("--> Parsing FILE: cms-template-setup01/taccsite_cms/__init__.py")
default_app_config = f'{TaccsiteCmsConfig.name}.apps.TaccsiteCmsConfig'
43 changes: 43 additions & 0 deletions taccsite_cms/apps.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
import logging
from django.apps import AppConfig
from django.db.models.signals import post_migrate

logger = logging.getLogger(f"portal.{__name__}")

class TaccsiteCmsConfig(AppConfig):
name = 'taccsite_cms'
verbose_name = 'TACC CMS'

def ready(self):
post_migrate.connect(self.create_groups, sender=self)

def create_groups(self, sender, **kwargs):
from django.contrib.auth.models import Group

from .management.commands.group_perms.text_editor_basic import \
set_group_perms as add_text_editor_basic, GROUP_NAME
from .management.commands.group_perms.text_editor_advanced import \
set_group_perms as add_text_editor_advanced
from .management.commands.group_perms.media_editor_basic import \
set_group_perms as add_media_editor_basic
from .management.commands.group_perms.media_editor_advanced import \
set_group_perms as add_media_editor_advanced
from .management.commands.group_perms.grid_editor_basic import \
set_group_perms as add_grid_editor_basic
from .management.commands.group_perms.grid_editor_advanced import \
set_group_perms as add_grid_editor_advanced

groups_exist = Group.objects.filter(name=GROUP_NAME).exists()
action = 'Updating' if groups_exist else 'Creating'

logger.info(f'{action} CMS groups via post_migrate signal')
try:
add_text_editor_basic()
add_text_editor_advanced()
add_media_editor_basic()
add_media_editor_advanced()
add_grid_editor_basic()
add_grid_editor_advanced()
logger.info(f'Finished {action.lower()} CMS groups')
except Exception as e:
logger.error(f'Error creating CMS groups: {e}', exc_info=True)
39 changes: 5 additions & 34 deletions taccsite_cms/migrations/0001_add_groups.py
Original file line number Diff line number Diff line change
@@ -1,42 +1,13 @@
from django.db import migrations

def add_groups(apps, schema_editor):
from taccsite_cms.management.commands.group_perms.text_editor_basic import set_group_perms as add_text_editor_basic
from taccsite_cms.management.commands.group_perms.text_editor_advanced import set_group_perms as add_text_editor_advanced
from taccsite_cms.management.commands.group_perms.media_editor_basic import set_group_perms as add_media_editor_basic
from taccsite_cms.management.commands.group_perms.media_editor_advanced import set_group_perms as add_media_editor_advanced
from taccsite_cms.management.commands.group_perms.grid_editor_basic import set_group_perms as add_grid_editor_basic
from taccsite_cms.management.commands.group_perms.grid_editor_advanced import set_group_perms as add_grid_editor_advanced
# No-op since group creation became handled by post_migrate signal (see apps.py)

add_text_editor_basic()
add_text_editor_advanced()
add_media_editor_basic()
add_media_editor_advanced()
add_grid_editor_basic()
add_grid_editor_advanced()
# Retained for backwards-compatibility / migration history integrity

def remove_groups(apps, schema_editor):
from taccsite_cms.management.commands.group_perms.text_editor_basic import GROUP_NAME as text_editor_basic_name
from taccsite_cms.management.commands.group_perms.text_editor_advanced import GROUP_NAME as text_editor_advanced_name
from taccsite_cms.management.commands.group_perms.media_editor_basic import GROUP_NAME as media_editor_basic_name
from taccsite_cms.management.commands.group_perms.media_editor_advanced import GROUP_NAME as media_editor_advanced_name
from taccsite_cms.management.commands.group_perms.grid_editor_basic import GROUP_NAME as grid_editor_basic_name
from taccsite_cms.management.commands.group_perms.grid_editor_advanced import GROUP_NAME as grid_editor_advanced_name

Group = apps.get_model('auth', 'Group')

group_names = [
text_editor_basic_name,
text_editor_advanced_name,
media_editor_basic_name,
media_editor_advanced_name,
grid_editor_basic_name,
grid_editor_advanced_name,
]

Group.objects.filter(name__in=group_names).delete()
def noop(apps, schema_editor):
pass

class Migration(migrations.Migration):
operations = [
migrations.RunPython(add_groups, reverse_code=remove_groups),
migrations.RunPython(noop),
]
8 changes: 8 additions & 0 deletions taccsite_cms/models.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
from django.db import models

class DummyModel(models.Model):
"""
Exists solely to trigger Django to send post_migrate signal (see apps.py)
"""
class Meta:
app_label = 'taccsite_cms'