• BaiJiangJie's avatar
    [Feature] 添加资产用户管理器 (#2489) · 4e705a52
    BaiJiangJie authored
    * [Feature] 1. 资产用户管理器
    
    * [Feature] 2. 资产用户管理器: 更新AuthBook
    
    * [Feature] 3. 资产用户管理器: 添加 AssetUser API
    
    * [Feature] 4. AssetUser Model: 添加方法 load_related_asset_auth
    
    * [Feature] 5. AdminUser: 更新管理用户获取认证信息时,先加载相关资产的认证
    
    * [Feature] 6. SystemUser: 更新系统用户获取认证信息时,先加载相关资产的认证
    
    * [Feature] 前端页面: 添加资产用户列表页面
    
    * [Feature] 前端页面: 管理用户的资产管理页面添加按钮: 修改资产用户认证信息
    
    * [Feature] 前端页面: 系统用户的资产管理页面添加按钮: 修改资产用户认证信息
    
    * [Feature] 优化: 从管理用户和系统用户的backend中获取相关资产用户的逻辑
    
    * [Update] Fix 1
    
    * [Feature] 优化: SystemUserBackend之filter功能
    
    * [Feature] 优化: AdminUserBackend之filter功能
    
    * [Feature] 优化: AdminUserBackend和SystemUserBackend功能
    
    * [Feature] 更新翻译: 资产用户管理器
    
    * [Update] 更新资产用户列表页名称为: asset_asset_user_list.html
    
    * [Bugfix] 修改bug: SystemUserBackend 根据用户名过滤系统用户
    
    * [Feature] 添加: 资产用户列表中可测试资产用户的连接性
    
    * [Update] 修改: AdHoc model的run_as字段从SystemUser外键修改为username字符串
    
    * [Feature] 添加: 获取系统用户认证信息(对应某个资产)API
    
    * [Update] 更新: API获取asset user时进行排序
    
    * [Bugfix] 修改: 资产用户可连接性CACHE_KEY
    
    * [Update] 更新翻译信息
    
    * [Update] 修改获取资产用户认证信息API的返回响应(200/400)
    
    * [Update] 修改BaseUser获取特定资产的方法名
    
    * [Update] 修改logger输出,AuthBook set_version_and_latest
    
    * [Update] 修改日志输出添加exc_info参数
    
    * [Update] 移除AuthBook迁移文件0026
    
    * [Bugfix] 修复AdminUserBackend获取instances为空的bug
    4e705a52
asset_user.py 1.11 KB
# -*- coding: utf-8 -*-
#

from ..base import BaseBackend
from .admin_user import AdminUserBackend
from .system_user import SystemUserBackend


class AssetUserBackend(BaseBackend):
    @classmethod
    def filter(cls, username=None, asset=None, **kwargs):
        admin_user_instances = AdminUserBackend.filter(username, asset)
        system_user_instances = SystemUserBackend.filter(username, asset)
        instances = cls._merge_instances(admin_user_instances, system_user_instances)
        return instances

    @classmethod
    def _merge_instances(cls, admin_user_instances, system_user_instances):
        admin_user_instances_keyword_list = [
            {'username': instance.username, 'asset': instance.asset}
            for instance in admin_user_instances
        ]
        instances = [
            instance for instance in system_user_instances
            if instance.keyword not in admin_user_instances_keyword_list
        ]
        admin_user_instances.extend(instances)
        return admin_user_instances

    @classmethod
    def create(cls, **kwargs):
        raise cls.NotSupportError("Not support create")