UnisKB/apps/application/views/application.py

216 lines
10 KiB
Python
Raw Normal View History

2025-05-26 10:39:53 +00:00
# coding=utf-8
"""
@project: MaxKB
@Author虎虎
@file application.py
@date2025/5/26 16:51
@desc:
"""
2025-06-05 06:08:24 +00:00
from django.db.models import QuerySet
2025-05-26 10:39:53 +00:00
from django.utils.translation import gettext_lazy as _
from drf_spectacular.utils import extend_schema
2025-05-30 12:02:39 +00:00
from rest_framework.parsers import MultiPartParser
2025-05-26 10:39:53 +00:00
from rest_framework.request import Request
from rest_framework.views import APIView
2025-05-30 12:02:39 +00:00
from application.api.application_api import ApplicationCreateAPI, ApplicationQueryAPI, ApplicationImportAPI, \
ApplicationExportAPI, ApplicationOperateAPI, ApplicationEditAPI
2025-06-05 06:08:24 +00:00
from application.models import Application
2025-05-30 12:02:39 +00:00
from application.serializers.application import ApplicationSerializer, Query, ApplicationOperateSerializer
2025-05-26 10:39:53 +00:00
from common import result
2025-05-27 03:08:55 +00:00
from common.auth import TokenAuth
2025-05-28 10:57:09 +00:00
from common.auth.authentication import has_permissions
from common.constants.permission_constants import PermissionConstants, RoleConstants
2025-06-05 06:08:24 +00:00
from common.log.log import log
def get_application_operation_object(application_id):
application_model = QuerySet(model=Application).filter(id=application_id).first()
if application_model is not None:
2025-06-06 09:05:25 +00:00
return {
2025-06-05 06:08:24 +00:00
'name': application_model.name
}
return {}
2025-05-26 10:39:53 +00:00
class ApplicationAPI(APIView):
2025-05-27 03:08:55 +00:00
authentication_classes = [TokenAuth]
2025-05-26 10:39:53 +00:00
@extend_schema(
methods=['POST'],
description=_('Create an application'),
summary=_('Create an application'),
operation_id=_('Create an application'), # type: ignore
parameters=ApplicationCreateAPI.get_parameters(),
request=ApplicationCreateAPI.get_request(),
responses=ApplicationCreateAPI.get_response(),
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.APPLICATION_READ.get_workspace_permission(),
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-06-05 06:08:24 +00:00
@log(menu='Application', operate='Create an application',
2025-06-10 06:50:25 +00:00
get_operation_object=lambda r, k: {'name': r.data.get('name')},
workspace_id=lambda r, k: k.get('workspace_id'))
2025-05-27 03:08:55 +00:00
def post(self, request: Request, workspace_id: str):
return result.success(
ApplicationSerializer(data={'workspace_id': workspace_id, 'user_id': request.user.id}).insert(request.data))
2025-05-28 10:57:09 +00:00
@extend_schema(
methods=['GET'],
description=_('Get the application list'),
summary=_('Get the application list'),
operation_id=_('Get the application list'), # type: ignore
parameters=ApplicationQueryAPI.get_parameters(),
responses=ApplicationQueryAPI.get_response(),
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.APPLICATION_READ.get_workspace_permission(),
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-05-28 10:57:09 +00:00
def get(self, request: Request, workspace_id: str):
return result.success(Query(data={'workspace_id': workspace_id, 'user_id': request.user.id}).list(request.data))
class Page(APIView):
authentication_classes = [TokenAuth]
@extend_schema(
methods=['GET'],
description=_('Get the application list by page'),
summary=_('Get the application list by page'),
operation_id=_('Get the application list by page'), # type: ignore
parameters=ApplicationQueryAPI.get_parameters(),
responses=ApplicationQueryAPI.get_page_response(),
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.APPLICATION_READ.get_workspace_permission(),
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-05-28 10:57:09 +00:00
def get(self, request: Request, workspace_id: str, current_page: int, page_size: int):
return result.success(
Query(data={'workspace_id': workspace_id, 'user_id': request.user.id}).page(current_page, page_size,
request.query_params))
2025-05-30 12:02:39 +00:00
class Import(APIView):
authentication_classes = [TokenAuth]
parser_classes = [MultiPartParser]
@extend_schema(
methods=['POST'],
description=_('Import Application'),
summary=_('Import Application'),
operation_id=_('Import Application'), # type: ignore
parameters=ApplicationImportAPI.get_parameters(),
request=ApplicationImportAPI.get_request(),
responses=result.DefaultResultSerializer,
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.APPLICATION_READ, RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-06-10 06:50:25 +00:00
@log(menu='Application', operate="Import Application", workspace_id=lambda r, k: k.get('workspace_id'))
2025-05-30 12:02:39 +00:00
def post(self, request: Request, workspace_id: str):
return result.success(ApplicationSerializer(
data={'user_id': request.user.id, 'workspace_id': workspace_id,
}).import_({'file': request.FILES.get('file')}))
class Export(APIView):
authentication_classes = [TokenAuth]
@extend_schema(
methods=['POST'],
2025-06-04 05:05:39 +00:00
description=_('Export application'),
summary=_('Export application'),
operation_id=_('Export application'), # type: ignore
2025-05-30 12:02:39 +00:00
parameters=ApplicationExportAPI.get_parameters(),
2025-06-04 12:14:52 +00:00
request=None,
2025-05-30 12:02:39 +00:00
responses=ApplicationExportAPI.get_response(),
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.APPLICATION_EXPORT.get_workspace_application_permission(),
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-06-05 06:08:24 +00:00
@log(menu='Application', operate="Export Application",
2025-06-10 06:50:25 +00:00
get_operation_object=lambda r, k: get_application_operation_object(k.get('application_id')),
workspace_id=lambda r, k: k.get('workspace_id'))
2025-05-30 12:02:39 +00:00
def post(self, request: Request, workspace_id: str, application_id: str):
return ApplicationOperateSerializer(
data={'application_id': application_id,
'user_id': request.user.id}).export(request.data)
class Operate(APIView):
authentication_classes = [TokenAuth]
@extend_schema(
methods=['DELETE'],
description=_('Deleting application'),
summary=_('Deleting application'),
operation_id=_('Deleting application'), # type: ignore
parameters=ApplicationOperateAPI.get_parameters(),
responses=result.DefaultResultSerializer,
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.APPLICATION_DELETE.get_workspace_application_permission(),
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-06-05 06:08:24 +00:00
@log(menu='Application', operate='Deleting application',
2025-06-10 06:50:25 +00:00
get_operation_object=lambda r, k: get_application_operation_object(k.get('application_id')),
workspace_id=lambda r, k: k.get('workspace_id')
2025-06-05 06:08:24 +00:00
)
2025-06-04 05:05:39 +00:00
def delete(self, request: Request, workspace_id: str, application_id: str):
2025-05-30 12:02:39 +00:00
return result.success(ApplicationOperateSerializer(
data={'application_id': application_id, 'user_id': request.user.id}).delete(
with_valid=True))
@extend_schema(
methods=['PUT'],
description=_('Modify the application'),
summary=_('Modify the application'),
operation_id=_('Modify the application'), # type: ignore
parameters=ApplicationOperateAPI.get_parameters(),
request=ApplicationEditAPI.get_request(),
responses=ApplicationCreateAPI.get_response(),
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.APPLICATION_EDIT.get_workspace_application_permission(),
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-06-05 06:08:24 +00:00
@log(menu='Application', operate="Modify the application",
2025-06-10 06:50:25 +00:00
get_operation_object=lambda r, k: get_application_operation_object(k.get('application_id')),
workspace_id=lambda r, k: k.get('workspace_id'))
2025-06-04 05:05:39 +00:00
def put(self, request: Request, workspace_id: str, application_id: str):
2025-05-30 12:02:39 +00:00
return result.success(
ApplicationOperateSerializer(
data={'application_id': application_id, 'user_id': request.user.id}).edit(
request.data))
@extend_schema(
2025-06-04 05:05:39 +00:00
methods=['GET'],
2025-05-30 12:02:39 +00:00
description=_('Get application details'),
summary=_('Get application details'),
operation_id=_('Get application details'), # type: ignore
parameters=ApplicationOperateAPI.get_parameters(),
request=ApplicationEditAPI.get_request(),
responses=result.DefaultResultSerializer,
tags=[_('Application')] # type: ignore
)
@has_permissions(PermissionConstants.WORKSPACE_READ.get_workspace_application_permission(),
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
2025-06-04 05:05:39 +00:00
def get(self, request: Request, workspace_id: str, application_id: str):
2025-05-30 12:02:39 +00:00
return result.success(ApplicationOperateSerializer(
data={'application_id': application_id, 'user_id': request.user.id}).one())
2025-06-04 05:05:39 +00:00
class Publish(APIView):
authentication_classes = [TokenAuth]
@extend_schema(
methods=['PUT'],
description=_("Publishing an application"),
summary=_("Publishing an application"),
operation_id=_("Publishing an application"), # type: ignore
parameters=ApplicationOperateAPI.get_parameters(),
request=ApplicationEditAPI.get_request(),
responses=result.DefaultResultSerializer,
tags=[_('Application')] # type: ignore
)
2025-06-05 06:08:24 +00:00
@log(menu='Application', operate='Publishing an application',
2025-06-10 06:50:25 +00:00
get_operation_object=lambda r, k: get_application_operation_object(k.get('application_id')),
workspace_id=lambda r, k: k.get('workspace_id')
2025-06-05 06:08:24 +00:00
)
def put(self, request: Request, workspace_id: str, application_id: str):
2025-06-04 05:05:39 +00:00
return result.success(
ApplicationOperateSerializer(
data={'application_id': application_id, 'user_id': request.user.id}).publish(request.data))