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/
		
			
				
	
	
		
			102 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.2 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/>.
 | 
						|
 *
 | 
						|
 * @package    LibreNMS
 | 
						|
 * @link       http://librenms.org
 | 
						|
 * @copyright  2018 Vivia Nguyen-Tran
 | 
						|
 * @author     Vivia Nguyen-Tran <vivia@ualberta.ca>
 | 
						|
 */
 | 
						|
 | 
						|
use LibreNMS\Authentication\LegacyAuth;
 | 
						|
 | 
						|
header('Content-type: application/json');
 | 
						|
 | 
						|
if (!LegacyAuth::user()->hasGlobalAdmin()) {
 | 
						|
    die(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(array(
 | 
						|
            'transport_group_name' => $name
 | 
						|
        ), 'alert_transport_groups', "`transport_group_id`=?", [$group_id]);
 | 
						|
    } else {
 | 
						|
        // Insert into db
 | 
						|
        $group_id = dbInsert(array(
 | 
						|
            '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[] = array(
 | 
						|
                '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';
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
die(json_encode([
 | 
						|
    'status'       => $status,
 | 
						|
    'message'      => $message
 | 
						|
]));
 |