utils.py 10.3 KB
# coding: utf-8

from __future__ import absolute_import, unicode_literals
import collections
from collections import defaultdict
from django.utils import timezone
import copy

from common.utils import set_or_append_attr_bulk, get_logger
from .models import AssetPermission

logger = get_logger(__file__)


class AssetPermissionUtil:

    @staticmethod
    def get_user_permissions(user):
        return AssetPermission.valid.all().filter(users=user)

    @staticmethod
    def get_user_group_permissions(user_group):
        return AssetPermission.valid.all().filter(user_groups=user_group)

    @staticmethod
    def get_asset_permissions(asset):
        return AssetPermission.valid.all().filter(assets=asset)

    @staticmethod
    def get_node_permissions(node):
        return AssetPermission.valid.all().filter(nodes=node)

    @staticmethod
    def get_system_user_permissions(system_user):
        return AssetPermission.objects.all().filter(system_users=system_user)

    @classmethod
    def get_user_group_nodes(cls, group):
        nodes = defaultdict(set)
        permissions = cls.get_user_group_permissions(group)
        for perm in permissions:
            _nodes = perm.nodes.all()
            _system_users = perm.system_users.all()
            set_or_append_attr_bulk(_nodes, 'permission', perm.id)
            for node in _nodes:
                nodes[node].update(set(_system_users))
        return nodes

    @classmethod
    def get_user_group_assets_direct(cls, group):
        assets = defaultdict(set)
        permissions = cls.get_user_group_permissions(group)
        for perm in permissions:
            _assets = perm.assets.all()
            _system_users = perm.system_users.all()
            set_or_append_attr_bulk(_assets, 'permission', perm.id)
            for asset in _assets:
                assets[asset].update(set(_system_users))
        return assets

    @classmethod
    def get_user_group_nodes_assets(cls, group):
        assets = defaultdict(set)
        nodes = cls.get_user_group_nodes(group)
        for node, _system_users in nodes.items():
            _assets = node.get_all_assets()
            set_or_append_attr_bulk(_assets, 'inherit_node', node.id)
            set_or_append_attr_bulk(_assets, 'permission', getattr(node, 'permission', None))
            for asset in _assets:
                assets[asset].update(set(_system_users))
        return assets

    @classmethod
    def get_user_group_assets(cls, group):
        assets = defaultdict(set)
        _assets = cls.get_user_group_assets_direct(group)
        _nodes_assets = cls.get_user_group_nodes_assets(group)
        for asset, _system_users in _assets.items():
            assets[asset].update(set(_system_users))
        for asset, _system_users in _nodes_assets.items():
            assets[asset].update(set(_system_users))
        return assets

    @classmethod
    def get_user_group_nodes_with_assets(cls, user):
        """
        :param user:
        :return: {node: {asset: set(su1, su2)}}
        """
        nodes = defaultdict(dict)
        _assets = cls.get_user_group_assets(user)
        for asset, _system_users in _assets.items():
            _nodes = asset.get_nodes()
            for node in _nodes:
                if asset in nodes[node]:
                    nodes[node][asset].update(_system_users)
                else:
                    nodes[node][asset] = _system_users
        return nodes

    @classmethod
    def get_user_assets_direct(cls, user):
        assets = defaultdict(set)
        permissions = list(cls.get_user_permissions(user))
        for perm in permissions:
            _assets = perm.assets.all()
            _system_users = perm.system_users.all()
            set_or_append_attr_bulk(_assets, 'permission', perm.id)
            for asset in _assets:
                assets[asset].update(set(_system_users))
        return assets

    @classmethod
    def get_user_nodes_direct(cls, user):
        nodes = defaultdict(set)
        permissions = cls.get_user_permissions(user)
        for perm in permissions:
            _nodes = perm.nodes.all()
            _system_users = perm.system_users.all()
            set_or_append_attr_bulk(_nodes, 'permission', perm.id)
            for node in _nodes:
                nodes[node].update(set(_system_users))
        return nodes

    @classmethod
    def get_user_nodes_assets_direct(cls, user):
        assets = defaultdict(set)
        nodes = cls.get_user_nodes_direct(user)
        for node, _system_users in nodes.items():
            _assets = node.get_all_assets()
            set_or_append_attr_bulk(_assets, 'inherit_node', node.id)
            set_or_append_attr_bulk(_assets, 'permission', getattr(node, 'permission', None))
            for asset in _assets:
                assets[asset].update(set(_system_users))
        return assets

    @classmethod
    def get_user_assets_inherit_group(cls, user):
        assets = defaultdict(set)
        for group in user.groups.all():
            _assets = cls.get_user_group_assets(group)
            set_or_append_attr_bulk(_assets, 'inherit_group', group.id)
            for asset, _system_users in _assets.items():
                assets[asset].update(_system_users)
        return assets

    @classmethod
    def get_user_assets(cls, user):
        assets = defaultdict(set)
        _assets_direct = cls.get_user_assets_direct(user)
        _nodes_assets_direct = cls.get_user_nodes_assets_direct(user)
        _assets_inherit_group = cls.get_user_assets_inherit_group(user)
        for asset, _system_users in _assets_direct.items():
            assets[asset].update(_system_users)
        for asset, _system_users in _nodes_assets_direct.items():
            assets[asset].update(_system_users)
        for asset, _system_users in _assets_inherit_group.items():
            assets[asset].update(_system_users)
        return assets

    @classmethod
    def get_user_nodes_with_assets(cls, user):
        """
        :param user:
        :return: {node: {asset: set(su1, su2)}}
        """
        nodes = defaultdict(dict)
        _assets = cls.get_user_assets(user)
        for asset, _system_users in _assets.items():
            _nodes = asset.get_nodes()
            for node in _nodes:
                if asset in nodes[node]:
                    nodes[node][asset].update(_system_users)
                else:
                    nodes[node][asset] = _system_users
        return nodes

    @classmethod
    def get_system_user_assets(cls, system_user):
        assets = set()
        permissions = cls.get_system_user_permissions(system_user)
        for perm in permissions:
            assets.update(set(perm.assets.all()))
            nodes = perm.nodes.all()
            for node in nodes:
                assets.update(set(node.get_all_assets()))
        return assets

    @classmethod
    def get_node_system_users(cls, node):
        system_users = set()
        permissions = cls.get_node_permissions(node)
        for perm in permissions:
            system_users.update(perm.system_users.all())
        return system_users


