mirror of https://github.com/jumpserver/jumpserver
commit
e9fe5b3004
|
@ -76,9 +76,15 @@ class TreeService(Tree):
|
||||||
ancestor_ids.pop(0)
|
ancestor_ids.pop(0)
|
||||||
return ancestor_ids
|
return ancestor_ids
|
||||||
|
|
||||||
def ancestors(self, nid, with_self=False, deep=False):
|
def ancestors(self, nid, with_self=False, deep=False, with_assets=True):
|
||||||
ancestor_ids = self.ancestors_ids(nid, with_self=with_self)
|
ancestor_ids = self.ancestors_ids(nid, with_self=with_self)
|
||||||
return [self.get_node(i, deep=deep) for i in ancestor_ids]
|
ancestors = [self.get_node(i, deep=deep) for i in ancestor_ids]
|
||||||
|
if with_assets:
|
||||||
|
return ancestors
|
||||||
|
for n in ancestors:
|
||||||
|
n.data['assets'] = set()
|
||||||
|
n.data['all_assets'] = None
|
||||||
|
return ancestors
|
||||||
|
|
||||||
def get_node_full_tag(self, nid):
|
def get_node_full_tag(self, nid):
|
||||||
ancestors = self.ancestors(nid, with_self=True)
|
ancestors = self.ancestors(nid, with_self=True)
|
||||||
|
|
|
@ -84,8 +84,7 @@ class SimpleMetadataWithFilters(SimpleMetadata):
|
||||||
def get_filters_fields(self, request, view):
|
def get_filters_fields(self, request, view):
|
||||||
fields = []
|
fields = []
|
||||||
if hasattr(view, 'get_filter_fields'):
|
if hasattr(view, 'get_filter_fields'):
|
||||||
# fields = view.get_filter_fields(request)
|
fields = view.get_filter_fields(request)
|
||||||
fields = view.get_filter_fields()
|
|
||||||
elif hasattr(view, 'filter_fields'):
|
elif hasattr(view, 'filter_fields'):
|
||||||
fields = view.filter_fields
|
fields = view.filter_fields
|
||||||
return fields
|
return fields
|
||||||
|
@ -93,9 +92,9 @@ class SimpleMetadataWithFilters(SimpleMetadata):
|
||||||
def get_ordering_fields(self, request, view):
|
def get_ordering_fields(self, request, view):
|
||||||
fields = []
|
fields = []
|
||||||
if hasattr(view, 'get_ordering_fields'):
|
if hasattr(view, 'get_ordering_fields'):
|
||||||
fields = view.get_filter_fields(request)
|
fields = view.get_ordering_fields(request)
|
||||||
elif hasattr(view, 'ordering_fields'):
|
elif hasattr(view, 'ordering_fields'):
|
||||||
fields = view.filter_fields
|
fields = view.ordering_fields
|
||||||
return fields
|
return fields
|
||||||
|
|
||||||
def determine_metadata(self, request, view):
|
def determine_metadata(self, request, view):
|
||||||
|
|
|
@ -290,7 +290,7 @@ class AssetPermissionUtil(AssetPermissionUtilCacheMixin):
|
||||||
def parse_user_tree_to_full_tree(self, user_tree):
|
def parse_user_tree_to_full_tree(self, user_tree):
|
||||||
"""
|
"""
|
||||||
经过前面两个动作,用户授权的节点已放到树上,但是树不是完整的,
|
经过前面两个动作,用户授权的节点已放到树上,但是树不是完整的,
|
||||||
这里要讲树构造成一个完整的书
|
这里要讲树构造成一个完整的树
|
||||||
"""
|
"""
|
||||||
# 开始修正user_tree,保证父节点都在树上
|
# 开始修正user_tree,保证父节点都在树上
|
||||||
root_children = user_tree.children('')
|
root_children = user_tree.children('')
|
||||||
|
@ -300,7 +300,8 @@ class AssetPermissionUtil(AssetPermissionUtilCacheMixin):
|
||||||
if child.identifier.startswith('-'):
|
if child.identifier.startswith('-'):
|
||||||
continue
|
continue
|
||||||
ancestors = self.full_tree.ancestors(
|
ancestors = self.full_tree.ancestors(
|
||||||
child.identifier, with_self=False, deep=True
|
child.identifier, with_self=False, deep=True,
|
||||||
|
with_assets=False,
|
||||||
)
|
)
|
||||||
if not ancestors:
|
if not ancestors:
|
||||||
continue
|
continue
|
||||||
|
|
|
@ -63,7 +63,7 @@ class CommandQueryMixin:
|
||||||
def filter_queryset(self, queryset):
|
def filter_queryset(self, queryset):
|
||||||
return queryset
|
return queryset
|
||||||
|
|
||||||
def get_filter_fields(self):
|
def get_filter_fields(self, request):
|
||||||
fields = self.filter_fields
|
fields = self.filter_fields
|
||||||
fields.extend(["date_from", "date_to"])
|
fields.extend(["date_from", "date_to"])
|
||||||
return fields
|
return fields
|
||||||
|
|
|
@ -43,11 +43,13 @@ class UserForgotPasswordView(FormView):
|
||||||
user = get_object_or_none(User, email=email)
|
user = get_object_or_none(User, email=email)
|
||||||
if not user:
|
if not user:
|
||||||
error = _('Email address invalid, please input again')
|
error = _('Email address invalid, please input again')
|
||||||
return self.get(request, errors=error)
|
form.add_error('email', error)
|
||||||
|
return self.form_invalid(form)
|
||||||
elif not user.can_update_password():
|
elif not user.can_update_password():
|
||||||
error = _('User auth from {}, go there change password'.format(
|
error = _('User auth from {}, go there change password'.format(
|
||||||
user.source))
|
user.source))
|
||||||
return self.get(request, errors=error)
|
form.add_error('email', error)
|
||||||
|
return self.form_invalid(form)
|
||||||
else:
|
else:
|
||||||
send_reset_password_mail(user)
|
send_reset_password_mail(user)
|
||||||
return redirect('users:forgot-password-sendmail-success')
|
return redirect('users:forgot-password-sendmail-success')
|
||||||
|
|
Loading…
Reference in New Issue