<?php namespace Bixo\Shop\Providers; use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; use Bixo\Shop\Models\ServiceKit; use Bixo\Shop\Models\Accessory; use Bixo\Shop\Models\SparePart; use Request; use Route; class RouteServiceProvider extends ServiceProvider { /** * This namespace is applied to the controller routes in your routes file. * * In addition, it is set as the URL generator's root namespace. * * @var string */ protected $namespace = 'Bixo\Shop\Http\Controllers'; /** * Define your route model bindings, pattern filters, etc. * * @param \Illuminate\Routing\Router $router * @return void */ public function boot() { parent::boot(); if (Request::is('*/shop/service_kit/*')) { Route::bind('service_kit', function ($service_kit) { return ServiceKit::findorNew($service_kit); }); } if (Request::is('*/shop/accessory/*')) { Route::bind('accessory', function ($accessory) { return Accessory::findorNew($accessory); }); } if (Request::is('*/shop/spare_part/*')) { Route::bind('spare_part', function ($spare_part) { return SparePart::findorNew($spare_part); }); } } /** * Define the routes for the package. * * @return void */ public function map() { $this->mapWebRoutes(); $this->mapApiRoutes(); } /** * Define the "web" routes for the package. * * These routes all receive session state, CSRF protection, etc. * * @return void */ protected function mapWebRoutes() { Route::group([ 'middleware' => 'web', 'namespace' => $this->namespace, ], function ($router) { require (__DIR__ . '/../../routes/web.php'); }); } /** * Define the "api" routes for the package. * * These routes are typically stateless. * * @return void */ protected function mapApiRoutes() { Route::group([ 'middleware' => 'api', 'namespace' => $this->namespace, 'prefix' => 'api', ], function ($router) { require (__DIR__ . '/../../routes/api.php'); }); } }