mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
* Install bouncer * Seeder and level migration * Display and edit roles * remove unused deluser page * Update Radius and SSO to assign roles * update AlertUtil direct level check to use roles instead * rewrite ircbot auth handling * Remove legacy auth getUserlist and getUserlevel methods, add getRoles Set roles in LegacyUserProvider * Small cleanups * centralize role sync code show roles on user preferences page * VueSelect component WIP and a little docs * WIP * SelectControllers id and text fields. * LibrenmsSelect component extracted from SettingSelectDynamic * Handle multiple selections * allow type coercion * full width settings * final style adjustments * Final compiled assets update * Style fixes * Fix SSO tests * Lint cleanups * small style fix * don't use json yet * Update baseline for usptream package issues * Change schema, not 100% sure it is correct not sure why xor doesn't work
102 lines
2.1 KiB
PHP
102 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
|
|
class Service extends DeviceRelatedModel
|
|
{
|
|
public $timestamps = false;
|
|
protected $primaryKey = 'service_id';
|
|
protected $fillable = [
|
|
'service_id',
|
|
'device_id',
|
|
'service_ip',
|
|
'service_type',
|
|
'service_desc',
|
|
'service_param',
|
|
'service_ignore',
|
|
'service_status',
|
|
'service_changed',
|
|
'service_message',
|
|
'service_disabled',
|
|
'service_ds',
|
|
'service_template_id',
|
|
'service_name',
|
|
];
|
|
|
|
// ---- Query Scopes ----
|
|
|
|
/**
|
|
* @param Builder $query
|
|
* @return Builder
|
|
*/
|
|
public function scopeIsActive($query)
|
|
{
|
|
return $query->where([
|
|
['service_ignore', '=', 0],
|
|
['service_disabled', '=', 0],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @param Builder $query
|
|
* @return Builder
|
|
*/
|
|
public function scopeIsOk($query)
|
|
{
|
|
return $query->where([
|
|
['service_ignore', '=', 0],
|
|
['service_disabled', '=', 0],
|
|
['service_status', '=', 0],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @param Builder $query
|
|
* @return Builder
|
|
*/
|
|
public function scopeIsCritical($query)
|
|
{
|
|
return $query->where([
|
|
['service_ignore', '=', 0],
|
|
['service_disabled', '=', 0],
|
|
['service_status', '=', 2],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @param Builder $query
|
|
* @return Builder
|
|
*/
|
|
public function scopeIsWarning($query)
|
|
{
|
|
return $query->where([
|
|
['service_ignore', '=', 0],
|
|
['service_disabled', '=', 0],
|
|
['service_status', '=', 1],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @param Builder $query
|
|
* @return Builder
|
|
*/
|
|
public function scopeIsIgnored($query)
|
|
{
|
|
return $query->where([
|
|
['service_ignore', '=', 1],
|
|
['service_disabled', '=', 0],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @param Builder $query
|
|
* @return Builder
|
|
*/
|
|
public function scopeIsDisabled($query)
|
|
{
|
|
return $query->where('service_disabled', 1);
|
|
}
|
|
}
|