webworld888/app/Providers/RouteServiceProvider.php
2021-10-26 19:14:12 +09:00

111 lines
2.4 KiB
PHP

<?php
/**
* RouteServiceProvider.php
*
* PHP version 7
*
* @category Providers
* @package App\Providers
* @license https://opensource.org/licenses/MIT MIT
* @link https://laravel.com
*/
namespace App\Providers;
use Blade;
use Illuminate\Support\Facades\Route;
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
/**
* Class RouteServiceProvider
*
* @category Providers
* @package App\Providers
* @license https://opensource.org/licenses/MIT MIT
* @link https://laravel.com
*/
class RouteServiceProvider extends ServiceProvider
{
/**
* This namespace is applied to your controller routes.
*
* In addition, it is set as the URL generator's root namespace.
*
* @var string
*/
protected $namespace = 'App\Http\Controllers';
/**
* Define your route model bindings, pattern filters, etc.
*
* @return void
*/
public function boot()
{
parent::boot();
$this->extendBlade();
}
/**
* Define the routes for the application.
*
* @return void
*/
public function map()
{
$this->mapApiRoutes();
$this->mapWebRoutes();
}
/**
* Define the "web" routes for the application.
*
* These routes all receive session state, CSRF protection, etc.
*
* @return void
*/
protected function mapWebRoutes()
{
Route::middleware('web')
->namespace($this->namespace)
->group(base_path('routes/web.php'));
}
/**
* Define the "api" routes for the application.
*
* These routes are typically stateless.
*
* @return void
*/
protected function mapApiRoutes()
{
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->group(base_path('routes/api.php'));
}
/**
* Add the directive for blade template.
*
* @return void
*/
protected function extendBlade()
{
Blade::directive(
'expose_route',
function ($expression) {
return "<?php expose_route($expression); ?>";
}
);
Blade::directive(
'expose_instance_route',
function ($expression) {
return "<?php expose_instance_route($expression); ?>";
}
);
}
}