2017-12-09 20:17:15 +08:00
|
|
|
<?php
|
2018-10-11 17:59:23 +08:00
|
|
|
require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/prerequisites.inc.php';
|
2017-12-09 20:17:15 +08:00
|
|
|
|
2021-09-23 02:47:10 +08:00
|
|
|
if (!isset($_SESSION['mailcow_cc_role']) || $_SESSION['mailcow_cc_role'] != "admin") {
|
|
|
|
header('Location: /');
|
|
|
|
exit();
|
|
|
|
}
|
|
|
|
|
2018-10-11 17:59:23 +08:00
|
|
|
require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/header.inc.php';
|
2017-12-09 20:17:15 +08:00
|
|
|
$_SESSION['return_to'] = $_SERVER['REQUEST_URI'];
|
2020-01-11 18:00:56 +08:00
|
|
|
$solr_status = (preg_match("/^([yY][eE][sS]|[yY])+$/", $_ENV["SKIP_SOLR"])) ? false : solr_status();
|
2020-01-11 18:22:08 +08:00
|
|
|
$clamd_status = (preg_match("/^([yY][eE][sS]|[yY])+$/", $_ENV["SKIP_CLAMD"])) ? false : true;
|
2017-12-09 20:17:15 +08:00
|
|
|
|
2022-12-26 19:03:51 +08:00
|
|
|
|
|
|
|
if (!isset($_SESSION['gal']) && $license_cache = $redis->Get('LICENSE_STATUS_CACHE')) {
|
|
|
|
$_SESSION['gal'] = json_decode($license_cache, true);
|
|
|
|
}
|
|
|
|
|
2021-09-23 02:47:10 +08:00
|
|
|
$js_minifier->add('/web/js/site/debug.js');
|
2017-12-09 20:17:15 +08:00
|
|
|
|
2021-09-23 02:47:10 +08:00
|
|
|
// vmail df
|
|
|
|
$exec_fields = array('cmd' => 'system', 'task' => 'df', 'dir' => '/var/vmail');
|
|
|
|
$vmail_df = explode(',', (string)json_decode(docker('post', 'dovecot-mailcow', 'exec', $exec_fields), true));
|
|
|
|
|
|
|
|
// containers
|
|
|
|
$containers = (array) docker('info');
|
|
|
|
if ($clamd_status === false) unset($containers['clamd-mailcow']);
|
|
|
|
if ($solr_status === false) unset($containers['solr-mailcow']);
|
|
|
|
ksort($containers);
|
|
|
|
foreach ($containers as $container => $container_info) {
|
|
|
|
date_default_timezone_set('UTC');
|
|
|
|
$StartedAt = date_parse($container_info['State']['StartedAt']);
|
|
|
|
if ($StartedAt['hour'] !== false) {
|
|
|
|
$date = new \DateTime();
|
|
|
|
$date->setTimestamp(mktime(
|
|
|
|
$StartedAt['hour'],
|
|
|
|
$StartedAt['minute'],
|
|
|
|
$StartedAt['second'],
|
|
|
|
$StartedAt['month'],
|
|
|
|
$StartedAt['day'],
|
|
|
|
$StartedAt['year']));
|
|
|
|
$user_tz = new DateTimeZone(getenv('TZ'));
|
|
|
|
$date->setTimezone($user_tz);
|
|
|
|
$started = $date->format('r');
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$started = '?';
|
|
|
|
}
|
|
|
|
$containers[$container]['State']['StartedAtHR'] = $started;
|
|
|
|
}
|
2017-12-09 20:17:15 +08:00
|
|
|
|
2022-09-26 18:19:51 +08:00
|
|
|
// get mailcow data
|
2022-08-10 02:29:33 +08:00
|
|
|
$hostname = getenv('MAILCOW_HOSTNAME');
|
|
|
|
$timezone = getenv('TZ');
|
|
|
|
|
2021-09-23 02:47:10 +08:00
|
|
|
$template = 'debug.twig';
|
|
|
|
$template_data = [
|
|
|
|
'log_lines' => getenv('LOG_LINES'),
|
|
|
|
'vmail_df' => $vmail_df,
|
2022-08-10 02:29:33 +08:00
|
|
|
'hostname' => $hostname,
|
|
|
|
'timezone' => $timezone,
|
2022-12-26 19:03:51 +08:00
|
|
|
'gal' => @$_SESSION['gal'],
|
2022-09-30 17:38:43 +08:00
|
|
|
'license_guid' => license('guid'),
|
2021-09-23 02:47:10 +08:00
|
|
|
'solr_status' => $solr_status,
|
|
|
|
'solr_uptime' => round($solr_status['status']['dovecot-fts']['uptime'] / 1000 / 60 / 60),
|
|
|
|
'clamd_status' => $clamd_status,
|
|
|
|
'containers' => $containers,
|
2023-01-06 19:09:15 +08:00
|
|
|
'ip_check' => customize('get', 'ip_check'),
|
2021-09-23 02:47:10 +08:00
|
|
|
'lang_admin' => json_encode($lang['admin']),
|
2022-08-10 02:29:33 +08:00
|
|
|
'lang_debug' => json_encode($lang['debug']),
|
2022-05-17 20:08:22 +08:00
|
|
|
'lang_datatables' => json_encode($lang['datatables']),
|
2021-09-23 02:47:10 +08:00
|
|
|
];
|
2017-12-09 20:17:15 +08:00
|
|
|
|
2021-09-23 02:47:10 +08:00
|
|
|
require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/footer.inc.php';
|
2018-12-16 04:24:39 +08:00
|
|
|
|
2019-10-03 01:23:09 +08:00
|
|
|
|