Files

138 lines
3.5 KiB
PHP
Raw Permalink Normal View History

2018-05-09 08:05:17 -05:00
<?php
namespace App\Models;
2018-09-11 07:51:35 -05:00
use Illuminate\Database\Eloquent\Builder;
2018-05-09 08:05:17 -05:00
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
2018-09-11 07:51:35 -05:00
use LibreNMS\Authentication\LegacyAuth;
2018-05-09 08:05:17 -05:00
class User extends Authenticatable
{
use Notifiable;
protected $primaryKey = 'user_id';
2018-09-11 07:51:35 -05:00
protected $fillable = ['realname', 'username', 'email', 'level', 'descr', 'can_modify_passwd', 'auth_type', 'auth_id'];
2018-05-09 08:05:17 -05:00
protected $hidden = ['password', 'remember_token', 'pivot'];
2018-09-11 07:51:35 -05:00
protected $attributes = [ // default values
'descr' => '',
'realname' => '',
'email' => '',
'can_modify_passwd' => 0,
];
2018-05-09 08:05:17 -05:00
// ---- Helper Functions ----
/**
* Test if this user has global read access
* these users have a level of 5, 10 or 11 (demo).
*
* @return boolean
*/
public function hasGlobalRead()
{
return $this->hasGlobalAdmin() || $this->level == 5;
2018-05-09 08:05:17 -05:00
}
/**
2018-09-11 07:51:35 -05:00
* Test if this user has global admin access
* these users have a level of 10 or 11 (demo).
2018-05-09 08:05:17 -05:00
*
* @return boolean
*/
2018-09-11 07:51:35 -05:00
public function hasGlobalAdmin()
2018-05-09 08:05:17 -05:00
{
return $this->level >= 10;
}
2018-09-11 07:51:35 -05:00
/**
* Test if the User is an admin.
*
* @return boolean
*/
public function isAdmin()
{
return $this->level == 10;
}
/**
* Test if this user is the demo user
*
* @return bool
*/
public function isDemo()
{
return $this->level == 11;
}
2018-05-09 08:05:17 -05:00
/**
* Check if this user has access to a device
*
* @param Device|int $device can be a device Model or device id
* @return bool
*/
public function canAccessDevice($device)
{
return $this->hasGlobalRead() || $this->devices->contains($device);
}
2018-09-11 07:51:35 -05:00
// ---- Query scopes ----
/**
* This restricts the query to only users that match the current auth method
* It is not needed when using user_id, but should be used for username and auth_id
*
* @param Builder $query
* @return Builder
*/
public function scopeThisAuth($query)
{
// find user including ones where we might not know the auth type
$type = LegacyAuth::getType();
return $query->where(function ($query) use ($type) {
$query->where('auth_type', $type)
->orWhereNull('auth_type')
->orWhere('auth_type', '');
});
}
2018-05-09 08:05:17 -05:00
// ---- Define Relationships ----
public function devices()
{
if ($this->hasGlobalRead()) {
// $instance = $this->newRelatedInstance('App\Models\Device');
// return new HasAll($instance);
return Device::query();
} else {
return $this->belongsToMany('App\Models\Device', 'devices_perms', 'user_id', 'device_id');
}
}
public function ports()
{
if ($this->hasGlobalRead()) {
return Port::query();
} else {
//FIXME we should return all ports for a device if the user has been given access to the whole device.
return $this->belongsToMany('App\Models\Port', 'ports_perms', 'user_id', 'port_id');
}
}
public function dashboards()
{
return $this->hasMany('App\Models\Dashboard', 'user_id');
}
2018-09-11 07:51:35 -05:00
public function preferences()
{
return $this->hasMany('App\Models\UserPref', 'user_id');
}
2018-05-09 08:05:17 -05:00
public function widgets()
{
2018-09-11 07:51:35 -05:00
return $this->hasMany('App\Models\UserWidget', 'user_id');
2018-05-09 08:05:17 -05:00
}
}