# Abandon
class NodePermissionUtil:
    """

    """

    @staticmethod
    def get_user_group_permissions(user_group):
        return user_group.nodepermission_set.all() \
            .filter(is_active=True) \
            .filter(date_expired__gt=timezone.now())

    @staticmethod
    def get_system_user_permissions(system_user):
        return system_user.nodepermission_set.all() \
            .filter(is_active=True) \
            .filter(date_expired__gt=timezone.now())

    @classmethod
    def get_user_group_nodes(cls, user_group):
        """
        获取用户组授权的node和系统用户
        :param user_group:
        :return: {"node": set(systemuser1, systemuser2), ..}
        """
        permissions = cls.get_user_group_permissions(user_group)
        nodes_directed = collections.defaultdict(set)

        for perm in permissions:
            nodes_directed[perm.node].add(perm.system_user)

        nodes = copy.deepcopy(nodes_directed)
        for node, system_users in nodes_directed.items():
            for child in node.get_family():
                nodes[child].update(system_users)
        return nodes

    @classmethod
    def get_user_group_nodes_with_assets(cls, user_group):
        """
        获取用户组授权的节点和系统用户,节点下带有资产
        :param user_group:
        :return: {"node": {"assets": "", "system_user": ""}, {}}
        """
        nodes = cls.get_user_group_nodes(user_group)
        nodes_with_assets = dict()
        for node, system_users in nodes.items():
            nodes_with_assets[node] = {
                'assets': node.get_active_assets(),
                'system_users': system_users
            }
        return nodes_with_assets

    @classmethod
    def get_user_group_assets(cls, user_group):
        assets = collections.defaultdict(set)
        permissions = cls.get_user_group_permissions(user_group)

        for perm in permissions:
            for asset in perm.node.get_all_assets():
                assets[asset].add(perm.system_user)
        return assets

    @classmethod
    def get_user_nodes(cls, user):
        nodes = collections.defaultdict(set)
        groups = user.groups.all()
        for group in groups:
            group_nodes = cls.get_user_group_nodes(group)
            for node, system_users in group_nodes.items():
                nodes[node].update(system_users)
        return nodes

    @classmethod
    def get_user_nodes_with_assets(cls, user):
        nodes = cls.get_user_nodes(user)
        nodes_with_assets = dict()
        for node, system_users in nodes.items():
            nodes_with_assets[node] = {
                'assets': node.get_active_assets(),
                'system_users': system_users
            }
        return nodes_with_assets

    @classmethod
    def get_user_assets(cls, user):
        assets = collections.defaultdict(set)
        nodes_with_assets = cls.get_user_nodes_with_assets(user)

        for v in nodes_with_assets.values():
            for asset in v['assets']:
                assets[asset].update(v['system_users'])
        return assets

    @classmethod
    def get_system_user_assets(cls, system_user):
        assets = set()
        permissions = cls.get_system_user_permissions(system_user)

        for perm in permissions:
            assets.update(perm.node.get_all_assets())
        return assets