From 12af23d98ad79a9706ff9c6dc81a4c86bdd71447 Mon Sep 17 00:00:00 2001 From: Florian Strzelecki Date: Fri, 9 Jul 2021 23:15:39 +0200 Subject: [PATCH] translate: catch requests exceptions --- sopel/modules/translate.py | 37 +++++++++++++++++++++++++++++++++++-- 1 file changed, 35 insertions(+), 2 deletions(-) diff --git a/sopel/modules/translate.py b/sopel/modules/translate.py index 8d09eb9778..07cb1a8078 100644 --- a/sopel/modules/translate.py +++ b/sopel/modules/translate.py @@ -9,6 +9,7 @@ from __future__ import generator_stop import json +import logging import random import requests @@ -17,6 +18,7 @@ from sopel.tools import web +LOGGER = logging.getLogger(__name__) PLUGIN_OUTPUT_PREFIX = '[translate] ' @@ -64,6 +66,9 @@ def translate(text, in_lang='auto', out_lang='en'): try: data = json.loads(result) except ValueError: + LOGGER.error( + 'Error parsing JSON response from translate API (%s to %s: "%s")', + in_lang, out_lang, text) return None, None if raw: @@ -100,7 +105,21 @@ def tr(bot, trigger): bot.reply('Language guessing failed, so try suggesting one!') return - msg, in_lang = translate(phrase, in_lang, out_lang) + try: + msg, in_lang = translate(phrase, in_lang, out_lang) + except requests.Timeout: + bot.reply("Translation service unavailable (timeout).") + LOGGER.error( + 'Translate API error (%s to %s: "%s"): timeout.', + in_lang, out_lang, phrase) + return + except requests.RequestException as http_error: + bot.reply("Failed to request the translation service.") + LOGGER.exception( + 'Translate API error (%s to %s: "%s"): %s.', + in_lang, out_lang, phrase, http_error) + return + if not in_lang: bot.reply("Translation failed, probably because of a rate-limit.") return @@ -164,7 +183,21 @@ def langcode(p): bot.reply('Language guessing failed, so try suggesting one!') return - msg, src = translate(phrase, src, dest) + try: + msg, src = translate(phrase, src, dest) + except requests.Timeout: + bot.reply("Translation service unavailable (timeout).") + LOGGER.error( + 'Translate API error (%s to %s: "%s"): timeout.', + src, dest, phrase) + return + except requests.RequestException as http_error: + bot.reply("Failed to request the translation service.") + LOGGER.exception( + 'Translate API error (%s to %s: "%s"): %s.', + src, dest, phrase, http_error) + return + if not src: return bot.say("Translation failed, probably because of a rate-limit.")