芝麻web文件管理V1.00
编辑当前文件:/home/pulsehostuk9/public_html/status.pulsehost.co.uk/app/controllers/api/ApiServerMonitors.php
monitors_heartbeats->server_monitors_is_enabled) { redirect('not-found'); } $this->verify_request(); /* Decide what to continue with */ switch($_SERVER['REQUEST_METHOD']) { case 'GET': /* Detect if we only need an object, or the whole list */ if(isset($this->params[0])) { $this->get(); } else { $this->get_all(); } break; case 'DELETE': $this->delete(); break; } $this->return_404(); } private function get_all() { /* Prepare the filtering system */ $filters = (new \Altum\Filters([], [], [])); $filters->set_default_order_by($this->api_user->preferences->server_monitors_default_order_by, $this->api_user->preferences->default_order_type ?? settings()->main->default_order_type); $filters->set_default_results_per_page($this->api_user->preferences->default_results_per_page ?? settings()->main->default_results_per_page); $filters->process(); /* Prepare the paginator */ $total_rows = database()->query("SELECT COUNT(*) AS `total` FROM `server_monitors` WHERE `user_id` = {$this->api_user->user_id}")->fetch_object()->total ?? 0; $paginator = (new \Altum\Paginator($total_rows, $filters->get_results_per_page(), $_GET['page'] ?? 1, url('api/server_monitors?' . $filters->get_get() . '&page=%d'))); /* Get the data */ $data = []; $data_result = database()->query(" SELECT * FROM `server_monitors` WHERE `user_id` = {$this->api_user->user_id} {$filters->get_sql_where()} {$filters->get_sql_order_by()} {$paginator->get_sql_limit()} "); while($row = $data_result->fetch_object()) { /* Prepare the data */ $row = [ 'id' => (int) $row->server_monitor_id, 'user_id' => (int) $row->user_id, 'project_id' => (int) $row->project_id, 'name' => $row->name, 'target' => $row->target, 'notifications' => json_decode($row->notifications ?? ''), 'settings' => json_decode($row->settings ?? ''), 'uptime' => (int) $row->uptime, 'network_total_download' => (int) $row->network_total_download, 'network_download' => (int) $row->network_download, 'network_total_upload' => (int) $row->network_total_upload, 'network_upload' => (int) $row->network_upload, 'os_name' => $row->os_name, 'os_version' => $row->os_version, 'kernel_name' => $row->kernel_name, 'kernel_version' => $row->kernel_version, 'kernel_release' => $row->kernel_release, 'cpu_architecture' => $row->cpu_architecture, 'cpu_model' => $row->cpu_model, 'cpu_cores' => (int) $row->cpu_cores, 'cpu_frequency' => (int) $row->cpu_frequency, 'cpu_usage' => (float) $row->cpu_usage, 'ram_usage' => (float) $row->ram_usage, 'ram_used' => (float) $row->ram_used, 'ram_total' => (float) $row->ram_total, 'disk_usage' => (float) $row->disk_usage, 'disk_used' => (float) $row->disk_used, 'disk_total' => (float) $row->disk_total, 'cpu_load_1' => (float) $row->cpu_load_1, 'cpu_load_5' => (float) $row->cpu_load_5, 'cpu_load_15' => (float) $row->cpu_load_15, 'is_enabled' => (bool) $row->is_enabled, 'total_logs' => (int) $row->total_logs, 'last_log_datetime' => $row->last_log_datetime, 'datetime' => $row->datetime, 'last_datetime' => $row->last_datetime, ]; $data[] = $row; } /* Prepare the data */ $meta = [ 'page' => $_GET['page'] ?? 1, 'total_pages' => $paginator->getNumPages(), 'results_per_page' => $filters->get_results_per_page(), 'total_results' => (int) $total_rows, ]; /* Prepare the pagination links */ $others = ['links' => [ 'first' => $paginator->getPageUrl(1), 'last' => $paginator->getNumPages() ? $paginator->getPageUrl($paginator->getNumPages()) : null, 'next' => $paginator->getNextUrl(), 'prev' => $paginator->getPrevUrl(), 'self' => $paginator->getPageUrl($_GET['page'] ?? 1) ]]; Response::jsonapi_success($data, $meta, 200, $others); } private function get() { $server_monitor_id = isset($this->params[0]) ? (int) $this->params[0] : null; /* Try to get details about the resource id */ $server_monitor = db()->where('server_monitor_id', $server_monitor_id)->where('user_id', $this->api_user->user_id)->getOne('server_monitors'); /* We haven't found the resource */ if(!$server_monitor) { $this->return_404(); } /* Prepare the data */ $data = [ 'id' => (int) $server_monitor->server_monitor_id, 'user_id' => (int) $server_monitor->user_id, 'project_id' => (int) $server_monitor->project_id, 'name' => $server_monitor->name, 'target' => $server_monitor->target, 'notifications' => json_decode($server_monitor->notifications ?? ''), 'settings' => json_decode($server_monitor->settings ?? ''), 'uptime' => (int) $server_monitor->uptime, 'network_total_download' => (int) $server_monitor->network_total_download, 'network_download' => (int) $server_monitor->network_download, 'network_total_upload' => (int) $server_monitor->network_total_upload, 'network_upload' => (int) $server_monitor->network_upload, 'os_name' => $server_monitor->os_name, 'os_version' => $server_monitor->os_version, 'kernel_name' => $server_monitor->kernel_name, 'kernel_version' => $server_monitor->kernel_version, 'kernel_release' => $server_monitor->kernel_release, 'cpu_architecture' => $server_monitor->cpu_architecture, 'cpu_model' => $server_monitor->cpu_model, 'cpu_cores' => (int) $server_monitor->cpu_cores, 'cpu_frequency' => (int) $server_monitor->cpu_frequency, 'cpu_usage' => (float) $server_monitor->cpu_usage, 'ram_usage' => (float) $server_monitor->ram_usage, 'ram_used' => (float) $server_monitor->ram_used, 'ram_total' => (float) $server_monitor->ram_total, 'disk_usage' => (float) $server_monitor->disk_usage, 'disk_used' => (float) $server_monitor->disk_used, 'disk_total' => (float) $server_monitor->disk_total, 'cpu_load_1' => (float) $server_monitor->cpu_load_1, 'cpu_load_5' => (float) $server_monitor->cpu_load_5, 'cpu_load_15' => (float) $server_monitor->cpu_load_15, 'is_enabled' => (bool) $server_monitor->is_enabled, 'total_logs' => (int) $server_monitor->total_logs, 'last_log_datetime' => $server_monitor->last_log_datetime, 'datetime' => $server_monitor->datetime, 'last_datetime' => $server_monitor->last_datetime, ]; Response::jsonapi_success($data); } private function delete() { $server_monitor_id = isset($this->params[0]) ? (int) $this->params[0] : null; /* Try to get details about the resource id */ $server_monitor = db()->where('server_monitor_id', $server_monitor_id)->where('user_id', $this->api_user->user_id)->getOne('server_monitors'); /* We haven't found the resource */ if(!$server_monitor) { $this->return_404(); } /* Delete the resource */ db()->where('server_monitor_id', $server_monitor_id)->delete('server_monitors'); /* Clear cache */ cache()->deleteItemsByTag('server_monitor_id=' . $server_monitor->server_monitor_id); cache()->deleteItem('server_monitor?server_monitor_id=' . $server_monitor->server_monitor_id); http_response_code(200); die(); } }