summaryrefslogtreecommitdiff
path: root/scripts/2017-03-29-missing-rights.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2017-04-07 12:16:37 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2017-04-07 12:16:37 +0200
commit6b87dae76d931ead9838db1f66a6ff1fe1cc1dd1 (patch)
tree0a2273d9db0499214e18a041987339eac9d20ac9 /scripts/2017-03-29-missing-rights.py
parent75730c0ac55c935c03e58977405b4b8a2233595d (diff)
parent3d8b8d86f01ecb9b37e24e25fd15500b8f4fb2a0 (diff)
downloadIshtar-6b87dae76d931ead9838db1f66a6ff1fe1cc1dd1.tar.bz2
Ishtar-6b87dae76d931ead9838db1f66a6ff1fe1cc1dd1.zip
Merge branch 'master' into v0.9
Diffstat (limited to 'scripts/2017-03-29-missing-rights.py')
-rw-r--r--scripts/2017-03-29-missing-rights.py24
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)