Как я могу назначить роль пользователю во время регистрации? (Доверить) (Laravel 5.1)

Я только что установил в свой проект laravel 5.1 пакет entrust, вы можете найти этот пакет здесь Доверьте пакет Github .
Я хочу назначить роль пользователю после кнопки регистрации, потому что после этого каждый пользователь заполняет свой профиль. Вы можете увидеть AuthController.php выше.

<?phpnamespace App\Http\Controllers\Auth;

use App\User;
use Validator;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ThrottlesLogins;
use Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsers;

class AuthController extends Controller{

use AuthenticatesAndRegistersUsers, ThrottlesLogins;protected $redirectPath = '/';

protected $loginPath = '/';

/**
* Create a new authentication controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('guest', ['except' => 'getLogout']);
}

/**
* Get a validator for an incoming registration request.
*
* @param  array  $data
* @return \Illuminate\Contracts\Validation\Validator
*/
protected function validator(array $data)
{
return Validator::make($data, [
'name' => 'required|max:255',
'email' => 'required|email|max:255|unique:users',
'password' => 'required|confirmed|min:6',
'role' => 'required|',

]);
}

/**
* Create a new user instance after a valid registration.
*
* @param  array  $data
* @return User
*/
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => bcrypt($data['password']),
'role' => $data['role'],
]);

$tutorschoolRole = DB::table('roles')->where('name', '=', 'Φροντιστήριο')->pluck('id');
$studentRole = DB::table('roles')->where('name', '=', 'Μαθητής')->pluck('id');
$teacherRole = DB::table('roles')->where('name', '=', 'Καθηγητής')->pluck('id');
$parentRole = DB::table('roles')->where('name', '=', 'Γονέας')->pluck('id');

if(User::role == "Φροντιστήριο"){
User::roles()->attach($tutorschoolRole);
}

if(User::role == "Μαθητής"){
User::roles()->attach($studentRole);
}

if(User::role == "Καθηγητής"){
User::roles()->attach($teacherRole);
}

if(User::role == "Γονέας"){
User::roles()->attach($parentRole);
}
}

}

1

Решение

Удалите столбец роли из таблицы пользователей и перенесите таблицы Entrust с помощью этой команды.

php artisan entrust:migration

Будут созданы 4 таблицы:

  • Роли — хранит записи о ролях
  • permissions — хранит записи разрешений
  • role_user — хранит отношения «многие ко многим» между ролями и пользователями
  • allow_role — хранит отношения «многие ко многим» между ролями и
    разрешений

Из вашей БД вы можете добавлять роли и разрешения вручную. Простой способ прикрепить роль к пользователю.

$admin = new Role();
$admin->name         = 'admin';
$admin->display_name = 'User Administrator'; // optional
$admin->description  = 'User is allowed to manage and edit other users'; // optional
$admin->save();
$user = User::find(1);
$user->attachRole($admin); // parameter can be an Role object, array, or id
0

Другие решения

Я решил это, я должен был вернуть пользователя в конце.

protected function create(array $data)
{$user =  User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => bcrypt($data['password']),
'role' => $data['role'],
]);$role_value = $user->role;
$id = 0;

if($role_value == 'Φροντιστήριο')
$userRole = DB::table('roles')->where('name', '=', 'Tutorschool')->pluck('id');

if($role_value == 'Μαθητής')
$userRole = DB::table('roles')->where('name', '=', 'Student')->pluck('id');

if($role_value == 'Καθηγητής')
$userRole = DB::table('roles')->where('name', '=', 'Teacher')->pluck('id');

if($role_value == 'Γονέας')
$userRole = DB::table('roles')->where('name', '=', 'Parent')->pluck('id');

$user->roles()->attach($userRole);

return $user;
}
0

По вопросам рекламы [email protected]