dxdo / proxy-detection
PSR-7 Middleware that determines the scheme, host and port from the 'X-Forwarded-Proto', 'X-Forwarded-Host' and 'X-Forwarded-Port' headers and updates the Request's Uri object.
Requires
- psr/http-message: ^1.0
Requires (Dev)
- php: >=5.6
- phpunit/phpunit: ^5
- squizlabs/php_codesniffer: ^2.3
- zendframework/zend-diactoros: ^1.1
This package is not auto-updated.
Last update: 2024-11-14 14:51:33 UTC
README
PSR-7 Middleware that determines the scheme, host and port from the 'X-Forwarded-Proto', 'X-Forwarded-Host' and 'X-Forwarded-Port' headers and updates the Request's Uri object.
You can set a list of proxies that are trusted as the second constructor parameter. If this list is set, then the proxy headers will only be checked if the REMOTE_ADDR
is in the trusted list.
Based on akrabat/proxy-detection-middleware
. It uses PHPUnit 5 and supports PHP 5.6.
Installation
composer require wellingguzman/proxy-detection
Usage
In Slim 3:
$trustedProxies = ['10.0.0.1', '10.0.0.2']; $app->add(new RKA\Middleware\ProxyDetection($trustedProxies)); $app->get('/', function ($request, $response, $args) { $scheme = $request->getUri()->getScheme(); $host = $request->getUri()->getHost(); $port = $request->getUri()->getPort(); return $response; });
Testing
- Code coverage:
$ vendor/bin/phpcs
- Unit tests:
$ vendor/bin/phpunit
- Code coverage:
$ vendor/bin/phpunit --coverage-html ./build