From 26f3f79388a5e8587d9e8f704cc868398e022c94 Mon Sep 17 00:00:00 2001 From: Matt Scott Date: Fri, 10 Mar 2023 16:23:33 -0500 Subject: [PATCH] Corrected unauthorized side navigation change regarding the placement of the "Global Search" feature. Removed the statistics and recent activity / history data display from the dashboard view. --- powerdnsadmin/routes/dashboard.py | 70 ++----------- powerdnsadmin/templates/base.html | 12 +-- powerdnsadmin/templates/dashboard.html | 135 ------------------------- 3 files changed, 14 insertions(+), 203 deletions(-) diff --git a/powerdnsadmin/routes/dashboard.py b/powerdnsadmin/routes/dashboard.py index 51dadfd..0f24121 100644 --- a/powerdnsadmin/routes/dashboard.py +++ b/powerdnsadmin/routes/dashboard.py @@ -36,7 +36,7 @@ class ZoneTabs: """ tabs = { - 'forward': TabInfo("", None), + 'forward': TabInfo("", None), 'reverse_ipv4': TabInfo("in-addr.arpa", '%.in-addr.arpa'), 'reverse_ipv6': TabInfo("ip6.arpa", '%.ip6.arpa'), } @@ -55,7 +55,7 @@ def before_request(): # Check site is in maintenance mode maintenance = Setting().get('maintenance') if maintenance and current_user.is_authenticated and current_user.role.name not in [ - 'Administrator', 'Operator' + 'Administrator', 'Operator' ]: return render_template('maintenance.html') @@ -83,13 +83,14 @@ def domains_custom(tab_id): .outerjoin(Account, Domain.account_id == Account.id) \ .outerjoin(AccountUser, Account.id == AccountUser.account_id) \ .filter( - db.or_( - DomainUser.user_id == current_user.id, - AccountUser.user_id == current_user.id - )) + db.or_( + DomainUser.user_id == current_user.id, + AccountUser.user_id == current_user.id + )) template = current_app.jinja_env.get_template("dashboard_domain.html") - render = template.make_module(vars={"current_user": current_user, "allow_user_view_history": Setting().get('allow_user_view_history')}) + render = template.make_module( + vars={"current_user": current_user, "allow_user_view_history": Setting().get('allow_user_view_history')}) columns = [ Domain.name, Domain.dnssec, Domain.type, Domain.serial, Domain.master, @@ -184,64 +185,9 @@ def dashboard(): if BG_DOMAIN_UPDATE and current_user.role.name not in ['Administrator', 'Operator']: show_bg_domain_button = False - # Stats for dashboard - domain_count = 0 - history_number = 0 - history = [] - user_num = User.query.count() - if current_user.role.name in ['Administrator', 'Operator']: - domain_count = Domain.query.count() - history_number = History.query.count() - history = History.query.order_by(History.created_on.desc()).limit(4).all() - elif Setting().get('allow_user_view_history'): - allowed_domain_id_subquery = db.session.query(Domain.id) \ - .outerjoin(DomainUser, Domain.id == DomainUser.domain_id) \ - .outerjoin(Account, Domain.account_id == Account.id) \ - .outerjoin(AccountUser, Account.id == AccountUser.account_id) \ - .filter(db.or_( - DomainUser.user_id == current_user.id, - AccountUser.user_id == current_user.id - )) \ - .subquery() - history = db.session.query(History) \ - .with_hint(History, "FORCE INDEX (ix_history_created_on)", 'mysql') \ - .order_by(History.created_on.desc()) \ - .filter(History.domain_id.in_(allowed_domain_id_subquery)) \ - .limit(4) \ - .all() - history_number = db.session.query(History) \ - .filter(History.domain_id.in_(allowed_domain_id_subquery)) \ - .count() - domain_count = db.session.query(Domain) \ - .outerjoin(DomainUser, Domain.id == DomainUser.domain_id) \ - .outerjoin(Account, Domain.account_id == Account.id) \ - .outerjoin(AccountUser, Account.id == AccountUser.account_id) \ - .filter( - db.or_( - DomainUser.user_id == current_user.id, - AccountUser.user_id == current_user.id - )).count() - - from .admin import convert_histories, DetailedHistory - detailedHistories = convert_histories(history) - - server = Server(server_id='localhost') - statistics = server.get_statistic() - if statistics: - uptime = list([ - uptime for uptime in statistics if uptime['name'] == 'uptime' - ])[0]['value'] - else: - uptime = 0 - # Add custom boxes to render_template return render_template('dashboard.html', zone_tabs=ZoneTabs, - domain_count=domain_count, - user_num=user_num, - history_number=history_number, - uptime=uptime, - histories=detailedHistories, show_bg_domain_button=show_bg_domain_button, pdns_version=Setting().get('pdns_version')) diff --git a/powerdnsadmin/templates/base.html b/powerdnsadmin/templates/base.html index 0a526d5..0ba24cf 100644 --- a/powerdnsadmin/templates/base.html +++ b/powerdnsadmin/templates/base.html @@ -85,12 +85,6 @@

Dashboard

-
  • - - -

    Global Search

    -
    -
  • {% if SETTING.get('allow_user_create_domain') or current_user.role.name in ['Administrator', 'Operator'] %}
  • @@ -109,6 +103,12 @@ {% endif %} {% if current_user.role.name in ['Administrator', 'Operator'] %}
  • +
  • + + +

    Global Search

    +
    +
  • diff --git a/powerdnsadmin/templates/dashboard.html b/powerdnsadmin/templates/dashboard.html index c632e5a..1dde5af 100755 --- a/powerdnsadmin/templates/dashboard.html +++ b/powerdnsadmin/templates/dashboard.html @@ -21,144 +21,9 @@ {% endblock %} -{% import 'applied_change_macro.html' as applied_change_macro %} - {% block content %}
    - - - - - {% if current_user.role.name in ['Administrator', 'Operator'] or SETTING.get('allow_user_view_history') %} -
    -
    -
    -
    -

    Recent Activity

    -
    - -
    - - - - - - - - - - - {% for history in histories %} - - - - - - - {% endfor %} - -
    Log MessageTimestampUserActions
    {{ history.history.msg }}{{ history.history.created_on | format_datetime_local }}{{ history.history.created_by }} - - -
    -
    - -
    - -
    - -
    - - {% endif %} -