mirror of
https://github.com/mailcow/mailcow-dockerized.git
synced 2025-01-06 16:04:31 +08:00
323 lines
29 KiB
Twig
323 lines
29 KiB
Twig
{% extends 'base.twig' %}
|
|
|
|
{% block content %}
|
|
<ul class="nav nav-tabs" role="tablist">
|
|
<li role="presentation" class="nav-item"><button class="nav-link active" data-bs-target="#tab-containers" aria-controls="tab-containers" role="tab" data-bs-toggle="tab">{{ lang.debug.system_containers }}</button></li>
|
|
<li class="nav-item dropdown">
|
|
<a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#">{{ lang.debug.logs }}</a>
|
|
<ul class="dropdown-menu">
|
|
<li role="presentation"><span class="dropdown-header fs-6">{{ lang.debug.in_memory_logs }}</span></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-postfix-logs" aria-selected="false" aria-controls="tab-postfix-logs" role="tab" data-bs-toggle="tab">Postfix</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-dovecot-logs" aria-selected="false" aria-controls="tab-dovecot-logs" role="tab" data-bs-toggle="tab">Dovecot</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-sogo-logs" aria-selected="false" aria-controls="tab-sogo-logs" role="tab" data-bs-toggle="tab">SOGo</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-netfilter-logs" aria-selected="false" aria-controls="tab-netfilter-logs" role="tab" data-bs-toggle="tab">Netfilter</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-autodiscover-logs" aria-selected="false" aria-controls="tab-autodiscover-logs" role="tab" data-bs-toggle="tab">Autodiscover</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-watchdog-logs" aria-selected="false" aria-controls="tab-watchdog-logs" role="tab" data-bs-toggle="tab">Watchdog</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-acme-logs" aria-selected="false" aria-controls="tab-acme-logs" role="tab" data-bs-toggle="tab">ACME</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-api-logs" aria-selected="false" aria-controls="tab-api-logs" role="tab" data-bs-toggle="tab">API</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-api-rl" aria-selected="false" aria-controls="tab-api-rl" role="tab" data-bs-toggle="tab">Ratelimits</button></li>
|
|
<li role="presentation"><span class="dropdown-header fs-6">{{ lang.debug.external_logs }}</span></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-rspamd-history" aria-selected="false" aria-controls="tab-rspamd-history" role="tab" data-bs-toggle="tab">Rspamd</button></li>
|
|
<li role="presentation"><span class="dropdown-header fs-6">{{ lang.debug.static_logs }}</span></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-ui" aria-selected="false" aria-controls="tab-ui" role="tab" data-bs-toggle="tab">Mailcow UI</button></li>
|
|
<li role="presentation"><button class="dropdown-item" data-bs-target="#tab-sasl" aria-selected="false" aria-controls="tab-sasl" role="tab" data-bs-toggle="tab">SASL</button></li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<div class="row">
|
|
<div class="col-md-12">
|
|
<div class="tab-content" style="padding-top:20px">
|
|
<div class="debug-log-info">{{ lang.debug.log_info|format(log_lines+1)|raw }}</div>
|
|
<div role="tabpanel" class="tab-pane active" id="tab-containers">
|
|
<div class="card mb-4">
|
|
<div class="card-header">
|
|
<h3 class="card-title">{{ lang.debug.disk_usage }}</h3>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="row">
|
|
<div class="col-sm-3">
|
|
<p><i class="bi bi-hdd-fill"></i> {{ vmail_df[0] }}</p>
|
|
<p>{{ vmail_df[2] }} / {{ vmail_df[1] }} ({{ vmail_df[4] }})</p>
|
|
</div>
|
|
<div class="col-sm-9">
|
|
<div class="progress">
|
|
<div class="progress-bar bg-info" role="progressbar" style="width:{{ vmail_df[4] }}"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="card mb-4">
|
|
<div class="card-header">
|
|
<h3 class="card-title">{{ lang.debug.solr_status }}</h3>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="row">
|
|
<div class="col-sm-3">
|
|
<p><img class="img-responsive" alt="Solr Logo" width="128px" src="" /></p>
|
|
</div>
|
|
<div class="col-sm-9">
|
|
{% if solr_status != false %}
|
|
<div class="progress">
|
|
<div class="progress-bar bg-info" role="progressbar" style="width:{{ solr_status.jvm.memory.raw['used%']|round }}%"></div>
|
|
</div>
|
|
<p>{{ lang.debug.jvm_memory_solr }}: {{ (solr_status.jvm.memory.total - solr_status.jvm.memory.free) }} / {{ solr_status.jvm.memory.total }}
|
|
({{ solr_status.jvm.memory.raw['used%']|round }}%)</p>
|
|
<hr>
|
|
<p>{{ lang.debug.uptime }}: {{ solr_uptime }}h</p>
|
|
<p>{{ lang.debug.started_at }}: <span class="parse_date">{{ solr_status.status['dovecot-fts'].startTime }}</span></p>
|
|
<p>{{ lang.debug.last_modified }}: <span class="parse_date">{{ solr_status.status['dovecot-fts'].index.lastModified }}</span></p>
|
|
<p>{{ lang.debug.size }}: {{ solr_status.status['dovecot-fts'].index.size }}</p>
|
|
<p><i class="bi bi-file-text"></i> {{ lang.debug.docs }}: {{ solr_status.status['dovecot-fts'].index.numDocs }}</p>
|
|
{% else %}
|
|
<p>{{ lang.debug.solr_dead }}</p>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="card mb-4">
|
|
<div class="card-header">
|
|
<h3 class="card-title">{{ lang.debug.containers_info }}</h3>
|
|
</div>
|
|
<div class="card-body">
|
|
<ul class="list-group">
|
|
{% for container, container_info in containers %}
|
|
<li class="list-group-item d-flex">
|
|
<div>
|
|
<span>{{ container }}</span>
|
|
<span class="d-block d-md-inline">({{ container_info.Config.Image }})</span>
|
|
<small class="d-block">({{ lang.debug.started_on }} <span class="parse_date">{{ container_info.State.StartedAtHR }}</span>)</small>
|
|
</div>
|
|
<div class="ms-auto">
|
|
<a href data-bs-toggle="modal" data-container="{{ container }}" data-bs-target="#RestartContainer" class="btn btn-sm btn-secondary d-flex align-items-center mb-2" style="height: 30px;">{{ lang.debug.restart_container }}
|
|
<i class="ms-1 bi
|
|
{% if container_info.State.Running == 1 %}
|
|
bi-record-fill text-success
|
|
{% elseif container_info.State %}
|
|
bi-record-fill text-danger
|
|
{% else %}
|
|
default
|
|
{% endif %}
|
|
"
|
|
></i></a>
|
|
{% if container_info.State.Running == 1 %}
|
|
<span class="badge fs-7 bg-success loader" style="min-width:100px">
|
|
{{ lang.debug.container_running }}
|
|
<span class="loader-dot">.</span>
|
|
<span class="loader-dot">.</span>
|
|
<span class="loader-dot">.</span>
|
|
</span>
|
|
{% elseif container_info.State %}
|
|
<span class="badge fs-7 bg-danger" style="min-width:100px">
|
|
{{ lang.debug.container_stopped }}
|
|
<i class="bi-x ms-1"></i>
|
|
</span>
|
|
{% endif %}
|
|
</div>
|
|
</li>
|
|
{% endfor %}
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-postfix-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">Postfix
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="postfix_log" data-log-url="postfix" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="postfix_log" data-log-url="postfix" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_postfix_logs" data-table="postfix_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="postfix_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-ui">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex"> Mailcow UI
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="mailcow_ui" data-table="ui_logs" data-log-url="ui" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="mailcow_ui" data-table="ui_logs" data-log-url="ui" data-nrows="10000">+ 10000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_ui_logs" data-table="ui_logs">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="ui_logs" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-sasl">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">SASL
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="sasl_log_table" data-table="sasl_logs" data-log-url="ui" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="sasl_log_table" data-table="sasl_logs" data-log-url="ui" data-nrows="10000">+ 10000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_sasl_logs" data-table="sasl_logs">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="sasl_logs" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-dovecot-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">Dovecot
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="dovecot_log" data-log-url="dovecot" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="dovecot_log" data-log-url="dovecot" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_dovecot_logs" data-table="dovecot_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="dovecot_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-sogo-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">SOGo
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="sogo_log" data-log-url="sogo" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="sogo_log" data-log-url="sogo" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_sogo_logs" data-table="sogo_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="sogo_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-netfilter-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">Netfilter
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="netfilter_log" data-log-url="netfilter" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="netfilter_log" data-log-url="netfilter" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_netfilter_logs" data-table="netfilter_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="netfilter_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-rspamd-history">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">Rspamd history
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="rspamd_history" data-table="rspamd_history" data-log-url="rspamd-history" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="rspamd_history" data-table="rspamd_history" data-log-url="rspamd-history" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_rspamd_history" data-table="rspamd_history">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<legend>{{ lang.debug.chart_this_server }}</legend><hr />
|
|
<div id="chart-container">
|
|
<canvas id="rspamd_donut" style="width:100%;height:400px"></canvas>
|
|
</div>
|
|
<legend>{{ lang.debug.history_all_servers }}</legend><hr />
|
|
<table id="rspamd_history" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-autodiscover-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">Autodiscover
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="autodiscover_log" data-table="autodiscover_log" data-log-url="autodiscover" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="autodiscover_log" data-table="autodiscover_log" data-log-url="autodiscover" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_autodiscover_logs" data-table="autodiscover_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="autodiscover_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-watchdog-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">Watchdog
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="watchdog" data-table="watchdog_log" data-log-url="watchdog" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="watchdog" data-table="watchdog_log" data-log-url="watchdog" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_watchdog_logs" data-table="watchdog_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="watchdog_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-acme-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">ACME
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="acme_log" data-log-url="acme" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="general_syslog" data-table="acme_log" data-log-url="acme" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_acme_logs" data-table="acme_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="acme_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-api-logs">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">API
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="apilog" data-table="api_log" data-log-url="api" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="apilog" data-table="api_log" data-log-url="api" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_api_logs" data-table="api_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<table id="api_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div role="tabpanel" class="tab-pane" id="tab-api-rl">
|
|
<div class="card panel-xs-lg">
|
|
<div class="card-header d-flex">Ratelimits
|
|
<div class="btn-group ms-auto">
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="rllog" data-table="rl_log" data-log-url="ratelimited" data-nrows="100">+ 100</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary add_log_lines" data-post-process="rllog" data-table="rl_log" data-log-url="ratelimited" data-nrows="1000">+ 1000</button>
|
|
<button class="btn btn-xs btn-xs-lg btn-secondary refresh_table" data-draw="draw_rl_logs" data-table="rl_log">{{ lang.admin.refresh }}</button>
|
|
</div>
|
|
</div>
|
|
<div class="card-body">
|
|
<p class="text-muted">{{ lang.admin.hash_remove_info }}</p>
|
|
<table id="rl_log" class="table table-striped dt-responsive w-100"></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div> <!-- /tab-content -->
|
|
</div> <!-- /col-md-12 -->
|
|
</div> <!-- /row -->
|
|
|
|
<script type='text/javascript'>
|
|
var lang = {{ lang_admin|raw }};
|
|
var lang_datatables = {{ lang_datatables|raw }};
|
|
var csrf_token = '{{ csrf_token }}';
|
|
var log_pagination_size = '{{ log_pagination_size }}';
|
|
</script>
|
|
{% endblock %}
|