Download the PHP package maxr/firewall without Composer
On this page you can find all versions of the php package maxr/firewall. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download maxr/firewall
More information about maxr/firewall
Files in maxr/firewall
Informations about the package firewall
Firewall 2.2
Purpose
This a "soft-firewall" package. Its purpose is to help people prevent unauthorized access to routes by IP address. It is able to keep track of IPs, countries and hosts (dynamic ip), and redirect non-authorized users to, for instance, a "Coming Soon" page, while letting whitelisted IPs to have access to the entire site. It is now also able to detect and block attacks (too many requests) from single IPs or whole countries.
This package can prevent some headaches and help you block some access to your apps, but cannot replace firewalls and appliances, for attacks at the network level, you'll still need a real firewall.
Features
- Control access to routes and groups via black and white lists.
- Detect and block attacks to your application, from IP addresses or countries.
- Send Slack notifications in attack events.
- Allow whitelisted to access the whole site and send everyone else to a "coming soon page".
- Redirect blacklisted users to some other page.
- Use database or arrays to store IP lists.
- Whitelist your development machine using a dynamic DNS host name.
- Done using middleware, so you can protect/unprotect groups of routes.
- All features are available for hosts, IP addresses, ranges of IP addresses and whole countries.
- Super fast, less than 10ms increase in each request.
- Highly configurable.
Concepts
Blacklist
All IP addresses in those lists will no be able to access routes filtered by the blacklist filter.
Whitelist
Those IP addresses, ranges or countries can
- Access blacklisted routes even if they are in a range of blacklisted IP addresses.
- Access 'allow whitelisted' filtered routes.
- If a route is filtered by the 'allow whitelisted' filter and the IP is not whitelisted, the request will be redirected to an alternative url or route name.
Attack Detection
Firewall is able to detect simple attacks to your page, by counting requests from the same IP or country. Just enable it on your config/firewall.php
and, to receive notifications, configure the Slack service in config/services.php
:
and add the route notification method to your user model:
IPs lists
IPs (white and black) lists can be stored in array, files and database. Initially database access to lists is disabled, so, to test your Firewall configuration you can publish the config file and edit the blacklist
or whitelist
arrays:
The file (for instance /usr/bin/firewall/blacklisted.txt
) must contain one IP, range or file name per line, and, yes, it will search for files recursivelly, so you can have a file of files if you need:
Redirecting non-whitelisted IP addresses
Non-whitelisted IP addresses can be blocked or redirected. To configure redirection you'll have to publish the config.php
file and configure:
Artisan Commands
You have access to the following commands:
Global
When database is enabled
Those are results from firewall:list
:
Facade
You can also use the Firewall Facade
to manage the lists:
Return a blocking access response:
Suspicious events will be (if you wish) logged, so tail
it:
Blocking Whole Countries
You can block a country by, instead of an ip address, pass country:<2-letter ISO code>
. So, to block all Brazil's IP addresses, you do:
You will have to add this requirement to your composer.json
file:
or
You need to enable country search on your firewall.php config file:
And you can schedule this command to update your cities GeoIp database regularly:
You can find those codes here: isocodes
Session Blocking
You can block users from accessing some pages only for the current session, by using those methods:
Playground & Bootstrap App
Click here to see it working and in case you need a help figuring out things, try this repository.
Installation
Compatible with
- Laravel 4+ (version 1.*)
- Laravel 5.0, 5.1, 5.2 and 5.3 (version 1.*)
- Laravel 5.4, 5.5, 5.6 and 5.7 (version 2.*)
Installing
Require the Firewall package using Composer:
-
Laravel 5.5 and up
You don't have to do anything else, this package uses Package Auto-Discovery's feature, and should be available as soon as you install it via Composer.
-
Laravel 5.4 and below
Add the Service Provider and the Facade to your app/config/app.php:
Add middlewares to your app/Http/Kernel.php
or
Then you can use them in your routes:
Or you could use both. In the following example the allow group will give free access to the 'coming soon' page and block or just redirect non-whitelisted IP addresses to another, while still blocking access to the blacklisted ones.
Note: You can add other middleware you have already created to the new groups by simply
adding it to the fw-allow-wl
or fw-block-bl
middleware group.
Migrate your database
Warning: If you already have a Firewall package installed and migrated, you need to update your migration name, in the migrations
table, to 2014_02_01_311070_create_firewall_table
, otherwise the migrate command will fail tell you the table already exists.
To publish the configuration file you'll have to:
Laravel 4
Laravel 5
TODO
- Tests, tests, tests.
Author
License
Firewall is licensed under the BSD 3-Clause License - see the LICENSE
file for details
Contributing
Pull requests and issues are more than welcome.