$filter) + $other_filter)); if ($modules === false) $modules = array(); $modules = array_unique($modules); $modules = io_safe_output($modules); echo json_encode($modules); } $get_plugin_macros = get_parameter('get_plugin_macros'); if ($get_plugin_macros) { $plugin_macros = db_get_value('macros','tplugin','id',get_parameter('id_plugin',0)); $macros = array(); $macros['base64'] = base64_encode($plugin_macros); $macros['array'] = json_decode($plugin_macros,true); echo json_encode($macros); } $get_module_detail = get_parameter ('get_module_detail', 0); if ($get_module_detail) { $module_id = get_parameter ('id_module'); $period = get_parameter ("period", 86400); $group = agents_get_agentmodule_group ($module_id); $agentId = get_parameter("id_agent"); $server_name = get_parameter('server_name'); if (defined ('METACONSOLE')) { $server = metaconsole_get_connection ($server_name); $conexion = mysql_connect ($server['dbhost'], $server['dbuser'], $server['dbpass']); $select_db = mysql_select_db ($server['dbname'], $conexion); } $selection_mode = get_parameter('selection_mode', 'fromnow'); $date_from = (string) get_parameter ('date_from', date ('Y-m-j')); $time_from = (string) get_parameter ('time_from', date ('h:iA')); $date_to = (string) get_parameter ('date_to', date ('Y-m-j')); $time_to = (string) get_parameter ('time_to', date ('h:iA')); $formtable->width = '98%'; $formtable->class = "databox"; $formtable->data = array (); $formtable->size = array (); $periods = array(SECONDS_5MINUTES =>__('5 minutes'), SECONDS_30MINUTES =>__('30 minutes'), SECONDS_1HOUR =>__('1 hour'), SECONDS_6HOURS =>__('6 hours'), SECONDS_12HOURS =>__('12 hours'), SECONDS_1DAY =>__('1 day'), SECONDS_1WEEK =>__('1 week'), SECONDS_15DAYS =>__('15 days'), SECONDS_1MONTH =>__('1 month'), SECONDS_3MONTHS =>__('3 months'), SECONDS_6MONTHS =>__('6 months'), SECONDS_1YEAR =>__('1 year'), SECONDS_2YEARS =>__('2 years'), SECONDS_3YEARS =>__('3 years')); $formtable->data[0][0] = html_print_radio_button_extended ("selection_mode", 'fromnow', '', $selection_mode, false, '', 'style="margin-right: 15px;"', true) . __("Choose a time from now"); $formtable->data[0][1] = html_print_select ($periods, 'period', $period, '', '', 0, true, false, false); $formtable->data[0][2] = ''; $formtable->data[0][3] = "". html_print_image ("images/refresh.png", true, array ("style" => 'vertical-align: middle;', "border" => "0" )) . ""; $formtable->rowspan[0][3] = 2; $formtable->cellstyle[0][3] = 'vertical-align: middle;'; $formtable->data[1][0] = html_print_radio_button_extended ("selection_mode", 'range','', $selection_mode, false, '', 'style="margin-right: 15px;"', true) . __("Specify time range"); $formtable->data[1][1] = __('Timestamp from:'); $formtable->data[1][2] = html_print_input_text ('date_from', $date_from, '', 10, 10, true); $formtable->data[1][2] .= html_print_input_text ('time_from', $time_from, '', 9, 7, true); $formtable->data[1][1] .= '
'; $formtable->data[1][1] .= __('Timestamp to:'); $formtable->data[1][2] .= '
'; $formtable->data[1][2] .= html_print_input_text ('date_to', $date_to, '', 10, 10, true); $formtable->data[1][2] .= html_print_input_text ('time_to', $time_to, '', 9, 7, true); html_print_table($formtable); $moduletype_name = modules_get_moduletype_name (modules_get_agentmodule_type ($module_id)); $offset = (int) get_parameter("offset"); $block_size = (int) $config["block_size"]; $columns = array (); $datetime_from = strtotime ($date_from.' '.$time_from); $datetime_to = strtotime ($date_to.' '.$time_to); if ($moduletype_name == "log4x") { $table->width = "100%"; if ($selection_mode == "fromnow") { $sql_body = sprintf ("FROM tagente_datos_log4x WHERE id_agente_modulo = %d AND utimestamp > %d ORDER BY utimestamp DESC", $module_id, get_system_time () - $period); } else { $sql_body = sprintf ("FROM tagente_datos_log4x WHERE id_agente_modulo = %d AND utimestamp >= %d AND utimestamp <= %d ORDER BY utimestamp DESC", $module_id, $datetime_from, $datetime_to); } $columns = array( "Timestamp" => array("utimestamp", "modules_format_timestamp", "align" => "center" ), "Sev" => array("severity", "modules_format_data", "align" => "center", "width" => "70px"), "Message"=> array("message", "modules_format_verbatim", "align" => "left", "width" => "45%"), "StackTrace" => array("stacktrace", "modules_format_verbatim", "align" => "left", "width" => "50%") ); } else if (preg_match ("/string/", $moduletype_name)) { if ($selection_mode == "fromnow") { $sql_body = sprintf (" FROM tagente_datos_string WHERE id_agente_modulo = %d AND utimestamp > %d ORDER BY utimestamp DESC", $module_id, get_system_time () - $period); } else { $sql_body = sprintf (" FROM tagente_datos_string WHERE id_agente_modulo = %d AND utimestamp >= %d AND utimestamp <= %d ORDER BY utimestamp DESC", $module_id, $datetime_from, $datetime_to); } $columns = array( "Timestamp" => array( "utimestamp", "modules_format_timestamp", "align" => "left"), "Data" => array( "datos", "modules_format_data", "align" => "left"), "Time" => array( "utimestamp", "modules_format_time", "align" => "center") ); } else { if ($selection_mode == "fromnow") { $sql_body = sprintf (" FROM tagente_datos WHERE id_agente_modulo = %d AND utimestamp > %d ORDER BY utimestamp DESC", $module_id, get_system_time () - $period); } else { $sql_body = sprintf (" FROM tagente_datos WHERE id_agente_modulo = %d AND utimestamp >= %d AND utimestamp <= %d ORDER BY utimestamp DESC", $module_id, $datetime_from, $datetime_to); } $columns = array( "Timestamp" => array( "utimestamp", "modules_format_timestamp", "align" => "left"), "Data" => array( "datos", "modules_format_data", "align" => "left"), "Time" => array( "utimestamp", "modules_format_time", "align" => "center") ); } $sql_body = io_safe_output($sql_body); // Clean all codification characters $sql = "SELECT * " . $sql_body; $sql_count = "SELECT count(*) " . $sql_body; $count = db_get_value_sql ($sql_count, $conexion); switch ($config["dbtype"]) { case "mysql": $sql .= " LIMIT " . $offset . "," . $block_size; break; case "postgresql": $sql .= " LIMIT " . $block_size . " OFFSET " . $offset; break; case "oracle": $set = array(); $set['limit'] = $block_size; $set['offset'] = $offset; $sql = oracle_recode_query ($sql, $set); break; } $result = db_get_all_rows_sql ($sql, false, true, $conexion); if ($result === false) { $result = array (); } if (($config['dbtype'] == 'oracle') && ($result !== false)) { for ($i=0; $i < count($result); $i++) { unset($result[$i]['rnum']); } } $table->width = '98%'; $table->data = array(); $index = 0; foreach($columns as $col => $attr) { $table->head[$index] = $col; if (isset($attr["align"])) $table->align[$index] = $attr["align"]; if (isset($attr["width"])) $table->size[$index] = $attr["width"]; $index++; } $id_type_web_content_string = db_get_value('id_tipo', 'ttipo_modulo', 'nombre', 'web_content_string'); foreach ($result as $row) { $data = array (); $is_web_content_string = (bool)db_get_value_filter('id_agente_modulo', 'tagente_modulo', array('id_agente_modulo' => $row['id_agente_modulo'], 'id_tipo_modulo' => $id_type_web_content_string)); foreach ($columns as $col => $attr) { if ($attr[1] != "modules_format_data") { $data[] = $attr[1] ($row[$attr[0]]); } elseif (($config['command_snapshot']) && (preg_match ("/[\n]+/i", $row[$attr[0]]))) { // Its a single-data, multiline data (data snapshot) ? // Detect string data with \n and convert to
's $datos = preg_replace ('/\n/i','
',$row[$attr[0]]); $datos = preg_replace ('/\s/i',' ',$datos); // Because this *SHIT* of print_table monster, I cannot format properly this cells // so, eat this, motherfucker :)) $datos = "" . $datos . ""; // I dont why, but using index (value) method, data is automatically converted to html entities ¿? $data[$attr[1]] = $datos; } elseif ($is_web_content_string) { //Fixed the goliat sends the strings from web //without HTML entities $data[$attr[1]] = io_safe_input($row[$attr[0]]); } else { // Just a string of alphanumerical data... just do print //Fixed the data from Selenium Plugin if ($row[$attr[0]] != strip_tags($row[$attr[0]])) $data[$attr[1]] = io_safe_input($row[$attr[0]]); else $data[$attr[1]] = $row[$attr[0]]; } } array_push ($table->data, $data); if (count($table->data) > 200) break; } if (empty ($table->data)) { ui_print_error_message(__('No available data to show')); } else { ui_pagination($count, false, $offset); html_print_table($table); } return; } ?>