laravel-threat-blocker maintained by keepsuit
Description
Block threat request to your application
Author
Last update
2026/04/20 05:46
(dev-dependabot/github_actions/dependabot/fetch-metadata-3.1.0)
License
Downloads
1 030
Tags
Block threat request to your application
Laravel Threat Blocker is a package to block threat requests to your Laravel application based on different rules.
Installation
You can install the package via composer:
composer require keepsuit/laravel-threat-blocker
You can publish the config file with:
php artisan vendor:publish --tag="laravel-threat-blocker-config"
This is the contents of the published config file:
return [
/**
* This option enables or disables the Threat Blocker protection.
*/
'enabled' => env('THREAT_BLOCKER_ENABLED', true),
/**
* Storage driver to use for caching detectors data.
*/
'storage_driver' => env('THREAT_BLOCKER_STORAGE_DRIVER', 'cache'),
'storage' => [
'cache' => [
'store' => env('THREAT_BLOCKER_CACHE_STORE', env('CACHE_STORE', 'file')),
'prefix' => env('THREAT_BLOCKER_CACHE_PREFIX', 'threat_blocker'),
],
],
/**
* The following list of "detectors" will be used to identify threats.
* You can enable or disable each detector individually and configure their settings.
*/
'detectors' => [
/**
* Block requests coming from IPs listed in the AbuseIPDB database.
*/
\Keepsuit\ThreatBlocker\Detectors\AbuseIpDetector::class => [
'enabled' => env('THREAT_BLOCKER_ABUSE_IP_DETECTOR_ENABLED', true),
// Source url for AbuseIP data, it can be a custom url or one of the predefined sources (provided by https://github.com/borestad/blocklist-abuseipdb)
'source' => \Keepsuit\ThreatBlocker\Enums\AbuseIpSource::Days30->url(),
'blacklist' => [
// These IPs will always be blocked by the AbuseIpDetector
],
'whitelist' => [
// These IPs will never be blocked by the AbuseIpDetector
'127.0.0.1',
],
],
/**
* Block requests that contain form submissions with honeypot fields filled out.
* This detector requires spatie/laravel-honeypot package to be installed and configured.
*/
\Keepsuit\ThreatBlocker\Detectors\FormHoneypotDetector::class => [
'enabled' => env('THREAT_BLOCKER_FORM_HONEYPOT_DETECTOR_ENABLED', true),
],
],
];
Usage
-
Add the
ProtectAgainstThreatsmiddleware to routes you want to protect:use Keepsuit\ThreatBlocker\Middleware\ProtectAgainstThreats; Route::post('contact', [ContactController::class, 'submit'])->middleware(ProtectAgainstThreats::class); -
Run the update command to warm the detectors cache:
php artisan threat-blocker:update -
Schedule the update command to run periodically (e.g., daily) using Laravel's task scheduling:
$schedule->command('threat-blocker:update')->daily();
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.