'.$bad.''; } else { $output = '<'.$tag.' class="suc" '.$attributes.'>'.$good.''; } if ($return) return $output; echo $output; } /** * Evaluates a unix timestamp and returns a span (or whatever tag specified) * with as title the correctly formatted full timestamp and a time comparation * in the tag * * @param int $unixtime: Any type of timestamp really, but we prefer unixtime * @param bool $return whether to output the string or return it * @param array $option: An array with different options for this function * Key html_attr: which html attributes to add (defaults to none) * Key tag: Which html tag to use (defaults to span) * Key prominent: Overrides user preference and display "comparation" or "timestamp" * * @return string HTML code if return parameter is true. */ function print_timestamp ($unixtime, $return = false, $option = array ()) { global $config; //TODO: Add/use a javascript timer for the seconds so it automatically updates as time passes by if (isset ($option["html_attr"])) { $attributes = $option["html_attr"]; } else { $attributes = ""; } if (isset ($option["tag"])) { $tag = $option["tag"]; } else { $tag = "span"; } if (empty ($option["style"])) { $style = 'style="white-space:nowrap;"'; } else { $style = 'style="'.$option["style"].'"'; } if (!empty ($option["prominent"])) { $prominent = $option["prominent"]; } else { $prominent = $config["prominent_time"]; } if (!is_numeric ($unixtime)) { $unixtime = strtotime ($unixtime); } //prominent_time is either timestamp or comparation if ($unixtime == 0) { $title = __('Unknown').'/'.__('Never'); $data = __('Unknown'); } elseif ($prominent == "timestamp") { $title = human_time_comparation ($unixtime); $data = date ($config["date_format"], $unixtime); } else { $title = date ($config["date_format"], $unixtime); $data = human_time_comparation ($unixtime); } $output = '<'.$tag; switch ($tag) { default: //Usually tags have title attributes, so by default we add, then fall through to add attributes and data $output .= ' title="'.$title.'"'; case "h1": case "h2": case "h3": //Above tags don't have title attributes $output .= ' '.$attributes.' '.$style.'>'.$data.''; } if ($return) return $output; echo $output; } /** * Prints a username with real name, link to the user_edit page etc. * * @param string $username The username to render * @param bool $return Whether to return or print * * @return string HTML code if return parameter is true. */ function print_username ($username, $return = false) { $string = ''.get_user_fullname ($username).''; if ($return) return $string; echo $string; } /** * Print group icon within a link * * @param string $id_group Group id * @param bool $return Whether to return or print * @param string $path What path to use (relative to images/). Defaults to groups_small * * @return string HTML code if return parameter is true. */ function print_group_icon ($id_group, $return = false, $path = "groups_small") { $icon = (string) get_db_value ('icon', 'tgrupo', 'id_grupo', (int) $id_group); if (empty ($icon)) { return "-"; } $output = ''; $output .= ''.get_group_name ($id_group).''; $output .= ''; if ($return) return $output; echo $output; } /** * Get the icon of an operating system. * * @param int Operating system id * @param bool Whether to also append the name of the OS after the icon * @param bool Whether to return or echo the result * * @return string HTML with icon of the OS */ function print_os_icon ($id_os, $name = true, $return = false) { $icon = (string) get_db_value ('icon_name', 'tconfig_os', 'id_os', (int) $id_os); $os_name = get_os_name ($id_os); if (empty ($icon)) { return "-"; } $output = ''.$os_name.''; if ($name === true) { $output .= ' - '.$os_name; } if ($return) return $output; echo $output; } /** * Prints an agent name with the correct link * * @param int $id_agent Agent id * @param bool $return Whether to return the string or echo it too * @param int $cutoff After how much characters to cut off the inside of the * link. The full agent name will remain in the roll-over * * @return string HTML with agent name and link */ function print_agent_name ($id_agent, $return = false, $cutoff = 0) { $agent_name = (string) get_agent_name ($id_agent); $output = ''; if ($cutoff > 0 && (mb_strlen ($agent_name, "UTF-8") > $cutoff)) { $output .= mb_substr (utf8_decode ($agent_name), 0, $cutoff, "UTF-8").'...'; } else { $output .= $agent_name; } $output .= ''; //TODO: Add a pretty javascript (using jQuery) popup-box with agent details if ($return) return $output; echo $output; } /** * Formats a row from the alert table and returns an array usable in the table function * * @param array A valid (non empty) row from the alert table * @param bool Whether or not this is a combined alert * @param bool Whether to print the agent information with the module information * @param string Tab where the function was called from (used for urls) * * @return array A formatted array with proper html for use in $table->data (6 columns) */ function format_alert_row ($alert, $compound = false, $agent = true, $url = '') { require_once ("include/functions_alerts.php"); if (empty ($alert)) return array ("", "", "", "", "", "", ""); // Get agent id if ($compound) { $id_agent = $alert['id_agent']; $description = $alert['description']; } else { $id_agent = get_agentmodule_agent ($alert['id_agent_module']); $template = get_alert_template ($alert['id_alert_template']); $description = $template['name']; } $data = array (); // Force alert execution $data[0] = ''; if (! $compound) { if ($alert["force_execution"] == 0) { $data[0] = ''; } else { $data[0] = ''; } } if ($compound) { $data[1] = print_agent_name ($id_agent, true, 20); } elseif ($agent == 0) { $data[1] = mb_substr (get_agentmodule_name ($alert["id_agent_module"]), 0, 20); } else { $data[1] = print_agent_name (get_agentmodule_agent ($alert["id_agent_module"]), true, 20); } $data[2] = ''; $data[2] .= mb_substr (safe_input ($description), 0, 35); $data[2] .= ''; if (! $compound) { $data[2] .= ' '; $data[2] .= ''; $data[2] .= ''; $data[2] .= ''; } $data[3] = print_timestamp ($alert["last_fired"], true); $options = array (); $options["height"] = 18; $options["width"] = 40; if ($alert["times_fired"] > 0) { $options["src"] = "images/pixel_red.png"; $options["title"] = __('Alert fired').' '.$alert["times_fired"].' '.__('times'); } elseif ($alert["disabled"] > 0) { $options["src"] = "images/pixel_gray.png"; $options["title"] = __('Alert disabled'); } else { $options["src"] = "images/pixel_green.png"; $options["title"] = __('Alert not fired'); } $data[4] = print_image ($options["src"], true, $options); if ($compound) { $data[5] = print_checkbox ("validate_compound[]", $alert["id"], false, true); } else { $data[5] = print_checkbox ("validate[]", $alert["id"], false, true); } return $data; } /** * Prints a substracted string, length specified by cutoff, the full string will be in a rollover. * * @param string The string to be cut * @param int At how much characters to cut * @param bool Whether to return or print it out * * @return An HTML string */ function print_string_substr ($string, $cutoff = 16, $return = false) { if (empty ($string)) { return ""; } $string = ''.mb_substr ($string, 0, $cutoff, "UTF-8").(mb_strlen ($string. "UTF-8") > $cutoff ? '...' : '').''; if ($return === false) { echo $string; } return $string; } /** * Gets a helper text explaining the requirement needs for an alert template * to get it fired. * * @param int Alert template id. * @param bool Wheter to return or print it out. * @param bool Wheter to put the values in the string or not. * * @return An HTML string if return was true. */ function print_alert_template_example ($id_alert_template, $return = false, $print_values = true) { $output = ''; $output .= ' '; $output .= ''; $template = get_alert_template ($id_alert_template); switch ($template['type']) { case 'equal': /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value is '); break; case 'not_equal': /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value is not '); break; case 'regex': if ($template['matches_value']) /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value matches '); else /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value doesn\'t match '); $value = $template['value']; break; case 'max_min': if ($template['matches_value']) /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value is between and '); else /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value is not between and '); break; case 'max': /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value is over '); break; case 'min': /* Do not translate the HTML attributes */ $output .= __('The alert would fire when the value is under '); break; } if ($print_values) { /* Replace span elements with real values. This is done in such way to avoid duplicating strings and make it easily modificable via Javascript. */ $output = str_replace ('', $template['value'], $output); $output = str_replace ('', $template['max_value'], $output); $output = str_replace ('', $template['min_value'], $output); } $output .= ''; if ($return) return $output; echo $output; } /** * Prints a help tip icon. * * @param string $help_id Id of the help article * @param bool $return Whether to return or output the result * * @return string The help tip */ function print_help_icon ($help_id, $return = false) { $output = ' '.print_image ("images/help.png", true, array ("class" => "img_help", "title" => __('Help'), "onclick" => "open_help ('".$help_id."')")); if (!$return) echo $output; return $output; } /** * Add a CSS file to the HTML head tag. * * To make a CSS file available just put it in include/styles. The * file name should be like "name.css". The "name" would be the value * needed to pass to this function. * @param string Script name to add without the "jquery." prefix and the ".js" * suffix. Example: require_css_file ('pandora'); // Would include include/styles/pandora.js * * @return bool True if the file was added. False if the file doesn't exist. */ function require_css_file ($name, $path = 'include/styles/') { global $config; $filename = $path.$name.'.css'; if (! isset ($config['css'])) $config['css'] = array (); if (isset ($config['css'][$name])) return true; if (! file_exists ($filename) && ! file_exists ($config['homedir'].'/'.$filename)) return false; $config['css'][$name] = $filename; return true; } /** * Add a javascript file to the HTML head tag. * * To make a javascript file available just put it in include/javascript. The * file name should be like "name.js". The "name" would be the value * needed to pass to this function. * @param string Script name to add without the "jquery." prefix and the ".js" * suffix. Example: require_javascript_file ('pandora'); // Would include include/javascript/pandora.js * * @return bool True if the file was added. False if the file doesn't exist. */ function require_javascript_file ($name, $path = 'include/javascript/') { global $config; $filename = $path.$name.'.js'; if (! isset ($config['js'])) $config['js'] = array (); if (isset ($config['js'][$name])) return true; /* We checks two paths because it may fails on enterprise */ if (! file_exists ($filename) && ! file_exists ($config['homedir'].'/'.$filename)) return false; $config['js'][$name] = $filename; return true; } /** * Add a jQuery file to the HTML head tag. * * To make a jQuery script available just put it in include/javascript. The * file name should be like "jquery.name.js". The "name" would be the value * needed to pass to this function. Notice that this function does not manage * jQuery denpendencies. * @param string Script name to add without the "jquery." prefix and the ".js" * suffix. Example: require_jquery_file ('form'); // Would include include/javascript/jquery.form.js * * @return bool True if the file was added. False if the file doesn't exist. */ function require_jquery_file ($name, $path = 'include/javascript/') { global $config; $filename = $path.'jquery.'.$name.'.js'; if (! isset ($config['jquery'])) $config['jquery'] = array (); if (isset ($config['jquery'][$name])) return true; /* We checks two paths because it may fails on enterprise */ if (! file_exists ($filename) && ! file_exists ($config['homedir'].'/'.$filename)) return false; $config['jquery'][$name] = $filename; return true; } /** * Callback function to add stuff to the head. This allows us to add scripts * to the header after the fact as well as extensive validation. * * DO NOT CALL print_f, echo, ob_start, ob_flush, ob_end functions here. * * To add css just put them in include/styles and then add them to the * $config['css'] array * * @param string Callback will fill this with the current buffer. * @param bitfield Callback will fill this with a bitfield (see ob_start) * * @return string String to return to the browser */ function process_page_head ($string, $bitfield) { global $config; $output = ''; if ($config["refr"] > 0) { // Agent selection filters and refresh $protocol = 'http'; $ssl = false; if ($config['https']) { /* Check with "on" because some web servers like Cherokee always set this value even if SSL is not enabled */ if (isset ($_SERVER['HTTPS']) && ($_SERVER['HTTPS'] == true || $_SERVER['HTTPS'] == 'on')) { $protocol = 'https'; $ssl = true; } } $query = $protocol.'://' . $_SERVER['SERVER_NAME']; if ($_SERVER['SERVER_PORT'] != 80 && ($ssl && $_SERVER['SERVER_PORT'] != 443)) { $query .= ":".$_SERVER['SERVER_PORT']; } $query .= $_SERVER['SCRIPT_NAME']; if (sizeof ($_REQUEST)) //Some (old) browsers don't like the ?&key=var $query .= '?1=1'; //We don't clean these variables up as they're only being passed along foreach ($_GET as $key => $value) { /* Avoid the 1=1 */ if ($key == 1) continue; $query .= '&'.$key.'='.$value; } foreach ($_POST as $key => $value) { $query .= '&'.$key.'='.$value; } $output .= ''; } $output .= "\n\t"; $output .= 'Pandora FMS - '.__('the Flexible Monitoring System').' '; if ($config["language"] != "en") { //Load translated strings - load them last so they overload all the objects require_javascript_file ("time_".$config["language"]); require_javascript_file ("date".$config["language"]); require_javascript_file ("countdown_".$config["language"]); } $output .= "\n\t"; //Load CSS if (empty ($config['css'])) { $config['css'] = array (); } //Style should go first $config['css'] = array_merge (array ($config['style'] => "include/styles/".$config['style'].".css", "menu" => "include/styles/menu.css", "tip", "include/styles/tip.css"), $config['css']); //We can't load empty and we loaded (conditionally) ie $loaded = array ('', 'ie'); foreach ($config['css'] as $name => $filename) { if (in_array ($name, $loaded)) continue; array_push ($loaded, $name); if (!empty ($config["compact_header"])) { $output .= ''; } else { $output .= ''."\n\t"; } } //End load CSS //Load JS if (empty ($config['js'])) { $config['js'] = array (); //If it's empty, false or not init set array to empty just in case } //Pandora specific JavaScript should go first $config['js'] = array_merge (array ("pandora" => "include/javascript/pandora.js"), $config['js']); //Load other javascript //We can't load empty $loaded = array (''); foreach ($config['js'] as $name => $filename) { if (in_array ($name, $loaded)) continue; array_push ($loaded, $name); if (!empty ($config["compact_header"])) { $output .= ''; } else { $output .= ''."\n\t"; } } //End load JS //Load jQuery if (empty ($config['jquery'])) { $config['jquery'] = array (); //If it's empty, false or not init set array to empty just in case } //Pandora specific jquery should go first $config['jquery'] = array_merge (array ("jquery" => "include/javascript/jquery.js", "pandora" => "include/javascript/jquery.pandora.js"), $config['jquery']); //Then add each script as necessary $loaded = array (''); foreach ($config['jquery'] as $name => $filename) { if (in_array ($name, $loaded)) continue; array_push ($loaded, $name); if (!empty ($config["compact_header"])) { $output .= ''; } else { $output .= ''."\n\t"; } } $output .= ''; $output .= $string; return $output; } /** * Callback function to add stuff to the body * * @param string Callback will fill this with the current buffer. * @param bitfield Callback will fill this with a bitfield (see ob_start) * * @return string String to return to the browser */ function process_page_body ($string, $bitfield) { global $config; // Show custom background if ($config["pure"] == 0) { $output = ''; } else { $output = ''; //Don't enforce a white background color. Let user style sheet do that } $output .= $string; $output .= ''; return $output; } /** * Prints a pagination menu to browse into a collection of data. * * @param int $count Number of elements in the collection. * @param string $url URL of the pagination links. It must include all form * values as GET form. * @param int $offset Current offset for the pagination. Default value would be * taken from $_REQUEST['offset'] * @param int $pagination Current pagination size. If a user requests a larger * pagination than config["block_size"] * @param bool $return Whether to return or print this * * @return string The pagination div or nothing if no pagination needs to be done */ function pagination ($count, $url, $offset = 0, $pagination = 0, $return = false) { global $config; if (empty ($pagination)) { $pagination = $config["block_size"]; } if (empty ($offset)) { $offset = (int) get_parameter ('offset'); } $url = safe_input ($url); /* URL passed render links with some parameter &offset - Offset records passed to next page &counter - Number of items to be blocked Pagination needs $url to build the base URL to render links, its a base url, like " http://pandora/index.php?sec=godmode&sec2=godmode/admin_access_logs " */ $block_limit = 15; // Visualize only $block_limit blocks if ($count <= $pagination) { return false; } // If exists more registers than I can put in a page, calculate index markers $index_counter = ceil ($count /$pagination); // Number of blocks of block_size with data $index_page = ceil ($offset / $pagination) - (ceil ($block_limit / 2)); // block to begin to show data; if ($index_page < 0) $index_page = 0; // This calculate index_limit, block limit for this search. if (($index_page + $block_limit) > $index_counter) $index_limit = $index_counter; else $index_limit = $index_page + $block_limit; // This calculate if there are more blocks than visible (more than $block_limit blocks) if ($index_counter > $block_limit ) $paginacion_maxima = 1; // If maximum blocks ($block_limit), show only 10 and "...." else $paginacion_maxima = 0; // This setup first block of query if ( $paginacion_maxima == 1) if ($index_page == 0) $inicio_pag = 0; else $inicio_pag = $index_page; else $inicio_pag = 0; $output = '
'; // Show GOTO FIRST button $output .= ' '; // Show PREVIOUS button if ($index_page > 0) { $index_page_prev = ($index_page - (floor ($block_limit / 2))) * $pagination; if ($index_page_prev < 0) $index_page_prev = 0; $output .= ''; } $output .= "  "; // Draw blocks markers // $i stores number of page for ($i = $inicio_pag; $i < $index_limit; $i++) { $inicio_bloque = ($i * $pagination); $final_bloque = $inicio_bloque + $pagination; if ($final_bloque > $count){ // if upper limit is beyond max, this shouldnt be possible ! $final_bloque = ($i-1) * $pagination + $count-(($i-1) * $pagination); } $output .= ""; $inicio_bloque_fake = $inicio_bloque + 1; // To Calculate last block (doesnt end with round data, // it must be shown if not round to block limit) $output .= ''; } $output .= "  "; // Show NEXT PAGE (fast forward) // Index_counter stores max of blocks if (($paginacion_maxima == 1) AND (($index_counter - $i) > 0)) { $prox_bloque = ($i + ceil ($block_limit / 2)) * $pagination; if ($prox_bloque > $count) $prox_bloque = ($count -1) - $pagination; $output .= ''; $i = $index_counter; } // if exists more registers than i can put in a page (defined by $block_size config parameter) // get offset for index calculation // Draw "last" block link, ajust for last block will be the same // as painted in last block (last integer block). if (($count - $pagination) > 0) { $myoffset = floor (($count - 1) / $pagination) * $pagination; $output .= ''; } // End div and layout $output .= "
"; if ($return === false) echo $output; return $output; } /** * Prints only a tip button which shows a text when the user puts the mouse over it. * * @param string Complete text to show in the tip * @param bool whether to return an output string or echo now * * @return string HTML code if return parameter is true. */ function print_help_tip ($text, $return = false) { $output = ' '.$text.''; if ($return) return $output; echo $output; } /** * Powerful debug function that also shows a backtrace. * * This functions need to have active $config['debug'] variable to work. * * @param mixed Variable name to debug * @param bool Wheter to print the backtrace or not. */ function debug ($var, $backtrace = true) { global $config; if (! isset ($config['debug'])) return; static $id = 0; static $trace_id = 0; $id++; if ($backtrace) { echo '
'; echo 'Backtrace'; echo '
'; } /* Actually print the variable given */ echo '
';
	print_r ($var);
	echo '
'; } /** * Prints icon of a module type * * @param int Module Type ID * @param bool Whether to return or print * * @return string An HTML string with the icon. Printed if return is false */ function print_moduletype_icon ($id_moduletype, $return = false) { global $config; $type = get_db_row ("ttipo_modulo", "id_tipo", (int) $id_moduletype, array ("nombre", "icon")); if ($type === false) { $type = array (); $type["nombre"] = __('Unknown Type'); $type["icon"] = 'b_down.png'; } $imagepath = 'images/'.$type["icon"]; if (! file_exists ($config['homedir'].'/'.$imagepath)) $imagepath = ENTERPRISE_DIR.'/'.$imagepath; return print_image ($imagepath, $return, array ("border" => 0, "title" => $type["nombre"])); } /** * Format a file size from bytes to a human readable meassure. * * @param int File size in bytes * @return string Bytes converted to a human readable meassure. */ function format_filesize ($bytes) { $bytes = (int) $bytes; $strs = array ('B', 'kB', 'MB', 'GB', 'TB'); if ($bytes < 0) { return "0 ".$strs[0]; } $con = 1024; $log = (int) (log ($bytes, $con)); return format_numeric ($bytes / pow ($con, $log), 1).' '.$strs[$log]; } ?>