* chore: user store code refactor * chore: general unauthorized screen asset added * chore: workspace setting sidebar options updated for guest and viewer * chore: NotAuthorizedView component code updated * chore: project setting layout code refactor * chore: workspace setting members and exports page permission validation added * chore: workspace members and exports settings page improvement * chore: project invite modal updated * chore: workspace setting unauthorized access empty state * chore: workspace setting unauthorized access empty state * chore: project settings sidebar permission updated * fix: project settings user role permission updated * chore: app sidebar role permission validation updated * chore: app sidebar role permission validation * chore: disabled page empty state validation * chore: app sidebar add project improvement * chore: guest role changes * fix: user favorite * chore: changed pages permission * chore: guest role changes * fix: app sidebar project item permission * fix: project setting empty state flicker * fix: workspace setting empty state flicker * chore: granted notification permission to viewer * chore: project invite and edit validation updated * chore: favorite validation added for guest and viewer role * chore: create view validation updated * chore: views permission changes * chore: create view empty state validation updated * chore: created ENUM for permissions --------- Co-authored-by: NarayanBavisetti <narayan3119@gmail.com> Co-authored-by: Bavisetti Narayan <72156168+NarayanBavisetti@users.noreply.github.com>
87 lines
3.1 KiB
Python
87 lines
3.1 KiB
Python
# Third Party imports
|
|
from rest_framework import status
|
|
from rest_framework.response import Response
|
|
|
|
from plane.app.permissions import allow_permission, ROLE
|
|
from plane.app.serializers import ExporterHistorySerializer
|
|
from plane.bgtasks.export_task import issue_export_task
|
|
from plane.db.models import ExporterHistory, Project, Workspace
|
|
|
|
# Module imports
|
|
from .. import BaseAPIView
|
|
|
|
|
|
class ExportIssuesEndpoint(BaseAPIView):
|
|
model = ExporterHistory
|
|
serializer_class = ExporterHistorySerializer
|
|
|
|
@allow_permission(allowed_roles=[ROLE.ADMIN], level="WORKSPACE")
|
|
def post(self, request, slug):
|
|
# Get the workspace
|
|
workspace = Workspace.objects.get(slug=slug)
|
|
|
|
provider = request.data.get("provider", False)
|
|
multiple = request.data.get("multiple", False)
|
|
project_ids = request.data.get("project", [])
|
|
|
|
if provider in ["csv", "xlsx", "json"]:
|
|
if not project_ids:
|
|
project_ids = Project.objects.filter(
|
|
workspace__slug=slug,
|
|
project_projectmember__member=request.user,
|
|
project_projectmember__is_active=True,
|
|
archived_at__isnull=True,
|
|
).values_list("id", flat=True)
|
|
project_ids = [str(project_id) for project_id in project_ids]
|
|
|
|
exporter = ExporterHistory.objects.create(
|
|
workspace=workspace,
|
|
project=project_ids,
|
|
initiated_by=request.user,
|
|
provider=provider,
|
|
type="issue_exports",
|
|
)
|
|
|
|
issue_export_task.delay(
|
|
provider=exporter.provider,
|
|
workspace_id=workspace.id,
|
|
project_ids=project_ids,
|
|
token_id=exporter.token,
|
|
multiple=multiple,
|
|
slug=slug,
|
|
)
|
|
return Response(
|
|
{
|
|
"message": "Once the export is ready you will be able to download it"
|
|
},
|
|
status=status.HTTP_200_OK,
|
|
)
|
|
else:
|
|
return Response(
|
|
{"error": f"Provider '{provider}' not found."},
|
|
status=status.HTTP_400_BAD_REQUEST,
|
|
)
|
|
|
|
@allow_permission(allowed_roles=[ROLE.ADMIN], level="WORKSPACE")
|
|
def get(self, request, slug):
|
|
exporter_history = ExporterHistory.objects.filter(
|
|
workspace__slug=slug,
|
|
type="issue_exports",
|
|
).select_related("workspace", "initiated_by")
|
|
|
|
if request.GET.get("per_page", False) and request.GET.get(
|
|
"cursor", False
|
|
):
|
|
return self.paginate(
|
|
order_by=request.GET.get("order_by", "-created_at"),
|
|
request=request,
|
|
queryset=exporter_history,
|
|
on_results=lambda exporter_history: ExporterHistorySerializer(
|
|
exporter_history, many=True
|
|
).data,
|
|
)
|
|
else:
|
|
return Response(
|
|
{"error": "per_page and cursor are required"},
|
|
status=status.HTTP_400_BAD_REQUEST,
|
|
)
|