mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	* user deactivation feature * update db_schema.yaml * travis fix * readd sqlfile with alter statement * .. * revert force push * combine all queries * fix query * user enable/disable only visible on mysql authorization * Update form.blade.php * Update index.blade.php * disable 'enabled' on own profile * bootstraping checkboxes
		
			
				
	
	
		
			207 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			207 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Models;
 | 
						|
 | 
						|
use App\Events\UserCreated;
 | 
						|
use Illuminate\Database\Eloquent\Builder;
 | 
						|
use Illuminate\Foundation\Auth\User as Authenticatable;
 | 
						|
use Illuminate\Notifications\Notifiable;
 | 
						|
use LibreNMS\Authentication\LegacyAuth;
 | 
						|
 | 
						|
class User extends Authenticatable
 | 
						|
{
 | 
						|
    use Notifiable;
 | 
						|
 | 
						|
    protected $primaryKey = 'user_id';
 | 
						|
    protected $fillable = ['realname', 'username', 'email', 'level', 'descr', 'can_modify_passwd', 'auth_type', 'auth_id', 'enabled'];
 | 
						|
    protected $hidden = ['password', 'remember_token', 'pivot'];
 | 
						|
    protected $attributes = [ // default values
 | 
						|
        'descr' => '',
 | 
						|
        'realname' => '',
 | 
						|
        'email' => '',
 | 
						|
    ];
 | 
						|
    protected $dispatchesEvents = [
 | 
						|
        'created' => UserCreated::class,
 | 
						|
    ];
 | 
						|
 | 
						|
    protected $casts = [
 | 
						|
        'realname' => 'string',
 | 
						|
        'descr' => 'string',
 | 
						|
        'email' => 'string',
 | 
						|
        'can_modify_passwd' => 'integer',
 | 
						|
    ];
 | 
						|
 | 
						|
    // ---- 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;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test if this user has global admin access
 | 
						|
     * these users have a level of 10 or 11 (demo).
 | 
						|
     *
 | 
						|
     * @return boolean
 | 
						|
     */
 | 
						|
    public function hasGlobalAdmin()
 | 
						|
    {
 | 
						|
        return $this->level >= 10;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 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;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 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);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Helper function to hash passwords before setting
 | 
						|
     *
 | 
						|
     * @param string $password
 | 
						|
     */
 | 
						|
    public function setPassword($password)
 | 
						|
    {
 | 
						|
        $this->attributes['password'] = $password ? password_hash($password, PASSWORD_DEFAULT) : null;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Check if the given user can set the password for this user
 | 
						|
     *
 | 
						|
     * @param User $user
 | 
						|
     * @return bool
 | 
						|
     */
 | 
						|
    public function canSetPassword($user)
 | 
						|
    {
 | 
						|
        if ($user && LegacyAuth::get()->canUpdatePasswords()) {
 | 
						|
            if ($user->isAdmin()) {
 | 
						|
                return true;
 | 
						|
            }
 | 
						|
 | 
						|
            return $user->is($this) && $this->can_modify_passwd;
 | 
						|
        }
 | 
						|
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
 | 
						|
    // ---- 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', '');
 | 
						|
        });
 | 
						|
    }
 | 
						|
 | 
						|
    // ---- Accessors/Mutators ----
 | 
						|
 | 
						|
    public function setRealnameAttribute($realname)
 | 
						|
    {
 | 
						|
        $this->attributes['realname'] = (string)$realname;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setDescrAttribute($descr)
 | 
						|
    {
 | 
						|
        $this->attributes['descr'] = (string)$descr;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setEmailAttribute($email)
 | 
						|
    {
 | 
						|
        $this->attributes['email'] = (string)$email;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setCanModifyPasswdAttribute($modify)
 | 
						|
    {
 | 
						|
        $this->attributes['can_modify_passwd'] = $modify ? 1 : 0;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setEnabledAttribute($enable)
 | 
						|
    {
 | 
						|
        $this->attributes['enabled'] = $enable ? 1 : 0;
 | 
						|
    }
 | 
						|
 | 
						|
    // ---- Define Relationships ----
 | 
						|
 | 
						|
    public function apiToken()
 | 
						|
    {
 | 
						|
        return $this->hasOne('App\Models\ApiToken', 'user_id', 'user_id');
 | 
						|
    }
 | 
						|
 | 
						|
    public function devices()
 | 
						|
    {
 | 
						|
        if ($this->hasGlobalRead()) {
 | 
						|
            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');
 | 
						|
    }
 | 
						|
 | 
						|
    public function preferences()
 | 
						|
    {
 | 
						|
        return $this->hasMany('App\Models\UserPref', 'user_id');
 | 
						|
    }
 | 
						|
 | 
						|
    public function widgets()
 | 
						|
    {
 | 
						|
        return $this->hasMany('App\Models\UserWidget', 'user_id');
 | 
						|
    }
 | 
						|
}
 |