blob: c8f83804702e93f67c491085c114c219961f509e [file] [log] [blame]
# use some undocumented Django tricks to execute custom logic after syncdb
from django.dispatch import dispatcher
from django.db.models import signals
import frontend.afe.models
from django.contrib import auth
BASIC_ADMIN = 'Basic admin'
def create_admin_group(app, created_models, verbosity, **kwargs):
"""\
Create a basic admin group with permissions for managing basic autotest
objects.
"""
admin_group, created = auth.models.Group.objects.get_or_create(
name=BASIC_ADMIN)
admin_group.save() # must save before adding permissions
PermissionModel = auth.models.Permission
have_permissions = list(admin_group.permissions.all())
for model_name in ('host', 'label', 'test', 'acl_group'):
for permission_type in ('add', 'change', 'delete'):
codename = permission_type + '_' + model_name
permissions = list(PermissionModel.objects.filter(
codename=codename))
if len(permissions) == 0:
print ' No permission ' + codename
continue
for permission in permissions:
if permission not in have_permissions:
print ' Adding permission ' + codename
admin_group.permissions.add(permission)
if created:
print 'Created group "%s"' % BASIC_ADMIN
else:
print 'Group "%s" already exists' % BASIC_ADMIN
dispatcher.connect(create_admin_group, sender=frontend.afe.models,
signal=signals.post_syncdb)