mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
77 lines
2.8 KiB
PHP
77 lines
2.8 KiB
PHP
<?php
|
|
|
|
/*
|
|
* LibreNMS
|
|
*
|
|
* Copyright (c) 2014 Neil Lathwood <https://github.com/laf/ http://www.lathwood.co.uk/fa>
|
|
*
|
|
* 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 3 of the License, or (at your
|
|
* option) any later version. Please see LICENSE.txt at the top level of
|
|
* the source code distribution for details.
|
|
*/
|
|
|
|
if (is_admin() === false) {
|
|
die('ERROR: You need to be admin');
|
|
}
|
|
|
|
$rule = mres($_POST['rule']);
|
|
$target = mres($_POST['target']);
|
|
$map_id = mres($_POST['map_id']);
|
|
$ret = array();
|
|
|
|
if (empty($rule) || empty($target)) {
|
|
$ret[] = 'ERROR: No map was generated';
|
|
}
|
|
else {
|
|
$raw = $rule;
|
|
$rule = dbFetchCell('SELECT id FROM alert_rules WHERE name = ?', array($rule));
|
|
if (!is_numeric($rule)) {
|
|
array_unshift($ret, "ERROR: Could not find rule for '".$raw."'");
|
|
}
|
|
else {
|
|
$raw = $target;
|
|
if ($target[0].$target[1] == 'g:') {
|
|
$target = 'g'.dbFetchCell('SELECT id FROM device_groups WHERE name = ?', array(substr($target, 2)));
|
|
}
|
|
else {
|
|
$target = dbFetchCell('SELECT device_id FROM devices WHERE hostname = ?', array($target));
|
|
}
|
|
|
|
if (!is_numeric(str_replace('g', '', $target))) {
|
|
array_unshift($ret, "ERROR: Could not find entry for '".$raw."'");
|
|
}
|
|
else {
|
|
if (is_numeric($map_id) && $map_id > 0) {
|
|
if (dbUpdate(array('rule' => $rule, 'target' => $target), 'alert_map', 'id=?', array($map_id)) >= 0) {
|
|
$ret[] = 'Edited Map: <i>'.$map_id.': '.$rule.' = '.$target.'</i>';
|
|
}
|
|
else {
|
|
array_unshift($ret, 'ERROR: Failed to edit Map: <i>'.$map_id.': '.$rule.' = '.$target.'</i>');
|
|
}
|
|
}
|
|
else {
|
|
if (dbInsert(array('rule' => $rule, 'target' => $target), 'alert_map')) {
|
|
$ret[] = 'Added Map: <i>'.$rule.' = '.$target.'</i>';
|
|
}
|
|
else {
|
|
array_unshift($ret, 'ERROR: Failed to add Map: <i>'.$rule.' = '.$target.'</i>');
|
|
}
|
|
}
|
|
|
|
if (($tmp = dbFetchCell('SELECT device_id FROM alert_rules WHERE id = ?', array($rule))) && $tmp[0] != ':') {
|
|
if (dbUpdate(array('device_id' => ':'.$tmp), 'alert_rules', 'id=?', array($rule)) >= 0) {
|
|
$ret[] = 'Edited Rule: <i>'.$rule." device_id = ':".$tmp."'</i>";
|
|
}
|
|
else {
|
|
array_unshift($ret, 'ERROR: Failed to edit Rule: <i>'.$rule.": device_id = ':".$tmp."'</i>");
|
|
}
|
|
}
|
|
}//end if
|
|
}//end if
|
|
}//end if
|
|
foreach ($ret as $msg) {
|
|
echo $msg.'<br/>';
|
|
}
|