Skip to content

Instantly share code, notes, and snippets.

@pferreirafabricio
Created June 11, 2024 23:50
Show Gist options
  • Save pferreirafabricio/39d96e57391cc3128367632c33907f3b to your computer and use it in GitHub Desktop.
Save pferreirafabricio/39d96e57391cc3128367632c33907f3b to your computer and use it in GitHub Desktop.
Setup rate limit IP whitelist in Laravel 8 application
<?php
namespace App\Providers;
use Illuminate\Cache\RateLimiting\Limit;
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\RateLimiter;
use Illuminate\Support\Facades\Route;
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 = '/home';
/**
* The controller namespace for the application.
*
* When present, controller route declarations will automatically be prefixed with this namespace.
*
* @var string|null
*/
// protected $namespace = 'App\\Http\\Controllers';
/**
* Define your route model bindings, pattern filters, etc.
*
* @return void
*/
public function boot()
{
$this->configureRateLimiting();
$this->routes(function () {
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->group(base_path('routes/api.php'));
Route::middleware('web')
->namespace($this->namespace)
->group(base_path('routes/web.php'));
});
}
/**
* Configure the rate limiters for the application.
*
* @return void
*/
protected function configureRateLimiting()
{
RateLimiter::for('api', function (Request $request) {
$whiteListIps = env('RATE_LIMITER_IP_WHITELIST', '');
if (in_array($request->ip(), explode(',', $whiteListIps))) {
return Limit::none();
}
return Limit::perMinute(60)->by(optional($request->user())->id ?: $request->ip());
});
}
}
@pferreirafabricio
Copy link
Author

Example in .env file:

RATE_LIMITER_IP_WHITELIST="127.0.0.1,localhost"

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment