1
0
mirror of https://github.com/BookStackApp/BookStack.git synced 2024-11-24 20:02:35 +01:00
BookStack/app/Providers/RouteServiceProvider.php

92 lines
2.2 KiB
PHP
Raw Normal View History

2015-07-12 21:01:42 +02:00
<?php
namespace BookStack\Providers;
2015-07-12 21:01:42 +02:00
use Illuminate\Cache\RateLimiting\Limit;
2015-07-12 21:01:42 +02:00
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\RateLimiter;
use Illuminate\Support\Facades\Route;
2015-07-12 21:01:42 +02:00
class RouteServiceProvider extends ServiceProvider
{
/**
* The path to the "home" route for your application.
*
* This is used by Laravel authentication to redirect users after login.
*
* @var string
*/
public const HOME = '/';
2015-07-12 21:01:42 +02:00
/**
* 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
*/
/**
* Define your route model bindings, pattern filters, etc.
*
* @return void
*/
public function boot()
2015-07-12 21:01:42 +02:00
{
$this->configureRateLimiting();
2015-07-12 21:01:42 +02:00
$this->routes(function () {
$this->mapWebRoutes();
$this->mapApiRoutes();
});
}
2021-06-26 17:23:15 +02:00
/**
* Define the "web" routes for the application.
*
* These routes all receive session state, CSRF protection, etc.
*
* @return void
*/
protected function mapWebRoutes()
{
Route::group([
'middleware' => 'web',
2021-06-26 17:23:15 +02:00
'namespace' => $this->namespace,
], function ($router) {
require base_path('routes/web.php');
});
}
2021-06-26 17:23:15 +02:00
/**
* Define the "api" routes for the application.
*
* These routes are typically stateless.
*
* @return void
*/
protected function mapApiRoutes()
2015-07-12 21:01:42 +02:00
{
Route::group([
'middleware' => 'api',
2021-06-26 17:23:15 +02:00
'namespace' => $this->namespace . '\Api',
'prefix' => 'api',
], function ($router) {
require base_path('routes/api.php');
2015-07-12 21:01:42 +02:00
});
}
/**
* Configure the rate limiters for the application.
*
* @return void
*/
protected function configureRateLimiting()
{
RateLimiter::for('api', function (Request $request) {
return Limit::perMinute(60)->by(optional($request->user())->id ?: $request->ip());
});
}
2015-07-12 21:01:42 +02:00
}