title = __('Alerts'); $this->ajaxMethods = ['getUsers']; $this->ajaxMethods = [ 'getUsers', 'getCurrentlyTriggered', 'getActiveAlerts', ]; $this->interval = 300000; $this->refreshConfig = [ 'triggered' => [ 'id' => 'currently-triggered', 'method' => 'getCurrentlyTriggered', ], 'active-correlation' => [ 'id' => 'active-correlation', 'method' => 'getActiveAlerts', ], ]; } /** * Returns the html of currently triggered. * * @return string */ public function getCurrentlyTriggered():string { $total = alerts_get_alerts(0, '', 'fired', -1, 'AR', true); return html_print_div( [ 'content' => format_numeric($total, 0), 'class' => 'text-l', 'id' => 'currently-triggered', 'style' => 'margin: 0px 10px 10px 10px;', ], true ); } /** * Returns the html of active correlation. * * @return string */ public function getActiveAlerts():string { $total = alerts_get_alerts(0, '', 'all', -1, 'AR', true); return html_print_div( [ 'content' => format_numeric($total, 0), 'class' => 'text-l', 'id' => 'active-correlation', 'style' => 'margin: 0px 10px 10px 10px;', ], true ); } /** * Return a datatable with de users lists. * * @return string */ public function getDataTableUsers():string { $columns = [ 'id_user', 'is_admin', 'last_connect', ]; $columnNames = [ __('User'), __('Role'), __('Last seen'), ]; return ui_print_datatable( [ 'id' => 'list_users', 'class' => 'info_table', 'style' => 'width: 90%', 'dom_elements' => 'tfp', 'filter_main_class' => 'box-flat white_table_graph fixed_filter_bar', 'columns' => $columns, 'column_names' => $columnNames, 'ajax_url' => $this->ajaxController, 'ajax_data' => [ 'method' => 'getUsers', 'class' => static::class, ], 'order' => [ 'field' => 'title', 'direction' => 'asc', ], 'default_pagination' => 10, 'search_button_class' => 'sub filter float-right', 'return' => true, ] ); } /** * Return all users for ajax. * * @return string */ public function getUsers():string { global $config; $start = get_parameter('start', 0); $length = get_parameter('length', $config['block_size']); $orderDatatable = get_datatable_order(true); $pagination = ''; $order = ''; try { ob_start(); if (isset($orderDatatable)) { $order = sprintf( ' ORDER BY %s %s', $orderDatatable['field'], $orderDatatable['direction'] ); } if (isset($length) && $length > 0 && isset($start) && $start >= 0 ) { $pagination = sprintf( ' LIMIT %d OFFSET %d ', $length, $start ); } $id_groups = array_keys(users_get_groups($config['id_user'], 'AR', false)); if (in_array(0, $id_groups) === false) { foreach ($id_groups as $key => $id_group) { if ((bool) check_acl_restricted_all($config['id_user'], $id_group, 'AR') === false) { unset($id_groups[$key]); } } } if (users_can_manage_group_all() === true) { $id_groups[] = 0; } $id_groups = implode(',', $id_groups); $sql = sprintf( 'SELECT DISTINCT id_user, is_admin ,last_connect FROM tusuario u LEFT JOIN tusuario_perfil p ON p.id_usuario = u.id_user WHERE id_grupo IN ('.$id_groups.') GROUP BY id_user %s %s', $order, $pagination ); $rows = db_process_sql($sql); foreach ($rows as $key => $row) { $rows[$key]['id_user'] = ''.$row['id_user'].''; if ((bool) $row['is_admin'] === true) { $rows[$key]['is_admin'] = ''.__('Admin').''; } else { $rows[$key]['is_admin'] = ''.__('User').''; } if ($row['last_connect'] > 0) { $rows[$key]['last_connect'] = ui_print_timestamp($row['last_connect'], true, ['prominent' => 'compact']); } else { $rows[$key]['last_connect'] = __('Unknown'); } } $sql_count = sprintf( 'SELECT DISTINCT id_user, count(*) as total FROM tusuario u LEFT JOIN tusuario_perfil p ON p.id_usuario = u.id_user WHERE id_grupo IN ('.$id_groups.') %s', $order, ); $total = db_process_sql($sql_count); // Capture output. $response = ob_get_clean(); return json_encode( [ 'data' => $rows, 'recordsTotal' => $total[0]['total'], 'recordsFiltered' => $total[0]['total'], ] ); } catch (Exception $e) { return json_encode(['error' => $e->getMessage()]); } json_decode($response); if (json_last_error() === JSON_ERROR_NONE) { return $response; } else { return json_encode( [ 'success' => false, 'error' => $response, ] ); } } /** * Check if user can manager users. * * @return boolean */ public function checkAclUserList():bool { global $config; $user_m = (bool) check_acl($config['id_user'], 0, 'UM'); return $user_m; } }