Впервые до laravel,
У меня есть три таблицы users
, roles
и permissions
. Они связаны со следующими двумя сводными таблицами role_user
и permission_role
Здесь я хочу соединить три таблицы, чтобы получить такой результат, как многие-ко-многим и отношения один-ко-многим . Например, я могу получить все разрешения и роли для данного пользователя (один ко многим) и наоборот для ролей и разрешений друг для друга. Кроме того, я хочу получить всех пользователей и соответствующие роли и разрешения и наоборот для ролей и разрешений.
Я только что решил проблему получения ролей для данного пользователя с помощью сообщества, но теперь я застрял чтобы получить вышеуказанный результат. Может ли кто-нибудь помочь мне сделать это?
Схема БД
Модель пользователя
<?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');
}
}