diff options
| author | Valérie-Emma Leroux <valerie-emma.leroux@iggdrasil.net> | 2017-04-07 11:40:31 +0200 | 
|---|---|---|
| committer | Valérie-Emma Leroux <valerie-emma.leroux@iggdrasil.net> | 2017-04-07 11:40:31 +0200 | 
| commit | 655236dd5d04d6527184a58ef8622e75c73f8a65 (patch) | |
| tree | f773b80964981c231c892ee5255b94285bc5620a /scripts/2017-03-29-missing-rights.py | |
| parent | dc08e5f643562a6ecf3b208c1e2cd44e5350af3c (diff) | |
| parent | a4f1766d2217b1a3bc4d1d17625d9d808eed7416 (diff) | |
| download | Ishtar-655236dd5d04d6527184a58ef8622e75c73f8a65.tar.bz2 Ishtar-655236dd5d04d6527184a58ef8622e75c73f8a65.zip | |
Merge branch 'master' of git.iggdrasil.net:/srv/git/ishtar
Conflicts:
	archaeological_operations/templates/ishtar/sheet_operation.html
Diffstat (limited to 'scripts/2017-03-29-missing-rights.py')
| -rw-r--r-- | scripts/2017-03-29-missing-rights.py | 24 | 
1 files changed, 24 insertions, 0 deletions
| diff --git a/scripts/2017-03-29-missing-rights.py b/scripts/2017-03-29-missing-rights.py new file mode 100644 index 000000000..81a9b86ee --- /dev/null +++ b/scripts/2017-03-29-missing-rights.py @@ -0,0 +1,24 @@ +from django.contrib.auth.models import Group, Permission + +for group in Group.objects.all(): +    if ':' not in group.name or u"rattaché" in group.name: +        continue +    permissions = [] +    for perm in group.permissions.all(): +        codenames = perm.codename.split('_') +        own_codename = codenames[0] + "_own_" + '_'.join(codenames[1:]) +        if Permission.objects.filter(codename=own_codename).count(): +            permissions.append(Permission.objects.get(codename=own_codename)) +    if not permissions: +        print(u'No permission: ' + group.name) +        continue +    names = group.name.split(':') +    if Group.objects.filter(name__startswith=names[0] + u"rattaché", +                            name__endswith=names[1]).count(): +        print(u'Already here: ' + group.name) +        continue +    name = names[0] + u"rattachés " + u":" + names[1] +    new_group = Group.objects.create(name=name) +    for perm in permissions: +        new_group.permissions.add(perm) +    print(u'New: ' + group.name) | 
