Commit 00df0e3b authored by Michal Čihař's avatar Michal Čihař

Make Group ACL work per project as well

We need this for project level operations like repository maintenance.

Issue #1004
Signed-off-by: default avatarMichal Čihař <michal@cihar.com>
parent 0cee8550
...@@ -42,15 +42,19 @@ def check_owner(user, project, permission): ...@@ -42,15 +42,19 @@ def check_owner(user, project, permission):
).exists() ).exists()
def has_group_perm(user, permission, translation): def has_group_perm(user, permission, translation=None, project=None):
""" """
Checks whether GroupACL rules allow user to have Checks whether GroupACL rules allow user to have
given permission. given permission.
""" """
if project is None:
acls = list(GroupACL.objects.filter( acls = list(GroupACL.objects.filter(
Q(language=translation.language) | Q(language=translation.language) |
Q(project=translation.subproject.project) | Q(project=translation.subproject.project) |
Q(subproject=translation.subproject))) Q(subproject=translation.subproject)
))
else:
acls = list(GroupACL.objects.filter(project=project))
if not acls: if not acls:
return user.has_perm(permission) return user.has_perm(permission)
...@@ -78,6 +82,7 @@ def check_permission(user, project, permission): ...@@ -78,6 +82,7 @@ def check_permission(user, project, permission):
Generic check for permission with owner fallback. Generic check for permission with owner fallback.
""" """
return ( return (
has_group_perm(user, permission, project=project) or
check_owner(user, project, permission) or check_owner(user, project, permission) or
user.has_perm(permission) user.has_perm(permission)
) )
......
...@@ -28,7 +28,8 @@ from weblate.trans.models import ( ...@@ -28,7 +28,8 @@ from weblate.trans.models import (
GroupACL, Project, Translation GroupACL, Project, Translation
) )
from weblate.trans.permissions import ( from weblate.trans.permissions import (
check_owner, check_permission, can_delete_comment, can_edit check_owner, check_permission, can_delete_comment, can_edit,
can_author_translation,
) )
from weblate.trans.tests.test_models import ModelTestCase from weblate.trans.tests.test_models import ModelTestCase
...@@ -164,3 +165,17 @@ class GroupACLTest(ModelTestCase): ...@@ -164,3 +165,17 @@ class GroupACLTest(ModelTestCase):
acl.subproject = self.subproject acl.subproject = self.subproject
acl.clean() acl.clean()
self.assertIsNone(acl.project) self.assertIsNone(acl.project)
def test_acl_project(self):
acl = GroupACL.objects.create(project=self.project)
acl.groups.add(self.group)
permission = Permission.objects.get(
codename='author_translation', content_type__app_label='trans'
)
self.group.permissions.add(permission)
self.assertFalse(
can_author_translation(self.user, self.project)
)
self.assertTrue(
can_author_translation(self.privileged, self.project)
)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment