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
|