Laravel 5.6在关系中应用枢轴作用域

时间:2019-03-21 10:05:26

标签: php laravel laravel-5 eloquent

我需要在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();

是否有任何方法可以将数据透视表类的作用域应用于此关系?

预先感谢

0 个答案:

没有答案