mirror of
				https://github.com/searxng/searxng.git
				synced 2025-11-04 03:27:06 -05:00 
			
		
		
		
	Replaces `x_for` functionality with `trusted_proxies`. This allows defining which IP / ranges to trust extracting the client IP address from X-Forwarded-For and X-Real-IP headers. We don't know if the proxy chain will give us the proper client address (REMOTE_ADDR in the WSGI environment), so we rely on reading the headers of the proxy before SearXNG (if there is one, in that case it must be added to trusted_proxies) hoping it has done the proper checks. In case a proxy in the chain does not check the client address correctly, integrity is compromised and this should be fixed by whoever manages the proxy, not us. Closes: - https://github.com/searxng/searxng/issues/4940 - https://github.com/searxng/searxng/issues/4939 - https://github.com/searxng/searxng/issues/4907 - https://github.com/searxng/searxng/issues/3632 - https://github.com/searxng/searxng/issues/3191 - https://github.com/searxng/searxng/issues/1237 Related: - https://github.com/searxng/searxng-docker/issues/386 - https://github.com/inetol-infrastructure/searxng-container/issues/81
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# SPDX-License-Identifier: AGPL-3.0-or-later
 | 
						|
"""
 | 
						|
Method ``http_accept_encoding``
 | 
						|
-------------------------------
 | 
						|
 | 
						|
The ``http_accept_encoding`` method evaluates a request as the request of a
 | 
						|
bot if the Accept-Encoding_ header ..
 | 
						|
 | 
						|
- did not contain ``gzip`` AND ``deflate`` (if both values are missed)
 | 
						|
- did not contain ``text/html``
 | 
						|
 | 
						|
.. _Accept-Encoding:
 | 
						|
   https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept-Encoding
 | 
						|
 | 
						|
"""
 | 
						|
 | 
						|
from __future__ import annotations
 | 
						|
from ipaddress import (
 | 
						|
    IPv4Network,
 | 
						|
    IPv6Network,
 | 
						|
)
 | 
						|
 | 
						|
import werkzeug
 | 
						|
import flask
 | 
						|
 | 
						|
from . import config
 | 
						|
from ._helpers import too_many_requests
 | 
						|
 | 
						|
 | 
						|
def filter_request(
 | 
						|
    network: IPv4Network | IPv6Network,
 | 
						|
    request: flask.Request,
 | 
						|
    cfg: config.Config,  # pylint: disable=unused-argument
 | 
						|
) -> werkzeug.Response | None:
 | 
						|
 | 
						|
    accept_list = [l.strip() for l in request.headers.get('Accept-Encoding', '').split(',')]
 | 
						|
    if not ('gzip' in accept_list or 'deflate' in accept_list):
 | 
						|
        return too_many_requests(network, "HTTP header Accept-Encoding did not contain gzip nor deflate")
 | 
						|
    return None
 |