HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/sigedo-demo.allup.com.co/app/Role.php
<?php

namespace App;

use Illuminate\Support\Facades\Auth;
use Illuminate\Database\Eloquent\Model;

class Role extends Model
{
    protected $guarded  = ['id','deleted_at','created_at','updated_at'];
    public $module = "role";

    public function scopeGates($query,$operation)
    {
        if(Auth::user()->roles->pluck('name')->contains('root')){
            return $query;
        }else{
            $roles = Role::where('active', 1)->get();
            $whereItems = [];
            foreach ($roles as $role){
                if(\Gate::check($this->module.'_'.$operation.'Info'.ucfirst($role->name))){
                    $whereItems[] = $role->id;
                }
            }
            if(count($whereItems)){
                foreach ($whereItems as $key => $item) {
                    $query->orWhere('id',$item);
                }
                return $query;
            }
            return $query->where('id', 0);
        }
    }

    public function users()
    {
        return $this->belongsToMany(User::class, 'user_roles')->withTimestamps();
    }

    public function permissions()
    {
        return $this->belongsToMany(Permission::class, 'role_permissions')->withTimestamps();
    }

    public function filetypes()
    {
        return $this->belongsToMany(Filetype::class);
    }
}