2022-10-14 09:01:36 +00:00
|
|
|
from collections import defaultdict
|
2022-11-11 07:04:31 +00:00
|
|
|
|
2023-01-16 11:02:09 +00:00
|
|
|
from accounts.const import AliasAccount
|
2023-08-08 02:16:23 +00:00
|
|
|
from accounts.models import VirtualAccount
|
2023-06-27 03:23:56 +00:00
|
|
|
from orgs.utils import tmp_to_org
|
2022-10-18 07:21:44 +00:00
|
|
|
from .permission import AssetPermissionUtil
|
2022-10-14 09:01:36 +00:00
|
|
|
|
2022-10-18 08:42:32 +00:00
|
|
|
__all__ = ['PermAccountUtil']
|
|
|
|
|
2022-10-14 09:01:36 +00:00
|
|
|
|
2022-10-18 07:21:44 +00:00
|
|
|
class PermAccountUtil(AssetPermissionUtil):
|
|
|
|
""" 资产授权账号相关的工具 """
|
2022-11-14 06:44:18 +00:00
|
|
|
|
2022-12-02 12:33:32 +00:00
|
|
|
def validate_permission(self, user, asset, account_name):
|
2022-11-16 03:29:02 +00:00
|
|
|
""" 校验用户有某个资产下某个账号名的权限
|
|
|
|
:param user: User
|
|
|
|
:param asset: Asset
|
2022-12-02 12:33:32 +00:00
|
|
|
:param account_name: 可能是 @USER @INPUT 字符串
|
2022-11-16 03:29:02 +00:00
|
|
|
"""
|
2023-02-23 16:04:53 +00:00
|
|
|
with tmp_to_org(asset.org):
|
|
|
|
permed_accounts = self.get_permed_accounts_for_user(user, asset)
|
|
|
|
accounts_mapper = {account.alias: account for account in permed_accounts}
|
|
|
|
account = accounts_mapper.get(account_name)
|
|
|
|
return account
|
2022-11-16 03:29:02 +00:00
|
|
|
|
2022-11-15 09:49:28 +00:00
|
|
|
def get_permed_accounts_for_user(self, user, asset):
|
|
|
|
""" 获取授权给用户某个资产的账号 """
|
|
|
|
perms = self.get_permissions_for_user_asset(user, asset)
|
|
|
|
permed_accounts = self.get_permed_accounts_from_perms(perms, user, asset)
|
|
|
|
return permed_accounts
|
|
|
|
|
2022-11-11 07:04:31 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_permed_accounts_from_perms(perms, user, asset):
|
2023-06-27 03:23:56 +00:00
|
|
|
# alias: is a collection of account usernames and special accounts [@ALL, @INPUT, @USER, @ANON]
|
2022-11-11 07:04:31 +00:00
|
|
|
alias_action_bit_mapper = defaultdict(int)
|
2023-06-27 03:23:56 +00:00
|
|
|
alias_date_expired_mapper = defaultdict(list)
|
2022-11-11 07:04:31 +00:00
|
|
|
|
|
|
|
for perm in perms:
|
|
|
|
for alias in perm.accounts:
|
|
|
|
alias_action_bit_mapper[alias] |= perm.actions
|
2023-06-27 03:23:56 +00:00
|
|
|
alias_date_expired_mapper[alias].append(perm.date_expired)
|
2022-11-11 07:04:31 +00:00
|
|
|
|
2023-02-14 06:36:22 +00:00
|
|
|
asset_accounts = asset.accounts.all().active()
|
2023-07-19 12:16:40 +00:00
|
|
|
username_accounts_mapper = defaultdict(list)
|
|
|
|
for account in asset_accounts:
|
|
|
|
username_accounts_mapper[account.username].append(account)
|
2022-11-16 03:29:02 +00:00
|
|
|
|
2022-11-11 07:04:31 +00:00
|
|
|
cleaned_accounts_action_bit = defaultdict(int)
|
|
|
|
cleaned_accounts_expired = defaultdict(list)
|
|
|
|
|
|
|
|
# @ALL 账号先处理,后面的每个最多映射一个账号
|
2022-12-27 09:45:41 +00:00
|
|
|
all_action_bit = alias_action_bit_mapper.pop(AliasAccount.ALL, None)
|
2022-11-11 07:04:31 +00:00
|
|
|
if all_action_bit:
|
|
|
|
for account in asset_accounts:
|
|
|
|
cleaned_accounts_action_bit[account] |= all_action_bit
|
2022-11-16 03:29:02 +00:00
|
|
|
cleaned_accounts_expired[account].extend(
|
2023-06-27 03:23:56 +00:00
|
|
|
alias_date_expired_mapper[AliasAccount.ALL]
|
2022-11-16 03:29:02 +00:00
|
|
|
)
|
2022-11-11 07:04:31 +00:00
|
|
|
|
|
|
|
for alias, action_bit in alias_action_bit_mapper.items():
|
2023-07-19 12:16:40 +00:00
|
|
|
account = None
|
2023-07-19 12:27:06 +00:00
|
|
|
_accounts = []
|
2023-08-08 02:16:23 +00:00
|
|
|
if alias == AliasAccount.USER and user.username in username_accounts_mapper:
|
2023-08-10 07:56:31 +00:00
|
|
|
_accounts = username_accounts_mapper[user.username]
|
2023-07-19 12:27:06 +00:00
|
|
|
elif alias in username_accounts_mapper:
|
|
|
|
_accounts = username_accounts_mapper[alias]
|
2023-08-08 02:16:23 +00:00
|
|
|
elif alias in ['@INPUT', '@ANON', '@USER']:
|
|
|
|
account = VirtualAccount.get_special_account(alias, user, asset, from_permed=True)
|
2023-06-27 03:23:56 +00:00
|
|
|
elif alias.startswith('@'):
|
|
|
|
continue
|
2022-10-14 09:01:36 +00:00
|
|
|
|
2022-11-11 07:04:31 +00:00
|
|
|
if account:
|
2023-07-19 12:27:06 +00:00
|
|
|
_accounts += [account]
|
2023-07-19 12:16:40 +00:00
|
|
|
|
2023-07-19 12:27:06 +00:00
|
|
|
for account in _accounts:
|
2022-11-11 07:04:31 +00:00
|
|
|
cleaned_accounts_action_bit[account] |= action_bit
|
2023-06-27 03:23:56 +00:00
|
|
|
cleaned_accounts_expired[account].extend(alias_date_expired_mapper[alias])
|
2022-11-11 07:04:31 +00:00
|
|
|
|
|
|
|
accounts = []
|
|
|
|
for account, action_bit in cleaned_accounts_action_bit.items():
|
|
|
|
account.actions = action_bit
|
|
|
|
account.date_expired = max(cleaned_accounts_expired[account])
|
|
|
|
accounts.append(account)
|
2022-10-18 08:42:32 +00:00
|
|
|
return accounts
|