diff options
author | Markus Heiser <markus.heiser@darmarit.de> | 2023-08-03 11:14:20 +0200 |
---|---|---|
committer | Markus Heiser <markus.heiser@darmarIT.de> | 2023-08-03 16:23:36 +0200 |
commit | 207fcc0c8c6caedb7189694ce0957c4992fdb3c9 (patch) | |
tree | 57319bed4a753cf739d981fbfa7fc049f86a323d /searx/engines/piped.py | |
parent | ef5831cd848b276449f57173120e1e86cb573541 (diff) | |
download | searxng-207fcc0c8c6caedb7189694ce0957c4992fdb3c9.tar.gz searxng-207fcc0c8c6caedb7189694ce0957c4992fdb3c9.zip |
[mod] engine piped: add paging support
Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
Diffstat (limited to 'searx/engines/piped.py')
-rw-r--r-- | searx/engines/piped.py | 39 |
1 files changed, 34 insertions, 5 deletions
diff --git a/searx/engines/piped.py b/searx/engines/piped.py index 7f6902777..af1cba379 100644 --- a/searx/engines/piped.py +++ b/searx/engines/piped.py @@ -32,6 +32,18 @@ named `piped` and are used by all piped engines shortcut: ppdm piped_filter: music_songs ... + +Known Quirks +============ + +The implementation to support :py:obj:`paging <searx.enginelib.Engine.paging>` +is based on the *nextpage* method of Piped's REST API / the :py:obj:`frontend +API <frontend_url>`. This feature is *next page driven* and plays well with the +:ref:`infinite_scroll <settings ui>` setting in SearXNG but it does not really +fit into SearXNG's UI to select a page by number. + +Implementations +=============== """ from __future__ import annotations @@ -54,7 +66,7 @@ about = { # engine dependent config categories = [] -paging = False +paging = True # search-url backend_url: list | str = "https://pipedapi.kavin.rocks" @@ -95,18 +107,29 @@ def _frontend_url() -> str: def request(query, params): - query = urlencode({'q': query}) - params["url"] = _backend_url() + f"/search?{query}&filter={piped_filter}" + args = { + 'q': query, + 'filter': piped_filter, + } + path = "/search" + if params['pageno'] > 1: + # don't use nextpage when user selected to jump back to page 1 + nextpage = params['engine_data'].get('nextpage') + if nextpage: + path = "/nextpage/search" + args['nextpage'] = nextpage + + params["url"] = _backend_url() + f"{path}?" + urlencode(args) return params def response(resp): results = [] - search_results = resp.json()["items"] + json = resp.json() - for result in search_results: + for result in json["items"]: publishedDate = parser.parse(time.ctime(result.get("uploaded", 0) / 1000)) item = { @@ -132,4 +155,10 @@ def response(resp): results.append(item) + results.append( + { + "engine_data": json["nextpage"], + "key": "nextpage", + } + ) return results |