Avoid receive feedback in private projects from non-member users
parent
124e2838fb
commit
b9da70d58c
|
@ -22,7 +22,13 @@ from taiga.base.api.permissions import TaigaResourcePermission
|
||||||
|
|
||||||
class IsContactActivated(PermissionComponent):
|
class IsContactActivated(PermissionComponent):
|
||||||
def check_permissions(self, request, view, obj=None):
|
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):
|
class ContactPermission(TaigaResourcePermission):
|
||||||
|
|
|
@ -32,7 +32,7 @@ pytestmark = pytest.mark.django_db
|
||||||
def data():
|
def data():
|
||||||
m = type("Models", (object,), {})
|
m = type("Models", (object,), {})
|
||||||
m.user = f.UserFactory.create()
|
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)
|
f.MembershipFactory(user=m.project.owner, project=m.project, is_admin=True)
|
||||||
|
|
||||||
return m
|
return m
|
||||||
|
|
|
@ -28,12 +28,15 @@ import pytest
|
||||||
pytestmark = pytest.mark.django_db
|
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()
|
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)
|
m1 = f.MembershipFactory(user=project.owner, project=project)
|
||||||
m2 = f.MembershipFactory(project=project, is_admin=True)
|
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")
|
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])
|
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):
|
def test_create_comment_disabled(client):
|
||||||
user = f.UserFactory.create()
|
user = f.UserFactory.create()
|
||||||
project = f.ProjectFactory.create()
|
project = f.ProjectFactory.create()
|
||||||
|
|
Loading…
Reference in New Issue