Laravel Gate:授权不起作用

时间:2017-02-08 09:20:36

标签: php laravel laravel-5 laravel-authorization

我正在尝试进行laravel基本授权。我正在使用门进行laravel授权。

表格结构

User Table, Permission Table, Role, role_permission table 

user : id, name , password, email
permission : id, name
role:id , name
role_permission: id, role_id, permission_id

authServiceProvider

public function boot(GateContract  $gate)
{
    $this->registerPolicies();

   foreach($this->getPermissions() as $permission)
    {
      $gate->define($permission->name,function($user) use($permission){  
      return $user->role->id == $permission->role_id;              
            });
    }       
}

public function getPermissions()
{

    $permissions = \DB::table('role_permission')
        ->join('permissions', 'permissions.id', '=', 'role_permission.permission_id')
        ->select('role_permission.*','permissions.*')
        ->get();
    return $permissions;

}

它无法正常工作意味着我无法访问路线,尽管它位于具有相应用户的权限表中。

1 个答案:

答案 0 :(得分:1)

您不应该从服务提供商访问数据库。始终尽量保持服务提供商的简单。请按照以下步骤为您的目的服务。

  

AuthServiceProvider.class

public function boot(GateContract $gate)
{
    $this->registerPolicies($gate);

    $gate->before(function($user, $ability) {

          return $user->hasPermission($ability);
    });

}

现在在App\User模型中添加以下方法。

public function hasPermission($name)
{
    $permission = Permission::where('name','=', $name)->first();
    if(! $permission) {
        return false;
    }

    return $this->hasRole($permission->roles);
} 

public function hasRole($role)
{
    if (is_string($role)) {
        return $this->roles->contains('name', $role);
    }

    return (bool) $role->intersect($this->roles)->count();
}

希望这将有助于实现您的目的。