array(T_ZBX_INT, O_OPT, P_SYS, DB_ID, '!isset({favobj})'), "from"=> array(T_ZBX_INT, O_OPT, null, '{}>=0', null), "period"=> array(T_ZBX_INT, O_OPT, null, null, null), "dec"=> array(T_ZBX_INT, O_OPT, null, null, null), "inc"=> array(T_ZBX_INT, O_OPT, null, null, null), "left"=> array(T_ZBX_INT, O_OPT, null, null, null), "right"=> array(T_ZBX_INT, O_OPT, null, null, null), "stime"=> array(T_ZBX_STR, O_OPT, null, null, null), "filter_task"=> array(T_ZBX_STR, O_OPT, null, IN(FILTER_TAST_SHOW.','.FILTER_TAST_HIDE.','.FILTER_TAST_MARK.','.FILTER_TAST_INVERT_MARK), null), "filter"=> array(T_ZBX_STR, O_OPT, null, null, null), "mark_color"=> array(T_ZBX_STR, O_OPT, null, IN(MARK_COLOR_RED.','.MARK_COLOR_GREEN.','.MARK_COLOR_BLUE), null), "cmbloglist"=> array(T_ZBX_INT, O_OPT, null, DB_ID, null), "plaintext"=> array(T_ZBX_STR, O_OPT, null, null, null), "action"=> array(T_ZBX_STR, O_OPT, null, IN('"showgraph","showvalues","showlatest","add","remove"'), null), //ajax 'favobj'=> array(T_ZBX_STR, O_OPT, P_ACT, NULL, NULL), 'favid'=> array(T_ZBX_STR, O_OPT, P_ACT, NOT_EMPTY, 'isset({favobj})'), /* actions */ "remove_log"=> array(T_ZBX_STR, O_OPT, P_SYS|P_ACT, null, null), "reset"=> array(T_ZBX_STR, O_OPT, P_SYS|P_ACT, null, null), "cancel"=> array(T_ZBX_STR, O_OPT, P_SYS, null, null), /* other */ "form"=> array(T_ZBX_STR, O_OPT, P_SYS, null, null), "form_copy_to"=> array(T_ZBX_STR, O_OPT, P_SYS, null, null), "form_refresh"=> array(T_ZBX_INT, O_OPT, null, null, null), "fullscreen"=> array(T_ZBX_STR, O_OPT, P_SYS, null, null) ); check_fields($fields); ?> $itemid) if((bccomp($itemid , $_REQUEST["cmbloglist"])==0)) unset($_REQUEST["itemid"][$id]); } $items_count = count($_REQUEST["itemid"]); if($items_count > 1) { $main_header = count($_REQUEST["itemid"])." log files"; } else { $_REQUEST["itemid"] = array_pop($_REQUEST["itemid"]); } } $denyed_hosts = get_accessible_hosts_by_user($USER_DETAILS,PERM_READ_ONLY,PERM_MODE_LT); $availiable_hosts = get_accessible_hosts_by_user($USER_DETAILS,PERM_READ_ONLY,null,null,get_current_nodeid()); if((DBfetch(DBselect("select h.host,i.hostid,i.description,i.key_ from items i,hosts h ". " where i.itemid in (".(is_array($_REQUEST["itemid"]) ? implode(',', $_REQUEST["itemid"]) : $_REQUEST["itemid"]).") ". " and h.hostid=i.hostid ". " and h.hostid in (".$denyed_hosts.")")))) { access_deny(); } $item_data = DBfetch(DBselect("select h.host,i.hostid,i.* from items i,hosts h ". " where i.itemid in (".(is_array($_REQUEST["itemid"]) ? implode(',', $_REQUEST["itemid"]) : $_REQUEST["itemid"]).") ". " and h.hostid=i.hostid ")); $item_type = $item_data["value_type"]; $l_header = null; if(!is_array($_REQUEST["itemid"])) { $main_header = $item_data["host"].": ".item_description($item_data["description"],$item_data["key_"]); if(isset($_REQUEST["plaintext"])) echo $main_header.SBR; if($_REQUEST["action"]=="showgraph") { $_REQUEST["period"] = get_request("period",get_profile("web.item[".$_REQUEST["itemid"]."].graph.period", ZBX_PERIOD_DEFAULT)); if($_REQUEST["period"] >= ZBX_MIN_PERIOD) { update_profile("web.item[".$_REQUEST["itemid"]."].graph.period",$_REQUEST["period"]); } } $l_header = array(new CLink($item_data['host'],"latest.php?hostid=".$item_data['hostid']),": ", item_description($item_data["description"],$item_data["key_"])); if('showgraph' == $_REQUEST['action']){ if(infavorites('web.favorite.graphids',$_REQUEST['itemid'],'simple_graph')){ $icon = new CDiv(SPACE,'iconminus'); $icon->AddOption('title',S_REMOVE_FROM.' '.S_FAVORITES); $icon->AddAction('onclick',new CScript("javascript: rm4favorites('simple_graph','".$_REQUEST['itemid']."',0);")); } else{ $icon = new CDiv(SPACE,'iconplus'); $icon->AddOption('title',S_ADD_TO.' '.S_FAVORITES); $icon->AddAction('onclick',new CScript("javascript: add2favorites('simple_graph','".$_REQUEST['itemid']."');")); } $icon->AddOption('id','addrm_fav'); $icon_tab = new CTable(); $icon_tab->AddRow(array($icon,SPACE,$l_header)); $l_header = $icon_tab; } } $effectiveperiod = navigation_bar_calc(); unset($item_data); $to_save_request = null; if( !isset($_REQUEST['plaintext']) && !isset($_REQUEST['fullscreen']) ){ if($item_type == ITEM_VALUE_TYPE_LOG){ $l_header = new CForm(); $l_header->SetName("loglist"); $l_header->AddVar("action",$_REQUEST["action"]); $l_header->AddVar("from",$_REQUEST["from"]); $l_header->AddVar("period",$_REQUEST["period"]); $l_header->AddVar("itemid",$_REQUEST["itemid"]); if(isset($_REQUEST["filter_task"])) $l_header->AddVar("filter_task",$_REQUEST["filter_task"]); if(isset($_REQUEST["filter"])) $l_header->AddVar("filter",$_REQUEST["filter"]); if(isset($_REQUEST["mark_color"])) $l_header->AddVar("mark_color",$_REQUEST["mark_color"]); $cmbLogList = new CComboBox("cmbloglist"); if(is_array($_REQUEST["itemid"])) { $cmbLogList->AddItem(0, $main_header); foreach($_REQUEST["itemid"] as $itemid) { if(!($item = get_item_by_itemid($itemid)) || $item["value_type"] != ITEM_VALUE_TYPE_LOG) { invalid_url(); } $host = get_host_by_hostid($item["hostid"]); $cmbLogList->AddItem($itemid,$host["host"].": ".item_description($item["description"],$item["key_"])); } } else { $cmbLogList->AddItem($_REQUEST["itemid"], $main_header); } $l_header->AddItem(array( "Log files list",SPACE, $cmbLogList,SPACE, new CButton("add_log","Add","return PopUp('popup.php?". "dstfrm=".$l_header->GetName()."&srctbl=logitems&dstfld1=itemid&srcfld1=itemid');"),SPACE, $cmbLogList->ItemsCount() > 1 ? new CButton("remove_log","Remove selected") : null )); } $form = new CForm(); $form->SetMethod('get'); $form->AddVar("itemid",$_REQUEST["itemid"]); if($_REQUEST["action"]!="showlatest") { $form->AddVar("from",$_REQUEST["from"]); $form->AddVar("period",$_REQUEST["period"]); } if(isset($_REQUEST["filter_task"])) $form->AddVar("filter_task",$_REQUEST["filter_task"]); if(isset($_REQUEST["filter"])) $form->AddVar("filter",$_REQUEST["filter"]); if(isset($_REQUEST["mark_color"])) $form->AddVar("mark_color",$_REQUEST["mark_color"]); $cmbAction = new CComboBox("action",$_REQUEST["action"],"submit()"); if(str_in_array($item_type,array(ITEM_VALUE_TYPE_FLOAT,ITEM_VALUE_TYPE_UINT64))) { $cmbAction->AddItem("showgraph",S_GRAPH_OF_SPECIFIED_PERIOD); } $cmbAction->AddItem("showvalues",S_VALUES_OF_SPECIFIED_PERIOD); $cmbAction->AddItem("showlatest",S_500_LATEST_VALUES); $form->AddItem($cmbAction); if($_REQUEST["action"]!="showgraph") $form->AddItem(array(SPACE,new CButton("plaintext",S_AS_PLAIN_TEXT))); show_table_header($l_header, $form); } ?> SetMethod('get'); $r_header->AddVar("action",$_REQUEST["action"]); $r_header->AddVar("from",$_REQUEST["from"]); $r_header->AddVar("period",$_REQUEST["period"]); $r_header->AddVar("itemid",$_REQUEST["itemid"]); $cmbFTask = new CComboBox("filter_task",$filter_task,"submit()"); $cmbFTask->AddItem(FILTER_TAST_SHOW,S_SHOW_SELECTED); $cmbFTask->AddItem(FILTER_TAST_HIDE,S_HIDE_SELECTED); $cmbFTask->AddItem(FILTER_TAST_MARK,S_MARK_SELECTED); $cmbFTask->AddItem(FILTER_TAST_INVERT_MARK,S_MARK_OTHERS); $r_header->AddItem(array( S_SELECT_ROWS_WITH_VALUE_LIKE,SPACE, new CTextBox("filter",$filter,25), $cmbFTask,SPACE)); if(str_in_array($filter_task,array(FILTER_TAST_MARK,FILTER_TAST_INVERT_MARK))){ $cmbColor = new CComboBox("mark_color",$mark_color); $cmbColor->AddItem(MARK_COLOR_RED,S_AS_RED); $cmbColor->AddItem(MARK_COLOR_GREEN,S_AS_GREEN); $cmbColor->AddItem(MARK_COLOR_BLUE,S_AS_BLUE); $r_header->AddItem(array($cmbColor,SPACE)); } $r_header->AddItem(new CButton("select","Select")); } else{ $r_header = null; } if(($l_header || $r_header) && !isset($_REQUEST['fullscreen'])) show_table_header($l_header,$r_header); } else{ $txt = new CTag('p','yes',$l_header); $txt->Show(); echo "\n"; } $cond_clock = ""; $limit = "NO"; if($_REQUEST["action"]=="showlatest"){ $limit = 500; } elseif($_REQUEST["action"]=="showvalues"){ $cond_clock = " and h.clock>$time and h.clock<$till"; } if($item_type==ITEM_VALUE_TYPE_LOG) { $itemid_lst = ""; if(is_array($_REQUEST["itemid"])) { $itemid_lst = implode(',',$_REQUEST["itemid"]); $item_cout = count($_REQUEST["itemid"]); } else { $itemid_lst = $_REQUEST["itemid"]; $item_cout = 1; } $sql_filter = ""; if(isset($_REQUEST["filter"]) && $_REQUEST["filter"]!="") { if($_REQUEST["filter_task"] == FILTER_TAST_SHOW) $sql_filter = " and h.value like ".zbx_dbstr("%".$_REQUEST["filter"]."%").""; elseif($_REQUEST["filter_task"] == FILTER_TAST_HIDE) $sql_filter = " and h.value not like ".zbx_dbstr("%".$_REQUEST["filter"]."%").""; } $sql = "select hst.host,i.itemid,i.key_,i.description,h.clock,h.value,i.valuemapid,h.timestamp,h.source,h.severity". " from history_log h, items i, hosts hst". " where hst.hostid=i.hostid and h.itemid=i.itemid".$sql_filter." and i.itemid in (".$itemid_lst.")".$cond_clock. " order by h.clock desc, h.id desc"; $result=DBselect($sql,$limit); if(!isset($_REQUEST["plaintext"])) { $table = new CTableInfo('...','log_history_table'); $table->SetHeader(array(S_TIMESTAMP, $item_cout > 1 ? S_ITEM : null, S_LOCAL_TIME,S_SOURCE,S_SEVERITY,S_VALUE),"header"); $table->ShowStart(); // to solve memory leak we call 'Show' method by steps } else { echo "
\n";
			}

			while($row=DBfetch($result))
			{
				$color_style = null;

				if(isset($_REQUEST["filter"]) && $_REQUEST["filter"]!="")
				{
					$contain = zbx_stristr($row["value"],$_REQUEST["filter"]) ? TRUE : FALSE;

					if(!isset($_REQUEST["mark_color"])) $_REQUEST["mark_color"] = MARK_COLOR_RED;

					if(($contain) && ($_REQUEST["filter_task"] == FILTER_TAST_MARK))
						$color_style = $_REQUEST["mark_color"];
					if((!$contain) && ($_REQUEST["filter_task"] == FILTER_TAST_INVERT_MARK))
						$color_style = $_REQUEST["mark_color"];

					switch($color_style)
					{
						case MARK_COLOR_RED:	$color_style="mark_as_red"; break;
						case MARK_COLOR_GREEN:	$color_style="mark_as_green"; break;
						case MARK_COLOR_BLUE:	$color_style="mark_as_blue"; break;
					}
				}

				$new_row = array(nbsp(date("[Y.M.d H:i:s]",$row["clock"])));

				if($item_cout > 1)
					array_push($new_row,$row["host"].":".item_description($row["description"],$row["key_"]));

				if($row["timestamp"] == 0)
				{
					array_push($new_row,new CCol("-","center"));
				}
				else
				{
					array_push($new_row,date("Y.M.d H:i:s",$row["timestamp"]));
				}
				
				if($row["source"] == "")
				{
					array_push($new_row,new CCol("-","center"));
				}
				else
				{
					array_push($new_row,$row["source"]);
				}

				array_push($new_row, 
						new CCol(
							get_severity_description($row["severity"]),
							get_severity_style($row["severity"])
							)
					);

				$row["value"] = trim($row["value"],"\r\n");
//				array_push($new_row,htmlspecialchars($row["value"]));
				array_push($new_row,htmlspecialchars(encode_log($row["value"])));

				if(!isset($_REQUEST["plaintext"]))
				{

					$crow = new CRow($new_row); 

					if(is_null($color_style) && is_array($_REQUEST["itemid"]))
					{
						$min_color = 0x98;
						$max_color = 0xF8;
						$int_color = ($max_color - $min_color) / count($_REQUEST["itemid"]);
						$int_color *= array_search($row["itemid"],$_REQUEST["itemid"]);
						$int_color += $min_color;
						$crow->AddOption("style","background-color: ".sprintf("#%X%X%X",$int_color,$int_color,$int_color));
					} else {
						$crow->SetClass($color_style);
					}

					$crow->Show();	// to solve memory leak we call 'Show' method for each element
				}
				else
				{
					echo date("Y-m-d H:i:s",$row["clock"]);
					echo "\t".$row["clock"]."\t".$row["value"]."\n";
				}
			}
			if(!isset($_REQUEST["plaintext"]))
				$table->ShowEnd();	// to solve memory leak we call 'Show' method by steps
			else
				echo "
