| # 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) |