diff options
author | Bnyro <bnyro@tutanota.com> | 2024-12-27 20:12:02 +0100 |
---|---|---|
committer | Markus Heiser <markus.heiser@darmarIT.de> | 2025-01-06 13:46:13 +0100 |
commit | 0642c5434a26f9483a935389dedbe1209d21e23a (patch) | |
tree | fedaaca080fc2870365d4dc7c43c3404f4a9f12a | |
parent | 18c3e088374b997352cf5856fdddb6d89b6fef14 (diff) | |
download | searxng-0642c5434a26f9483a935389dedbe1209d21e23a.tar.gz searxng-0642c5434a26f9483a935389dedbe1209d21e23a.zip |
[fix] dockerhub: switch to new api path
Co-authored-by: Markus Heiser <markus.heiser@darmarit.de>
-rw-r--r-- | searx/engines/docker_hub.py | 36 |
1 files changed, 24 insertions, 12 deletions
diff --git a/searx/engines/docker_hub.py b/searx/engines/docker_hub.py index 5963ee2c5..021c05827 100644 --- a/searx/engines/docker_hub.py +++ b/searx/engines/docker_hub.py @@ -19,14 +19,17 @@ about = { categories = ['it', 'packages'] # optional paging = True -base_url = "https://hub.docker.com/" -search_url = base_url + "api/content/v1/products/search?{query}&type=image&page_size=25" +base_url = "https://hub.docker.com" +page_size = 10 def request(query, params): - - params['url'] = search_url.format(query=urlencode(dict(q=query, page=params["pageno"]))) - params["headers"]["Search-Version"] = "v3" + args = { + "query": query, + "from": page_size * (params['pageno'] - 1), + "size": page_size, + } + params['url'] = f"{base_url}/api/search/v3/catalog/search?{urlencode(args)}" return params @@ -36,23 +39,32 @@ def response(resp): resp: requests response object ''' results = [] - body = resp.json() + json_resp = resp.json() + + for item in json_resp.get("results", []): + image_source = item.get("source") + is_official = image_source in ["store", "official"] + + popularity_infos = [f"{item.get('star_count', 0)} stars"] - for item in body.get("summaries", []): - filter_type = item.get("filter_type") - is_official = filter_type in ["store", "official"] + architectures = [] + for rate_plan in item.get("rate_plans", []): + pull_count = rate_plan.get("repositories", [{}])[0].get("pull_count") + if pull_count: + popularity_infos.insert(0, f"{pull_count} pulls") + architectures.extend(arch['name'] for arch in rate_plan.get("architectures", []) if arch['name']) result = { 'template': 'packages.html', - 'url': base_url + ("_/" if is_official else "r/") + item.get("slug", ""), + 'url': base_url + ("/_/" if is_official else "/r/") + item.get("slug", ""), 'title': item.get("name"), 'content': item.get("short_description"), 'thumbnail': item["logo_url"].get("large") or item["logo_url"].get("small"), 'package_name': item.get("name"), 'maintainer': item["publisher"].get("name"), 'publishedDate': parser.parse(item.get("updated_at") or item.get("created_at")), - 'popularity': item.get("pull_count", "0") + " pulls", - 'tags': [arch['name'] for arch in item["architectures"]], + 'popularity': ', '.join(popularity_infos), + 'tags': architectures, } results.append(result) |