Маршруты Laravel 5.6.20 с одинаковыми URL в разных группах - PullRequest
0 голосов
/ 25 мая 2018

У меня есть группа 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

1 Ответ

0 голосов
/ 25 мая 2018

Я думаю, что лучшим подходом было бы переосмыслить ваши маршруты , поскольку это не хороший дизайн , если вы хотите следовать стандартам.Вы можете иметь один и тот же URL с разными контроллерами, когда петиция отличается (отправлять, получать, помещать и т. Д.).

Не могли бы вы представить логику того, что должно быть сделано в зависимости от роли пользователя внутри контроллера?Пример:

Route::get('/', 'UserController@index');

Затем в индексе UserController ->

public function index()
{
    if (Auth::user()->role->id == 1) :
       //do X
    else : 
      //do y
    endif;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...