[WEB - 485] chore: external apis validation (#3737)

* dev: add integrity validation for states

* dev: add validation for issue comment with same external id and external source
This commit is contained in:
Nikhil 2024-02-21 19:51:25 +05:30 committed by GitHub
parent b10e89fdd7
commit e86d2ba743
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 95 additions and 33 deletions

View File

@ -647,6 +647,33 @@ class IssueCommentAPIEndpoint(WebhookMixin, BaseAPIView):
) )
def post(self, request, slug, project_id, issue_id): def post(self, request, slug, project_id, issue_id):
# Validation check if the issue already exists
if (
request.data.get("external_id")
and request.data.get("external_source")
and IssueComment.objects.filter(
project_id=project_id,
workspace__slug=slug,
external_source=request.data.get("external_source"),
external_id=request.data.get("external_id"),
).exists()
):
issue_comment = IssueComment.objects.filter(
workspace__slug=slug,
project_id=project_id,
external_id=request.data.get("external_id"),
external_source=request.data.get("external_source"),
).first()
return Response(
{
"error": "Issue Comment with the same external id and external source already exists",
"id": str(issue_comment.id),
},
status=status.HTTP_409_CONFLICT,
)
serializer = IssueCommentSerializer(data=request.data) serializer = IssueCommentSerializer(data=request.data)
if serializer.is_valid(): if serializer.is_valid():
serializer.save( serializer.save(
@ -680,6 +707,29 @@ class IssueCommentAPIEndpoint(WebhookMixin, BaseAPIView):
IssueCommentSerializer(issue_comment).data, IssueCommentSerializer(issue_comment).data,
cls=DjangoJSONEncoder, cls=DjangoJSONEncoder,
) )
# Validation check if the issue already exists
if (
str(request.data.get("external_id"))
and (issue_comment.external_id != str(request.data.get("external_id")))
and Issue.objects.filter(
project_id=project_id,
workspace__slug=slug,
external_source=request.data.get(
"external_source", issue_comment.external_source
),
external_id=request.data.get("external_id"),
).exists()
):
return Response(
{
"error": "Issue Comment with the same external id and external source already exists",
"id": str(issue_comment.id),
},
status=status.HTTP_409_CONFLICT,
)
serializer = IssueCommentSerializer( serializer = IssueCommentSerializer(
issue_comment, data=request.data, partial=True issue_comment, data=request.data, partial=True
) )

View File

@ -1,7 +1,5 @@
# Python imports
from itertools import groupby
# Django imports # Django imports
from django.db import IntegrityError
from django.db.models import Q from django.db.models import Q
# Third party imports # Third party imports
@ -34,37 +32,51 @@ class StateAPIEndpoint(BaseAPIView):
) )
def post(self, request, slug, project_id): def post(self, request, slug, project_id):
serializer = StateSerializer( try:
data=request.data, context={"project_id": project_id} serializer = StateSerializer(
) data=request.data, context={"project_id": project_id}
if serializer.is_valid(): )
if ( if serializer.is_valid():
request.data.get("external_id") if (
and request.data.get("external_source") request.data.get("external_id")
and State.objects.filter( and request.data.get("external_source")
project_id=project_id, and State.objects.filter(
workspace__slug=slug, project_id=project_id,
external_source=request.data.get("external_source"), workspace__slug=slug,
external_id=request.data.get("external_id"), external_source=request.data.get("external_source"),
).exists() external_id=request.data.get("external_id"),
): ).exists()
state = State.objects.filter( ):
workspace__slug=slug, state = State.objects.filter(
project_id=project_id, workspace__slug=slug,
external_id=request.data.get("external_id"), project_id=project_id,
external_source=request.data.get("external_source"), external_id=request.data.get("external_id"),
).first() external_source=request.data.get("external_source"),
return Response( ).first()
{ return Response(
"error": "State with the same external id and external source already exists", {
"id": str(state.id), "error": "State with the same external id and external source already exists",
}, "id": str(state.id),
status=status.HTTP_409_CONFLICT, },
) status=status.HTTP_409_CONFLICT,
)
serializer.save(project_id=project_id) serializer.save(project_id=project_id)
return Response(serializer.data, status=status.HTTP_200_OK) return Response(serializer.data, status=status.HTTP_200_OK)
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST) return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
except IntegrityError as e:
state = State.objects.filter(
workspace__slug=slug,
project_id=project_id,
name=request.data.get("name"),
).first()
return Response(
{
"error": "State with the same name already exists in the project",
"id": str(state.id),
},
status=status.HTTP_409_CONFLICT,
)
def get(self, request, slug, project_id, state_id=None): def get(self, request, slug, project_id, state_id=None):
if state_id: if state_id: