Download the PHP package spinen/laravel-browser-filter without Composer
On this page you can find all versions of the php package spinen/laravel-browser-filter. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download spinen/laravel-browser-filter
More information about spinen/laravel-browser-filter
Files in spinen/laravel-browser-filter
Package laravel-browser-filter
Short Description Filters http requests based on browser type.
License MIT
Informations about the package laravel-browser-filter
SPINEN's Laravel Browser Filter
This is a Laravel 5 middleware to filter routes based on browser types.
We specify the browsers that we are going to support at the beginning of a project, so this package makes sure that the visitor is using a supported browser.
Build Status
Branch | Status | Coverage | Code Quality |
---|---|---|---|
Develop | |||
Master |
Prerequisites
NOTE: If you need to use PHP <7.2 or Laravel <5.2, please stay with version 1.x
As side from Laravel >= 5.5, there are 2 packages that are required:
- mobiledetect - To get the user agent string. This package is not needed to get to the user agent string, but there are other features that I plan on using in the future so I kept it installed.
- ua-parser PHP Library - To parse the user agent string
Install
Install Browser Filter:
The package uses the auto registration feature of Laravel 5.
Register the middleware
The middleware needs to be registered with the Kernel to allow it to parse the request.
Laravel 11 & newer
Register the HTTP Stack Middleware for the web group in bootstrap/app.php
:
Register the Route Middlewares in bootstrap/app.php
:
Before Laravel 11
Register the HTTP Stack Middleware for the web group in app/Http/Kernel.php
:
Register the Route Middlewares in app/Http/Kernel.php
:
Page to show if blocked
Build a page with a named route to redirect blocked browsers to:
Configure middleware options
Publish the package config file to config/browserfilter.php
:
This file is fully documented, so please read it to know how to configure the middleware. There are 4 top level items that you can configure...
- type - The type of filtering strategy to apply to the stack filter
- rules - The array of devices/browsers/versions to allow or block for ALL http requests
- route - The name of the route to redirect the user to if they are using a blocked client
- timeout - The length of time to cache the client data, where "0" disables the cache
Using the Route middleware
The route middleware uses the same configuration file as the stack middleware, but ignores the rules.
The rules are passed in after the ':' behind the route filter that you wish to use...
or
The format of the filter is Device/Browser/operatorVersion|operatorVersion2;Device/Browser2/operatorVersion
, so the following rule:
would be written as: Mobile;Other/Ie/<10|>13;Tablet
.
All versions of laravel-browser-filter with dependencies
ext-json Version *
illuminate/cache Version ^9.19|^10|^11
illuminate/routing Version ^9.19|^10|^11
illuminate/support Version ^9.42|^10|^11
mobiledetect/mobiledetectlib Version ~2.8
ua-parser/uap-php Version ~3.9