.oO SearXNG Developer Documentation Oo.
Loading...
Searching...
No Matches
searx.engines.mozhi Namespace Reference

Functions

 request (_query, params)
 
EngineResults response (resp)
 

Variables

dict about
 
str engine_type = 'online_dictionary'
 
list categories = ['general', 'translate']
 
str base_url = "https://mozhi.aryak.me"
 
str mozhi_engine = "google"
 
str re_transliteration_unsupported = "Direction '.*' is not supported"
 

Detailed Description

Mozhi (alternative frontend for popular translation engines)

Function Documentation

◆ request()

searx.engines.mozhi.request ( _query,
params )

Definition at line 28 of file mozhi.py.

28def request(_query, params):
29 request_url = random.choice(base_url) if isinstance(base_url, list) else base_url
30
31 args = {'from': params['from_lang'][1], 'to': params['to_lang'][1], 'text': params['query'], 'engine': mozhi_engine}
32 params['url'] = f"{request_url}/api/translate?{urllib.parse.urlencode(args)}"
33 return params
34
35

◆ response()

EngineResults searx.engines.mozhi.response ( resp)

Definition at line 36 of file mozhi.py.

36def response(resp) -> EngineResults:
37 res = EngineResults()
38 translation = resp.json()
39
40 item = res.types.Translations.Item(text=translation['translated-text'])
41
42 if translation['target_transliteration'] and not re.match(
43 re_transliteration_unsupported, translation['target_transliteration']
44 ):
45 item.transliteration = translation['target_transliteration']
46
47 if translation['word_choices']:
48 for word in translation['word_choices']:
49 if word.get('definition'):
50 item.definitions.append(word['definition'])
51
52 for example in word.get('examples_target', []):
53 item.examples.append(re.sub(r"<|>", "", example).lstrip('- '))
54
55 item.synonyms = translation.get('source_synonyms', [])
56
57 url = urllib.parse.urlparse(resp.search_params["url"])
58 # remove the api path
59 url = url._replace(path="", fragment="").geturl()
60 res.add(res.types.Translations(translations=[item], url=url))
61 return res

Variable Documentation

◆ about

dict searx.engines.mozhi.about
Initial value:
1= {
2 "website": 'https://codeberg.org/aryak/mozhi',
3 "wikidata_id": None,
4 "official_api_documentation": 'https://mozhi.aryak.me/api/swagger/index.html',
5 "use_official_api": True,
6 "require_api_key": False,
7 "results": 'JSON',
8}

Definition at line 10 of file mozhi.py.

◆ base_url

str searx.engines.mozhi.base_url = "https://mozhi.aryak.me"

Definition at line 22 of file mozhi.py.

◆ categories

list searx.engines.mozhi.categories = ['general', 'translate']

Definition at line 20 of file mozhi.py.

◆ engine_type

str searx.engines.mozhi.engine_type = 'online_dictionary'

Definition at line 19 of file mozhi.py.

◆ mozhi_engine

str searx.engines.mozhi.mozhi_engine = "google"

Definition at line 23 of file mozhi.py.

◆ re_transliteration_unsupported

str searx.engines.mozhi.re_transliteration_unsupported = "Direction '.*' is not supported"

Definition at line 25 of file mozhi.py.