load_tables(); } $column_names = [ 'id_evento', 'evento', 'timestamp', 'estado', 'event_type', 'utimestamp', 'id_agente', 'agent_name', 'id_usuario', 'id_grupo', 'id_agentmodule', 'id_alert_am', 'criticity', 'user_comment', 'tags', 'source', 'id_extra', 'critical_instructions', 'warning_instructions', 'unknown_instructions', 'owner_user', 'ack_utimestamp', 'custom_data', 'data', 'module_status', ]; if (is_metaconsole() === true) { $fields = [ 'te.id_evento', 'te.evento', 'te.timestamp', 'te.estado', 'te.event_type', 'te.utimestamp', 'te.id_agente', 'ta.alias as agent_name', 'te.id_usuario', 'te.id_grupo', 'te.id_agentmodule', 'te.id_alert_am', 'te.criticity', 'te.user_comment', 'te.tags', 'te.source', 'te.id_extra', 'te.critical_instructions', 'te.warning_instructions', 'te.unknown_instructions', 'te.owner_user', 'te.ack_utimestamp', 'te.custom_data', 'te.data', 'te.module_status', 'tg.nombre as group_name', ]; } else { $fields = [ 'te.id_evento', 'te.evento', 'te.timestamp', 'te.estado', 'te.event_type', 'te.utimestamp', 'te.id_agente', 'ta.alias as agent_name', 'te.id_usuario', 'te.id_grupo', 'te.id_agentmodule', 'am.nombre as module_name', 'te.id_alert_am', 'te.criticity', 'te.user_comment', 'te.tags', 'te.source', 'te.id_extra', 'te.critical_instructions', 'te.warning_instructions', 'te.unknown_instructions', 'te.owner_user', 'te.ack_utimestamp', 'te.custom_data', 'te.data', 'te.module_status', 'tg.nombre as group_name', ]; } $now = date('Y-m-d'); // Download header. header('Content-type: text/txt'); header('Content-Disposition: attachment; filename="export_events_'.$now.'.csv"'); try { $fb64 = get_parameter('fb64', null); $plain_filter = base64_decode($fb64); $filter = json_decode($plain_filter, true); if (json_last_error() != JSON_ERROR_NONE) { throw new Exception('Invalid filter. ['.$plain_filter.']'); } $names = events_get_column_names($column_names); // Dump headers. foreach ($names as $n) { echo io_safe_output($n).$config['csv_divider']; } echo chr(13); // Dump events. $events_per_step = 1000; $step = 0; while (1) { $events = events_get_all( $fields, $filter, (($step++) * $events_per_step), $events_per_step, 'desc', 'timestamp', $filter['history'] ); if ($events === false) { break; } foreach ($events as $row) { foreach ($column_names as $val) { $key = $val; if ($val == 'id_grupo') { $key = 'group_name'; } else if ($val == 'id_agentmodule') { $key = 'module_name'; } switch ($key) { case 'module_status': echo events_translate_module_status( $row[$key] ); break; case 'event_type': echo events_translate_event_type( $row[$key] ); break; case 'criticity': echo events_translate_event_criticity( $row[$key] ); break; case 'custom_data': $custom_data_array = json_decode( $row[$key], true ); $custom_data = ''; $separator = ($config['csv_divider'] === ';') ? ',' : ';'; if ($custom_data_array !== null) { array_walk( $custom_data_array, function (&$value, $field) use ($separator) { if (is_array($value) === true) { $value = '['.implode($separator, $value).']'; } $value = $field.'='.$value; } ); $custom_data = implode($separator, $custom_data_array); } echo io_safe_output($custom_data); break; default: echo io_safe_output($row[$key]); break; } echo $config['csv_divider']; } echo chr(13); } } } catch (Exception $e) { echo 'ERROR'.chr(13); echo $e->getMessage(); exit; } exit;