michaelnabil230 / laravel-block-ip
This package is for controlling everything related to website visits using the Laravel framework
Requires
- php: ^8.1
- illuminate/contracts: ^10.0
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- laravel/pint: ^1.10
- laravel/slack-notification-channel: ^2.5
- nunomaduro/collision: ^7
- nunomaduro/larastan: ^2.6.0
- orchestra/testbench: ^8.5.5
- pestphp/pest: ^2.6.2
- pestphp/pest-plugin-arch: ^2.2
- pestphp/pest-plugin-laravel: ^2.0.0
- phpstan/extension-installer: ^1.3.1
- phpstan/phpstan-deprecation-rules: ^1.1.3
- phpstan/phpstan-phpunit: ^1.3.13
- phpunit/phpunit: ^10.2
This package is auto-updated.
Last update: 2024-10-08 00:59:12 UTC
README
The Laravel Block IP package provides a convenient way to control everything related to website visits using the Laravel framework. It allows you to block specific IP addresses, configure rate limiting, and receive notifications for certain events.
Installation
You can install the package via Composer by running the following command:
composer require michaelnabil230/laravel-block-ip
After installing the package, you need to publish the package files and run the migrations:
php artisan block-ip:install php artisan migrate
To publish and run the migrations separately, you can use the following commands:
php artisan vendor:publish --tag="laravel-block-ip-migrations"
php artisan migrate
You can also publish the package's configuration file using the following command:
php artisan vendor:publish --tag="laravel-block-ip-config"
The published configuration file allows you to customize various settings related to block IP functionality, notifications, caching, and more.
Usage
To configure rate limiting and use the package's functionality, you can add code to your app/Providers/RouteServiceProvider.php
file. The following code demonstrates how to configure rate limiting and enable the package:
protected function configureRateLimiting() { RateLimiter::for('api', function (Request $request) { return Limit::perMinute(60)->by($request->user()?->id ?: $request->ip()); }); \MichaelNabil230\BlockIp\BlockIpRegistrar::rateLimiter(); }
By default, the rate limiter is set to allow 60 requests per minute, but you can customize this value by passing it to the rateLimiter()
method.
The package provides a BlockIpMiddleware
middleware that you can add to your routes in the app/Http/Kernel.php
file. Make sure to uncomment the necessary line for the throttle
middleware as well. Here's an example:
protected $middlewareAliases = [ // ... 'block-ip' => \MichaelNabil230\BlockIp\Middleware\BlockIpMiddleware::class, ];
To protect your routes using the block IP middleware and rate limiting, you can define them as follows:
Route::middleware(['block-ip', 'throttle:block-ip'])->group(function () { // Your protected routes here });
If you want to unblock all IP addresses, you can use the following command:
php artisan block-ip:unblock --all
You can also unblock multiple IP addresses by providing them as a comma-separated list:
php artisan block-ip:unblock --ips=127.0.0.1,127.0.0.2
To block new IP addresses, you can use the following command:
php artisan block-ip:block 127.0.0.1 127.0.0.2
Support
If you find this package useful, you can show your support by contributing financially:
Testing
You can run the package's tests using the following command:
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.