mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	* Device group based access * Use Permissions class to resolve permissions Also give port access based on device access * Convert more pages to use Permissions class * shorten config setting name use Eloquent relationships in several places alphabetize config_definitions.json * Change Models and Permissions * Clean up ajax_search LIMIT sql * Convert more pages to use Permissions class Co-authored-by: Tony Murray <murraytony@gmail.com>
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
if (Auth::user()->hasGlobalRead()) {
 | 
						|
    $data['count'] = array('query' => 'SELECT COUNT(*) FROM devices');
 | 
						|
 | 
						|
    $data['up'] = array('query' => "SELECT COUNT(*) FROM devices WHERE `status` = '1' AND `ignore` = '0'  AND `disabled` = '0'",);
 | 
						|
 | 
						|
    $data['down'] = array('query' => "SELECT COUNT(*) FROM devices WHERE `status` = '0' AND `ignore` = '0'  AND `disabled` = '0'");
 | 
						|
 | 
						|
    $data['ignored'] = array('query' => "SELECT COUNT(*) FROM devices WHERE `ignore` = '1' AND `disabled` = '0'");
 | 
						|
 | 
						|
    $data['disabled'] = array('query' => "SELECT COUNT(*) FROM devices WHERE `disabled` = '1'");
 | 
						|
} else {
 | 
						|
    $device_ids = Permissions::devicesForUser()->toArray() ?: [0];
 | 
						|
    $perms_sql = "`D`.`device_id` IN " .dbGenPlaceholders(count($device_ids));
 | 
						|
 | 
						|
    $data['count'] = array(
 | 
						|
        'query'  => 'SELECT COUNT(*) FROM devices AS D WHERE $perms_sql',
 | 
						|
        'params' => $device_ids
 | 
						|
    );
 | 
						|
 | 
						|
    $data['up'] = array(
 | 
						|
        'query'  => "SELECT COUNT(*) FROM devices AS D WHERE $perms_sql AND D.`status` = '1' AND D.`ignore` = '0' AND D.`disabled` = '0'",
 | 
						|
        'params' => $device_ids
 | 
						|
    );
 | 
						|
 | 
						|
    $data['down'] = array(
 | 
						|
        'query'  => "SELECT COUNT(*) FROM devices AS D WHERE $perms_sql AND D.`status` = '0' AND D.`ignore` = '0' AND D.`disabled` = '0'",
 | 
						|
        'params' => $device_ids
 | 
						|
    );
 | 
						|
 | 
						|
    $data['ignored'] = array(
 | 
						|
        'query'  => "SELECT COUNT(*) FROM devices AS D WHERE $perms_sql AND D.`ignore` = '1' AND D.`disabled` = '0'",
 | 
						|
        'params' => $device_ids
 | 
						|
    );
 | 
						|
 | 
						|
    $data['disabled'] = array(
 | 
						|
        'query'  => "SELECT COUNT(*) FROM devices AS D WHERE $perms_sql AND D.`disabled` = '1'",
 | 
						|
        'params' => $device_ids
 | 
						|
    );
 | 
						|
}//end if
 |