* * 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 = implode(' ', $_POST['rules']); $rule = rtrim($rule, '&&'); $rule = rtrim($rule, '||'); $alert_id = $_POST['alert_id']; $count = mres($_POST['count']); $delay = mres($_POST['delay']); $interval = mres($_POST['interval']); $mute = mres($_POST['mute']); $invert = mres($_POST['invert']); $name = mres($_POST['name']); if (empty($rule)) { $update_message = 'ERROR: No rule was generated - did you forget to click and / or?'; } else if (validate_device_id($_POST['device_id']) || $_POST['device_id'] == '-1' || $_POST['device_id'][0] == ':') { $device_id = $_POST['device_id']; if (!is_numeric($count)) { $count = '-1'; } $delay_sec = convert_delay($delay); $interval_sec = convert_delay($interval); if ($mute == 'on') { $mute = true; } else { $mute = false; } if ($invert == 'on') { $invert = true; } else { $invert = false; } $extra = array( 'mute' => $mute, 'count' => $count, 'delay' => $delay_sec, 'invert' => $invert, 'interval' => $interval_sec, ); $extra_json = json_encode($extra); if (is_numeric($alert_id) && $alert_id > 0) { if (dbUpdate(array('rule' => $rule, 'severity' => mres($_POST['severity']), 'extra' => $extra_json, 'name' => $name), 'alert_rules', 'id=?', array($alert_id)) >= 0) { $update_message = "Edited Rule: $name: $rule"; } else { $update_message = 'ERROR: Failed to edit Rule: '.$rule.''; } } else { if (is_array($_POST['maps'])) { $device_id = ':'.$device_id; } if (dbInsert(array('device_id' => $device_id, 'rule' => $rule, 'severity' => mres($_POST['severity']), 'extra' => $extra_json, 'name' => $name), 'alert_rules')) { $update_message = "Added Rule: $name: $rule"; if (is_array($_POST['maps'])) { foreach ($_POST['maps'] as $target) { $_POST['rule'] = $name; $_POST['target'] = $target; $_POST['map_id'] = ''; include 'forms/create-map-item.inc.php'; unset($ret,$target,$raw,$rule,$msg,$map_id); } } } else { $update_message = 'ERROR: Failed to add Rule: '.$rule.''; } }//end if } else { $update_message = 'ERROR: invalid device ID or not a global alert'; }//end if echo $update_message;