mozhi.py 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. """Mozhi (alternative frontend for popular translation engines)"""
  3. import random
  4. import re
  5. from urllib.parse import urlencode
  6. from flask_babel import gettext
  7. about = {
  8. "website": 'https://codeberg.org/aryak/mozhi',
  9. "wikidata_id": None,
  10. "official_api_documentation": 'https://mozhi.aryak.me/api/swagger/index.html',
  11. "use_official_api": True,
  12. "require_api_key": False,
  13. "results": 'JSON',
  14. }
  15. engine_type = 'online_dictionary'
  16. categories = ['general', 'translate']
  17. base_url = "https://mozhi.aryak.me"
  18. mozhi_engine = "google"
  19. re_transliteration_unsupported = "Direction '.*' is not supported"
  20. def request(_query, params):
  21. request_url = random.choice(base_url) if isinstance(base_url, list) else base_url
  22. args = {'from': params['from_lang'][1], 'to': params['to_lang'][1], 'text': params['query'], 'engine': mozhi_engine}
  23. params['url'] = f"{request_url}/api/translate?{urlencode(args)}"
  24. return params
  25. def response(resp):
  26. translation = resp.json()
  27. infobox = ""
  28. if translation['target_transliteration'] and not re.match(
  29. re_transliteration_unsupported, translation['target_transliteration']
  30. ):
  31. infobox = f"<b>{translation['target_transliteration']}</b>"
  32. if translation['word_choices']:
  33. for word in translation['word_choices']:
  34. infobox += f"<dl><dt>{word['word']}: {word['definition']}</dt>"
  35. if word['examples_target']:
  36. for example in word['examples_target']:
  37. infobox += f"<dd>{re.sub(r'<|>', '', example)}</dd>"
  38. infobox += f"<dd>{re.sub(r'<|>', '', example)}</dd>"
  39. infobox += "</dl>"
  40. if translation['source_synonyms']:
  41. infobox += f"<dl><dt>{gettext('Synonyms')}: {', '.join(translation['source_synonyms'])}</dt></dl>"
  42. result = {
  43. 'infobox': translation['translated-text'],
  44. 'content': infobox,
  45. }
  46. return [result]