From 933ce7e0685148033aa92ed4ed03efb0c062a201 Mon Sep 17 00:00:00 2001 From: Ben Busby Date: Wed, 28 Oct 2020 23:02:41 -0400 Subject: [PATCH] Handle FF sending bad search suggestion param Occasionally, Firefox will send the search suggestion string to the server without a mimetype, resulting in the suggestion only appearing in Flask's `request.data` field. This field is typically not used for parsing arguments, as the documentation states: Contains the incoming request data as string in case it came with a mimetype Flask does not handle. This fix captures the bytes object sent to the server and parses it into a normal query to be used in forming suggestions. --- app/routes.py | 4 ++++ app/templates/opensearch.xml | 8 ++++++-- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/app/routes.py b/app/routes.py index 3916c23..d1734a3 100644 --- a/app/routes.py +++ b/app/routes.py @@ -136,6 +136,10 @@ def opensearch(): @app.route('/autocomplete', methods=['GET', 'POST']) def autocomplete(): q = g.request_params.get('q') + if not q: + # FF will occasionally (incorrectly) send the q field without a + # mimetype in the format "b'q='" through the request.data field + q = str(request.data).replace('q=', '') # Search bangs if the query begins with "!", but not "! " (feeling lucky) if q.startswith('!') and len(q) > 1 and not q.startswith('! '): diff --git a/app/templates/opensearch.xml b/app/templates/opensearch.xml index c1d2898..5b533f4 100644 --- a/app/templates/opensearch.xml +++ b/app/templates/opensearch.xml @@ -5,8 +5,12 @@ Whoogle: A lightweight, deployable Google search proxy for desktop/mobile that removes Javascript, AMP links, and ads UTF-8  - - + + + + + + {{ main_url }}/search