summaryrefslogtreecommitdiff
path: root/searx/engines/duckduckgo.py
diff options
context:
space:
mode:
Diffstat (limited to 'searx/engines/duckduckgo.py')
-rw-r--r--searx/engines/duckduckgo.py10
1 files changed, 7 insertions, 3 deletions
diff --git a/searx/engines/duckduckgo.py b/searx/engines/duckduckgo.py
index a7226043b..36125556b 100644
--- a/searx/engines/duckduckgo.py
+++ b/searx/engines/duckduckgo.py
@@ -6,7 +6,7 @@ DuckDuckGo Lite
from typing import TYPE_CHECKING
import re
-from urllib.parse import urlencode, quote_plus
+from urllib.parse import urlencode
import json
import babel
import lxml.html
@@ -263,7 +263,7 @@ def request(query, params):
params['url'] = url
params['method'] = 'POST'
- params['data']['q'] = quote_plus(query)
+ params['data']['q'] = query
# The API is not documented, so we do some reverse engineering and emulate
# what https://html.duckduckgo.com/html does when you press "next Page" link
@@ -381,7 +381,11 @@ def response(resp):
zero_click_info_xpath = '//div[@id="zero_click_abstract"]'
zero_click = extract_text(eval_xpath(doc, zero_click_info_xpath)).strip()
- if zero_click and "Your IP address is" not in zero_click and "Your user agent:" not in zero_click:
+ if zero_click and (
+ "Your IP address is" not in zero_click
+ and "Your user agent:" not in zero_click
+ and "URL Decoded:" not in zero_click
+ ):
current_query = resp.search_params["data"].get("q")
results.append(