mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
98 lines
3.1 KiB
PHP
98 lines
3.1 KiB
PHP
<?php
|
|
/**
|
|
* transport-groups.inc.php
|
|
*
|
|
* LibreNMS alert-transportsinc.php for processor
|
|
*
|
|
* 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.
|
|
*
|
|
* 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @link http://librenms.org
|
|
* @copyright 2018 Vivia Nguyen-Tran
|
|
* @author Vivia Nguyen-Tran <vivia@ualberta.ca>
|
|
*/
|
|
header('Content-type: application/json');
|
|
|
|
if (! Auth::user()->hasGlobalAdmin()) {
|
|
exit(json_encode([
|
|
'status' => 'error',
|
|
'message' => 'You need to be admin',
|
|
]));
|
|
}
|
|
|
|
$status = 'ok';
|
|
$message = '';
|
|
|
|
$group_id = $vars['group_id'];
|
|
$name = $vars['name'];
|
|
|
|
$target_members = [];
|
|
foreach ((array) $vars['members'] as $target) {
|
|
$target_members[] = (int) $target;
|
|
}
|
|
|
|
if (empty($name)) {
|
|
$status = 'error';
|
|
$message = 'No transport group name provided';
|
|
} elseif (sizeof($target_members) < 1) {
|
|
// Not enough members for a group; requires 1 at least
|
|
$status = 'error';
|
|
$message = 'Not enough group members';
|
|
} else {
|
|
if (is_numeric($group_id) && $group_id > 0) {
|
|
dbUpdate([
|
|
'transport_group_name' => $name,
|
|
], 'alert_transport_groups', '`transport_group_id`=?', [$group_id]);
|
|
} else {
|
|
// Insert into db
|
|
$group_id = dbInsert([
|
|
'transport_group_name' => $name,
|
|
], 'alert_transport_groups');
|
|
}
|
|
|
|
if (is_numeric($group_id) && $group_id > 0) {
|
|
$sql = 'SELECT `transport_id` FROM `transport_group_transport` WHERE `transport_group_id`=?';
|
|
$db_members = dbFetchColumn($sql, [$group_id]);
|
|
|
|
// Compare arrays to get added and removed transports
|
|
$add = array_diff($target_members, $db_members);
|
|
$remove = array_diff($db_members, $target_members);
|
|
|
|
// Insert new transport group members
|
|
$insert = [];
|
|
foreach ($add as $transport_id) {
|
|
$insert[] = [
|
|
'transport_id' => $transport_id,
|
|
'transport_group_id' => $group_id,
|
|
];
|
|
}
|
|
if (! empty($insert)) {
|
|
dbBulkInsert($insert, 'transport_group_transport');
|
|
}
|
|
|
|
// Remove old transport group members
|
|
if (! empty($remove)) {
|
|
dbDelete('transport_group_transport', 'transport_group_id=? AND `transport_id` IN ' . dbGenPlaceholders(count($remove)), array_merge([$group_id], $remove));
|
|
}
|
|
$message = 'Updated alert transport group';
|
|
} else {
|
|
$status = 'error';
|
|
$message = 'Did not update alert transport group';
|
|
}
|
|
}
|
|
|
|
exit(json_encode([
|
|
'status' => $status,
|
|
'message' => $message,
|
|
]));
|