1 Star 0 Fork 0

wlnmp/cacti

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
utilities.php 90.50 KB
一键复制 编辑 原始数据 按行查看 历史
cigamit 提交于 2019-11-30 09:34 . Resolving Issue #3121
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783
<?php
/*
+-------------------------------------------------------------------------+
| Copyright (C) 2004-2019 The Cacti Group |
| |
| This program is free software; you can redistribute it and/or |
| modify it under the terms of the GNU General Public License |
| as published by the Free Software Foundation; either version 2 |
| of the License, or (at your option) any later version. |
| |
| This program is distributed in the hope that it will be useful, |
| but WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| GNU General Public License for more details. |
+-------------------------------------------------------------------------+
| Cacti: The Complete RRDtool-based Graphing Solution |
+-------------------------------------------------------------------------+
| This code is designed, written, and maintained by the Cacti Group. See |
| about.php and/or the AUTHORS file for specific developer information. |
+-------------------------------------------------------------------------+
| http://www.cacti.net/ |
+-------------------------------------------------------------------------+
*/
include('./include/auth.php');
include_once('./lib/api_data_source.php');
include_once('./lib/boost.php');
include_once('./lib/clog_webapi.php');
include_once('./lib/poller.php');
include_once('./lib/utility.php');
/* set default action */
set_default_action();
switch (get_request_var('action')) {
case 'clear_poller_cache':
/* obtain timeout settings */
$max_execution = ini_get('max_execution_time');
ini_set('max_execution_time', '0');
repopulate_poller_cache();
ini_set('max_execution_time', $max_execution);
header('Location: utilities.php?action=view_poller_cache');exit;
break;
case 'rebuild_resource_cache':
rebuild_resource_cache();
header('Location: utilities.php?header=false');exit;
break;
case 'view_snmp_cache':
top_header();
utilities_view_snmp_cache();
bottom_footer();
break;
case 'view_poller_cache':
top_header();
utilities_view_poller_cache();
bottom_footer();
break;
case 'view_logfile':
utilities_view_logfile();
break;
case 'clear_logfile':
utilities_clear_logfile();
utilities_view_logfile();
break;
case 'purge_logfile':
clog_purge_logfile();
utilities_view_logfile();
break;
case 'view_cleaner':
top_header();
utilities_view_cleaner();
bottom_footer();
break;
case 'view_user_log':
top_header();
utilities_view_user_log();
bottom_footer();
break;
case 'clear_user_log':
utilities_clear_user_log();
utilities_view_user_log();
break;
case 'view_tech':
$php_info = utilities_php_modules();
top_header();
utilities_view_tech($php_info);
bottom_footer();
break;
case 'view_boost_status':
top_header();
boost_display_run_status();
bottom_footer();
break;
case 'view_snmpagent_cache':
top_header();
snmpagent_utilities_run_cache();
bottom_footer();
break;
case 'rebuild_snmpagent_cache';
snmpagent_cache_rebuilt();
header('Location: utilities.php?action=view_snmpagent_cache');exit;
break;
case 'view_snmpagent_events':
top_header();
snmpagent_utilities_run_eventlog();
bottom_footer();
break;
case 'ajax_hosts':
get_allowed_ajax_hosts();
break;
case 'ajax_hosts_noany':
get_allowed_ajax_hosts(false);
break;
default:
if (!api_plugin_hook_function('utilities_action', get_request_var('action'))) {
top_header();
utilities();
bottom_footer();
}
break;
}
/* -----------------------
Utilities Functions
----------------------- */
function rebuild_resource_cache() {
db_execute('DELETE FROM settings WHERE name LIKE "md5dirsum%"');
db_execute('TRUNCATE TABLE poller_resource_cache');
raise_message('resource_cache_rebuild');
cacti_log('NOTE: Poller Resource Cache scheduled for rebuild by user ' . get_username($_SESSION['sess_user_id']), false, 'WEBUI');
}
function utilities_view_tech($php_info = '') {
global $database_default, $config, $rrdtool_versions, $poller_options, $input_types, $local_db_cnn_id;
/* Get table status */
if ($config['poller_id'] == 1) {
$tables = db_fetch_assoc('SELECT *
FROM information_schema.tables
WHERE table_schema = SCHEMA()');
} else {
$tables = db_fetch_assoc('SELECT *
FROM information_schema.tables
WHERE table_schema = SCHEMA()', false, $local_db_cnn_id);
}
/* Get poller stats */
$poller_item = db_fetch_assoc('SELECT action, count(action) AS total
FROM poller_item
GROUP BY action');
/* Get system stats */
$host_count = db_fetch_cell('SELECT COUNT(*) FROM host WHERE deleted = ""');
$graph_count = db_fetch_cell('SELECT COUNT(*) FROM graph_local');
$data_count = db_fetch_assoc('SELECT i.type_id, COUNT(i.type_id) AS total
FROM data_template_data AS d, data_input AS i
WHERE d.data_input_id = i.id
AND local_data_id <> 0
GROUP BY i.type_id');
/* Get RRDtool version */
$rrdtool_version = 'Unknown';
if ((file_exists(read_config_option('path_rrdtool'))) && ((function_exists('is_executable')) && (is_executable(read_config_option('path_rrdtool'))))) {
$out_array = array();
exec(cacti_escapeshellcmd(read_config_option('path_rrdtool')), $out_array);
if (cacti_sizeof($out_array) > 0) {
if (preg_match('/^RRDtool ([0-9.]+)/', $out_array[0], $m)) {
preg_match('/^([0-9]+\.[0-9]+\.[0.9]+)/', $m[1], $m2);
$rrdtool_release = $m[1];
$rrdtool_version = $rrdtool_release;
}
}
}
/* Get SNMP cli version */
if ((file_exists(read_config_option('path_snmpget'))) && ((function_exists('is_executable')) && (is_executable(read_config_option('path_snmpget'))))) {
$snmp_version = shell_exec(cacti_escapeshellcmd(read_config_option('path_snmpget')) . ' -V 2>&1');
} else {
$snmp_version = "<span class='deviceDown'>" . __('NET-SNMP Not Installed or its paths are not set. Please install if you wish to monitor SNMP enabled devices.') . "</span>";
}
/* Check RRDtool issues */
$rrdtool_errors = array();
if (cacti_version_compare($rrdtool_version, get_rrdtool_version(), '<')) {
$rrdtool_errors[] = "<span class='deviceDown'>" . __('ERROR: Installed RRDtool version does not exceed configured version.<br>Please visit the %s and select the correct RRDtool Utility Version.', "<a href='" . html_escape('settings.php?tab=general') . "'>" . __('Configuration Settings') . '</a>') . "</span>";
}
$graph_gif_count = db_fetch_cell('SELECT COUNT(*) FROM graph_templates_graph WHERE image_format_id = 2');
if ($graph_gif_count > 0) {
$rrdtool_errors[] = "<span class='deviceDown'>" . __('ERROR: RRDtool 1.2.x+ does not support the GIF images format, but %d" graph(s) and/or templates have GIF set as the image format.', $graph_gif_count) . '</span>';
}
/* Get spine version */
$spine_version = 'Unknown';
if ((file_exists(read_config_option('path_spine'))) && ((function_exists('is_executable')) && (is_executable(read_config_option('path_spine'))))) {
$out_array = array();
exec(cacti_escapeshellcmd(read_config_option('path_spine')) . ' --version', $out_array);
if (cacti_sizeof($out_array) > 0) {
$spine_version = $out_array[0];
}
}
/* ================= input validation ================= */
get_filter_request_var('tab', FILTER_VALIDATE_REGEXP, array('options' => array('regexp' => '/^([a-z_A-Z]+)$/')));
/* ==================================================== */
/* present a tabbed interface */
$tabs = array(
'summary' => __('Summary'),
'database' => __('Database'),
'phpinfo' => __('PHP Info'),
);
/* set the default tab */
load_current_session_value('tab', 'sess_ts_tabs', 'summary');
$current_tab = get_nfilter_request_var('tab');
$header_label = __('Technical Support [%s]', $tabs[get_request_var('tab')]);
if (cacti_sizeof($tabs)) {
$i = 0;
/* draw the tabs */
print "<div class='tabs'><nav><ul role='tablist'>\n";
foreach (array_keys($tabs) as $tab_short_name) {
print "<li class='subTab'><a class='tab" . (($tab_short_name == $current_tab) ? " selected'" : "'") .
" href='" . html_escape($config['url_path'] .
'utilities.php?action=view_tech' .
'&tab=' . $tab_short_name) .
"'>" . $tabs[$tab_short_name] . "</a></li>\n";
$i++;
}
api_plugin_hook('utilities_tab');
print "</ul></nav></div>\n";
}
/* Display tech information */
html_start_box($header_label, '100%', '', '3', 'center', '');
if (get_request_var('tab') == 'summary') {
html_section_header(__('General Information'), 2);
form_alternate_row();
print '<td>' . __('Date') . "</td>\n";
print '<td>' . date('r') . "</td>\n";
form_end_row();
api_plugin_hook_function('custom_version_info');
form_alternate_row();
print '<td>' . __('Cacti Version') . "</td>\n";
print '<td>' . CACTI_VERSION . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Cacti OS') . "</td>\n";
print '<td>' . $config['cacti_server_os'] . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('RSA Fingerprint') . "</td>\n";
print '<td>' . read_config_option('rsa_fingerprint') . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('NET-SNMP Version') . "</td>\n";
print '<td>' . $snmp_version . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('RRDtool Version') . ' ' . __('Configured') . "</td>\n";
print '<td>' . get_rrdtool_version() . "+</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('RRDtool Version') . ' ' . __('Found') . "</td>\n";
print '<td>' . $rrdtool_release . "</td>\n";
form_end_row();
if (!empty($rrdtool_errors)) {
form_alternate_row();
print "<td>&nbsp;</td>\n";
$br = '';
print "<td>";
foreach ($rrdtool_errors as $rrdtool_error) {
print $br . $rrdtool_error;
$br = '<br/>';
}
print "</td>\n";
form_end_row();
}
form_alternate_row();
print '<td>' . __('Devices') . "</td>\n";
print '<td>' . number_format_i18n($host_count, -1) . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Graphs') . "</td>\n";
print '<td>' . number_format_i18n($graph_count, -1) . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Data Sources') . "</td>\n";
print '<td>';
$data_total = 0;
if (cacti_sizeof($data_count)) {
foreach ($data_count as $item) {
print $input_types[$item['type_id']] . ': ' . number_format_i18n($item['total'], -1) . '<br>';
$data_total += $item['total'];
}
print __('Total: %s', number_format_i18n($data_total, -1));
} else {
print "<span class='deviceDown'>0</span>";
}
print "</td>\n";
form_end_row();
html_section_header(__('Poller Information'), 2);
form_alternate_row();
print "<td>Interval</td>\n";
print '<td>' . read_config_option('poller_interval') . "</td>\n";
if (file_exists(read_config_option('path_spine')) && $poller_options[read_config_option('poller_type')] == 'spine') {
$type = $spine_version;
if (!strpos($spine_version, CACTI_VERSION)) {
$type .= '<span class="textError"> (' . __('Different version of Cacti and Spine!') . ')</span>';
}
} else {
$type = $poller_options[read_config_option('poller_type')];
}
form_end_row();
form_alternate_row();
print '<td>' . __('Type') . "</td>\n";
print '<td>' . $type . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Items') . "</td>\n";
print '<td>';
$total = 0;
if (cacti_sizeof($poller_item)) {
foreach ($poller_item as $item) {
print __('Action[%s]', $item['action']) . ': ' . number_format_i18n($item['total'], -1) . '<br>';
$total += $item['total'];
}
print __('Total: %s', number_format_i18n($total, -1));
} else {
print "<span class='deviceDown'>" . __('No items to poll') . "</span>";
}
print "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Concurrent Processes') . "</td>\n";
print '<td>' . read_config_option('concurrent_processes') . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Max Threads') . "</td>\n";
print '<td>' . read_config_option('max_threads') . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('PHP Servers') . "</td>\n";
print '<td>' . read_config_option('php_servers') . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Script Timeout') . "</td>\n";
print '<td>' . read_config_option('script_timeout') . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Max OID') . "</td>\n";
print '<td>' . read_config_option('max_get_size') . "</td>\n";
form_end_row();
form_alternate_row();
print '<td>' . __('Last Run Statistics') . "</td>\n";
print '<td>' . read_config_option('stats_poller') . "</td>\n";
form_end_row();
/* Get System Memory */
$memInfo = utilities_get_system_memory();
if (cacti_sizeof($memInfo)) {
html_section_header(__('System Memory'), 2);
foreach($memInfo as $name => $value) {
if ($config['cacti_server_os'] == 'win32') {
form_alternate_row();
print "<td>$name</td>\n";
print '<td>' . number_format_i18n($value/1000, 2) . " MB</td>\n";
form_end_row();
} else {
switch($name) {
case 'SwapTotal':
case 'SwapFree':
case 'Cached':
case 'MemTotal':
case 'MemFree':
case 'MemAvailable':
case 'Buffers':
case 'Active':
case 'Inactive':
form_alternate_row();
print "<td>$name</td>\n";
print '<td>' . number_format_i18n($value, 2) . "</td>\n";
form_end_row();
}
}
}
form_end_row();
}
html_section_header(__('PHP Information'), 2);
form_alternate_row();
print "<td>" . __('PHP Version') . "</td>\n";
if (version_compare(PHP_VERSION, '5.5.0') >= 0) {
print '<td>' . PHP_VERSION . "</td>\n";
} else {
print '<td>' . PHP_VERSION . "</br><span class='deviceDown'>" . __('PHP Version 5.5.0+ is recommended due to strong password hashing support.') . "</span></td>\n";
}
form_end_row();
form_alternate_row();
print "<td>" . __('PHP OS') . "</td>\n";
print '<td>' . PHP_OS . "</td>\n";
form_end_row();
form_alternate_row();
print "<td>" . __('PHP uname') . "</td>\n";
print '<td>';
if (function_exists('php_uname')) {
print php_uname();
} else {
print __('N/A');
}
print "</td>\n";
form_end_row();
form_alternate_row();
print "<td>" . __('PHP SNMP') . "</td>\n";
print '<td>';
if (function_exists('snmpget')) {
print __('Installed');
} else {
print __('Not Installed');
}
print "</td>\n";
form_end_row();
form_alternate_row();
print "<td>max_execution_time</td>\n";
print '<td>' . ini_get('max_execution_time') . "</td>\n";
form_end_row();
form_alternate_row();
print "<td>memory_limit</td>\n";
print '<td>' . ini_get('memory_limit');
/* Calculate memory suggestion based off of data source count */
$memory_suggestion = $data_total * 32768;
/* Set minimum - 16M */
if ($memory_suggestion < 16777216) {
$memory_suggestion = 16777216;
}
/* Set maximum - 512M */
if ($memory_suggestion > 536870912) {
$memory_suggestion = 536870912;
}
/* Suggest values in 8M increments */
$memory_suggestion = round($memory_suggestion / 8388608) * 8388608;
if (memory_bytes(ini_get('memory_limit')) < $memory_suggestion) {
print "<br><span class='deviceDown'>";
if ((ini_get('memory_limit') == -1)) {
print __("You've set memory limit to 'unlimited'.") . "<br>";
}
print __('It is highly suggested that you alter you php.ini memory_limit to %s or higher.', memory_readable($memory_suggestion)) . ' <br/>' .
__('This suggested memory value is calculated based on the number of data source present and is only to be used as a suggestion, actual values may vary system to system based on requirements.');
print '</span><br>';
}
print "</td>\n";
form_end_row();
utilities_get_mysql_recommendations();
} elseif (get_request_var('tab') == 'database') {
html_section_header(__('MySQL Table Information - Sizes in KBytes'), 2);
form_alternate_row();
print " <td colspan='2' style='text-align:left;padding:0px'>";
if (cacti_sizeof($tables) > 0) {
print "<table id='tables' class='cactiTable' style='width:100%'>\n";
print "<thead>\n";
print "<tr class='tableHeader'>\n";
print " <th class='tableSubHeaderColumn'>" . __('Name') . "</th>\n";
print " <th class='tableSubHeaderColumn'>" . __('Engine') . "</th>\n";
print " <th class='tableSubHeaderColumn right'>" . __('Rows') . "</th>\n";
print " <th class='tableSubHeaderColumn right'>" . __('Avg Row Length') . "</th>\n";
print " <th class='tableSubHeaderColumn right'>" . __('Data Length') . "</th>\n";
print " <th class='tableSubHeaderColumn right'>" . __('Index Length') . "</th>\n";
print " <th class='tableSubHeaderColumn'>" . __('Collation') . "</th>\n";
print " <th class='tableSubHeaderColumn'>" . __('Row Format') . "</th>\n";
print " <th class='tableSubHeaderColumn'>" . __('Comment') . "</th>\n";
print "</tr>\n";
print "</thead>\n";
foreach ($tables as $table) {
form_alternate_row();
print '<td>' . $table['TABLE_NAME'] . "</td>\n";
print '<td>' . $table['ENGINE'] . "</td>\n";
print '<td class="right">' . number_format_i18n($table['TABLE_ROWS'], -1) . "</td>\n";
print '<td class="right">' . number_format_i18n($table['AVG_ROW_LENGTH'], -1) . "</td>\n";
print '<td class="right">' . number_format_i18n($table['DATA_LENGTH'], -1) . "</td>\n";
print '<td class="right">' . number_format_i18n($table['INDEX_LENGTH'], -1) . "</td>\n";
print '<td>' . $table['TABLE_COLLATION'] . "</td>\n";
print '<td>' . $table['ROW_FORMAT'] . "</td>\n";
print '<td>' . $table['TABLE_COMMENT'] . "</td>\n";
form_end_row();
}
print "</table>\n";
} else {
print __('Unable to retrieve table status');
}
print "</td>\n";
form_end_row();
} else {
html_section_header(__('PHP Module Information'), 2);
form_alternate_row();
$php_info = str_replace(
array('width="600"', 'th colspan="2"', ','),
array('', 'th class="subHeaderColumn"', ', '),
$php_info
);
print "<td colspan='2'>" . $php_info . "</td>\n";
form_end_row();
}
html_end_box();
?>
<script type='text/javascript'>
$(function() {
$('#tables').tablesorter({
widgets: ['zebra'],
widgetZebra: { css: ['even', 'odd'] },
headerTemplate: '<div class="textSubHeaderDark">{content} {icon}</div>',
cssIconAsc: 'fa-sort-up',
cssIconDesc: 'fa-sort-down',
cssIconNone: 'fa-sort',
cssIcon: 'fa'
});
});
</script>
<?php
}
function utilities_view_user_log() {
global $auth_realms, $item_rows;
/* ================= input validation and session storage ================= */
$filters = array(
'rows' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'filter' => array(
'filter' => FILTER_DEFAULT,
'pageset' => true,
'default' => ''
),
'sort_column' => array(
'filter' => FILTER_CALLBACK,
'default' => 'time',
'options' => array('options' => 'sanitize_search_string')
),
'sort_direction' => array(
'filter' => FILTER_CALLBACK,
'default' => 'DESC',
'options' => array('options' => 'sanitize_search_string')
),
'username' => array(
'filter' => FILTER_CALLBACK,
'default' => '-1',
'options' => array('options' => 'sanitize_search_string')
),
'result' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
)
);
validate_store_request_vars($filters, 'sess_userlog');
/* ================= input validation ================= */
if (get_request_var('rows') == '-1') {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
?>
<script type="text/javascript">
function clearFilter() {
strURL = urlPath+'utilities.php?action=view_user_log&clear=1&header=false';
loadPageNoHeader(strURL);
}
function purgeLog() {
strURL = urlPath+'utilities.php?action=clear_user_log&header=false';
loadPageNoHeader(strURL);
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#purge').click(function() {
purgeLog();
});
$('#form_userlog').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
function applyFilter() {
strURL = urlPath+'utilities.php?username=' + $('#username').val();
strURL += '&result=' + $('#result').val();
strURL += '&rows=' + $('#rows').val();
strURL += '&filter=' + $('#filter').val();
strURL += '&action=view_user_log';
strURL += '&header=false';
loadPageNoHeader(strURL);
}
</script>
<?php
html_start_box(__('User Login History'), '100%', '', '3', 'center', '');
?>
<tr class='even noprint'>
<td>
<form id='form_userlog' action='utilities.php'>
<table class='filterTable'>
<tr>
<td>
<?php print __('User');?>
</td>
<td>
<select id='username' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('username') == '-1') {?> selected<?php }?>><?php print __('All');?></option>
<option value='-2'<?php if (get_request_var('username') == '-2') {?> selected<?php }?>><?php print __('Deleted/Invalid');?></option>
<?php
$users = db_fetch_assoc('SELECT DISTINCT username FROM user_auth ORDER BY username');
if (cacti_sizeof($users)) {
foreach ($users as $user) {
print "<option value='" . $user['username'] . "'"; if (get_request_var('username') == $user['username']) { print ' selected'; } print '>' . $user['username'] . "</option>\n";
}
}
?>
</select>
</td>
<td>
<?php print __('Result');?>
</td>
<td>
<select id='result' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('result') == '-1') {?> selected<?php }?>><?php print __('Any');?></option>
<option value='1'<?php if (get_request_var('result') == '1') {?> selected<?php }?>><?php print __('Success - Password');?></option>
<option value='2'<?php if (get_request_var('result') == '2') {?> selected<?php }?>><?php print __('Success - Token');?></option>
<option value='3'<?php if (get_request_var('result') == '3') {?> selected<?php }?>><?php print __('Success - Password Change');?></option>
<option value='0'<?php if (get_request_var('result') == '0') {?> selected<?php }?>><?php print __('Failed');?></option>
</select>
</td>
<td>
<?php print __('Attempts');?>
</td>
<td>
<select id='rows' onChange='applyFilter()'>
<option value='-1'<?php print (get_request_var('rows') == '-1' ? ' selected>':'>') . __('Default');?></option>
<?php
if (cacti_sizeof($item_rows)) {
foreach ($item_rows as $key => $value) {
print "<option value='" . $key . "'"; if (get_request_var('rows') == $key) { print ' selected'; } print '>' . html_escape($value) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<span>
<input type='button' class='ui-button ui-corner-all ui-widget' id='refresh' value='<?php print __esc_x('Button: use filter settings', 'Go');?>' title='<?php print __esc('Set/Refresh Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='clear' value='<?php print __esc_x('Button: reset filter settings', 'Clear');?>' title='<?php print __esc('Clear Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='purge' value='<?php print __esc_x('Button: delete all table entries', 'Purge');?>' title='<?php print __esc('Purge User Log');?>'>
</span>
</td>
</tr>
</table>
<table class='filterTable'>
<tr>
<td>
<?php print __('Search');?>
</td>
<td>
<input type='text' class='ui-state-default ui-corner-all' id='filter' size='25' value='<?php print html_escape_request_var('filter');?>'>
</td>
</tr>
</table>
<input type='hidden' name='action' value='view_user_log'>
</form>
</td>
</tr>
<?php
html_end_box();
$sql_where = '';
/* filter by username */
if (get_request_var('username') == '-2') {
$sql_where = 'WHERE ul.username NOT IN (SELECT DISTINCT username FROM user_auth)';
} elseif (get_request_var('username') != '-1') {
$sql_where = "WHERE ul.username='" . get_request_var('username') . "'";
}
/* filter by result */
if (get_request_var('result') != '-1') {
$sql_where .= ($sql_where != '' ? ' AND ':'WHERE ') . ' ul.result=' . get_request_var('result');
}
/* filter by search string */
if (get_request_var('filter') != '') {
$sql_where .= ($sql_where != '' ? ' AND ':'WHERE ') . ' (
ul.username LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR ul.time LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR ua.full_name LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR ul.ip LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . ')';
}
$total_rows = db_fetch_cell("SELECT
COUNT(*)
FROM user_auth AS ua
RIGHT JOIN user_log AS ul
ON ua.username=ul.username
$sql_where");
$user_log_sql = "SELECT ul.username, ua.full_name, ua.realm,
ul.time, ul.result, ul.ip
FROM user_auth AS ua
RIGHT JOIN user_log AS ul
ON ua.username=ul.username
$sql_where
ORDER BY " . get_request_var('sort_column') . ' ' . get_request_var('sort_direction') . '
LIMIT ' . ($rows*(get_request_var('page')-1)) . ',' . $rows;
$user_log = db_fetch_assoc($user_log_sql);
$nav = html_nav_bar('utilities.php?action=view_user_log&username=' . get_request_var('username') . '&filter=' . get_request_var('filter'), MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 6, __('User Logins'), 'page', 'main');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
$display_text = array(
'username' => array(__('User'), 'ASC'),
'full_name' => array(__('Full Name'), 'ASC'),
'realm' => array(__('Authentication Realm'), 'ASC'),
'time' => array(__('Date'), 'DESC'),
'result' => array(__('Result'), 'DESC'),
'ip' => array(__('IP Address'), 'DESC')
);
html_header_sort($display_text, get_request_var('sort_column'), get_request_var('sort_direction'), 1, 'utilities.php?action=view_user_log');
$i = 0;
if (cacti_sizeof($user_log)) {
foreach ($user_log as $item) {
form_alternate_row('line' . $i, true);
?>
<td class='nowrap'>
<?php print filter_value($item['username'], get_request_var('filter'));?>
</td>
<td class='nowrap'>
<?php if (isset($item['full_name'])) {
print filter_value($item['full_name'], get_request_var('filter'));
} else {
print __('(User Removed)');
}
?>
</td>
<td class='nowrap'>
<?php if (isset($auth_realms[$item['realm']])) {
print filter_value($auth_realms[$item['realm']], get_request_var('filter'));
} else {
print __('N/A');
}
?>
</td>
<td class='nowrap'>
<?php print filter_value($item['time'], get_request_var('filter'));?>
</td>
<td class='nowrap'>
<?php print ($item['result'] == 0 ? __('Failed'):($item['result'] == 1 ? __('Success - Password'):($item['result'] == 3 ? __('Success - Password Change'):__('Success - Token'))));?>
</td>
<td class='nowrap'>
<?php print filter_value($item['ip'], get_request_var('filter'));?>
</td>
</tr>
<?php
$i++;
}
}
html_end_box();
if (cacti_sizeof($user_log)) {
print $nav;
}
}
function utilities_clear_user_log() {
$users = db_fetch_assoc('SELECT DISTINCT username FROM user_auth');
if (cacti_sizeof($users)) {
/* remove active users */
foreach ($users as $user) {
$total_login_rows = db_fetch_cell_prepared('SELECT COUNT(username)
FROM user_log
WHERE username = ?
AND result IN (1)',
array($user['username']));
$total_token_rows = db_fetch_cell_prepared('SELECT COUNT(username)
FROM user_log
WHERE username = ?
AND result IN (2)',
array($user['username']));
if ($total_login_rows > 1) {
db_execute_prepared('DELETE
FROM user_log
WHERE username = ?
AND result IN(1)
ORDER BY time LIMIT ' . ($total_login_rows - 1),
array($user['username']));
}
if ($total_token_rows > 1) {
db_execute_prepared('DELETE
FROM user_log
WHERE username = ?
AND result IN(2)
ORDER BY time
LIMIT ' . ($total_token_rows - 1),
array($user['username']));
}
db_execute_prepared('DELETE
FROM user_log
WHERE username = ?
AND result = 0',
array($user['username']));
}
/* delete inactive users */
db_execute('DELETE
FROM user_log
WHERE user_id NOT IN (SELECT id FROM user_auth)
OR username NOT IN (SELECT username FROM user_auth)');
}
}
function utilities_view_logfile() {
global $log_tail_lines, $page_refresh_interval, $config;
$logfile = read_config_option('path_cactilog');
$logbase = basename($logfile);
if (isset_request_var('filename')) {
$requestedFile = dirname($logfile) . '/' . basename(get_nfilter_request_var('filename'));
if (file_exists($requestedFile)) {
$logfile = $requestedFile;
} else {
$logfile = read_config_option('path_cactilog');
}
}
if ($logfile == '') {
$logfile = $config['base_path'] . '/log/cacti.log';
}
if (get_nfilter_request_var('filename') != '') {
if (strpos(get_nfilter_request_var('filename'), $logbase) === false) {
raise_message('clog_invalid');
header('Location: utilities.php?action=view_logfile&filename=' . $logbase);
exit(0);
}
}
/* ================= input validation and session storage ================= */
$filters = array(
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'tail_lines' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'rfilter' => array(
'filter' => FILTER_VALIDATE_IS_REGEX,
'pageset' => true,
'default' => ''
),
'message_type' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'reverse' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'refresh' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => read_config_option('log_refresh_interval')
)
);
validate_store_request_vars($filters, 'sess_log');
/* ================= input validation ================= */
$page_nr = get_request_var('page');
$page = 'utilities.php?action=view_logfile&header=false';
$page .= '&filename=' . basename($logfile) . '&page=' . $page_nr;
$refresh = array(
'seconds' => get_request_var('refresh'),
'page' => $page,
'logout' => 'false'
);
set_page_refresh($refresh);
top_header();
?>
<script type='text/javascript'>
function purgeLog() {
strURL = urlPath+'utilities.php?action=purge_logfile&header=false&filename='+$('#filename').val();
loadPageNoHeader(strURL);
}
$(function() {
$('#refreshme').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#purge').click(function() {
purgeLog();
});
$('#form_logfile').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
function applyFilter() {
strURL = urlPath+'utilities.php' +
'?tail_lines=' + $('#tail_lines').val() +
'&message_type=' + $('#message_type').val() +
'&refresh=' + $('#refresh').val() +
'&reverse=' + $('#reverse').val() +
'&rfilter=' + base64_encode($('#rfilter').val()) +
'&filename=' + $('#filename').val() +
'&action=view_logfile' +
'&header=false';
refreshMSeconds=$('#refresh').val()*1000;
loadPageNoHeader(strURL);
}
function clearFilter() {
strURL = urlPath+'utilities.php?clear=1';
strURL += '&action=view_logfile';
strURL += '&header=false';
loadPageNoHeader(strURL);
}
</script>
<?php
html_start_box(__('Log Filters'), '100%', '', '3', 'center', '');
?>
<tr class='even noprint'>
<td>
<form id='form_logfile' action='utilities.php'>
<table class='filterTable'>
<tr>
<td>
<?php print __('File');?>
</td>
<td>
<select id='filename' onChange='applyFilter()'>
<?php
$logFileArray = clog_get_logfiles();
if (cacti_sizeof($logFileArray)) {
foreach ($logFileArray as $logFile) {
print "<option value='" . $logFile . "'";
if (get_nfilter_request_var('filename') == $logFile) {
print ' selected';
}
$logParts = explode('-', $logFile);
$logDate = count($logParts) < 2 ? '' : $logParts[1] . (isset($logParts[2]) ? '-' . $logParts[2]:'');
$logName = $logParts[0];
print '>' . $logName . ($logDate != '' ? ' [' . substr($logDate,4) . ']':'') . "</option>\n";
}
}
?>
</select>
</td>
<td>
<?php print __('Tail Lines');?>
</td>
<td>
<select id='tail_lines' onChange='applyFilter()'>
<?php
foreach($log_tail_lines AS $tail_lines => $display_text) {
print "<option value='" . $tail_lines . "'"; if (get_request_var('tail_lines') == $tail_lines) { print ' selected'; } print '>' . $display_text . "</option>\n";
}
?>
</select>
</td>
<td>
<span>
<input type='button' class='ui-button ui-corner-all ui-widget' id='refreshme' value='<?php print __esc_x('Button: use filter settings', 'Go');?>' title='<?php print __esc('Set/Refresh Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='clear' value='<?php print __esc_x('Button: reset filter settings', 'Clear');?>' title='<?php print __esc('Clear Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='purge' value='<?php print __esc_x('Button: delete all table entries', 'Purge');?>' title='<?php print __esc('Purge Log');?>'>
</span>
</td>
</tr>
</table>
<table class='filterTable'>
<tr>
<td>
<?php print __('Type');?>
</td>
<td>
<select id='message_type' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('message_type') == '-1') {?> selected<?php }?>><?php print __('All');?></option>
<option value='1'<?php if (get_request_var('message_type') == '1') {?> selected<?php }?>><?php print __('Stats');?></option>
<option value='2'<?php if (get_request_var('message_type') == '2') {?> selected<?php }?>><?php print __('Warnings');?></option>
<option value='3'<?php if (get_request_var('message_type') == '3') {?> selected<?php }?>><?php print __('Errors');?></option>
<option value='4'<?php if (get_request_var('message_type') == '4') {?> selected<?php }?>><?php print __('Debug');?></option>
<option value='5'<?php if (get_request_var('message_type') == '5') {?> selected<?php }?>><?php print __('SQL Calls');?></option>
</select>
</td>
<td>
<?php print __('Display Order');?>
</td>
<td>
<select id='reverse' onChange='applyFilter()'>
<option value='1'<?php if (get_request_var('reverse') == '1') {?> selected<?php }?>><?php print __('Newest First');?></option>
<option value='2'<?php if (get_request_var('reverse') == '2') {?> selected<?php }?>><?php print __('Oldest First');?></option>
</select>
</td>
<td>
<?php print __('Refresh');?>
</td>
<td>
<select id='refresh' onChange='applyFilter()'>
<?php
foreach($page_refresh_interval AS $seconds => $display_text) {
print "<option value='" . $seconds . "'"; if (get_request_var('refresh') == $seconds) { print ' selected'; } print '>' . $display_text . "</option>\n";
}
?>
</select>
</td>
</tr>
</table>
<table class='filterTable'>
<tr>
<td>
<?php print __('Search');?>
</td>
<td>
<input type='text' class='ui-state-default ui-corner-all' id='rfilter' size='75' value='<?php print html_escape_request_var('rfilter');?>'>
</td>
</tr>
</table>
<input type='hidden' name='action' value='view_logfile'>
</form>
</td>
</tr>
<?php
html_end_box();
/* read logfile into an array and display */
$total_rows = 0;
$number_of_lines = get_request_var('tail_lines') < 0 ? read_config_option('max_display_rows') : get_request_var('tail_lines');
$logcontents = tail_file($logfile, $number_of_lines, get_request_var('message_type'), get_request_var('rfilter'), $page_nr, $total_rows);
if (get_request_var('reverse') == 1) {
$logcontents = array_reverse($logcontents);
}
if (get_request_var('message_type') > 0) {
$start_string = __('Log [Total Lines: %d - Non-Matching Items Hidden]', $total_rows);
} else {
$start_string = __('Log [Total Lines: %d - All Items Shown]', $total_rows);
}
$rfilter = get_request_var('rfilter');
$reverse = get_request_var('reverse');
$refreshTime = get_request_var('refresh');
$message_type = get_request_var('message_type');
$tail_lines = get_request_var('tail_lines');
$base_url = 'utilities.php?action=view_logfile&rfilter='.$rfilter.'&reverse='.$reverse.'&refresh='.$refreshTime.'&message_type='.$message_type.'&tail_lines='.$tail_lines.'&filename='.basename($logfile);
$nav = html_nav_bar($base_url, MAX_DISPLAY_PAGES, $page_nr, $number_of_lines, $total_rows, 13, __('Entries'), 'page', 'main');
echo $nav;
html_start_box($start_string, '100%', '', '3', 'center', '');
$linecolor = false;
foreach ($logcontents as $item) {
$host_start = strpos($item, 'Device[');
$ds_start = strpos($item, 'DS[');
if (!$host_start && !$ds_start) {
$new_item = html_escape($item);
} else {
$new_item = '';
while ($host_start) {
$host_end = strpos($item, ']', $host_start);
$host_id = substr($item, $host_start + 7, $host_end - ($host_start + 7));
$new_item .= html_escape(substr($item, 0, $host_start + 7)) . "<a href='" . html_escape('host.php?action=edit&id=' . $host_id) . "'>" . html_escape(substr($item, $host_start + 7, $host_end - ($host_start + 7))) . '</a>';
$item = substr($item, $host_end);
$host_start = strpos($item, 'Device[');
}
$ds_start = strpos($item, 'DS[');
while ($ds_start) {
$ds_end = strpos($item, ']', $ds_start);
$ds_id = substr($item, $ds_start + 3, $ds_end - ($ds_start + 3));
$new_item .= html_escape(substr($item, 0, $ds_start + 3)) . "<a href='" . html_escape('data_sources.php?action=ds_edit&id=' . $ds_id) . "'>" . html_escape(substr($item, $ds_start + 3, $ds_end - ($ds_start + 3))) . '</a>';
$item = substr($item, $ds_end);
$ds_start = strpos($item, 'DS[');
}
$new_item .= html_escape($item);
}
/* get the background color */
if (strpos($new_item, 'ERROR') !== false || strpos($new_item, 'FATAL') !== false) {
$class = 'clogError';
} elseif (strpos($new_item, 'WARN') !== false) {
$class = 'clogWarning';
} elseif (strpos($new_item, ' SQL ') !== false) {
$class = 'clogSQL';
} elseif (strpos($new_item, 'DEBUG') !== false) {
$class = 'clogDebug';
} elseif (strpos($new_item, 'STATS') !== false) {
$class = 'clogStats';
} else {
if ($linecolor) {
$class = 'odd';
} else {
$class = 'even';
}
$linecolor = !$linecolor;
}
print "<tr class='" . $class . "'><td>" . $new_item . "</td></tr>\n";
}
html_end_box();
if ($total_rows) {
echo $nav;
}
bottom_footer();
}
function utilities_clear_logfile() {
load_current_session_value('refresh', 'sess_logfile_refresh', read_config_option('log_refresh_interval'));
$refresh['seconds'] = get_request_var('refresh');
$refresh['page'] = 'utilities.php?action=view_logfile&header=false';
$refresh['logout'] = 'false';
set_page_refresh($refresh);
top_header();
$logfile = read_config_option('path_cactilog');
if ($logfile == '') {
$logfile = './log/cacti.log';
}
html_start_box(__('Clear Cacti Log'), '100%', '', '3', 'center', '');
if (file_exists($logfile)) {
if (is_writable($logfile)) {
/* fill in the current date for printing in the log */
if (defined('CACTI_DATE_TIME_FORMAT')) {
$date = date(CACTI_DATE_TIME_FORMAT);
} else {
$date = date('Y-m-d H:i:s');
}
$log_fh = fopen($logfile, 'w');
fwrite($log_fh, __('%s - WEBUI NOTE: Cacti Log Cleared from Web Management Interface.', $date) . PHP_EOL);
fclose($log_fh);
print '<tr><td>' . __('Cacti Log Cleared') . '</td></tr>';
} else {
print "<tr><td class='deviceDown'><b>" . __('Error: Unable to clear log, no write permissions.') . "<b></td></tr>";
}
} else {
print "<tr><td class='deviceDown'><b>" . __('Error: Unable to clear log, file does not exist.'). "</b></td></tr>";
}
html_end_box();
}
function utilities_view_snmp_cache() {
global $poller_actions, $item_rows;
/* ================= input validation and session storage ================= */
$filters = array(
'rows' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'filter' => array(
'filter' => FILTER_DEFAULT,
'pageset' => true,
'default' => ''
),
'with_index' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '0'
),
'host_id' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'snmp_query_id' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'poller_action' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
)
);
validate_store_request_vars($filters, 'sess_usnmp');
/* ================= input validation ================= */
if (get_request_var('rows') == '-1') {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
$refresh['seconds'] = '300';
$refresh['page'] = 'utilities.php?action=view_snmp_cache&header=false';
$refresh['logout'] = 'false';
set_page_refresh($refresh);
?>
<script type="text/javascript">
function applyFilter() {
strURL = urlPath+'utilities.php?host_id=' + $('#host_id').val();
strURL += '&snmp_query_id=' + $('#snmp_query_id').val();
if ($('#with_index').is(':checked')) {
strURL += '&with_index=1';
} else {
strURL += '&with_index=0';
}
strURL += '&filter=' + $('#filter').val();
strURL += '&rows=' + $('#rows').val();
strURL += '&action=view_snmp_cache';
strURL += '&header=false';
loadPageNoHeader(strURL);
}
function clearFilter() {
strURL = urlPath+'utilities.php?action=view_snmp_cache&clear=1&header=false';
loadPageNoHeader(strURL);
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#form_snmpcache').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
</script>
<?php
html_start_box(__('Data Query Cache Items'), '100%', '', '3', 'center', '');
?>
<tr class='even noprint'>
<td>
<form id='form_snmpcache' action='utilities.php'>
<table class='filterTable'>
<tr>
<?php print html_host_filter(get_request_var('host_id'));?>
<td>
<?php print __('Query Name');?>
</td>
<td>
<select id='snmp_query_id' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('host_id') == '-1') {?> selected<?php }?>><?php print __('Any');?></option>
<?php
if (get_request_var('host_id') == -1) {
$snmp_queries = db_fetch_assoc('SELECT DISTINCT sq.id, sq.name
FROM host_snmp_cache AS hsc
INNER JOIN snmp_query AS sq
ON hsc.snmp_query_id=sq.id
INNER JOIN host AS h
ON hsc.host_id=h.id
ORDER by sq.name');
} else {
$snmp_queries = db_fetch_assoc_prepared("SELECT DISTINCT sq.id, sq.name
FROM host_snmp_cache AS hsc
INNER JOIN snmp_query AS sq
ON hsc.snmp_query_id=sq.id
INNER JOIN host AS h
ON hsc.host_id=h.id
ORDER by sq.name", array(get_request_var('host_id')));
}
if (cacti_sizeof($snmp_queries)) {
foreach ($snmp_queries as $snmp_query) {
print "<option value='" . $snmp_query['id'] . "'"; if (get_request_var('snmp_query_id') == $snmp_query['id']) { print ' selected'; } print '>' . html_escape($snmp_query['name']) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<span>
<input type='submit' class='ui-button ui-corner-all ui-widget' id='refresh' value='<?php print __esc_x('Button: use filter settings', 'Go');?>' title='<?php print __esc('Set/Refresh Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='clear' value='<?php print __esc_x('Button: reset filter settings', 'Clear');?>' title='<?php print __esc('Clear Filters');?>'>
</span>
</td>
</tr>
</table>
<table class='filterTable'>
<tr>
<td>
<?php print __('Search');?>
</td>
<td>
<input type='text' class='ui-state-default ui-corner-all' id='filter' size='25' value='<?php print html_escape_request_var('filter');?>'>
</td>
<td>
<?php print __('Rows');?>
</td>
<td>
<select id='rows' onChange='applyFilter()'>
<option value='-1'<?php print (get_request_var('rows') == '-1' ? ' selected>':'>') . __('Default');?></option>
<?php
if (cacti_sizeof($item_rows)) {
foreach ($item_rows as $key => $value) {
print "<option value='" . $key . "'"; if (get_request_var('rows') == $key) { print ' selected'; } print '>' . html_escape($value) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<input type='checkbox' id='with_index' onChange='applyFilter()' title='<?php print __esc('Allow the search term to include the index column');?>' <?php if (get_request_var('with_index') == 1) { print ' checked '; }?>>
<label for='with_index'><?php print __('Include Index') ?></label>
</td>
</tr>
</table>
<input type='hidden' name='action' value='view_snmp_cache'>
</form>
</td>
</tr>
<?php
html_end_box();
$sql_where = '';
/* filter by host */
if (get_request_var('host_id') == '-1') {
/* Show all items */
} elseif (get_request_var('host_id') == '0') {
$sql_where .= ' AND h.id=0';
} elseif (!isempty_request_var('host_id')) {
$sql_where .= ' AND h.id=' . get_request_var('host_id');
}
/* filter by query name */
if (get_request_var('snmp_query_id') == '-1') {
/* Show all items */
} elseif (!isempty_request_var('snmp_query_id')) {
$sql_where .= ' AND hsc.snmp_query_id=' . get_request_var('snmp_query_id');
}
/* filter by search string */
if (get_request_var('filter') != '') {
$sql_where .= ' AND (
h.description LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR sq.name LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR hsc.field_name LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR hsc.field_value LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR hsc.oid LIKE ' . db_qstr('%' . get_request_var('filter') . '%');
if (get_request_var('with_index') == 1) {
$sql_where .= ' OR hsc.snmp_index LIKE ' . db_qstr('%' . get_request_var('filter') . '%');
}
$sql_where .= ')';
}
$total_rows = db_fetch_cell("SELECT COUNT(*)
FROM host_snmp_cache AS hsc
INNER JOIN snmp_query AS sq
ON hsc.snmp_query_id = sq.id
INNER JOIN host AS h
ON hsc.host_id = h.id
WHERE hsc.host_id = h.id
AND hsc.snmp_query_id = sq.id
$sql_where");
$snmp_cache_sql = "SELECT hsc.*, h.description, sq.name
FROM host_snmp_cache AS hsc
INNER JOIN snmp_query AS sq
ON hsc.snmp_query_id = sq.id
INNER JOIN host AS h
ON hsc.host_id = h.id
WHERE hsc.host_id = h.id
AND hsc.snmp_query_id = sq.id
$sql_where
LIMIT " . ($rows*(get_request_var('page')-1)) . ',' . $rows;
$snmp_cache = db_fetch_assoc($snmp_cache_sql);
$nav = html_nav_bar('utilities.php?action=view_snmp_cache&host_id=' . get_request_var('host_id') . '&filter=' . get_request_var('filter'), MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 6, __('Entries'), 'page', 'main');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
html_header(array(__('Device'), __('Data Query Name'), __('Index'), __('Field Name'), __('Field Value'), __('OID')));
$i = 0;
if (cacti_sizeof($snmp_cache)) {
foreach ($snmp_cache as $item) {
form_alternate_row();
?>
<td>
<?php print filter_value($item['description'], get_request_var('filter'));?>
</td>
<td>
<?php print filter_value($item['name'], get_request_var('filter'));?>
</td>
<td>
<?php print html_escape($item['snmp_index']);?>
</td>
<td>
<?php print filter_value($item['field_name'], get_request_var('filter'));?>
</td>
<td>
<?php print filter_value($item['field_value'], get_request_var('filter'));?>
</td>
<td>
<?php print filter_value($item['oid'], get_request_var('filter'));?>
</td>
</tr>
<?php
}
}
html_end_box();
if (cacti_sizeof($snmp_cache)) {
print $nav;
}
}
function utilities_view_poller_cache() {
global $poller_actions, $item_rows;
/* ================= input validation and session storage ================= */
$filters = array(
'rows' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'filter' => array(
'filter' => FILTER_DEFAULT,
'pageset' => true,
'default' => '',
'options' => array('options' => 'sanitize_search_string')
),
'sort_column' => array(
'filter' => FILTER_CALLBACK,
'default' => 'dtd.name_cache',
'options' => array('options' => 'sanitize_search_string')
),
'sort_direction' => array(
'filter' => FILTER_CALLBACK,
'default' => 'ASC',
'options' => array('options' => 'sanitize_search_string')
),
'host_id' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'template_id' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'poller_action' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
)
);
validate_store_request_vars($filters, 'sess_poller');
/* ================= input validation ================= */
if (get_request_var('rows') == '-1') {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
$refresh['seconds'] = '300';
$refresh['page'] = 'utilities.php?action=view_poller_cache';
$refresh['logout'] = 'false';
set_page_refresh($refresh);
?>
<script type="text/javascript">
function applyFilter() {
strURL = urlPath+'utilities.php?poller_action=' + $('#poller_action').val();
strURL += '&action=view_poller_cache';
strURL += '&host_id=' + $('#host_id').val();
strURL += '&template_id=' + $('#template_id').val();
strURL += '&filter=' + $('#filter').val();
strURL += '&rows=' + $('#rows').val();
strURL += '&header=false';
loadPageNoHeader(strURL);
}
function clearFilter() {
strURL = urlPath+'utilities.php?action=view_poller_cache&clear=1&header=false';
loadPageNoHeader(strURL);
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#form_pollercache').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
</script>
<?php
html_start_box(__('Poller Cache Items'), '100%', '', '3', 'center', '');
?>
<tr class='even noprint'>
<td>
<form id='form_pollercache' action='utilities.php'>
<table class='filterTable'>
<tr>
<?php print html_host_filter(get_request_var('host_id'));?>
<td>
<?php print __('Template');?>
</td>
<td>
<select id='template_id' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('template_id') == '-1') {?> selected<?php }?>><?php print __('Any');?></option>
<option value='0'<?php if (get_request_var('template_id') == '0') {?> selected<?php }?>><?php print __('None');?></option>
<?php
if (get_request_var('host_id') > 0) {
$sql_where = 'WHERE dl.host_id = ' . get_request_var('host_id');
} else {
$sql_where = '';
}
$templates = db_fetch_assoc("SELECT DISTINCT dt.id, dt.name
FROM data_template AS dt
INNER JOIN data_local AS dl
ON dt.id=dl.data_template_id
$sql_where
ORDER BY name");
if (cacti_sizeof($templates)) {
foreach ($templates as $template) {
print "<option value='" . $template['id'] . "'"; if (get_request_var('template_id') == $template['id']) { print ' selected'; } print '>' . title_trim(html_escape($template['name']), 40) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<span>
<input type='submit' class='ui-button ui-corner-all ui-widget' id='refresh' value='<?php print __esc_x('Button: use filter settings', 'Go');?>' title='<?php print __esc('Set/Refresh Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='clear' value='<?php print __esc_x('Button: reset filter settings', 'Clear');?>' title='<?php print __esc('Clear Filters');?>'>
</span>
</td>
</tr>
</table>
<table class='filterTable'>
<tr>
<td>
<?php print __('Search');?>
</td>
<td>
<input type='text' class='ui-state-default ui-corner-all' id='filter' size='25' value='<?php print html_escape_request_var('filter');?>'>
</td>
<td>
<?php print __('Action');?>
</td>
<td>
<select id='poller_action' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('poller_action') == '-1') {?> selected<?php }?>><?php print __('Any');?></option>
<option value='0'<?php if (get_request_var('poller_action') == '0') {?> selected<?php }?>><?php print __('SNMP');?></option>
<option value='1'<?php if (get_request_var('poller_action') == '1') {?> selected<?php }?>><?php print __('Script');?></option>
<option value='2'<?php if (get_request_var('poller_action') == '2') {?> selected<?php }?>><?php print __('Script Server');?></option>
</select>
</td>
<td>
<?php print __('Entries');?>
</td>
<td>
<select id='rows' onChange='applyFilter()'>
<option value='-1'<?php print (get_request_var('rows') == '-1' ? ' selected>':'>') . __('Default');?></option>
<?php
if (cacti_sizeof($item_rows)) {
foreach ($item_rows as $key => $value) {
print "<option value='" . $key . "'"; if (get_request_var('rows') == $key) { print ' selected'; } print '>' . html_escape($value) . "</option>\n";
}
}
?>
</select>
</td>
</tr>
</table>
<input type='hidden' name='action' value='view_poller_cache'>
</form>
</td>
</tr>
<?php
html_end_box();
/* form the 'where' clause for our main sql query */
$sql_where = 'WHERE pi.local_data_id = dtd.local_data_id';
if (get_request_var('poller_action') != '-1') {
$sql_where .= " AND pi.action='" . get_request_var('poller_action') . "'";
}
if (get_request_var('host_id') == '-1') {
/* Show all items */
} elseif (get_request_var('host_id') == '0') {
$sql_where .= ' AND pi.host_id = 0';
} elseif (!isempty_request_var('host_id')) {
$sql_where .= ' AND pi.host_id = ' . get_request_var('host_id');
}
if (get_request_var('template_id') == '-1') {
/* Show all items */
} elseif (get_request_var('template_id') == '0') {
$sql_where .= ($sql_where != '' ? ' AND ':'WHERE ') . ' dtd.data_template_id=0';
} elseif (!isempty_request_var('template_id')) {
$sql_where .= ($sql_where != '' ? ' AND ':'WHERE ') . ' dl.data_template_id=' . get_request_var('template_id');
}
if (get_request_var('filter') != '') {
$sql_where .= ' AND (
dtd.name_cache LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR h.description LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR pi.arg1 LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR pi.hostname LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR pi.rrd_path LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . ')';
}
$total_rows = db_fetch_cell("SELECT COUNT(*)
FROM poller_item AS pi
INNER JOIN data_local AS dl
ON dl.id=pi.local_data_id
INNER JOIN data_template_data AS dtd
ON dtd.local_data_id = pi.local_data_id
INNER JOIN host AS h
ON pi.host_id = h.id
$sql_where");
$poller_sql = "SELECT pi.*, dtd.name_cache, h.description
FROM poller_item AS pi
INNER JOIN data_local AS dl
ON dl.id=pi.local_data_id
INNER JOIN data_template_data AS dtd
ON dtd.local_data_id = pi.local_data_id
INNER JOIN host AS h
ON pi.host_id = h.id
$sql_where
ORDER BY " . get_request_var('sort_column') . ' ' . get_request_var('sort_direction') . ', action ASC
LIMIT ' . ($rows*(get_request_var('page')-1)) . ',' . $rows;
$poller_cache = db_fetch_assoc($poller_sql);
$nav = html_nav_bar('utilities.php?action=view_poller_cache&filter=' . get_request_var('filter'), MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 3, __('Entries'), 'page', 'main');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
$display_text = array(
'dtd.name_cache' => array(__('Data Source Name'), 'ASC'),
'h.description' => array(__('Device Description'), 'ASC'),
'nosort' => array(__('Details'), 'ASC'));
html_header_sort($display_text, get_request_var('sort_column'), get_request_var('sort_direction'), 1, 'utilities.php?action=view_poller_cache');
$i = 0;
if (cacti_sizeof($poller_cache)) {
foreach ($poller_cache as $item) {
if ($i % 2 == 0) {
$class = 'odd';
} else {
$class = 'even';
}
print "<tr class='$class'>\n";
?>
<td>
<?php print filter_value($item['name_cache'], get_request_var('filter'), 'data_sources.php?action=ds_edit&id=' . $item['local_data_id']);?>
</td>
<td>
<?php print html_escape($item['description']);?>
</td>
<td>
<?php
if ($item['action'] == 0) {
if ($item['snmp_version'] != 3) {
$details =
__('SNMP Version:') . ' ' . $item['snmp_version'] . ', ' .
__('Community:') . ' ' . html_escape($item['snmp_community']) . ', ' .
__('OID:') . ' ' . filter_value($item['arg1'], get_request_var('filter'));
} else {
$details =
__('SNMP Version:') . ' ' . $item['snmp_version'] . ', ' .
__('User:') . ' ' . html_escape($item['snmp_username']) . ', ' . __('OID:') . ' ' . html_escape($item['arg1']);
}
} elseif ($item['action'] == 1) {
$details = __('Script:') . ' ' . filter_value($item['arg1'], get_request_var('filter'));
} else {
$details = __('Script Server:') . ' ' . filter_value($item['arg1'], get_request_var('filter'));
}
print $details;
?>
</td>
</tr>
<?php
print "<tr class='$class'>\n";
?>
<td colspan='2'>
</td>
<td>
<?php print __('RRD:');?> <?php print html_escape($item['rrd_path']);?>
</td>
</tr>
<?php
$i++;
}
}
html_end_box();
if (cacti_sizeof($poller_cache)) {
print $nav;
}
}
function utilities() {
global $utilities;
$utilities[__('Technical Support')] = array(
__('Technical Support') => array(
'link' => 'utilities.php?action=view_tech',
'description' => __('Cacti technical support page. Used by developers and technical support persons to assist with issues in Cacti. Includes checks for common configuration issues.')
),
__('Log Administration') => array(
'link' => 'utilities.php?action=view_logfile',
'description' => __('The Cacti Log stores statistic, error and other message depending on system settings. This information can be used to identify problems with the poller and application.')
),
__('View User Log') => array(
'link' => 'utilities.php?action=view_user_log',
'description' => __('Allows Administrators to browse the user log. Administrators can filter and export the log as well.')
)
);
$utilities[__('Poller Cache Administration')] = array(
__('View Poller Cache') => array(
'link' => 'utilities.php?action=view_poller_cache',
'description' => __('This is the data that is being passed to the poller each time it runs. This data is then in turn executed/interpreted and the results are fed into the RRDfiles for graphing or the database for display.')
),
__('View Data Query Cache') => array(
'link' => 'utilities.php?action=view_snmp_cache',
'description' => __('The Data Query Cache stores information gathered from Data Query input types. The values from these fields can be used in the text area of Graphs for Legends, Vertical Labels, and GPRINTS as well as in CDEF\'s.')
),
__('Rebuild Poller Cache') => array(
'link' => 'utilities.php?action=clear_poller_cache',
'description' => __('The Poller Cache will be re-generated if you select this option. Use this option only in the event of a database crash if you are experiencing issues after the crash and have already run the database repair tools. Alternatively, if you are having problems with a specific Device, simply re-save that Device to rebuild its Poller Cache. There is also a command line interface equivalent to this command that is recommended for large systems. <i class="deviceDown">NOTE: On large systems, this command may take several minutes to hours to complete and therefore should not be run from the Cacti UI. You can simply run \'php -q cli/rebuild_poller_cache.php --help\' at the command line for more information.</i>')
),
__('Rebuild Resource Cache') => array(
'link' => 'utilities.php?action=rebuild_resource_cache',
'description' => __('When operating multiple Data Collectors in Cacti, Cacti will attempt to maintain state for key files on all Data Collectors. This includes all core, non-install related website and plugin files. When you force a Resource Cache rebuild, Cacti will clear the local Resource Cache, and then rebuild it at the next scheduled poller start. This will trigger all Remote Data Collectors to recheck their website and plugin files for consistency.')
),
);
$utilities[__('Boost Utilities')] = array(
__('View Boost Status') => array(
'link' => 'utilities.php?action=view_boost_status',
'description' => __('This menu pick allows you to view various boost settings and statistics associated with the current running Boost configuration.')
),
);
$utilities[__('RRD Utilities')] = array(
__('RRDfile Cleaner') => array(
'link' => 'rrdcleaner.php',
'description' => __('When you delete Data Sources from Cacti, the corresponding RRDfiles are not removed automatically. Use this utility to facilitate the removal of these old files.')
),
);
if (snmpagent_enabled()) {
$utilities[__('SNMPAgent Utilities')] = array(
__('View SNMPAgent Cache') => array(
'link' => 'utilities.php?action=view_snmpagent_cache',
'description' => __('This shows all objects being handled by the SNMPAgent.')
),
__('Rebuild SNMPAgent Cache') => array(
'link' => 'utilities.php?action=rebuild_snmpagent_cache',
'description' => __('The SNMP cache will be cleared and re-generated if you select this option. Note that it takes another poller run to restore the SNMP cache completely.')
),
__('View SNMPAgent Notification Log') => array(
'link' => 'utilities.php?action=view_snmpagent_events',
'description' => __('This menu pick allows you to view the latest events SNMPAgent has handled in relation to the registered notification receivers.')
),
__('SNMP Notification Receivers') => array(
'link' => 'managers.php',
'description' => __('Allows Administrators to maintain SNMP notification receivers.')
),
);
}
api_plugin_hook('utilities_array');
html_start_box(__('Cacti System Utilities'), '100%', '', '3', 'center', '');
foreach($utilities as $header => $content) {
html_section_header($header, 2);
foreach($content as $title => $details) {
form_alternate_row();
print "<td class='nowrap' style='vertical-align:top;'>";
print "<a class='hyperLink' href='" . html_escape($details['link']) . "'>" . $title . "</a>";
print "</td>\n";
print "<td>";
print $details['description'];
print "</td>\n";
form_end_row();
}
}
api_plugin_hook('utilities_list');
html_end_box();
}
function boost_display_run_status() {
global $config, $refresh_interval, $boost_utilities_interval, $boost_refresh_interval, $boost_max_runtime;
/* ================= input validation ================= */
get_filter_request_var('refresh');
/* ==================================================== */
load_current_session_value('refresh', 'sess_boost_utilities_refresh', '30');
$last_run_time = read_config_option('boost_last_run_time', true);
$next_run_time = read_config_option('boost_next_run_time', true);
$rrd_updates = read_config_option('boost_rrd_update_enable', true);
$boost_cache = read_config_option('boost_png_cache_enable', true);
$max_records = read_config_option('boost_rrd_update_max_records', true);
$max_runtime = read_config_option('boost_rrd_update_max_runtime', true);
$update_interval = read_config_option('boost_rrd_update_interval', true);
$peak_memory = read_config_option('boost_peak_memory', true);
$detail_stats = read_config_option('stats_detail_boost', true);
$refresh['seconds'] = get_request_var('refresh');
$refresh['page'] = 'utilities.php?action=view_boost_status&header=false';
$refresh['logout'] = 'false';
set_page_refresh($refresh);
html_start_box(__('Boost Status'), '100%', '', '3', 'center', '');
?>
<script type="text/javascript">
function applyFilter() {
strURL = urlPath+'utilities.php?action=view_boost_status&header=false&refresh=' + $('#refresh').val();
loadPageNoHeader(strURL);
}
</script>
<tr class='even'>
<form id='form_boost_utilities_stats' method='post'>
<td>
<table>
<tr>
<td class='nowrap'>
<?php print __('Refresh Interval');?>
</td>
<td>
<select id='refresh' name='refresh' onChange='applyFilter()'>
<?php
foreach ($boost_utilities_interval as $key => $interval) {
print '<option value="' . $key . '"'; if (get_request_var('refresh') == $key) { print ' selected'; } print '>' . $interval . '</option>';
}
?>
</td>
<td>
<input type='button' class='ui-button ui-corner-all ui-widget' value='<?php print __esc('Refresh');?>' onClick='applyFilter()'>
</td>
</tr>
</table>
</td>
</form>
</tr>
<?php
html_end_box(true);
html_start_box('', '100%', '', '3', 'center', '');
/* get the boost table status */
$boost_table_status = db_fetch_assoc("SELECT *
FROM INFORMATION_SCHEMA.TABLES
WHERE table_schema = SCHEMA()
AND (table_name LIKE 'poller_output_boost_arch_%'
OR table_name LIKE 'poller_output_boost')");
$pending_records = 0;
$arch_records = 0;
$data_length = 0;
$engine = '';
$max_data_length = 0;
foreach($boost_table_status as $table) {
if ($table['TABLE_NAME'] == 'poller_output_boost') {
$pending_records += $table['TABLE_ROWS'];
} else {
$arch_records += $table['TABLE_ROWS'];
}
$data_length += $table['DATA_LENGTH'];
$data_length += $table['INDEX_LENGTH'];
$engine = $table['ENGINE'];
$max_data_length = $table['MAX_DATA_LENGTH'];
}
$total_records = $pending_records + $arch_records;
$avg_row_length = ($total_records ? intval($data_length / $total_records) : 0);
$total_data_sources = db_fetch_cell('SELECT COUNT(*) FROM poller_item');
$boost_status = read_config_option('boost_poller_status', true);
if ($boost_status != '') {
$boost_status_array = explode(':', $boost_status);
$boost_status_date = $boost_status_array[1];
if (substr_count($boost_status_array[0], 'complete')) $boost_status_text = __('Idle');
elseif (substr_count($boost_status_array[0], 'running')) $boost_status_text = __('Running');
elseif (substr_count($boost_status_array[0], 'overrun')) $boost_status_text = __('Overrun Warning');
elseif (substr_count($boost_status_array[0], 'timeout')) $boost_status_text = __('Timed Out');
else $boost_status_text = __('Other');
} else {
$boost_status_text = __('Never Run');
$boost_status_date = '';
}
$stats_boost = read_config_option('stats_boost', true);
if ($stats_boost != '') {
$stats_boost_array = explode(' ', $stats_boost);
$stats_duration = explode(':', $stats_boost_array[0]);
$boost_last_run_duration = $stats_duration[1];
$stats_rrds = explode(':', $stats_boost_array[1]);
$boost_rrds_updated = $stats_rrds[1];
} else {
$boost_last_run_duration = '';
$boost_rrds_updated = '';
}
/* get cache directory size/contents */
$cache_directory = read_config_option('boost_png_cache_directory', true);
$directory_contents = array();
if (is_dir($cache_directory)) {
if ($handle = @opendir($cache_directory)) {
/* This is the correct way to loop over the directory. */
while (false !== ($file = readdir($handle))) {
$directory_contents[] = $file;
}
closedir($handle);
/* get size of directory */
$directory_size = 0;
$cache_files = 0;
if (cacti_sizeof($directory_contents)) {
/* goto the cache directory */
chdir($cache_directory);
/* check and fry as applicable */
foreach($directory_contents as $file) {
/* only remove jpeg's and png's */
if ((substr_count(strtolower($file), '.png')) ||
(substr_count(strtolower($file), '.jpg'))) {
$cache_files++;
$directory_size += filesize($file);
}
}
}
$directory_size = boost_file_size_display($directory_size);
$cache_files = $cache_files . ' Files';
} else {
$directory_size = '<strong>' . __('WARNING:') . '</strong>' . __('Cannot open directory');
$cache_files = '<strong>' . __('WARNING:') . '</strong> ' . __('Unknown');
}
} else {
$directory_size = '<strong>' . __('WARNING:') . '</strong> ' . __('Directory Does NOT Exist!!');
$cache_files = '<strong>' . __('WARNING:') . '</strong> ' . __('N/A');
}
$i = 0;
/* boost status display */
html_section_header(__('Current Boost Status'), 2);
form_alternate_row();
print '<td>' . __('Boost On-demand Updating:') . '</td><td>' . ($rrd_updates == '' ? 'Disabled' : $boost_status_text) . '</td>';
form_alternate_row();
print '<td>' . __('Total Data Sources:') . '</td><td>' . number_format_i18n($total_data_sources, -1) . '</td>';
if ($total_records) {
form_alternate_row();
print '<td>' . __('Pending Boost Records:') . '</td><td>' . number_format_i18n($pending_records, -1) . '</td>';
form_alternate_row();
print '<td>' . __('Archived Boost Records:') . '</td><td>' . number_format_i18n($arch_records, -1) . '</td>';
form_alternate_row();
print '<td>' . __('Total Boost Records:') . '</td><td>' . number_format_i18n($total_records, -1) . '</td>';
}
/* boost status display */
html_section_header(__('Boost Storage Statistics'), 2);
/* describe the table format */
form_alternate_row();
print '<td>' . __('Database Engine:') . '</td><td>' . $engine . '</td>';
/* tell the user how big the table is */
form_alternate_row();
print '<td>' . __('Current Boost Table(s) Size:') . '</td><td>' . boost_file_size_display($data_length, 2) . '</td>';
/* tell the user about the average size/record */
form_alternate_row();
print '<td>' . __('Avg Bytes/Record:') . '</td><td>' . boost_file_size_display($avg_row_length, 0) . '</td>';
/* tell the user about the average size/record */
$output_length = read_config_option('boost_max_output_length');
if ($output_length != '') {
$parts = explode(':', $output_length);
if ((time()-1200) > $parts[0]) {
$ref = true;
} else {
$ref = false;
}
} else {
$ref = true;
}
if ($ref) {
if (strcmp($engine, 'MEMORY') == 0) {
$max_length = db_fetch_cell('SELECT MAX(LENGTH(output)) FROM poller_output_boost');
} else {
$max_length = '0';
}
db_execute("REPLACE INTO settings (name, value) VALUES ('boost_max_output_length', '" . time() . ':' . $max_length . "')");
} else {
$max_length = $parts[1];
}
if ($max_length != 0) {
form_alternate_row();
print '<td>' . __('Max Record Length:') . '</td><td>' . __('%d Bytes', number_format_i18n($max_length)) . '</td>';
}
/* tell the user about the "Maximum Size" this table can be */
form_alternate_row();
if (strcmp($engine, 'MEMORY')) {
$max_table_allowed = __('Unlimited');
$max_table_records = __('Unlimited');
} else {
$max_table_allowed = boost_file_size_display($max_data_length, 2);
$max_table_records = number_format_i18n(($avg_row_length ? $max_data_length/$avg_row_length : 0), 3, 1000);
}
print '<td>' . __('Max Allowed Boost Table Size:') . '</td><td>' . $max_table_allowed . '</td>';
/* tell the user about the estimated records that "could" be held in memory */
form_alternate_row();
print '<td>' . __('Estimated Maximum Records:') . '</td><td>' . $max_table_records . ' Records</td>';
/* boost last runtime display */
html_section_header(__('Runtime Statistics'), 2);
form_alternate_row();
print '<td class="utilityPick">' . __('Last Start Time:') . '</td><td>' . $last_run_time . '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('Last Run Duration:') . '</td><td>';
if (is_numeric($boost_last_run_duration)) {
print (($boost_last_run_duration > 60) ? __('%d minutes', (int)($boost_last_run_duration/60)) : '' ) . __('%d seconds', $boost_last_run_duration%60);
if ($rrd_updates != ''){ print ' (' . __('%0.2f percent of update frequency)', round(100*$boost_last_run_duration/$update_interval/60));}
} else {
print __('N/A');
}
print '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('RRD Updates:') . '</td><td>' . ($boost_rrds_updated != '' ? number_format_i18n($boost_rrds_updated, -1):'-') . '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('Peak Poller Memory:') . '</td><td>' . ((read_config_option('boost_peak_memory') != '' && is_numeric(read_config_option('boost_peak_memory'))) ? (round(read_config_option('boost_peak_memory')/1024/1024,2)) . ' ' . __('MBytes') : __('N/A')) . '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('Detailed Runtime Timers:') . '</td><td>' . (($detail_stats != '') ? $detail_stats:__('N/A')) . '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('Max Poller Memory Allowed:') . '</td><td>' . ((read_config_option('boost_poller_mem_limit') != '') ? (read_config_option('boost_poller_mem_limit')) . ' ' . __('MBytes') : __('N/A')) . '</td>';
/* boost runtime display */
html_section_header(__('Run Time Configuration'), 2);
form_alternate_row();
print '<td class="utilityPick">' . __('Update Frequency:') . '</td><td>' . ($rrd_updates == '' ? __('N/A') : $boost_refresh_interval[$update_interval]) . '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('Next Start Time:') . '</td><td>' . $next_run_time . '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('Maximum Records:') . '</td><td>' . number_format_i18n($max_records, -1) . ' ' . __('Records') . '</td>';
form_alternate_row();
print '<td class="utilityPick">' . __('Maximum Allowed Runtime:') . '</td><td>' . $boost_max_runtime[$max_runtime] . '</td>';
/* boost caching */
html_section_header(__('Image Caching'), 2);
form_alternate_row();
print '<td>' . __('Image Caching Status:') . '</td><td>' . ($boost_cache == '' ? __('Disabled') : __('Enabled')) . '</td>';
form_alternate_row();
print '<td>' . __('Cache Directory:') . '</td><td>' . $cache_directory . '</td>';
form_alternate_row();
print '<td>' . __('Cached Files:') . '</td><td>' . $cache_files . '</td>';
form_alternate_row();
print '<td>' . __('Cached Files Size:') . '</td><td>' . $directory_size . '</td>';
html_end_box(true);
}
/**
*
*
* snmpagent_utilities_run_cache()
*
* @param mixed
* @return
*/
function snmpagent_utilities_run_cache() {
global $item_rows;
get_filter_request_var('mib', FILTER_CALLBACK, array('options' => 'sanitize_search_string'));
$mibs = db_fetch_assoc('SELECT DISTINCT mib FROM snmpagent_cache');
$registered_mibs = array();
if($mibs && $mibs >0) {
foreach($mibs as $mib) { $registered_mibs[] = $mib['mib']; }
}
/* ================= input validation ================= */
if(!in_array(get_request_var('mib'), $registered_mibs) && get_request_var('mib') != '-1' && get_request_var('mib') != '') {
die_html_input_error();
}
/* ==================================================== */
/* ================= input validation and session storage ================= */
$filters = array(
'rows' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'filter' => array(
'filter' => FILTER_DEFAULT,
'pageset' => true,
'default' => ''
),
'mib' => array(
'filter' => FILTER_CALLBACK,
'default' => '-1',
'options' => array('options' => 'sanitize_search_string')
)
);
validate_store_request_vars($filters, 'sess_snmpac');
/* ================= input validation ================= */
if (get_request_var('rows') == -1) {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
?>
<script type='text/javascript'>
function applyFilter() {
strURL = 'utilities.php?action=view_snmpagent_cache';
strURL += '&mib=' + $('#mib').val();
strURL += '&rows=' + $('#rows').val();
strURL += '&filter=' + $('#filter').val();
strURL += '&header=false';
loadPageNoHeader(strURL);
}
function clearFilter() {
strURL = 'utilities.php?action=view_snmpagent_cache&clear=1&header=false';
loadPageNoHeader(strURL);
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#form_snmpagent_cache').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
</script>
<?php
html_start_box(__('SNMPAgent Cache'), '100%', '', '3', 'center', '');
?>
<tr class='even noprint'>
<td>
<form id='form_snmpagent_cache' action='utilities.php'>
<table class='filterTable'>
<tr>
<td>
<?php print __('Search');?>
</td>
<td>
<input type='text' class='ui-state-default ui-corner-all' id='filter' size='25' value='<?php print html_escape_request_var('filter');?>'>
</td>
<td>
<?php print __('MIB');?>
</td>
<td>
<select id='mib' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('mib') == '-1') {?> selected<?php }?>><?php print __('Any');?></option>
<?php
if (cacti_sizeof($mibs) > 0) {
foreach ($mibs as $mib) {
print "<option value='" . $mib['mib'] . "'"; if (get_request_var('mib') == $mib['mib']) { print ' selected'; } print '>' . html_escape($mib['mib']) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<?php print __('OIDs');?>
</td>
<td>
<select id='rows' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('rows') == '-1') {?> selected<?php }?>><?php print __('Default');?></option>
<?php
if (cacti_sizeof($item_rows)) {
foreach ($item_rows as $key => $value) {
print "<option value='" . $key . "'"; if (get_request_var('rows') == $key) { print ' selected'; } print '>' . html_escape($value) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<span>
<input type='button' class='ui-button ui-corner-all ui-widget' id='refresh' value='<?php print __esc_x('Button: use filter settings', 'Go');?>' title='<?php print __esc('Set/Refresh Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='clear' value='<?php print __esc_x('Button: reset filter settings', 'Clear');?>' title='<?php print __esc('Clear Filters');?>'>
</span>
</td>
</tr>
</table>
</form>
</td>
</tr>
<?php
html_end_box();
$sql_where = '';
/* filter by host */
if (get_request_var('mib') == '-1') {
/* Show all items */
} elseif (!isempty_request_var('mib')) {
$sql_where .= " AND snmpagent_cache.mib='" . get_request_var('mib') . "'";
}
/* filter by search string */
if (get_request_var('filter') != '') {
$sql_where .= ' AND (
`oid` LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR `name` LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR `mib` LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . '
OR `max-access` LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . ')';
}
$sql_where .= ' ORDER by `oid`';
$total_rows = db_fetch_cell("SELECT COUNT(*) FROM snmpagent_cache WHERE 1 $sql_where");
$snmp_cache_sql = "SELECT * FROM snmpagent_cache WHERE 1 $sql_where LIMIT " . ($rows*(get_request_var('page')-1)) . ',' . $rows;
$snmp_cache = db_fetch_assoc($snmp_cache_sql);
/* generate page list */
$nav = html_nav_bar('utilities.php?action=view_snmpagent_cache&mib=' . get_request_var('mib') . '&filter=' . get_request_var('filter'), MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 11, __('Entries'), 'page', 'main');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
html_header(array(__('OID'), __('Name'), __('MIB'), __('Type'), __('Max-Access'), __('Value')));
if (cacti_sizeof($snmp_cache)) {
foreach ($snmp_cache as $item) {
$oid = filter_value($item['oid'], get_request_var('filter'));
$name = filter_value($item['name'], get_request_var('filter'));
$mib = filter_value($item['mib'], get_request_var('filter'));
$max_access = filter_value($item['max-access'], get_request_var('filter'));
form_alternate_row('line' . $item['oid'], false);
form_selectable_cell($oid, $item['oid']);
if($item['description']) {
print '<td><a href="#" title="<div class=\'header\'>' . $name . '</div><div class=\'content preformatted\'>' . html_escape($item['description']) . '</div>" class="tooltip">' . $name . '</a></td>';
}else {
print "<td>$name</td>";
}
form_selectable_cell($mib, $item['oid']);
form_selectable_cell($item['kind'], $item['oid']);
form_selectable_cell($max_access, $item['oid']);
form_selectable_ecell((in_array($item['kind'], array(__('Scalar'), __('Column Data'))) ? $item['value'] : __('N/A')), $item['oid']);
form_end_row();
}
}
html_end_box();
if (cacti_sizeof($snmp_cache)) {
print $nav;
}
?>
<script type='text/javascript'>
$('.tooltip').tooltip({
track: true,
show: 250,
hide: 250,
position: { collision: "flipfit" },
content: function() { return $(this).attr('title'); }
});
</script>
<?php
}
function snmpagent_utilities_run_eventlog(){
global $item_rows;
$severity_levels = array(
SNMPAGENT_EVENT_SEVERITY_LOW => 'LOW',
SNMPAGENT_EVENT_SEVERITY_MEDIUM => 'MEDIUM',
SNMPAGENT_EVENT_SEVERITY_HIGH => 'HIGH',
SNMPAGENT_EVENT_SEVERITY_CRITICAL => 'CRITICAL'
);
$severity_colors = array(
SNMPAGENT_EVENT_SEVERITY_LOW => '#00FF00',
SNMPAGENT_EVENT_SEVERITY_MEDIUM => '#FFFF00',
SNMPAGENT_EVENT_SEVERITY_HIGH => '#FF0000',
SNMPAGENT_EVENT_SEVERITY_CRITICAL => '#FF00FF'
);
$receivers = db_fetch_assoc('SELECT DISTINCT manager_id, hostname
FROM snmpagent_notifications_log
INNER JOIN snmpagent_managers
ON snmpagent_managers.id = snmpagent_notifications_log.manager_id');
/* ================= input validation ================= */
get_filter_request_var('receiver');
if(!in_array(get_request_var('severity'), array_keys($severity_levels)) && get_request_var('severity') != '-1' && get_request_var('severity') != '') {
die_html_input_error();
}
/* ==================================================== */
if (isset_request_var('purge')) {
db_execute('TRUNCATE table snmpagent_notifications_log');
/* reset filters */
set_request_var('clear', true);
}
/* ================= input validation and session storage ================= */
$filters = array(
'rows' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'filter' => array(
'filter' => FILTER_DEFAULT,
'pageset' => true,
'default' => ''
),
'severity' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'receiver' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
)
);
validate_store_request_vars($filters, 'sess_snmpl');
/* ================= input validation ================= */
if (get_request_var('rows') == -1) {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
?>
<script type='text/javascript'>
function applyFilter() {
strURL = 'utilities.php?action=view_snmpagent_events';
strURL += '&severity=' + $('#severity').val();
strURL += '&receiver=' + $('#receiver').val();
strURL += '&rows=' + $('#rows').val();
strURL += '&filter=' + $('#filter').val();
strURL += '&header=false';
loadPageNoHeader(strURL);
}
function clearFilter() {
strURL = 'utilities.php?action=view_snmpagent_events&clear=1&header=false';
loadPageNoHeader(strURL);
}
function purgeFilter() {
strURL = 'utilities.php?action=view_snmpagent_events&purge=1&header=false';
loadPageNoHeader(strURL);
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#purge').click(function() {
purgeFilter();
});
$('#form_snmpagent_notifications').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
</script>
<?php
html_start_box(__('SNMPAgent Notification Log'), '100%', '', '3', 'center', '');
?>
<tr class='even noprint'>
<td>
<form id='form_snmpagent_notifications' action='utilities.php'>
<table class='filterTable'>
<tr>
<td>
<?php print __('Search');?>
</td>
<td>
<input type='text' class='ui-state-default ui-corner-all' id='filter' size='25' value='<?php print html_escape_request_var('filter');?>'>
</td>
<td>
<?php print __('Severity');?>
</td>
<td>
<select id='severity' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('severity') == '-1') {?> selected<?php }?>><?php print __('Any');?></option>
<?php
foreach ($severity_levels as $level => $name) {
print "<option value='" . $level . "'"; if (get_request_var('severity') == $level) { print ' selected'; } print '>' . html_escape($name) . "</option>\n";
}
?>
</select>
</td>
<td>
<?php print __('Receiver');?>
</td>
<td>
<select id='receiver' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('receiver') == '-1') {?> selected<?php }?>><?php print __('Any');?></option>
<?php
foreach ($receivers as $receiver) {
print "<option value='" . $receiver['manager_id'] . "'"; if (get_request_var('receiver') == $receiver['manager_id']) { print ' selected'; } print '>' . $receiver['hostname'] . "</option>\n";
}
?>
</select>
</td>
<td>
<?php print __('Entries');?>
</td>
<td>
<select id='rows' onChange='applyFilter()'>
<option value='-1'<?php if (get_request_var('rows') == '-1') {?> selected<?php }?>><?php print __('Default');?></option>
<?php
if (cacti_sizeof($item_rows)) {
foreach ($item_rows as $key => $value) {
print "<option value='" . $key . "'"; if (get_request_var('rows') == $key) { print ' selected'; } print '>' . html_escape($value) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<span>
<input type='button' class='ui-button ui-corner-all ui-widget' id='refresh' value='<?php print __esc_x('Button: use filter settings', 'Go');?>' title='<?php print __esc('Set/Refresh Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='clear' value='<?php print __esc_x('Button: reset filter settings', 'Clear');?>' title='<?php print __esc('Clear Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='purge' value='<?php print __esc_x('Button: delete all table entries', 'Purge');?>' title='<?php print __esc('Purge Notification Log');?>'>
</span>
</td>
</tr>
</table>
</form>
</td>
</tr>
<?php
html_end_box();
$sql_where = ' 1';
/* filter by severity */
if(get_request_var('receiver') != '-1') {
$sql_where .= " AND snl.manager_id='" . get_request_var('receiver') . "'";
}
/* filter by severity */
if (get_request_var('severity') == '-1') {
/* Show all items */
} elseif (!isempty_request_var('severity')) {
$sql_where .= " AND snl.severity='" . get_request_var('severity') . "'";
}
/* filter by search string */
if (get_request_var('filter') != '') {
$sql_where .= ' AND (`varbinds` LIKE ' . db_qstr('%' . get_request_var('filter') . '%');
}
$sql_where .= ' ORDER by `time` DESC';
$sql_query = "SELECT snl.*, sm.hostname, sc.description
FROM snmpagent_notifications_log AS snl
INNER JOIN snmpagent_managers AS sm
ON sm.id = snl.manager_id
LEFT JOIN snmpagent_cache AS sc
ON sc.name = snl.notification
WHERE $sql_where
LIMIT " . ($rows*(get_request_var('page')-1)) . ',' . $rows;
$total_rows = db_fetch_cell("SELECT COUNT(*)
FROM snmpagent_notifications_log AS snl
WHERE $sql_where");
$logs = db_fetch_assoc($sql_query);
$nav = html_nav_bar('utilities.php?action=view_snmpagent_events&severity='. get_request_var('severity').'&receiver='. get_request_var('receiver').'&filter=' . get_request_var('filter'), MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 11, __('Log Entries'), 'page', 'main');
form_start('managers.php', 'chk');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
html_header(array(' ', __('Time'), __('Receiver'), __('Notification'), __('Varbinds')));
if (cacti_sizeof($logs)) {
foreach ($logs as $item) {
$varbinds = filter_value($item['varbinds'], get_request_var('filter'));
form_alternate_row('line' . $item['id'], false);
print "<td title='" . __esc('Severity Level: %s', $severity_levels[$item['severity']]) . "' style='width:10px;background-color: " . $severity_colors[$item['severity']] . ";border-top:1px solid white;border-bottom:1px solid white;'></td>";
print "<td class='nowrap'>" . date('Y-m-d H:i:s', $item['time']) . '</td>';
print '<td>' . html_escape($item['hostname']) . '</td>';
if($item['description']) {
print '<td><a href="#" title="<div class=\'header\'>' . html_escape($item['notification']) . '</div><div class=\'content preformatted\'>' . html_escape($item['description']) . '</div>" class="tooltip">' . html_escape($item['notification']) . '</a></td>';
}else {
print '<td>' . html_escape($item['notification']) . '</td>';
}
print "<td>$varbinds</td>";
form_end_row();
}
} else {
print '<tr><td colspan="5"><em>' . __('No SNMP Notification Log Entries') . '</em></td></tr>';
}
html_end_box();
if (cacti_sizeof($logs)) {
print $nav;
}
?>
<script type='text/javascript' >
$('.tooltip').tooltip({
track: true,
position: { collision: 'flipfit' },
content: function() { return $(this).attr('title'); }
});
</script>
<?php
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/whsir/cacti.git
git@gitee.com:whsir/cacti.git
whsir
cacti
cacti
master

搜索帮助