common.py 5.0 KB
Newer Older
baltery's avatar
baltery 已提交
1 2 3 4 5
# -*- coding: utf-8 -*-
#
import uuid

from django.shortcuts import get_object_or_404
X
xinwen 已提交
6
from django.utils.decorators import method_decorator
baltery's avatar
baltery 已提交
7 8
from rest_framework.views import APIView, Response
from rest_framework.generics import (
baltery's avatar
baltery 已提交
9
    ListAPIView, get_object_or_404, RetrieveAPIView, DestroyAPIView
baltery's avatar
baltery 已提交
10 11
)

X
xinwen 已提交
12
from orgs.utils import tmp_to_root_org
13
from perms.utils.asset.permission import get_asset_system_user_ids_with_actions_by_user
X
xinwen 已提交
14 15 16
from common.permissions import IsOrgAdminOrAppUser, IsOrgAdmin, IsValidUser
from common.utils import get_logger, lazyproperty

17 18 19
from perms.hands import User, Asset, SystemUser
from perms import serializers
from perms.models import Action
baltery's avatar
baltery 已提交
20 21 22 23 24

logger = get_logger(__name__)

__all__ = [
    'RefreshAssetPermissionCacheApi',
X
xinwen 已提交
25
    'UserGrantedAssetSystemUsersForAdminApi',
baltery's avatar
baltery 已提交
26 27
    'ValidateUserAssetPermissionApi',
    'GetUserAssetPermissionActionsApi',
baltery's avatar
baltery 已提交
28
    'UserAssetPermissionsCacheApi',
X
xinwen 已提交
29
    'MyGrantedAssetSystemUsersApi',
baltery's avatar
baltery 已提交
30 31 32
]


33
@method_decorator(tmp_to_root_org(), name='get')
X
xinwen 已提交
34
class GetUserAssetPermissionActionsApi(RetrieveAPIView):
baltery's avatar
baltery 已提交
35 36 37
    permission_classes = (IsOrgAdminOrAppUser,)
    serializer_class = serializers.ActionsSerializer

X
xinwen 已提交
38
    def get_user(self):
baltery's avatar
baltery 已提交
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
        user_id = self.request.query_params.get('user_id', '')
        user = get_object_or_404(User, id=user_id)
        return user

    def get_object(self):
        asset_id = self.request.query_params.get('asset_id', '')
        system_id = self.request.query_params.get('system_user_id', '')

        try:
            asset_id = uuid.UUID(asset_id)
            system_id = uuid.UUID(system_id)
        except ValueError:
            return Response({'msg': False}, status=403)

        asset = get_object_or_404(Asset, id=asset_id)
        system_user = get_object_or_404(SystemUser, id=system_id)

56
        system_users_actions = get_asset_system_user_ids_with_actions_by_user(self.get_user(), asset)
baltery's avatar
baltery 已提交
57
        actions = system_users_actions.get(system_user.id)
baltery's avatar
baltery 已提交
58 59 60
        return {"actions": actions}


61
@method_decorator(tmp_to_root_org(), name='get')
X
xinwen 已提交
62
class ValidateUserAssetPermissionApi(APIView):
baltery's avatar
baltery 已提交
63 64
    permission_classes = (IsOrgAdminOrAppUser,)

65 66 67
    def get_cache_policy(self):
        return 0

X
xinwen 已提交
68
    def get_user(self):
baltery's avatar
baltery 已提交
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
        user_id = self.request.query_params.get('user_id', '')
        user = get_object_or_404(User, id=user_id)
        return user

    def get(self, request, *args, **kwargs):
        asset_id = request.query_params.get('asset_id', '')
        system_id = request.query_params.get('system_user_id', '')
        action_name = request.query_params.get('action_name', '')

        try:
            asset_id = uuid.UUID(asset_id)
            system_id = uuid.UUID(system_id)
        except ValueError:
            return Response({'msg': False}, status=403)

X
xinwen 已提交
84
        asset = get_object_or_404(Asset, id=asset_id, is_active=True)
baltery's avatar
baltery 已提交
85 86
        system_user = get_object_or_404(SystemUser, id=system_id)

87
        system_users_actions = get_asset_system_user_ids_with_actions_by_user(self.get_user(), asset)
baltery's avatar
baltery 已提交
88
        actions = system_users_actions.get(system_user.id)
89 90
        if actions is None:
            return Response({'msg': False}, status=403)
baltery's avatar
baltery 已提交
91 92 93 94 95
        if action_name in Action.value_to_choices(actions):
            return Response({'msg': True}, status=200)
        return Response({'msg': False}, status=403)


X
xinwen 已提交
96
# TODO 删除
baltery's avatar
baltery 已提交
97 98 99 100 101 102 103
class RefreshAssetPermissionCacheApi(RetrieveAPIView):
    permission_classes = (IsOrgAdmin,)

    def retrieve(self, request, *args, **kwargs):
        return Response({'msg': True}, status=200)


X
xinwen 已提交
104
class UserGrantedAssetSystemUsersForAdminApi(ListAPIView):
baltery's avatar
baltery 已提交
105 106 107 108
    permission_classes = (IsOrgAdminOrAppUser,)
    serializer_class = serializers.AssetSystemUserSerializer
    only_fields = serializers.AssetSystemUserSerializer.Meta.only_fields

X
xinwen 已提交
109 110 111 112 113
    @lazyproperty
    def user(self):
        user_id = self.kwargs.get('pk')
        return User.objects.get(id=user_id)

114 115
    def get_asset_system_user_ids_with_actions(self, asset):
        return get_asset_system_user_ids_with_actions_by_user(self.user, asset)
X
xinwen 已提交
116

baltery's avatar
baltery 已提交
117 118
    def get_queryset(self):
        asset_id = self.kwargs.get('asset_id')
X
xinwen 已提交
119
        asset = get_object_or_404(Asset, id=asset_id, is_active=True)
120 121 122
        system_users_with_actions = self.get_asset_system_user_ids_with_actions(asset)
        system_user_ids = system_users_with_actions.keys()
        system_users = SystemUser.objects.filter(id__in=system_user_ids)\
baltery's avatar
baltery 已提交
123
            .only(*self.serializer_class.Meta.only_fields) \
124
            .order_by('name')
baltery's avatar
baltery 已提交
125 126 127
        system_users = list(system_users)
        for system_user in system_users:
            actions = system_users_with_actions.get(system_user.id, 0)
baltery's avatar
baltery 已提交
128 129
            system_user.actions = actions
        return system_users
baltery's avatar
baltery 已提交
130

baltery's avatar
baltery 已提交
131

X
xinwen 已提交
132 133 134 135 136 137 138 139 140 141 142
@method_decorator(tmp_to_root_org(), name='list')
class MyGrantedAssetSystemUsersApi(UserGrantedAssetSystemUsersForAdminApi):
    permission_classes = (IsValidUser,)

    @lazyproperty
    def user(self):
        return self.request.user


# TODO 删除
class UserAssetPermissionsCacheApi(DestroyAPIView):
baltery's avatar
baltery 已提交
143 144 145 146
    permission_classes = (IsOrgAdmin,)

    def destroy(self, request, *args, **kwargs):
        return Response(status=204)