У меня есть группа user
и роль admin
для моих пользователей.
Что я хочу:
Другое действие контроллера для того же URL-адреса.Я подумал, что было бы неплохо следующее, но это не работает.
В тот момент, когда я вхожу в систему как администратор, я получаю исключение, что мне не разрешено просматривать страницу.
routes/web.php
Route::group( [
'middleware' => [ 'auth', \App\Http\Middleware\UserLastActivity::class ],
'domain' => parse_url( env( 'APP_URL' ), PHP_URL_HOST )
], function () {
Route::group( [
'middleware' => [ \App\Http\Middleware\Admin::class ]
], function () {
Route::get('/', 'AdminController@index')->name('home');
} );
Route::group( [
'middleware' => [ \App\Http\Middleware\User::class ]
], function () {
Route::get( '/', 'CvController@index' )->name( 'home' );
} );
} );
Http/Middleware/User.php
<?php
namespace App\Http\Middleware;
use Closure;
class User {
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
*
* @return mixed
*/
public function handle( $request, Closure $next ) {
if ( \Auth::user()->role->id === \App\User::ROLE_USER ) {
return $next( $request );
}
abort( 401 );
}
}
Http/Middleware/Admin.php
<?php
namespace App\Http\Middleware;
use Closure;
class Admin
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
if ( \Auth::user()->role->id === \App\User::ROLE_ADMIN ) {
return $next( $request );
}
abort( 401, __('messages.http.unauthorized') );
}
}
Есть идеи, как этого добиться?
Для ясности:
Когда у пользователя есть role_id 1 (admin): , маршрут /
должен выполнить AdminController@index
Когдау пользователя есть role_id 2 (пользователь): маршрут /
должен выполнить CvController@index