# use some undocumented Django tricks to execute custom logic after syncdb from django.db.models import signals from django.contrib import auth from django.conf import settings # In this file, it is critical that we import models *just like this*. In # particular, we *cannot* do import common; from autotest_lib... import models. # This is because when we pass the models module to signal.connect(), it # calls id() on the module, and the id() of a module can differ depending on how # it was imported. For that reason, we must import models as Django does -- not # through the autotest_lib magic set up through common.py. If you do that, the # connection won't work and the dispatcher will simply never call the method. from frontend.afe import models 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', 'aclgroup', 'profiler', 'atomicgroup', 'hostattribute'): for permission_type in ('add', 'change', 'delete'): codename = permission_type + '_' + model_name permissions = list(PermissionModel.objects.filter( codename=codename)) if len(permissions) == 0: if verbosity: print ' No permission ' + codename continue for permission in permissions: if permission not in have_permissions: if verbosity: print ' Adding permission ' + codename admin_group.permissions.add(permission) if verbosity: if created: print 'Created group "%s"' % BASIC_ADMIN else: print 'Group "%s" already exists' % BASIC_ADMIN if settings.AUTOTEST_CREATE_ADMIN_GROUPS: signals.post_syncdb.connect(create_admin_group, sender=models)