fix: added serializer_class to views needed
This commit is contained in:
@@ -64,7 +64,6 @@ class User(auth_models.AbstractUser):
|
|||||||
_("Email Address"),
|
_("Email Address"),
|
||||||
blank=True,
|
blank=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
role = models.CharField(
|
role = models.CharField(
|
||||||
_("Role"),
|
_("Role"),
|
||||||
max_length=255,
|
max_length=255,
|
||||||
|
|||||||
@@ -5,8 +5,8 @@ from . import views
|
|||||||
|
|
||||||
router = DefaultRouter()
|
router = DefaultRouter()
|
||||||
|
|
||||||
router.register(r"company-accounts", views.CompanyAccountCrudViewSet, "company-account-view-set") # type: ignore
|
router.register(r"company-accounts", views.CompanyAccountViewSet, "company-account-view-set") # type: ignore
|
||||||
router.register(r"company-folders", views.CompanyFolderCrudViewSet, "company-folders-view-set") # type: ignore
|
router.register(r"company-folders", views.CompanyFolderViewSet, "company-folders-view-set") # type: ignore
|
||||||
router.register(r"companies", views.CompanyCrudViewSet, "companies-view-set") # type: ignore
|
router.register(r"companies", views.CompanyCrudViewSet, "companies-view-set") # type: ignore
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ from core.apps.companies.serializers.accounts import (
|
|||||||
# @view-set | ALL - /company-accounts
|
# @view-set | ALL - /company-accounts
|
||||||
###################################################################################
|
###################################################################################
|
||||||
@extend_schema(tags=["Company Accounts"])
|
@extend_schema(tags=["Company Accounts"])
|
||||||
class CompanyAccountCrudViewSet(BaseViewSetMixin, ModelViewSet):
|
class CompanyAccountViewSet(BaseViewSetMixin, ModelViewSet):
|
||||||
queryset = CompanyAccountModel.objects.all()
|
queryset = CompanyAccountModel.objects.all()
|
||||||
serializer_class = ListCompanyAccountSerializer
|
serializer_class = ListCompanyAccountSerializer
|
||||||
permission_classes = [AllowAny]
|
permission_classes = [AllowAny]
|
||||||
|
|||||||
@@ -28,6 +28,7 @@ from core.apps.companies.serializers import (
|
|||||||
from core.apps.contracts.serializers import (
|
from core.apps.contracts.serializers import (
|
||||||
RetrieveContractSerializer,
|
RetrieveContractSerializer,
|
||||||
BaseContractSerializer,
|
BaseContractSerializer,
|
||||||
|
RetrieveContractQuerySerializer,
|
||||||
)
|
)
|
||||||
from core.apps.contracts.models import ContractModel
|
from core.apps.contracts.models import ContractModel
|
||||||
|
|
||||||
@@ -79,7 +80,8 @@ class CompanyContractApiView(BaseApiViewMixin, GenericAPIView): # type: ignore
|
|||||||
#! TODO: status should be added.
|
#! TODO: status should be added.
|
||||||
@extend_schema(
|
@extend_schema(
|
||||||
summary="Company Contracts",
|
summary="Company Contracts",
|
||||||
description="Get List Company Contracts"
|
description="Get List Company Contracts",
|
||||||
|
parameters=[RetrieveContractQuerySerializer]
|
||||||
)
|
)
|
||||||
def get(
|
def get(
|
||||||
self,
|
self,
|
||||||
@@ -88,9 +90,13 @@ class CompanyContractApiView(BaseApiViewMixin, GenericAPIView): # type: ignore
|
|||||||
**kwargs: object,
|
**kwargs: object,
|
||||||
) -> Response:
|
) -> Response:
|
||||||
company = self.get_object()
|
company = self.get_object()
|
||||||
contracts = ContractModel.objects.filter(
|
contracts = (
|
||||||
owners__legal_entity__phone=company.phone,
|
ContractModel.objects.filter(
|
||||||
).distinct()
|
owners__legal_entity__phone=company.phone,
|
||||||
|
)
|
||||||
|
.select_related("owners")
|
||||||
|
.distinct()
|
||||||
|
)
|
||||||
|
|
||||||
folders_param = request.data.get("folders")
|
folders_param = request.data.get("folders")
|
||||||
if folders_param:
|
if folders_param:
|
||||||
|
|||||||
@@ -28,8 +28,9 @@ from core.apps.companies.serializers.folders import (
|
|||||||
# @view-set | ALL - /company-folders
|
# @view-set | ALL - /company-folders
|
||||||
###################################################################################
|
###################################################################################
|
||||||
@extend_schema(tags=["Company Folders"])
|
@extend_schema(tags=["Company Folders"])
|
||||||
class CompanyFolderCrudViewSet(BaseViewSetMixin, ModelViewSet):
|
class CompanyFolderViewSet(BaseViewSetMixin, ModelViewSet):
|
||||||
queryset = CompanyFolderModel.objects.all()
|
queryset = CompanyFolderModel.objects.all()
|
||||||
|
serializer_class = ListCompanyFolderSerializer
|
||||||
permission_classes = [AllowAny]
|
permission_classes = [AllowAny]
|
||||||
|
|
||||||
action_permission_classes = { # type: ignore
|
action_permission_classes = { # type: ignore
|
||||||
|
|||||||
@@ -154,3 +154,20 @@ class CreateContractSerializer(BaseContractSerializer):
|
|||||||
attached_files.save() # type: ignore
|
attached_files.save() # type: ignore
|
||||||
|
|
||||||
return contract
|
return contract
|
||||||
|
|
||||||
|
|
||||||
|
###########################################################
|
||||||
|
# Query Serializers
|
||||||
|
###########################################################
|
||||||
|
class RetrieveContractQuerySerializer(serializers.Serializer):
|
||||||
|
folders = serializers.ListField(
|
||||||
|
child=serializers.CharField(),
|
||||||
|
required=False,
|
||||||
|
help_text="Company Folders that contract should be allocated to."
|
||||||
|
)
|
||||||
|
status = serializers.ListField(
|
||||||
|
child=serializers.CharField(),
|
||||||
|
required=False,
|
||||||
|
help_text="Contract Status which contract have related to current owner."
|
||||||
|
)
|
||||||
|
only_my_contracts = serializers.BooleanField(default=False)
|
||||||
|
|||||||
@@ -61,6 +61,7 @@ class ContractOwnerViewSet(BaseViewSetMixin, ModelViewSet):
|
|||||||
@extend_schema(tags=["Contract Files"])
|
@extend_schema(tags=["Contract Files"])
|
||||||
class ContractOwnerAttachedFileApiView(BaseApiViewMixin, GenericAPIView): # type: ignore
|
class ContractOwnerAttachedFileApiView(BaseApiViewMixin, GenericAPIView): # type: ignore
|
||||||
permission_classes = [AllowAny]
|
permission_classes = [AllowAny]
|
||||||
|
serializer_class = ListContractOwnerSerializer
|
||||||
queryset = ContractOwnerModel.objects.all()
|
queryset = ContractOwnerModel.objects.all()
|
||||||
|
|
||||||
method_permission_classes = {"delete": [AllowAny]}
|
method_permission_classes = {"delete": [AllowAny]}
|
||||||
|
|||||||
@@ -68,7 +68,6 @@ Testers will write `done`, `not ok` and developers will define status that is no
|
|||||||
* `PATCH /company-accounts/<uuid:pk>` — admin — ok
|
* `PATCH /company-accounts/<uuid:pk>` — admin — ok
|
||||||
* `DELETE /company-accounts/<uuid:pk>` — admin — ok
|
* `DELETE /company-accounts/<uuid:pk>` — admin — ok
|
||||||
* `POST /accounts/verify` — user — TODO
|
* `POST /accounts/verify` — user — TODO
|
||||||
|
|
||||||
* required: `phone`, `code`
|
* required: `phone`, `code`
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|||||||
Reference in New Issue
Block a user