Avoid receive feedback in private projects from non-member users

remotes/origin/4.0rc
Daniel García 2018-08-14 15:08:11 +02:00 committed by Alex Hermida
parent 124e2838fb
commit b9da70d58c
3 changed files with 60 additions and 5 deletions

View File

@ -22,7 +22,13 @@ from taiga.base.api.permissions import TaigaResourcePermission
class IsContactActivated(PermissionComponent):
def check_permissions(self, request, view, obj=None):
return request.user.is_authenticated() and obj.project.is_contact_activated
if not request.user.is_authenticated() or not obj.project.is_contact_activated:
return False
if obj.project.is_private:
return obj.project.cached_memberships_for_user(request.user)
return True
class ContactPermission(TaigaResourcePermission):

View File

@ -32,7 +32,7 @@ pytestmark = pytest.mark.django_db
def data():
m = type("Models", (object,), {})
m.user = f.UserFactory.create()
m.project = f.ProjectFactory.create()
m.project = f.ProjectFactory.create(is_private=False)
f.MembershipFactory(user=m.project.owner, project=m.project, is_admin=True)
return m

View File

@ -28,12 +28,15 @@ import pytest
pytestmark = pytest.mark.django_db
def test_create_comment(client):
# Members can comment on a private project
# if the project has the contact activated
def test_member_create_comment_on_private_project(client):
user = f.UserFactory.create()
project = f.ProjectFactory.create()
project = f.ProjectFactory.create(is_private=True)
project.is_contact_activated = True
m1 = f.MembershipFactory(user=project.owner, project=project)
m2 = f.MembershipFactory(project=project, is_admin=True)
m3 = f.MembershipFactory(project=project, is_admin=False)
m3 = f.MembershipFactory(user=user, project=project, is_admin=False)
url = reverse("contact-list")
@ -51,7 +54,53 @@ def test_create_comment(client):
assert set(mail.outbox[0].to[0].split(", ")) == set([project.owner.email, m2.user.email])
# Non members user cannot comment on a private project
# even if the project has the contact activated
def test_guest_create_comment_on_private_project(client):
user = f.UserFactory.create()
project = f.ProjectFactory.create(is_private=True)
project.is_contact_activated = True
url = reverse("contact-list")
contact_data = json.dumps({
"project": project.id,
"comment": "Testing comment"
})
client.login(user)
response = client.post(url, contact_data, content_type="application/json")
assert response.status_code == 403
assert len(mail.outbox) == 0
# All user can comment on a public project
# if the project has the contact activated
def test_create_comment_on_public_project(client):
user = f.UserFactory.create()
project = f.ProjectFactory.create(is_private=False)
project.is_contact_activated = True
m1 = f.MembershipFactory(user=project.owner, project=project)
m2 = f.MembershipFactory(project=project, is_admin=True)
url = reverse("contact-list")
contact_data = json.dumps({
"project": project.id,
"comment": "Testing comment"
})
client.login(user)
assert len(mail.outbox) == 0
response = client.post(url, contact_data, content_type="application/json")
assert response.status_code == 201
assert len(mail.outbox) == 1
assert set(mail.outbox[0].to[0].split(", ")) == set([project.owner.email, m2.user.email])
# No user can comment on a project
# if the project does not have the contact activated
def test_create_comment_disabled(client):
user = f.UserFactory.create()
project = f.ProjectFactory.create()