[Из песочницы] Организация маршрутов в Laravel

Здравствуй, Habr. Недавно я согласился на ревью сайта, заказанного на фрилансе. Я ожидал увидеть контроллеры, которые делают вообще все и занимают 200+ строк (и прочие проявления плохого кода), но все было вполне прилично. Валидация не лежала в контроллере, что встречается достаточно часто. Иногда, конечно, встречались некоторые несоответствия PSR-2, но все выглядело нормально, пока я не заглянул в файл с маршрутами. Он занимал несколько экранов и имел комментарии о группах маршрутов. Я связался с разработчиком и он сказал, что все немного «разрослось» и согласился поправить. В следующей версии я увидел, что он создал несколько классов со статическими методами, в которые переложил код и вызвал их, как это обычно делается, с авторизацией. Тут я вспомнил, что уже сталкивался с подобным и встречал такую аргументацию: «В документации ничего не говорится о вынесении маршрутов в разные файлы». Буквально через пару минут я нашел статью и отправил разработчику. Через пол часа я получил маршруты в нормальном виде и принял решение, что многим новичкам эта статья будет полезна. Так родился этот вольный перевод.

Если вы ни разу не правили файл RouteServiceProvider, добро пожаловать под кат.
Если вы работаете с небольшим проектом и у вас всего пару маршрутов, то никаких проблем не возникнет. Но когда количество маршрутов слишком велико, работать в одном файле становится сложно, особенно когда у вас есть страницы для разных пользователей, администраторы, и т.д.

Изначально laravel создает 4 файла:

  • api.php
  • console.php
  • channels.php
  • web.php


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

  • Администратор [ настройки сайта, статистика, т.д. ]
  • Пользователь [ регистрация, вход, управление профилем, т.д. ]
  • Гости [ блог, контакты, т.д. ]


Создаем две директории внутри routes:

  • web — здесь описаны все маршруты, связанные с веб-интерфейсом.
  • api — здесь все маршруты, связанные с API


fa6_lmwu8dogiyu10uwbfn29rkm.png


Перемещаем api.php из routes в директорию routes/api и web.php в routes/web, а остальные console.php и channels.php оставляем в routes.

Создаем файл admin.php внутри routes/web. Этот файл будет содержать все наши веб-маршруты, связанные с администратором, а затем создайте там user.php, для маршрутов связанных с пользователем.

w-8369tz1opyfobrkwhiq0ocdts.png

app/Providers/RouteServiceProvider.php — этот файл отвечает за загрузку всех маршрутов нашего приложения. Метод map () вызывает методы mapApiRoutes () и mapWebRoutes () для загрузки файлов web.php и api.php, которые мы уже переместили, поэтому давайте исправим пути к файлам маршрутов.

protected function mapWebRoutes()
{
    Route::middleware('web')
         ->namespace($this->namespace)
         ->group(base_path('routes/web/web.php'));
}
protected function mapApiRoutes()
{
    Route::prefix('api')
         ->middleware('api')
         ->namespace($this->namespace)
         ->group(base_path('routes/api/api.php'));
}


Теперь создайте новые методы для routes/web/admin.php и routes/web/user.php внутри RouteServiceProvider.php

protected function mapAdminWebRoutes()
{
    Route::middleware('web')
        ->namespace($this->namespace)
        ->prefix('admin')
        ->group(base_path('routes/web/admin.php'));
}
protected function mapUserWebRoutes()
{
    Route::middleware('web')
        ->namespace($this->namespace)
        ->prefix('user')
        ->group(base_path('routes/web/user.php'));
}


Обратите внимание, что в данном коде возможно добавлять для путей namespace, middleware, prefix и т.д.


Далее просто вызываем их из map ():

public function map()
{
    $this->mapApiRoutes();
    $this->mapWebRoutes();
    $this->mapAdminWebRoutes();
    $this->mapUserWebRoutes();
}


Последний шаг:

Откройте routes/web/user.php и добавьте тестовый маршрут:

Route::get('/test', function () {
    return response('Тестовый маршрут', 200);
});


Перейти по адресу site.local/user/test, вы должны увидеть текст «Тестовый маршрут».

© Habrahabr.ru