httpKernel = $http_kernel; $this->settings = $settings; } /** * {@inheritdoc} */ public function handle(Request $request, $type = self::MAIN_REQUEST, $catch = TRUE): Response { // Initialize proxy settings. static::setSettingsOnRequest($request, $this->settings); return $this->httpKernel->handle($request, $type, $catch); } /** * Sets reverse proxy settings on Request object. * * @param \Symfony\Component\HttpFoundation\Request $request * A Request instance. * @param \Drupal\Core\Site\Settings $settings * The site settings. */ public static function setSettingsOnRequest(Request $request, Settings $settings) { // Initialize proxy settings. if ($settings->get('reverse_proxy', FALSE)) { $proxies = $settings->get('reverse_proxy_addresses', []); if (count($proxies) > 0) { // Set the default value. This is the most relaxed setting possible and // not recommended for production. $trusted_header_set = Request::HEADER_X_FORWARDED_FOR | Request::HEADER_X_FORWARDED_HOST | Request::HEADER_X_FORWARDED_PORT | Request::HEADER_X_FORWARDED_PROTO | Request::HEADER_FORWARDED; $request::setTrustedProxies( $proxies, $settings->get('reverse_proxy_trusted_headers', $trusted_header_set) ); } } } }