2015-07-12 15:01:42 -04:00
|
|
|
<?php
|
|
|
|
|
2023-05-17 12:56:55 -04:00
|
|
|
namespace BookStack\App\Providers;
|
2015-07-12 15:01:42 -04:00
|
|
|
|
2023-11-17 08:45:57 -05:00
|
|
|
use BookStack\Facades\Theme;
|
|
|
|
use BookStack\Theming\ThemeEvents;
|
2021-10-30 16:29:59 -04:00
|
|
|
use Illuminate\Cache\RateLimiting\Limit;
|
2015-07-12 15:01:42 -04:00
|
|
|
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
|
2021-10-30 16:29:59 -04:00
|
|
|
use Illuminate\Http\Request;
|
2023-11-17 08:45:57 -05:00
|
|
|
use Illuminate\Routing\Router;
|
2021-10-30 16:29:59 -04:00
|
|
|
use Illuminate\Support\Facades\RateLimiter;
|
2021-09-26 10:37:55 -04:00
|
|
|
use Illuminate\Support\Facades\Route;
|
2015-07-12 15:01:42 -04:00
|
|
|
|
|
|
|
class RouteServiceProvider extends ServiceProvider
|
|
|
|
{
|
2021-10-30 16:29:59 -04:00
|
|
|
/**
|
|
|
|
* 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 15:01:42 -04:00
|
|
|
/**
|
|
|
|
* Define your route model bindings, pattern filters, etc.
|
|
|
|
*/
|
2024-03-16 11:12:14 -04:00
|
|
|
public function boot(): void
|
2015-07-12 15:01:42 -04:00
|
|
|
{
|
2021-10-30 16:29:59 -04:00
|
|
|
$this->configureRateLimiting();
|
2015-07-12 15:01:42 -04:00
|
|
|
|
2021-10-30 16:29:59 -04:00
|
|
|
$this->routes(function () {
|
|
|
|
$this->mapWebRoutes();
|
|
|
|
$this->mapApiRoutes();
|
|
|
|
});
|
2016-09-17 13:22:04 -04:00
|
|
|
}
|
2021-06-26 11:23:15 -04:00
|
|
|
|
2016-09-17 13:22:04 -04:00
|
|
|
/**
|
|
|
|
* Define the "web" routes for the application.
|
|
|
|
*
|
|
|
|
* These routes all receive session state, CSRF protection, etc.
|
|
|
|
*/
|
2024-03-16 11:12:14 -04:00
|
|
|
protected function mapWebRoutes(): void
|
2016-09-17 13:22:04 -04:00
|
|
|
{
|
|
|
|
Route::group([
|
|
|
|
'middleware' => 'web',
|
2021-06-26 11:23:15 -04:00
|
|
|
'namespace' => $this->namespace,
|
2023-11-17 08:45:57 -05:00
|
|
|
], function (Router $router) {
|
2016-09-17 13:22:04 -04:00
|
|
|
require base_path('routes/web.php');
|
2023-11-17 08:45:57 -05:00
|
|
|
Theme::dispatch(ThemeEvents::ROUTES_REGISTER_WEB, $router);
|
|
|
|
});
|
|
|
|
|
|
|
|
Route::group([
|
|
|
|
'middleware' => ['web', 'auth'],
|
|
|
|
], function (Router $router) {
|
|
|
|
Theme::dispatch(ThemeEvents::ROUTES_REGISTER_WEB_AUTH, $router);
|
2016-09-17 13:22:04 -04:00
|
|
|
});
|
|
|
|
}
|
2021-06-26 11:23:15 -04:00
|
|
|
|
2016-09-17 13:22:04 -04:00
|
|
|
/**
|
|
|
|
* Define the "api" routes for the application.
|
|
|
|
*
|
|
|
|
* These routes are typically stateless.
|
|
|
|
*/
|
2024-03-16 11:12:14 -04:00
|
|
|
protected function mapApiRoutes(): void
|
2015-07-12 15:01:42 -04:00
|
|
|
{
|
2016-09-17 13:22:04 -04:00
|
|
|
Route::group([
|
|
|
|
'middleware' => 'api',
|
2021-06-26 11:23:15 -04:00
|
|
|
'namespace' => $this->namespace . '\Api',
|
|
|
|
'prefix' => 'api',
|
2016-09-17 13:22:04 -04:00
|
|
|
], function ($router) {
|
|
|
|
require base_path('routes/api.php');
|
2015-07-12 15:01:42 -04:00
|
|
|
});
|
|
|
|
}
|
2021-10-30 16:29:59 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Configure the rate limiters for the application.
|
|
|
|
*/
|
2024-03-16 11:12:14 -04:00
|
|
|
protected function configureRateLimiting(): void
|
2021-10-30 16:29:59 -04:00
|
|
|
{
|
|
|
|
RateLimiter::for('api', function (Request $request) {
|
2023-02-06 11:58:29 -05:00
|
|
|
return Limit::perMinute(60)->by($request->user()?->id ?: $request->ip());
|
2021-10-30 16:29:59 -04:00
|
|
|
});
|
2024-05-20 09:00:58 -04:00
|
|
|
|
|
|
|
RateLimiter::for('public', function (Request $request) {
|
|
|
|
return Limit::perMinute(10)->by($request->ip());
|
|
|
|
});
|
2021-10-30 16:29:59 -04:00
|
|
|
}
|
2015-07-12 15:01:42 -04:00
|
|
|
}
|