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
|