diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-04-07 12:22:27 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-04-07 12:22:27 +0200 |
commit | 93364489ab4e6daf16f924b2d8212f7fcdc5e477 (patch) | |
tree | e0686c289c399330f414b50ff8ef58f642833db2 /scripts/2017-03-29-missing-rights.py | |
parent | c788bef47de6bca5dda5dd1fa67dd6a2ac02e9b9 (diff) | |
parent | a8271676a0598594762cc53e4f577337eb275313 (diff) | |
download | Ishtar-93364489ab4e6daf16f924b2d8212f7fcdc5e477.tar.bz2 Ishtar-93364489ab4e6daf16f924b2d8212f7fcdc5e477.zip |
Merge branch 'v0.9' into wheezy
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) |