2021-05-07 11:40:04 +00:00
|
|
|
import time
|
2018-04-07 16:16:37 +00:00
|
|
|
from collections import defaultdict
|
2019-03-26 11:46:04 +00:00
|
|
|
|
2018-05-31 11:47:57 +00:00
|
|
|
from django.db.models import Q
|
2016-09-16 01:38:07 +00:00
|
|
|
|
2020-08-16 15:08:58 +00:00
|
|
|
from common.utils import get_logger
|
2021-05-07 11:40:04 +00:00
|
|
|
from perms.models import AssetPermission, Action
|
|
|
|
from perms.hands import Asset, User, UserGroup, SystemUser, Node
|
2021-03-02 06:48:47 +00:00
|
|
|
from perms.utils.asset.user_permission import get_user_all_asset_perm_ids
|
2017-03-09 06:55:33 +00:00
|
|
|
|
|
|
|
logger = get_logger(__file__)
|
2016-09-16 01:38:07 +00:00
|
|
|
|
|
|
|
|
2021-12-22 09:35:32 +00:00
|
|
|
def validate_permission(user, asset, system_user, action='connect'):
|
2021-05-07 11:40:04 +00:00
|
|
|
|
|
|
|
if not system_user.protocol in asset.protocols_as_dict.keys():
|
|
|
|
return False, time.time()
|
|
|
|
|
|
|
|
asset_perm_ids = get_user_all_asset_perm_ids(user)
|
|
|
|
|
|
|
|
asset_perm_ids_from_asset = AssetPermission.assets.through.objects.filter(
|
|
|
|
assetpermission_id__in=asset_perm_ids,
|
|
|
|
asset_id=asset.id
|
|
|
|
).values_list('assetpermission_id', flat=True)
|
|
|
|
|
|
|
|
nodes = asset.get_nodes()
|
|
|
|
node_keys = set()
|
|
|
|
for node in nodes:
|
|
|
|
ancestor_keys = node.get_ancestor_keys(with_self=True)
|
|
|
|
node_keys.update(ancestor_keys)
|
|
|
|
node_ids = Node.objects.filter(key__in=node_keys).values_list('id', flat=True)
|
|
|
|
|
|
|
|
node_ids = set(node_ids)
|
|
|
|
|
|
|
|
asset_perm_ids_from_node = AssetPermission.nodes.through.objects.filter(
|
|
|
|
assetpermission_id__in=asset_perm_ids,
|
|
|
|
node_id__in=node_ids
|
|
|
|
).values_list('assetpermission_id', flat=True)
|
|
|
|
|
|
|
|
asset_perm_ids = {*asset_perm_ids_from_asset, *asset_perm_ids_from_node}
|
|
|
|
|
|
|
|
asset_perm_ids = AssetPermission.system_users.through.objects.filter(
|
|
|
|
assetpermission_id__in=asset_perm_ids,
|
|
|
|
systemuser_id=system_user.id
|
|
|
|
).values_list('assetpermission_id', flat=True)
|
|
|
|
|
|
|
|
asset_perm_ids = set(asset_perm_ids)
|
|
|
|
|
|
|
|
asset_perms = AssetPermission.objects.filter(
|
|
|
|
id__in=asset_perm_ids
|
|
|
|
).order_by('-date_expired')
|
|
|
|
|
2021-12-22 09:35:32 +00:00
|
|
|
if asset_perms:
|
|
|
|
actions = set()
|
|
|
|
actions_values = asset_perms.values_list('actions', flat=True)
|
|
|
|
for value in actions_values:
|
|
|
|
_actions = Action.value_to_choices(value)
|
|
|
|
actions.update(_actions)
|
|
|
|
asset_perm: AssetPermission = asset_perms.first()
|
|
|
|
actions = list(actions)
|
|
|
|
expire_at = asset_perm.date_expired.timestamp()
|
|
|
|
else:
|
|
|
|
actions = []
|
|
|
|
expire_at = time.time()
|
|
|
|
|
|
|
|
# TODO: 组件改造API完成后统一通过actions判断has_perm
|
|
|
|
has_perm = action in actions
|
|
|
|
return has_perm, actions, expire_at
|
2021-05-07 11:40:04 +00:00
|
|
|
|
|
|
|
|
2021-03-08 02:08:51 +00:00
|
|
|
def get_asset_system_user_ids_with_actions(asset_perm_ids, asset: Asset):
|
2020-08-16 15:08:58 +00:00
|
|
|
nodes = asset.get_nodes()
|
|
|
|
node_keys = set()
|
|
|
|
for node in nodes:
|
|
|
|
ancestor_keys = node.get_ancestor_keys(with_self=True)
|
|
|
|
node_keys.update(ancestor_keys)
|
2019-09-11 10:52:42 +00:00
|
|
|
|
2021-03-02 06:48:47 +00:00
|
|
|
queryset = AssetPermission.objects.filter(id__in=asset_perm_ids)\
|
2021-02-23 06:37:42 +00:00
|
|
|
.filter(Q(assets=asset) | Q(nodes__key__in=node_keys))
|
2020-10-30 04:22:57 +00:00
|
|
|
|
2020-08-16 15:08:58 +00:00
|
|
|
asset_protocols = asset.protocols_as_dict.keys()
|
|
|
|
values = queryset.filter(
|
|
|
|
system_users__protocol__in=asset_protocols
|
|
|
|
).distinct().values_list('system_users', 'actions')
|
|
|
|
system_users_actions = defaultdict(int)
|
|
|
|
|
|
|
|
for system_user_id, actions in values:
|
|
|
|
if None in (system_user_id, actions):
|
|
|
|
continue
|
|
|
|
system_users_actions[system_user_id] |= actions
|
|
|
|
return system_users_actions
|
|
|
|
|
|
|
|
|
2021-03-08 02:08:51 +00:00
|
|
|
def get_asset_system_user_ids_with_actions_by_user(user: User, asset: Asset):
|
2021-03-02 06:48:47 +00:00
|
|
|
asset_perm_ids = get_user_all_asset_perm_ids(user)
|
2021-03-08 02:08:51 +00:00
|
|
|
return get_asset_system_user_ids_with_actions(asset_perm_ids, asset)
|
2019-07-11 10:12:14 +00:00
|
|
|
|
|
|
|
|
2021-02-23 06:37:42 +00:00
|
|
|
def has_asset_system_permission(user: User, asset: Asset, system_user: SystemUser):
|
2021-03-08 02:08:51 +00:00
|
|
|
systemuser_actions_mapper = get_asset_system_user_ids_with_actions_by_user(user, asset)
|
2021-11-16 03:12:59 +00:00
|
|
|
actions = systemuser_actions_mapper.get(system_user.id, 0)
|
2021-02-23 06:37:42 +00:00
|
|
|
if actions:
|
|
|
|
return True
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
2021-03-08 02:08:51 +00:00
|
|
|
def get_asset_system_user_ids_with_actions_by_group(group: UserGroup, asset: Asset):
|
2021-03-02 06:48:47 +00:00
|
|
|
asset_perm_ids = AssetPermission.objects.filter(
|
|
|
|
user_groups=group
|
|
|
|
).valid().values_list('id', flat=True).distinct()
|
2021-03-08 02:08:51 +00:00
|
|
|
return get_asset_system_user_ids_with_actions(asset_perm_ids, asset)
|