Repository URL to install this package:
|
Version:
1.0.0 ▾
|
<?php namespace Modules\Users\Entities;
use Illuminate\Database\Eloquent\Model;
use Modules\Users\Traits\HasPermission;
/**
* Modules\Users\Entities\Role
*
* @property integer $id
* @property string $name
* @property string $slug
* @property string $description
* @property \Carbon\Carbon $created_at
* @property \Carbon\Carbon $updated_at
* @property-read \Illuminate\Database\Eloquent\Collection|\Modules\Users\Entities\User[] $users
* @property-read \Illuminate\Database\Eloquent\Collection|\Modules\Users\Entities\Permission[] $permissions
*/
class Role extends Model
{
use HasPermission;
/**
* The attributes that are fillable via mass assignment.
*
* @var array
*/
protected $fillable = ['name', 'slug', 'description'];
/**
* The database table used by the model.
*
* @var string
*/
protected $table = 'roles';
/**
* Roles can belong to many users.
*
* @return Model
*/
public function users()
{
return $this->belongsToMany(config('auth.model'))->withTimestamps();
}
/**
* Checks if the role has the given permission.
*
* @param string $permission
* @param string $operator
* @param array $mergePermissions
* @return bool
*/
public function can($permission, $operator = null, $mergePermissions = [])
{
$operator = is_null($operator) ? $this->parseOperator($permission) : $operator;
$permission = $this->hasDelimiterToArray($permission);
$permissions = $this->getPermissions() + $mergePermissions;
// make permissions to dot notation.
// create.user, delete.admin etc.
$permissions = $this->toDotPermissions($permissions);
// validate permissions array
if (is_array($permission)) {
if (!in_array($operator, ['and', 'or'])) {
$e = 'Invalid operator, available operators are "and", "or".';
throw new \InvalidArgumentException($e);
}
$call = 'canWith' . ucwords($operator);
return $this->$call($permission, $permissions);
}
// validate single permission
return isset($permissions[$permission]) && $permissions[$permission] == true;
}
/**
* List all permissions
*
* @return mixed
*/
public function getPermissions()
{
return $this->getPermissionsInherited();
}
/**
* @param $permission
* @param $permissions
* @return bool
*/
protected function canWithAnd($permission, $permissions)
{
foreach ($permission as $check) {
if (!in_array($check, $permissions) || !isset($permissions[$check]) || $permissions[$check] != true) {
return false;
}
}
return true;
}
/**
* @param $permission
* @param $permissions
* @return bool
*/
protected function canWithOr($permission, $permissions)
{
foreach ($permission as $check) {
if (in_array($check, $permissions) && isset($permissions[$check]) && $permissions[$check] == true) {
return true;
}
}
return false;
}
}