mirror of https://github.com/jumpserver/jumpserver
commit
acc03f14dd
|
@ -1,5 +1,7 @@
|
|||
## Jumpserver 多云环境下更好用的堡垒机
|
||||
|
||||
data:image/s3,"s3://crabby-images/23f99/23f9998f52cd3ff79a81d9a9b42565e6978ab87d" alt="Total visitor"
|
||||
data:image/s3,"s3://crabby-images/b3bf1/b3bf12586afa39390b9b07617bd2abf644c84b16" alt="Visitors in today"
|
||||
[data:image/s3,"s3://crabby-images/8d491/8d4910599b578516e0707db1c84eacc7335e45ba" alt="Python3"](https://www.python.org/)
|
||||
[data:image/s3,"s3://crabby-images/f6710/f6710b57bf656b95aa380db86e697cc0fe837df6" alt="Django"](https://www.djangoproject.com/)
|
||||
[data:image/s3,"s3://crabby-images/a4161/a41614df4ae41956638b4d5119328e7d9f8104b5" alt="Ansible"](https://www.ansible.com/)
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
## Jumpserver
|
||||
|
||||
data:image/s3,"s3://crabby-images/23f99/23f9998f52cd3ff79a81d9a9b42565e6978ab87d" alt="Total visitor"
|
||||
data:image/s3,"s3://crabby-images/b3bf1/b3bf12586afa39390b9b07617bd2abf644c84b16" alt="Visitors in today"
|
||||
[data:image/s3,"s3://crabby-images/8d491/8d4910599b578516e0707db1c84eacc7335e45ba" alt="Python3"](https://www.python.org/)
|
||||
[data:image/s3,"s3://crabby-images/f6710/f6710b57bf656b95aa380db86e697cc0fe837df6" alt="Django"](https://www.djangoproject.com/)
|
||||
[data:image/s3,"s3://crabby-images/a4161/a41614df4ae41956638b4d5119328e7d9f8104b5" alt="Ansible"](https://www.ansible.com/)
|
||||
|
|
|
@ -7,7 +7,7 @@ from common.utils import get_ip_city, validate_ip
|
|||
def write_login_log(*args, **kwargs):
|
||||
from audits.models import UserLoginLog
|
||||
default_city = _("Unknown")
|
||||
ip = kwargs.get('ip', '')
|
||||
ip = kwargs.get('ip') or ''
|
||||
if not (ip and validate_ip(ip)):
|
||||
ip = ip[:15]
|
||||
city = default_city
|
||||
|
|
|
@ -379,6 +379,7 @@ defaults = {
|
|||
'ASSETS_PERM_CACHE_TIME': 3600*24,
|
||||
'SECURITY_MFA_VERIFY_TTL': 3600,
|
||||
'ASSETS_PERM_CACHE_ENABLE': False,
|
||||
'PERM_SINGLE_ASSET_TO_UNGROUP_NODE': False,
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -615,3 +615,5 @@ ASSETS_PERM_CACHE_TIME = CONFIG.ASSETS_PERM_CACHE_TIME
|
|||
|
||||
# Asset user auth external backend, default AuthBook backend
|
||||
BACKEND_ASSET_USER_AUTH_VAULT = False
|
||||
|
||||
PERM_SINGLE_ASSET_TO_UNGROUP_NODE = CONFIG.PERM_SINGLE_ASSET_TO_UNGROUP_NODE
|
||||
|
|
|
@ -180,6 +180,19 @@ class GenerateTree:
|
|||
assets.append({"id": asset_id, "system_users": system_users})
|
||||
return assets
|
||||
|
||||
def set_ungrouped_assets_nodes_if_need(self):
|
||||
if settings.PERM_SINGLE_ASSET_TO_UNGROUP_NODE:
|
||||
return
|
||||
ungrouped_assets_ids = self.nodes[self.ungrouped_key]["assets"]
|
||||
for asset_id in ungrouped_assets_ids:
|
||||
in_nodes = self.all_assets_nodes_keys.get(asset_id, [])
|
||||
for node_key in in_nodes:
|
||||
parents_keys = self.node_util.get_nodes_parents_keys_by_key(node_key, with_self=False)
|
||||
for parent_key in parents_keys:
|
||||
n = self.nodes[parent_key]
|
||||
self.nodes[node_key]["assets"].add(asset_id)
|
||||
self.nodes.pop(self.ungrouped_key, None)
|
||||
|
||||
@timeit
|
||||
def get_nodes_with_assets(self):
|
||||
"""
|
||||
|
@ -198,6 +211,7 @@ class GenerateTree:
|
|||
"""
|
||||
if self._nodes_with_assets:
|
||||
return self._nodes_with_assets
|
||||
self.set_ungrouped_assets_nodes_if_need()
|
||||
util = PermAssetsAmountUtil()
|
||||
nodes_with_assets_amount = util.compute_nodes_assets_amount(self.nodes)
|
||||
nodes = []
|
||||
|
@ -219,6 +233,7 @@ class GenerateTree:
|
|||
return nodes
|
||||
|
||||
def get_nodes(self):
|
||||
self.set_ungrouped_assets_nodes_if_need()
|
||||
nodes = list(self.nodes.keys())
|
||||
if not nodes:
|
||||
nodes.append(const.EMPTY_NODE_KEY)
|
||||
|
|
|
@ -76,3 +76,7 @@ REDIS_PORT: 6379
|
|||
# OTP/MFA 配置
|
||||
# OTP_VALID_WINDOW: 0
|
||||
# OTP_ISSUER_NAME: Jumpserver
|
||||
|
||||
# Perm show single asset to ungrouped node
|
||||
# 是否把未授权节点资产放入到 未分组 节点中
|
||||
# PERM_SINGLE_ASSET_TO_UNGROUP_NODE: false
|
||||
|
|
Loading…
Reference in New Issue