我需要在User类中包含的morphedByMany关系中,从数据透视表类中应用范围。这是关系:
public function nodes($nodeClass)
{
return
$this->morphedByMany(
$nodeClass,
'node',
'users_permissions',
'user_id',
'node_id',
'id',
'id'
)
->using('App\Models\UserNode');
}
然后,我在数据透视表类(UserNode)中具有角色范围。这个范围不是我们的代码,它来自spatie / laravel-permission包的HasRoles Traits:
public function scopeRole(Builder $query, $roles, $guard = null): Builder
{
if ($roles instanceof Collection) {
$roles = $roles->all();
}
if (! is_array($roles)) {
$roles = [$roles];
}
$roles = array_map(function ($role) use ($guard) {
if ($role instanceof Role) {
return $role;
}
$method = is_numeric($role) ? 'findById' : 'findByName';
$guard = $guard ?: $this->getDefaultGuardName();
return $this->getRoleClass()->{$method}($role, $guard);
}, $roles);
return $query->whereHas('roles', function ($query) use ($roles) {
$query->where(function ($query) use ($roles) {
foreach ($roles as $role) {
$query->orWhere(config('permission.table_names.roles').'.id', $role->id);
}
});
});
}
当我尝试像这样在User类中获取特定的节点类时,它可以很好地工作:
$nodes = $this->nodes($nodeClass)->get();
但是,我不知道如何将范围“角色”正确应用于关系的枢纽类,因为wherePivot或wherePivotIn不接受范围,关系或闭包。我还尝试了其他具有相同结果的事情,例如:
$nodes = $this->nodes($nodeClass)->whereHas('pivot', function($q) use ($roles) {
$q->role($roles);
})->get();
是否有任何方法可以将数据透视表类的作用域应用于此关系?
预先感谢