委托Laravel - 有条件角色的雄辩查询

时间:2017-06-02 11:46:22

标签: php mysql laravel entrust

我在Laravel App中拥有单一的用户口才模型:

我将使用Entrust作为角色。 用户可以拥有多个角色。

我已经设法让用户拥有多个具有相同雄辩模型用户的角色,如下所示:

  public function company(){

    if($this->hasRole('admin')){

        return $this->hasOne('App\Company');

    }elseif($this->hasRole('member')){

           return $this->belongsTo('App\Company');
     }

   }

如何在公司模型中假设的其他模型中处理此问题:

public function admin(){

    $this->hasOne('App\User'); //if has role admin
}

public function members(){

    $this->hasMany('App\User'); //if has role member
}

如何使这个工作?

修改 我能够遍历用户并获得具有特定角色的相关用户,但它在集合中添加了空项:

public function admin(){

    return $this->hasOne('App\User')->get()->map(function($u){

        if($u->hasRole('admin') && $u != null){

            return $u;

        }

    });


}

虽然,我正在检查$u != null我可以在集合中看到许多空对象。

1 个答案:

答案 0 :(得分:0)

这就是我设法让它发挥作用的方式。但是,我无法获取Relation对象,而是获得具有角色Admin的用户集合

public function admin(){

    return $this->hasOne('App\User')->get()->map(function($u){

        if($u->hasRole('admin') && $u != null){

            return $u;

        }

    })->reject(function ($u){
        return $u == null;
    });


}