diff options
author | 0xhtml <34682885+0xhtml@users.noreply.github.com> | 2024-09-29 02:27:57 +0200 |
---|---|---|
committer | Markus Heiser <markus.heiser@darmarIT.de> | 2024-09-29 14:29:22 +0200 |
commit | 0a0fb450b569dfbababd4bfe438b69a3957757ff (patch) | |
tree | f63e77197118d2658d8bc17aded3b13d8fc3ac65 | |
parent | b5009b861050ec139a42dc508c64e6edda1a7684 (diff) | |
download | searxng-0a0fb450b569dfbababd4bfe438b69a3957757ff.tar.gz searxng-0a0fb450b569dfbababd4bfe438b69a3957757ff.zip |
[enh] engine: stract - add language/region support
-rw-r--r-- | searx/engines/stract.py | 36 |
1 files changed, 34 insertions, 2 deletions
diff --git a/searx/engines/stract.py b/searx/engines/stract.py index 751d4da50..ffd475732 100644 --- a/searx/engines/stract.py +++ b/searx/engines/stract.py @@ -7,6 +7,7 @@ ends. from json import dumps from searx.utils import searx_useragent +from searx.enginelib.traits import EngineTraits about = { "website": "https://stract.com/", @@ -18,7 +19,10 @@ about = { categories = ['general'] paging = True -search_url = "https://stract.com/beta/api/search" +base_url = "https://stract.com/beta/api" +search_url = base_url + "/search" + +traits: EngineTraits def request(query, params): @@ -29,7 +33,14 @@ def request(query, params): 'Content-Type': 'application/json', 'User-Agent': searx_useragent(), } - params['data'] = dumps({'query': query, 'page': params['pageno'] - 1}) + region = traits.get_region(params["searxng_locale"], default=traits.all_locale) + params['data'] = dumps( + { + 'query': query, + 'page': params['pageno'] - 1, + 'selectedRegion': region, + } + ) return params @@ -47,3 +58,24 @@ def response(resp): ) return results + + +def fetch_traits(engine_traits: EngineTraits): + # pylint: disable=import-outside-toplevel + from searx import network + from babel import Locale, languages + from searx.locales import region_tag + + territories = Locale("en").territories + + json = network.get(base_url + "/docs/openapi.json").json() + regions = json['components']['schemas']['Region']['enum'] + + engine_traits.all_locale = regions[0] + + for region in regions[1:]: + for code, name in territories.items(): + if region not in (code, name): + continue + for lang in languages.get_official_languages(code, de_facto=True): + engine_traits.regions[region_tag(Locale(lang, code))] = region |