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