* 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>
97 lines
3.4 KiB
Python
97 lines
3.4 KiB
Python
# Third party modules
|
|
from rest_framework import status
|
|
from rest_framework.response import Response
|
|
|
|
# Django modules
|
|
from django.db.models import Q
|
|
|
|
# Module imports
|
|
from plane.app.views.base import BaseAPIView
|
|
from plane.db.models import UserFavorite, Workspace
|
|
from plane.app.serializers import UserFavoriteSerializer
|
|
from plane.app.permissions import allow_permission, ROLE
|
|
|
|
|
|
class WorkspaceFavoriteEndpoint(BaseAPIView):
|
|
|
|
@allow_permission(
|
|
allowed_roles=[ROLE.ADMIN, ROLE.MEMBER], level="WORKSPACE"
|
|
)
|
|
def get(self, request, slug):
|
|
# the second filter is to check if the user is a member of the project
|
|
favorites = UserFavorite.objects.filter(
|
|
user=request.user,
|
|
workspace__slug=slug,
|
|
parent__isnull=True,
|
|
).filter(
|
|
Q(project__isnull=True)
|
|
| (
|
|
Q(project__isnull=False)
|
|
& Q(project__project_projectmember__member=request.user)
|
|
& Q(project__project_projectmember__is_active=True)
|
|
)
|
|
)
|
|
serializer = UserFavoriteSerializer(favorites, many=True)
|
|
return Response(serializer.data, status=status.HTTP_200_OK)
|
|
|
|
@allow_permission(
|
|
allowed_roles=[ROLE.ADMIN, ROLE.MEMBER], level="WORKSPACE"
|
|
)
|
|
def post(self, request, slug):
|
|
workspace = Workspace.objects.get(slug=slug)
|
|
serializer = UserFavoriteSerializer(data=request.data)
|
|
if serializer.is_valid():
|
|
serializer.save(
|
|
user_id=request.user.id,
|
|
workspace=workspace,
|
|
project_id=request.data.get("project_id", None),
|
|
)
|
|
return Response(serializer.data, status=status.HTTP_200_OK)
|
|
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
@allow_permission(
|
|
allowed_roles=[ROLE.ADMIN, ROLE.MEMBER], level="WORKSPACE"
|
|
)
|
|
def patch(self, request, slug, favorite_id):
|
|
favorite = UserFavorite.objects.get(
|
|
user=request.user, workspace__slug=slug, pk=favorite_id
|
|
)
|
|
serializer = UserFavoriteSerializer(
|
|
favorite, data=request.data, partial=True
|
|
)
|
|
if serializer.is_valid():
|
|
serializer.save()
|
|
return Response(serializer.data, status=status.HTTP_200_OK)
|
|
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
@allow_permission(
|
|
allowed_roles=[ROLE.ADMIN, ROLE.MEMBER], level="WORKSPACE"
|
|
)
|
|
def delete(self, request, slug, favorite_id):
|
|
favorite = UserFavorite.objects.get(
|
|
user=request.user, workspace__slug=slug, pk=favorite_id
|
|
)
|
|
favorite.delete(soft=False)
|
|
return Response(status=status.HTTP_204_NO_CONTENT)
|
|
|
|
|
|
class WorkspaceFavoriteGroupEndpoint(BaseAPIView):
|
|
|
|
@allow_permission(
|
|
allowed_roles=[ROLE.ADMIN, ROLE.MEMBER], level="WORKSPACE"
|
|
)
|
|
def get(self, request, slug, favorite_id):
|
|
favorites = UserFavorite.objects.filter(
|
|
user=request.user,
|
|
workspace__slug=slug,
|
|
parent_id=favorite_id,
|
|
).filter(
|
|
Q(project__isnull=True)
|
|
| (
|
|
Q(project__isnull=False)
|
|
& Q(project__project_projectmember__member=request.user)
|
|
& Q(project__project_projectmember__is_active=True)
|
|
)
|
|
)
|
|
serializer = UserFavoriteSerializer(favorites, many=True)
|
|
return Response(serializer.data, status=status.HTTP_200_OK)
|