summaryrefslogtreecommitdiff
path: root/scripts/2017-03-29-missing-rights.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2017-03-29 11:51:09 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2017-03-29 11:51:09 +0200
commit6075aba180de1fd4dd4bf0cc457825f6fb24bb15 (patch)
tree74fbf8a5408180d0fdc9fcc4345842330217b359 /scripts/2017-03-29-missing-rights.py
parent600ca391dfc97cf3c3f49c759e6c91cdb02cb779 (diff)
downloadIshtar-6075aba180de1fd4dd4bf0cc457825f6fb24bb15.tar.bz2
Ishtar-6075aba180de1fd4dd4bf0cc457825f6fb24bb15.zip
Scripts: generate missing access control groups
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)