mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
dev: updated error handling for project deploy board attributes (#2062)
* dev: updated error handling for project deploy board attributes * dev: reaction integrity handling
This commit is contained in:
parent
63d799310b
commit
874d6e951b
@ -21,7 +21,7 @@ from django.db.models import (
|
|||||||
from django.core.serializers.json import DjangoJSONEncoder
|
from django.core.serializers.json import DjangoJSONEncoder
|
||||||
from django.utils.decorators import method_decorator
|
from django.utils.decorators import method_decorator
|
||||||
from django.views.decorators.gzip import gzip_page
|
from django.views.decorators.gzip import gzip_page
|
||||||
from django.db.models.functions import Coalesce
|
from django.db import IntegrityError
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
|
||||||
# Third Party imports
|
# Third Party imports
|
||||||
@ -1545,6 +1545,7 @@ class IssueCommentPublicViewSet(BaseViewSet):
|
|||||||
return super(IssueCommentPublicViewSet, self).get_permissions()
|
return super(IssueCommentPublicViewSet, self).get_permissions()
|
||||||
|
|
||||||
def get_queryset(self):
|
def get_queryset(self):
|
||||||
|
try:
|
||||||
project_deploy_board = ProjectDeployBoard.objects.get(
|
project_deploy_board = ProjectDeployBoard.objects.get(
|
||||||
workspace__slug=self.kwargs.get("slug"),
|
workspace__slug=self.kwargs.get("slug"),
|
||||||
project_id=self.kwargs.get("project_id"),
|
project_id=self.kwargs.get("project_id"),
|
||||||
@ -1572,6 +1573,8 @@ class IssueCommentPublicViewSet(BaseViewSet):
|
|||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
return IssueComment.objects.none()
|
return IssueComment.objects.none()
|
||||||
|
except ProjectDeployBoard.DoesNotExist:
|
||||||
|
return IssueComment.objects.none()
|
||||||
|
|
||||||
def create(self, request, slug, project_id, issue_id):
|
def create(self, request, slug, project_id, issue_id):
|
||||||
try:
|
try:
|
||||||
@ -1703,6 +1706,7 @@ class IssueReactionPublicViewSet(BaseViewSet):
|
|||||||
model = IssueReaction
|
model = IssueReaction
|
||||||
|
|
||||||
def get_queryset(self):
|
def get_queryset(self):
|
||||||
|
try:
|
||||||
project_deploy_board = ProjectDeployBoard.objects.get(
|
project_deploy_board = ProjectDeployBoard.objects.get(
|
||||||
workspace__slug=self.kwargs.get("slug"),
|
workspace__slug=self.kwargs.get("slug"),
|
||||||
project_id=self.kwargs.get("project_id"),
|
project_id=self.kwargs.get("project_id"),
|
||||||
@ -1719,6 +1723,8 @@ class IssueReactionPublicViewSet(BaseViewSet):
|
|||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
return IssueReaction.objects.none()
|
return IssueReaction.objects.none()
|
||||||
|
except ProjectDeployBoard.DoesNotExist:
|
||||||
|
return IssueReaction.objects.none()
|
||||||
|
|
||||||
def create(self, request, slug, project_id, issue_id):
|
def create(self, request, slug, project_id, issue_id):
|
||||||
try:
|
try:
|
||||||
@ -1818,6 +1824,7 @@ class CommentReactionPublicViewSet(BaseViewSet):
|
|||||||
model = CommentReaction
|
model = CommentReaction
|
||||||
|
|
||||||
def get_queryset(self):
|
def get_queryset(self):
|
||||||
|
try:
|
||||||
project_deploy_board = ProjectDeployBoard.objects.get(
|
project_deploy_board = ProjectDeployBoard.objects.get(
|
||||||
workspace__slug=self.kwargs.get("slug"),
|
workspace__slug=self.kwargs.get("slug"),
|
||||||
project_id=self.kwargs.get("project_id"),
|
project_id=self.kwargs.get("project_id"),
|
||||||
@ -1834,6 +1841,8 @@ class CommentReactionPublicViewSet(BaseViewSet):
|
|||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
return CommentReaction.objects.none()
|
return CommentReaction.objects.none()
|
||||||
|
except ProjectDeployBoard.DoesNotExist:
|
||||||
|
return CommentReaction.objects.none()
|
||||||
|
|
||||||
def create(self, request, slug, project_id, comment_id):
|
def create(self, request, slug, project_id, comment_id):
|
||||||
try:
|
try:
|
||||||
@ -1939,6 +1948,12 @@ class IssueVotePublicViewSet(BaseViewSet):
|
|||||||
serializer_class = IssueVoteSerializer
|
serializer_class = IssueVoteSerializer
|
||||||
|
|
||||||
def get_queryset(self):
|
def get_queryset(self):
|
||||||
|
try:
|
||||||
|
project_deploy_board = ProjectDeployBoard.objects.get(
|
||||||
|
workspace__slug=self.kwargs.get("slug"),
|
||||||
|
project_id=self.kwargs.get("project_id"),
|
||||||
|
)
|
||||||
|
if project_deploy_board.votes:
|
||||||
return (
|
return (
|
||||||
super()
|
super()
|
||||||
.get_queryset()
|
.get_queryset()
|
||||||
@ -1946,6 +1961,10 @@ class IssueVotePublicViewSet(BaseViewSet):
|
|||||||
.filter(workspace__slug=self.kwargs.get("slug"))
|
.filter(workspace__slug=self.kwargs.get("slug"))
|
||||||
.filter(project_id=self.kwargs.get("project_id"))
|
.filter(project_id=self.kwargs.get("project_id"))
|
||||||
)
|
)
|
||||||
|
else:
|
||||||
|
return IssueVote.objects.none()
|
||||||
|
except ProjectDeployBoard.DoesNotExist:
|
||||||
|
return IssueVote.objects.none()
|
||||||
|
|
||||||
def create(self, request, slug, project_id, issue_id):
|
def create(self, request, slug, project_id, issue_id):
|
||||||
try:
|
try:
|
||||||
@ -1974,6 +1993,8 @@ class IssueVotePublicViewSet(BaseViewSet):
|
|||||||
)
|
)
|
||||||
serializer = IssueVoteSerializer(issue_vote)
|
serializer = IssueVoteSerializer(issue_vote)
|
||||||
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
||||||
|
except IntegrityError:
|
||||||
|
return Response({"error": "Reaction already exists"}, status=status.HTTP_400_BAD_REQUEST)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
capture_exception(e)
|
capture_exception(e)
|
||||||
return Response(
|
return Response(
|
||||||
|
Loading…
Reference in New Issue
Block a user