TODO: fix create contract related endpoints

This commit is contained in:
2025-08-05 16:54:21 +05:00
parent 5630429974
commit 8de652c57b
6 changed files with 76 additions and 23 deletions

View File

@@ -1,12 +1,20 @@
from rest_framework import permissions from rest_framework import permissions # type: ignore
from rest_framework.request import HttpRequest # type: ignore
from rest_framework.views import APIView # type: ignore
from core.apps.companies.models import CompanyFolderModel
class CompanyfolderPermission(permissions.BasePermission): class IsFolderOwner(permissions.IsAuthenticated):
def __init__(self) -> None: ... def has_object_permission( # type: ignore
self,
request: HttpRequest,
view: APIView,
obj: CompanyFolderModel
) -> bool:
return CompanyFolderModel.objects.filter(
company__accounts__user=request.user,
id=obj.id
).exists()
def __call__(self, *args, **kwargs):
return self
def has_permission(self, request, view):
return True

View File

@@ -22,10 +22,6 @@ class RetrieveCompanyFolderSerializer(BaseCompanyFolderSerializer):
class Meta(BaseCompanyFolderSerializer.Meta): ... class Meta(BaseCompanyFolderSerializer.Meta): ...
class CreateCompanyFolderSerializer(BaseCompanyFolderSerializer):
class Meta(BaseCompanyFolderSerializer.Meta): ...
class UpdateCompanyFolderSerializer(BaseCompanyFolderSerializer): class UpdateCompanyFolderSerializer(BaseCompanyFolderSerializer):
class Meta(BaseCompanyFolderSerializer.Meta): ... class Meta(BaseCompanyFolderSerializer.Meta): ...
@@ -35,6 +31,13 @@ class DestroyCompanyFolderSerializer(BaseCompanyFolderSerializer):
fields = ["id"] fields = ["id"]
###########################################################
# Create Serializers
###########################################################
class CreateCompanyFolderSerializer(BaseCompanyFolderSerializer):
class Meta(BaseCompanyFolderSerializer.Meta): ...
class CreateCompanyFolderFromCompanySerializer(CreateCompanyFolderSerializer): class CreateCompanyFolderFromCompanySerializer(CreateCompanyFolderSerializer):
class Meta(CreateCompanyFolderSerializer.Meta): class Meta(CreateCompanyFolderSerializer.Meta):
read_only_fields = ( read_only_fields = (

View File

@@ -1,8 +1,16 @@
from django_core.mixins import BaseViewSetMixin from typing import cast
from drf_spectacular.utils import extend_schema
from rest_framework.permissions import AllowAny, IsAdminUser
from rest_framework.viewsets import ModelViewSet
from django_core.mixins import BaseViewSetMixin # type: ignore
from drf_spectacular.utils import extend_schema
from rest_framework.decorators import action # type: ignore
from rest_framework.permissions import AllowAny, IsAdminUser # type: ignore
from rest_framework.viewsets import ModelViewSet # type: ignore
from rest_framework.request import HttpRequest # type: ignore
from rest_framework.response import Response # type: ignore
from rest_framework import status # type: ignore
from core.apps.contracts.serializers.contracts import CreateContractSerializer
from core.apps.companies.permissions.folders import IsFolderOwner
from core.apps.companies.models import CompanyFolderModel from core.apps.companies.models import CompanyFolderModel
from core.apps.companies.serializers.folders import ( from core.apps.companies.serializers.folders import (
CreateCompanyFolderSerializer, CreateCompanyFolderSerializer,
@@ -19,17 +27,38 @@ class CompanyFolderView(BaseViewSetMixin, ModelViewSet):
serializer_class = ListCompanyFolderSerializer serializer_class = ListCompanyFolderSerializer
permission_classes = [AllowAny] permission_classes = [AllowAny]
action_permission_classes = { action_permission_classes = { # type: ignore
"list": [IsAdminUser], "list": [IsAdminUser],
"retrieve": [IsAdminUser], "retrieve": [IsAdminUser],
"create": [IsAdminUser], "create": [IsAdminUser],
"update": [IsAdminUser], "update": [IsAdminUser],
"destroy": [IsAdminUser], "destroy": [IsAdminUser],
"create_contract": [IsFolderOwner]
} }
action_serializer_class = { action_serializer_class = { # type: ignore
"list": ListCompanyFolderSerializer, "list": ListCompanyFolderSerializer,
"retrieve": RetrieveCompanyFolderSerializer, "retrieve": RetrieveCompanyFolderSerializer,
"create": CreateCompanyFolderSerializer, "create": CreateCompanyFolderSerializer,
"update": UpdateCompanyFolderSerializer, "update": UpdateCompanyFolderSerializer,
"destroy": DestroyCompanyFolderSerializer, "destroy": DestroyCompanyFolderSerializer,
"create_contract": CreateContractSerializer,
} }
@extend_schema(
summary="Create Contract For Folder",
description="Create Contract For Folder",
)
@action(methods=["POST"], detail=True, url_path="contracts")
def create_contract(
self,
request: HttpRequest,
*args: object,
**kwargs: object
) -> Response:
ser = cast(
CreateContractSerializer,
self.get_serializer(data=request.data) # type: ignore
)
ser.is_valid(raise_exception=True)
ser.save()
return Response(ser.data, status.HTTP_201_CREATED)

View File

@@ -93,7 +93,11 @@ class CreateOwnersForContractSerializer(CreateContractOwnerSerializer):
class CreateContractAttachedFileForContractSerializer(CreateContractAttachedFileSerializer): class CreateContractAttachedFileForContractSerializer(CreateContractAttachedFileSerializer):
class Meta(CreateContractAttachedFileSerializer.Meta): ... class Meta(CreateContractAttachedFileSerializer.Meta):
read_only_fields = (
"contract",
*CreateContractAttachedFileSerializer.Meta.read_only_fields
)
def create(self, validated_data: dict[str, object]) -> Meta.model: def create(self, validated_data: dict[str, object]) -> Meta.model:
contract = self.context.get("contract") contract = self.context.get("contract")

View File

@@ -1,7 +1,7 @@
import uuid import uuid
from drf_spectacular.utils import extend_schema from drf_spectacular.utils import extend_schema
from rest_framework.permissions import AllowAny, IsAdminUser # type: ignore from rest_framework.permissions import AllowAny, IsAdminUser, IsAuthenticated # type: ignore
from rest_framework.viewsets import ModelViewSet # type: ignore from rest_framework.viewsets import ModelViewSet # type: ignore
from rest_framework.views import APIView # type: ignore from rest_framework.views import APIView # type: ignore
@@ -38,7 +38,7 @@ class ContractView(BaseViewSetMixin, ModelViewSet):
action_permission_classes = { # type: ignore action_permission_classes = { # type: ignore
"list": [IsAdminUser], "list": [IsAdminUser],
"retrieve": [IsAdminUser], "retrieve": [IsAdminUser],
"create": [IsAdminUser], "create": [IsAuthenticated],
"update": [IsAdminUser], "update": [IsAdminUser],
"destroy": [IsAdminUser], "destroy": [IsAdminUser],
"list_file": [AllowAny], "list_file": [AllowAny],
@@ -54,6 +54,15 @@ class ContractView(BaseViewSetMixin, ModelViewSet):
"list_owner": RetrieveContractOwnerSerializer, "list_owner": RetrieveContractOwnerSerializer,
} }
def create(
self,
request: HttpRequest,
*args: object,
**kwargs: object,
) -> Response:
#! TODO: checkout if user has access to create new contract.
return super().create(request, *args, **kwargs) # type: ignore
@extend_schema( @extend_schema(
summary="Get List Of Files", summary="Get List Of Files",
description="Get List Of Files" description="Get List Of Files"