芝麻web文件管理V1.00
编辑当前文件:/home/pulsehostuk9/public_html/status.pulsehost.co.uk/app/controllers/Monitor.php
monitors_heartbeats->monitors_is_enabled) { redirect('not-found'); } \Altum\Authentication::guard(); $monitor_id = isset($this->params[0]) ? (int) $this->params[0] : null; if(!$monitor = db()->where('monitor_id', $monitor_id)->where('user_id', $this->user->user_id)->getOne('monitors')) { redirect('monitors'); } $monitor->details = json_decode($monitor->details); $monitor->settings = json_decode($monitor->settings ?? ''); $start_date = isset($_GET['start_date']) ? query_clean($_GET['start_date']) : Date::get('', 4); $end_date = isset($_GET['end_date']) ? query_clean($_GET['end_date']) : Date::get('', 4); $date = \Altum\Date::get_start_end_dates($start_date, $end_date); /* Get available ping servers */ $ping_servers = (new \Altum\Models\PingServers())->get_ping_servers(); /* Get the required statistics */ $monitor_logs = []; $monitor_logs_chart = []; $monitor_logs_result = database()->query(" SELECT `monitor_log_id`, `ping_server_id`, `is_ok`, `response_time`, `response_status_code`, `error`, `datetime` FROM `monitors_logs` WHERE `monitor_id` = {$monitor->monitor_id} AND (`datetime` BETWEEN '{$date->start_date_query}' AND '{$date->end_date_query}') "); $total_ok_checks = 0; $total_not_ok_checks = 0; $total_response_time = 0; $ping_servers_checks = []; /* Get monitor logs to calculate data and display charts */ while($monitor_log = $monitor_logs_result->fetch_object()) { /* Process for the ping server average */ if(isset($ping_servers[$monitor_log->ping_server_id])) { $ping_server = $ping_servers[$monitor_log->ping_server_id]; if(!isset($ping_servers_checks[$ping_server->ping_server_id])) { $ping_servers_checks[$ping_server->ping_server_id] = [ 'total_response_time' => $monitor_log->response_time, 'total_ok_checks' => $monitor_log->is_ok ? 1 : 0, 'total_not_ok_checks' => !$monitor_log->is_ok ? 1: 0, 'lowest_response_time' => $monitor_log->response_time, 'highest_response_time' => $monitor_log->response_time, ]; } else { if($monitor_log->is_ok) $ping_servers_checks[$ping_server->ping_server_id]['total_ok_checks']++; if(!$monitor_log->is_ok) $ping_servers_checks[$ping_server->ping_server_id]['total_not_ok_checks']++; $ping_servers_checks[$ping_server->ping_server_id]['total_response_time'] += $monitor_log->response_time; if($monitor_log->response_time < $ping_servers_checks[$ping_server->ping_server_id]['lowest_response_time']) { $ping_servers_checks[$ping_server->ping_server_id]['lowest_response_time'] = $monitor_log->response_time; } if($monitor_log->response_time > $ping_servers_checks[$ping_server->ping_server_id]['highest_response_time']) { $ping_servers_checks[$ping_server->ping_server_id]['highest_response_time'] = $monitor_log->response_time; } } } $monitor_logs[] = $monitor_log; /* Data for the chart */ $label = $start_date == $end_date ? \Altum\Date::get($monitor_log->datetime, 3) : \Altum\Date::get($monitor_log->datetime, 1); $monitor_log_error = json_decode($monitor_log->error ?? ''); if(isset($monitor_log_error->type)) { if($monitor_log_error->type == 'exception') { $monitor_log_error = $monitor_log_error->message; } elseif(in_array($monitor_log_error->type, ['response_status_code', 'response_body', 'response_header'])) { $monitor_log_error = l('monitor.checks.error.' . $monitor_log_error->type); } } else { $monitor_log_error = l('global.none'); } $monitor_logs_chart[$label] = [ 'ping_server' => isset($ping_servers[$monitor_log->ping_server_id]) ? get_countries_array()[$ping_servers[$monitor_log->ping_server_id]->country_code] . ', ' . $ping_servers[$monitor_log->ping_server_id]->city_name : null, 'error' => $monitor_log_error, 'response_status_code' => $monitor_log->response_status_code, 'is_ok' => $monitor_log->is_ok, 'response_time' => $monitor_log->is_ok ? $monitor_log->response_time : $monitor->average_response_time ?? 0, 'hour_minute_second_label' => \Altum\Date::get($monitor_log->datetime, 3) ]; $total_ok_checks = $monitor_log->is_ok ? $total_ok_checks + 1 : $total_ok_checks; $total_not_ok_checks = !$monitor_log->is_ok ? $total_not_ok_checks + 1 : $total_not_ok_checks; $total_response_time += $monitor_log->is_ok ? $monitor_log->response_time : 0; } /* Set a custom title */ Title::set(sprintf(l('monitor.title'), $monitor->name)); /* Export handler */ process_export_csv($monitor_logs, 'include', ['is_ok', 'response_time', 'response_status_code', 'datetime'], sprintf(l('monitor.title'), $monitor->name)); process_export_json($monitor_logs, 'include', ['is_ok', 'response_time', 'response_status_code', 'datetime'], sprintf(l('monitor.title'), $monitor->name)); $monitor_logs_chart = get_chart_data($monitor_logs_chart); /* Get the available incidents */ $monitor_incidents = []; $monitor_incidents_result = database()->query(" SELECT `start_datetime`, `end_datetime`, `comment`, `incident_id` FROM `incidents` WHERE `monitor_id` = {$monitor->monitor_id} AND `start_datetime` >= '{$date->start_date_query}' AND (`end_datetime` <= '{$date->end_date_query}' OR `end_datetime` IS NULL) ORDER BY `incident_id` DESC "); while($row = $monitor_incidents_result->fetch_object()) { $monitor_incidents[] = $row; } /* calculate some data */ $total_monitor_logs = count($monitor_logs); $uptime = $total_ok_checks > 0 ? $total_ok_checks / ($total_ok_checks + $total_not_ok_checks) * 100 : 0; $downtime = 100 - $uptime; $average_response_time = $total_ok_checks > 0 ? $total_response_time / $total_ok_checks : 0; /* Prepare the view */ $data = [ 'monitor' => $monitor, 'monitor_logs_chart' => $monitor_logs_chart, 'monitor_logs' => $monitor_logs, 'total_monitor_logs' => $total_monitor_logs, 'monitor_logs_data' => [ 'uptime' => $uptime, 'downtime' => $downtime, 'average_response_time' => $average_response_time, 'total_ok_checks' => $total_ok_checks, 'total_not_ok_checks' => $total_not_ok_checks ], 'date' => $date, 'monitor_incidents' => $monitor_incidents, 'ping_servers_checks' => $ping_servers_checks, 'ping_servers' => $ping_servers, ]; $view = new \Altum\View('monitor/index', (array) $this); $this->add_view_content('content', $view->run($data)); } }