| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 | 
							- # SPDX-License-Identifier: AGPL-3.0-or-later
 
- """Mozhi (alternative frontend for popular translation engines)"""
 
- import random
 
- import re
 
- import urllib.parse
 
- from searx.result_types import EngineResults
 
- about = {
 
-     "website": 'https://codeberg.org/aryak/mozhi',
 
-     "wikidata_id": None,
 
-     "official_api_documentation": 'https://mozhi.aryak.me/api/swagger/index.html',
 
-     "use_official_api": True,
 
-     "require_api_key": False,
 
-     "results": 'JSON',
 
- }
 
- engine_type = 'online_dictionary'
 
- categories = ['general', 'translate']
 
- base_url = "https://mozhi.aryak.me"
 
- mozhi_engine = "google"
 
- re_transliteration_unsupported = "Direction '.*' is not supported"
 
- def request(_query, params):
 
-     request_url = random.choice(base_url) if isinstance(base_url, list) else base_url
 
-     args = {'from': params['from_lang'][1], 'to': params['to_lang'][1], 'text': params['query'], 'engine': mozhi_engine}
 
-     params['url'] = f"{request_url}/api/translate?{urllib.parse.urlencode(args)}"
 
-     return params
 
- def response(resp) -> EngineResults:
 
-     res = EngineResults()
 
-     translation = resp.json()
 
-     item = res.types.Translations.Item(text=translation['translated-text'])
 
-     if translation['target_transliteration'] and not re.match(
 
-         re_transliteration_unsupported, translation['target_transliteration']
 
-     ):
 
-         item.transliteration = translation['target_transliteration']
 
-     if translation['word_choices']:
 
-         for word in translation['word_choices']:
 
-             if word.get('definition'):
 
-                 item.definitions.append(word['definition'])
 
-             for example in word.get('examples_target', []):
 
-                 item.examples.append(re.sub(r"<|>", "", example).lstrip('- '))
 
-     item.synonyms = translation.get('source_synonyms', [])
 
-     url = urllib.parse.urlparse(resp.search_params["url"])
 
-     # remove the api path
 
-     url = url._replace(path="", fragment="").geturl()
 
-     res.add(res.types.Translations(translations=[item], url=url))
 
-     return res
 
 
  |