summaryrefslogtreecommitdiff
path: root/searx
diff options
context:
space:
mode:
authorBnyro <bnyro@tutanota.com>2024-11-01 10:26:18 +0100
committerMarkus Heiser <markus.heiser@darmarIT.de>2024-11-01 12:49:33 +0100
commitb07c0ae39f087421d9ccd98a0faa5866c3bdb843 (patch)
treee1f17bfdee0eebcef53d2868ac88d45c0528c8e6 /searx
parent56e3d72a763bc71b0d57fe7f1f536209c526360a (diff)
downloadsearxng-b07c0ae39f087421d9ccd98a0faa5866c3bdb843.tar.gz
searxng-b07c0ae39f087421d9ccd98a0faa5866c3bdb843.zip
[fix] annas archive: crash when no thumbnail, differing results, paging
Diffstat (limited to 'searx')
-rw-r--r--searx/engines/annas_archive.py23
1 files changed, 16 insertions, 7 deletions
diff --git a/searx/engines/annas_archive.py b/searx/engines/annas_archive.py
index bc74b3c86..ea1ab42a4 100644
--- a/searx/engines/annas_archive.py
+++ b/searx/engines/annas_archive.py
@@ -34,10 +34,10 @@ Implementations
"""
from typing import List, Dict, Any, Optional
-from urllib.parse import quote
+from urllib.parse import urlencode
from lxml import html
-from searx.utils import extract_text, eval_xpath, eval_xpath_list
+from searx.utils import extract_text, eval_xpath, eval_xpath_getindex, eval_xpath_list
from searx.enginelib.traits import EngineTraits
from searx.data import ENGINE_TRAITS
@@ -53,7 +53,7 @@ about: Dict[str, Any] = {
# engine dependent config
categories: List[str] = ["files"]
-paging: bool = False
+paging: bool = True
# search-url
base_url: str = "https://annas-archive.org"
@@ -99,9 +99,18 @@ def init(engine_settings=None): # pylint: disable=unused-argument
def request(query, params: Dict[str, Any]) -> Dict[str, Any]:
- q = quote(query)
lang = traits.get_language(params["language"], traits.all_locale) # type: ignore
- params["url"] = base_url + f"/search?lang={lang or ''}&content={aa_content}&ext={aa_ext}&sort={aa_sort}&q={q}"
+ args = {
+ 'lang': lang,
+ 'content': aa_content,
+ 'ext': aa_ext,
+ 'sort': aa_sort,
+ 'q': query,
+ 'page': params['pageno'],
+ }
+ # filter out None and empty values
+ filtered_args = dict((k, v) for k, v in args.items() if v)
+ params["url"] = f"{base_url}/search?{urlencode(filtered_args)}"
return params
@@ -128,12 +137,12 @@ def response(resp) -> List[Dict[str, Optional[str]]]:
def _get_result(item):
return {
'template': 'paper.html',
- 'url': base_url + item.xpath('./@href')[0],
+ 'url': base_url + extract_text(eval_xpath_getindex(item, './@href', 0)),
'title': extract_text(eval_xpath(item, './/h3/text()[1]')),
'publisher': extract_text(eval_xpath(item, './/div[contains(@class, "text-sm")]')),
'authors': [extract_text(eval_xpath(item, './/div[contains(@class, "italic")]'))],
'content': extract_text(eval_xpath(item, './/div[contains(@class, "text-xs")]')),
- 'thumbnail': item.xpath('.//img/@src')[0],
+ 'thumbnail': extract_text(eval_xpath_getindex(item, './/img/@src', 0, default=None), allow_none=True),
}