Laravel - Красноречивый способ соединения трех таблиц с использованием двух опорных точек. - PullRequest
0 голосов
/ 28 января 2020

Впервые до laravel,

У меня есть три таблицы users, roles и permissions. Они связаны со следующими двумя сводными таблицами role_user и permission_role

Здесь я хочу соединить три таблицы, чтобы получить такой результат, как многие-ко-многим и отношения один-ко-многим . Например, я могу получить все разрешения и роли для данного пользователя (один ко многим) и наоборот для ролей и разрешений друг для друга. Кроме того, я хочу получить всех пользователей и соответствующие роли и разрешения и наоборот для ролей и разрешений.

Я только что решил проблему получения ролей для данного пользователя с помощью сообщества, но теперь я застрял чтобы получить вышеуказанный результат. Может ли кто-нибудь помочь мне сделать это?

Схема БД

enter image description here

Модель пользователя

<?php

namespace App;

use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;

class User extends Authenticatable
{
    use Notifiable;

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'name',
        'email',
        'password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password',
        'remember_token',
    ];

    /**
     * The attributes that should be cast to native types.
     *
     * @var array
     */
    protected $casts = [
        'email_verified_at' => 'datetime',
    ];


    public function roles() {
        return $this->belongsToMany('App\Admin\Role');
    }
}

Роль Модель

<?php

namespace App\Admin;

use Illuminate\Database\Eloquent\Model;

class Role extends Model
{
    protected $fillable = ['name', 'display'];

    public function permissions()
    {
        return $this->belongsToMany('App\Admin\Permission');
    }

    public function admin_users()
    {
        return $this->belongsToMany('App\Admin\Admin');
    }

    public function users()
    {
        return $this->belongsToMany('App\User');
    }

}

Разрешение Модель

<?php

namespace App\Admin;

use Illuminate\Database\Eloquent\Model;

class Permission extends Model
{
    protected $fillable = ['model', 'can'];

    public function roles()
    {
        return $this->belongsToMany('App\Admin\Role');
    }
}

1 Ответ

0 голосов
/ 28 января 2020

Во-первых, благодаря @ Он указывает направление.

Итак, здесь with() Мне пришлось добавить модель roles, чтобы вызвать из нее метод permissions. Таким образом, код будет выглядеть следующим образом.

User::with('roles', 'roles.permissions')->find($id);

Итак, здесь roles.permissions - это метод permissions() в Role модель

Ролевая модель

class Role extends Model
{
    protected $fillable = ['name', 'display'];

    public function permissions()
    {
        return $this->belongsToMany('App\Admin\Permission');
    }

    ...
}
...