lingva.py 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. """Lingva (alternative Google Translate frontend)"""
  4. from json import loads
  5. about = {
  6. "website": 'https://lingva.ml',
  7. "wikidata_id": None,
  8. "official_api_documentation": 'https://github.com/thedaviddelta/lingva-translate#public-apis',
  9. "use_official_api": True,
  10. "require_api_key": False,
  11. "results": 'JSON',
  12. }
  13. engine_type = 'online_dictionary'
  14. categories = ['general']
  15. url = "https://lingva.ml"
  16. search_url = "{url}/api/v1/{from_lang}/{to_lang}/{query}"
  17. def request(_query, params):
  18. params['url'] = search_url.format(
  19. url=url, from_lang=params['from_lang'][1], to_lang=params['to_lang'][1], query=params['query']
  20. )
  21. return params
  22. def response(resp):
  23. results = []
  24. result = loads(resp.text)
  25. info = result["info"]
  26. from_to_prefix = "%s-%s " % (resp.search_params['from_lang'][1], resp.search_params['to_lang'][1])
  27. if "typo" in info:
  28. results.append({"suggestion": from_to_prefix + info["typo"]})
  29. if 'definitions' in info: # pylint: disable=too-many-nested-blocks
  30. for definition in info['definitions']:
  31. if 'list' in definition:
  32. for item in definition['list']:
  33. if 'synonyms' in item:
  34. for synonym in item['synonyms']:
  35. results.append({"suggestion": from_to_prefix + synonym})
  36. infobox = ""
  37. for translation in info["extraTranslations"]:
  38. infobox += f"<b>{translation['type']}</b>"
  39. for word in translation["list"]:
  40. infobox += f"<dl><dt>{word['word']}</dt>"
  41. for meaning in word["meanings"]:
  42. infobox += f"<dd>{meaning}</dd>"
  43. infobox += "</dl>"
  44. results.append(
  45. {
  46. 'infobox': result["translation"],
  47. 'content': infobox,
  48. }
  49. )
  50. return results