2025-06-09 10:40:56 +00:00
|
|
|
|
# coding=utf-8
|
|
|
|
|
|
"""
|
|
|
|
|
|
@project: MaxKB
|
|
|
|
|
|
@Author:虎虎
|
|
|
|
|
|
@file: application_token.py
|
|
|
|
|
|
@date:2025/6/9 17:42
|
|
|
|
|
|
@desc:
|
|
|
|
|
|
"""
|
2025-07-14 09:39:24 +00:00
|
|
|
|
from django.db.models import QuerySet
|
2025-06-09 10:40:56 +00:00
|
|
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
|
|
from drf_spectacular.utils import extend_schema
|
|
|
|
|
|
from rest_framework.request import Request
|
|
|
|
|
|
from rest_framework.views import APIView
|
|
|
|
|
|
|
|
|
|
|
|
from application.api.application_access_token import ApplicationAccessTokenAPI
|
2025-07-14 09:39:24 +00:00
|
|
|
|
from application.models import Application
|
2025-06-09 10:40:56 +00:00
|
|
|
|
from application.serializers.application_access_token import AccessTokenSerializer
|
|
|
|
|
|
from common import result
|
|
|
|
|
|
from common.auth import TokenAuth
|
|
|
|
|
|
from common.auth.authentication import has_permissions
|
2025-07-02 11:05:05 +00:00
|
|
|
|
from common.constants.permission_constants import PermissionConstants, RoleConstants, ViewPermission, CompareConstants
|
2025-07-14 09:39: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:
|
|
|
|
|
|
return {
|
|
|
|
|
|
"name": application_model.name
|
|
|
|
|
|
}
|
|
|
|
|
|
return {}
|
2025-06-09 10:40:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AccessToken(APIView):
|
|
|
|
|
|
authentication_classes = [TokenAuth]
|
|
|
|
|
|
|
|
|
|
|
|
@extend_schema(
|
|
|
|
|
|
methods=['PUT'],
|
|
|
|
|
|
description=_("Modify application access restriction information"),
|
|
|
|
|
|
summary=_("Modify application access restriction information"),
|
|
|
|
|
|
operation_id=_("Modify application access restriction information"), # type: ignore
|
|
|
|
|
|
parameters=ApplicationAccessTokenAPI.get_parameters(),
|
|
|
|
|
|
request=ApplicationAccessTokenAPI.get_request(),
|
|
|
|
|
|
tags=[_('Application')] # type: ignore
|
|
|
|
|
|
)
|
2025-07-14 09:39:24 +00:00
|
|
|
|
@log(menu='Application', operate="Modify application access token",
|
|
|
|
|
|
get_operation_object= lambda r,k: get_application_operation_object((k.get('application_id')))
|
|
|
|
|
|
)
|
2025-06-11 07:21:01 +00:00
|
|
|
|
@has_permissions(PermissionConstants.APPLICATION_OVERVIEW_ACCESS.get_workspace_application_permission(),
|
2025-06-20 14:31:41 +00:00
|
|
|
|
PermissionConstants.APPLICATION_OVERVIEW_ACCESS.get_workspace_permission_workspace_manage_role(),
|
2025-07-02 11:05:05 +00:00
|
|
|
|
ViewPermission([RoleConstants.USER.get_workspace_role()],
|
|
|
|
|
|
[PermissionConstants.APPLICATION.get_workspace_application_permission()],
|
|
|
|
|
|
CompareConstants.AND),
|
2025-06-11 07:21:01 +00:00
|
|
|
|
RoleConstants.WORKSPACE_MANAGE.get_workspace_role())
|
2025-06-09 10:40:56 +00:00
|
|
|
|
def put(self, request: Request, workspace_id: str, application_id: str):
|
|
|
|
|
|
return result.success(
|
2025-06-25 08:56:10 +00:00
|
|
|
|
AccessTokenSerializer(data={'workspace_id': workspace_id, 'application_id': application_id}).edit(
|
2025-06-09 10:40:56 +00:00
|
|
|
|
request.data))
|
|
|
|
|
|
|
|
|
|
|
|
@extend_schema(
|
|
|
|
|
|
methods=['GET'],
|
|
|
|
|
|
description=_("Get application access restriction information"),
|
|
|
|
|
|
summary=_("Get application access restriction information"),
|
|
|
|
|
|
operation_id=_("Get application access restriction information"), # type: ignore
|
|
|
|
|
|
parameters=ApplicationAccessTokenAPI.get_parameters(),
|
|
|
|
|
|
tags=[_('Application')] # type: ignore
|
|
|
|
|
|
)
|
2025-07-08 13:01:32 +00:00
|
|
|
|
@has_permissions(PermissionConstants.APPLICATION_READ.get_workspace_application_permission(),
|
|
|
|
|
|
PermissionConstants.APPLICATION_READ.get_workspace_permission_workspace_manage_role(),
|
2025-07-02 11:05:05 +00:00
|
|
|
|
ViewPermission([RoleConstants.USER.get_workspace_role()],
|
|
|
|
|
|
[PermissionConstants.APPLICATION.get_workspace_application_permission()],
|
|
|
|
|
|
CompareConstants.AND),
|
2025-06-11 07:21:01 +00:00
|
|
|
|
RoleConstants.WORKSPACE_MANAGE.get_workspace_role()
|
|
|
|
|
|
)
|
2025-06-09 10:40:56 +00:00
|
|
|
|
def get(self, request: Request, workspace_id: str, application_id: str):
|
2025-06-25 08:56:10 +00:00
|
|
|
|
return result.success(
|
|
|
|
|
|
AccessTokenSerializer(data={'workspace_id': workspace_id, 'application_id': application_id}).one())
|