2017-11-19 15:56:06 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace BookStack\Http\Middleware;
|
|
|
|
|
2017-12-07 19:46:25 +00:00
|
|
|
use Closure;
|
2017-11-19 15:56:06 +00:00
|
|
|
use Fideloper\Proxy\TrustProxies as Middleware;
|
2018-09-25 16:58:03 +01:00
|
|
|
use Illuminate\Http\Request;
|
2017-11-19 15:56:06 +00:00
|
|
|
|
|
|
|
class TrustProxies extends Middleware
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The trusted proxies for this application.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $proxies;
|
|
|
|
|
|
|
|
/**
|
2019-09-06 22:14:39 +01:00
|
|
|
* The headers that should be used to detect proxies.
|
2017-11-19 15:56:06 +00:00
|
|
|
*
|
2019-09-06 22:14:39 +01:00
|
|
|
* @var int
|
2017-11-19 15:56:06 +00:00
|
|
|
*/
|
2019-09-06 22:14:39 +01:00
|
|
|
protected $headers = Request::HEADER_X_FORWARDED_ALL;
|
2017-12-07 19:46:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle the request, Set the correct user-configured proxy information.
|
|
|
|
* @param Request $request
|
|
|
|
* @param Closure $next
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function handle($request, Closure $next)
|
|
|
|
{
|
|
|
|
$setProxies = config('app.proxies');
|
|
|
|
if ($setProxies !== '**' && $setProxies !== '*' && $setProxies !== '') {
|
|
|
|
$setProxies = explode(',', $setProxies);
|
|
|
|
}
|
|
|
|
$this->proxies = $setProxies;
|
|
|
|
|
|
|
|
return parent::handle($request, $next);
|
|
|
|
}
|
2017-11-19 15:56:06 +00:00
|
|
|
}
|