mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
* Security fix: unauthorized access Affects nginx users: Moved php files outside of public html directory (Apache was protected by .htaccess) Affects all users: Some files did not check for authentication and could disclose some info. Better checks before including files from user input * git mv html/includes/ includes/html git mv html/pages/ includes/html/
51 lines
1.5 KiB
PHP
51 lines
1.5 KiB
PHP
<?php
|
|
|
|
/*
|
|
* LibreNMS
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
use LibreNMS\Authentication\LegacyAuth;
|
|
|
|
header('Content-type: application/json');
|
|
|
|
if (!LegacyAuth::user()->hasGlobalAdmin()) {
|
|
die(json_encode([
|
|
'status' => 'error',
|
|
'message' => 'You need to be admin'
|
|
]));
|
|
}
|
|
|
|
$group_id = $vars['group_id'];
|
|
// Retrieve alert transport
|
|
if (is_numeric($group_id) && $group_id > 0) {
|
|
$name = dbFetchCell('SELECT `transport_group_name` FROM `alert_transport_groups` WHERE `transport_group_id`=? LIMIT 1', [$group_id]);
|
|
|
|
$query = "SELECT `a`.`transport_id`, `transport_type`, `transport_name` FROM `transport_group_transport` AS `a` LEFT JOIN `alert_transports` AS `b` ON `a`.`transport_id`=`b`.`transport_id` WHERE `transport_group_id`=?";
|
|
|
|
$members = [];
|
|
foreach (dbFetchRows($query, [$group_id]) as $member) {
|
|
$members[] = [
|
|
'id' => $member['transport_id'],
|
|
'text' => ucfirst($member['transport_type']).": ".$member['transport_name']
|
|
];
|
|
}
|
|
}
|
|
|
|
if (is_array($members)) {
|
|
die(json_encode([
|
|
'name' => $name,
|
|
'members' => $members
|
|
]));
|
|
} else {
|
|
die(json_encode([
|
|
'status' => 'error',
|
|
'message' => 'No transport group found'
|
|
]));
|
|
}
|