"; } else { switch($item_type) { case ITEM_VALUE_TYPE_FLOAT: $h_table = "history"; break; case ITEM_VALUE_TYPE_UINT64: $h_table = "history_uint"; break; case ITEM_VALUE_TYPE_TEXT: $h_table = "history_text"; break; default: $h_table = "history_str"; } $result = DBselect("select h.clock,h.value,i.valuemapid from $h_table h, items i". " where h.itemid=i.itemid and i.itemid=".$_REQUEST["itemid"]. $cond_clock." order by clock desc", $limit); if(!isset($_REQUEST["plaintext"])) { $table = new CTableInfo(); $table->SetHeader(array(S_TIMESTAMP, S_VALUE)); $table->AddOption('id','graph'); $table->ShowStart(); // to solve memory leak we call 'Show' method by steps } else { echo "
\n";
			}

COpt::profiling_start("history");
			while($row=DBfetch($result))
			{
				
				if($DB_TYPE == "ORACLE" && $item_type == ITEM_VALUE_TYPE_TEXT)
				{
					if(isset($row["value"]))
						$row["value"] = $row["value"]->load();
					else
						$row["value"] = "";
				}

				if($row["valuemapid"] > 0)
					$value = replace_value_by_map($row["value"], $row["valuemapid"]);
				else
					$value = $row["value"]; 

				$new_row = array(date("Y.M.d H:i:s",$row["clock"]));
				if(str_in_array($item_type,array(ITEM_VALUE_TYPE_FLOAT,ITEM_VALUE_TYPE_UINT64)))
				{
					array_push($new_row,$value);
				}
				else
				{
					array_push($new_row,array("
",htmlspecialchars($value),"
")); } if(!isset($_REQUEST["plaintext"])) { $table->ShowRow($new_row); } else { echo date("Y-m-d H:i:s",$row["clock"]); echo "\t".$row["clock"]."\t".$row["value"]."\n"; } } if(!isset($_REQUEST["plaintext"])){ $table->ShowEnd(); // to solve memory leak we call 'Show' method by steps echo SBR; } else{ echo "
"; } COpt::profiling_stop("history"); } } if(!isset($_REQUEST["plaintext"])) { if(str_in_array($_REQUEST["action"],array("showvalues","showgraph"))){ $stime = get_min_itemclock_by_itemid($_REQUEST["itemid"]); $stime = (is_null($stime))?0:$stime; $bstime = time()-$effectiveperiod; if(isset($_REQUEST['stime'])){ $bstime = $_REQUEST['stime']; $bstime = mktime(substr($bstime,8,2),substr($bstime,10,2),0,substr($bstime,4,2),substr($bstime,6,2),substr($bstime,0,4)); } $script = 'scrollinit(0,0,0,'.$effectiveperiod.','.$stime.',0,'.$bstime.'); showgraphmenu("graph");'; if(isset($dom_graph_id)) $script.='graph_zoom_init("'.$dom_graph_id.'",'.$bstime.','.$effectiveperiod.',ZBX_G_WIDTH, 200);'; zbx_add_post_js($script); // navigation_bar("history.php",$to_save_request); } } ?>