eOSP2/app/User.php

63 lines
1.6 KiB
PHP
Raw Normal View History

2019-07-11 23:55:51 +02:00
<?php
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Database\Eloquent\Model;
2019-08-30 02:12:27 +02:00
use Illuminate\Foundation\Auth\User as Authenticatable;
2019-07-11 23:55:51 +02:00
class User extends Authenticatable
{
use Notifiable;
protected $primaryKey = 'id';
2019-07-11 23:55:51 +02:00
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'surname', 'password', 'PESEL', 'phoneNumber', 'email', 'fireStationID', 'functionID', 'degreeID', 'number', 'statusID', 'deleted', 'creatorID', 'changingID', 'confirmation_code',
2019-07-11 23:55:51 +02:00
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
/**
* The attributes that should be cast to native types.
*
* @var array
*/
protected $casts = [
'email_verified_at' => 'datetime',
];
2019-08-30 02:12:27 +02:00
public function setPasswordAttribute($password)
{
$this->attributes['password'] = bcrypt($password);
}
public function accessLevel()
{
if (auth()->user() != null && auth()->user()->fireStationID != null)
if ($this->functionID == 1 or $this->functionID == 5) //prezes lub naczelnik
return 50;
elseif ($this->functionID == 3) //skarbnik
return 30;
elseif($this->functionID == 4) //sekretarz
return 20;
else
return 0; //brak specjalnych uprawnień
else
return -1; //jednostka nie istnieje
}
2019-07-11 23:55:51 +02:00
}