File manager - Edit - /var/www/payraty/inventory_main/app/Models/User.php
Back
<?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Spatie\Permission\Traits\HasRoles; use Tymon\JWTAuth\Contracts\JWTSubject; // use App\Scopes\OrganisationScope; /** * User */ class User extends Authenticatable implements JWTSubject { use HasFactory, Notifiable, HasRoles; /** * appends * * @var array */ protected $appends = ['text', 'avatar_url']; protected static function booted() { // static::addGlobalScope(new OrganisationScope); // Automatically set the organisation_id before creating the model static::creating(function ($model) { if (auth()->check()) { $model->organisation_id = auth()->user()->organisation_id; } }); } // Const public const STATUS_ACTIVE = 'active'; public const STATUS_INACTIVE = 'inactive'; public const FILE_STORE_PATH = 'users'; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'organisation_id', 'name', 'email', 'phone', 'password', 'avatar', 'status', 'po_approval_level', 'is_active', ]; /** * 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', ]; // MUTATORS & ACCESSORS /** * getTextAttribute * * @return void */ public function getTextAttribute() { return $this->name; } /** * getAvatarUrlAttribute * * @return void */ public function getAvatarUrlAttribute() { return getStorageImage(self::FILE_STORE_PATH, $this->avatar, true); } public function creatorId() { if ($this->type == 'company' || $this->type == 'super admin') { return $this->id; } else { return $this->created_by; } } /** * Get the identifier that will be stored in the subject claim of the JWT. * * @return mixed */ public function getJWTIdentifier() { return $this->getKey(); } /** * Return a key value array, containing any custom claims to be added to the JWT. * * @return array */ public function getJWTCustomClaims() { return []; } public function organisation() { return $this->belongsTo(Organisation::class, 'organisation_id'); } public function warehouseTransfer() { return $this->hasMany(WarehouseTransferLog::class, 'transferred_by', 'id'); } }
| ver. 1.4 |
Github
|
.
| PHP 8.3.30 | Generation time: 0 |
proxy
|
phpinfo
|
Settings