File: /var/www/matriculas_api_dev/app/Models/User.php
<?php
namespace App\Models;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
use Laravel\Sanctum\HasApiTokens;
class User extends Authenticatable
{
use HasApiTokens, HasFactory, Notifiable;
protected $table = 'users';
protected $primaryKey = 'id';
/**
* The attributes that are mass assignable.
*
* @var array<int, string>
*/
protected $fillable = [
'name',
'username',
'rut',
'email',
'password',
'remember_token',
'last_entry',
'profile_id',
'status',
'validate_password',
'activation_token',
'account_confirmed',
'account_confirmed_at',
'user_created',
'created_at',
'user_updated',
'updated_at',
'deleted',
'user_deleted',
'deleted_at'
];
/**
* The attributes that should be hidden for serialization.
*
* @var array<int, string>
*/
protected $hidden = [
'password',
'remember_token',
'api_token',
'deleted',
'deleted_at',
'user_deleted'
];
/**
* The attributes that should be cast.
*
* @var array<string, string>
*/
protected $casts = [
'email_verified_at' => 'datetime',
];
public function profile()
{
return $this->belongsTo(Profile::class, 'profile_id');
}
public function permissions()
{
// Esto obtiene los permisos a través del perfil del usuario
return $this->profile ? $this->profile->permissions_users() : collect();
}
public function hasPermission($code)
{
return $this->permissions()->pluck('code')->contains($code);
}
public function getFrontPermissions()
{
return $this->permissions()->pluck('front_code')->filter()->values()->toArray();
}
public function parent()
{
return $this->hasOne(Parents::class, 'user_id');
}
// Relaciones con el modelo Users
public function createdBy()
{
return $this->belongsTo(User::class, 'user_created');
}
public function updatedBy()
{
return $this->belongsTo(User::class, 'user_updated');
}
public function deletedBy()
{
return $this->belongsTo(User::class, 'user_deleted');
}
}