Spaces:
Sleeping
Sleeping
| from flask import Flask, request, jsonify | |
| from deep_translator import GoogleTranslator | |
| from langdetect import detect, LangDetectException | |
| import logging | |
| from cachetools import TTLCache | |
| import hashlib | |
| app = Flask(__name__) | |
| # Настройка кэширования | |
| cache = TTLCache(maxsize=1024, ttl=86400) # Максимальный размер кэша 1024, срок жизни 24 часа (86400 секунд) | |
| # Настройка логирования | |
| logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s') | |
| def generate_cache_key(text): | |
| """Генерирует ключ для кэша на основе текста.""" | |
| return hashlib.md5(text.encode('utf-8')).hexdigest() | |
| def translate_text(text): | |
| """ | |
| Определяет язык текста и переводит его на английский, если необходимо, | |
| используя кэширование результатов с TTLCache. | |
| Args: | |
| text (str): Текст для перевода. | |
| Returns: | |
| dict: Словарь с результатом перевода или оригинальным текстом, а также информацией об ошибке. | |
| Формат: {"result": "переведенный текст", "original": "исходный текст", "error": null/сообщение об ошибке} | |
| """ | |
| cache_key = generate_cache_key(text) | |
| cached_result = cache.get(cache_key) | |
| if cached_result: | |
| app.logger.info(f"Cache hit for key: {cache_key}") | |
| return cached_result | |
| try: | |
| language = detect(text) | |
| app.logger.info(f"Detected language: {language}") | |
| except LangDetectException as e: | |
| app.logger.error(f"Error detecting language: {e}") | |
| result = {"result": text, "original": text, "error": f"Error detecting language: {e}"} | |
| # cache[cache_key] = result # Кэшируем ошибку | |
| return result | |
| if language != 'en': | |
| try: | |
| translator = GoogleTranslator(source=language, target='en') | |
| translated_text = translator.translate(text) | |
| app.logger.info(f"Translated from {language} to en") | |
| result = {"result": translated_text, "original": text, "error": None} | |
| cache[cache_key] = result # Кэшируем результат | |
| return result | |
| except Exception as e: | |
| app.logger.error(f"Error translating prompt: {e}") | |
| result = {"result": text, "original": text, "error": f"Error translating text: {e}"} | |
| # cache[cache_key] = result # Кэшируем ошибку | |
| return result | |
| else: | |
| app.logger.info("Text is already in English") | |
| result = {"result": text, "original": text, "error": None} | |
| cache[cache_key] = result # Кэшируем результат | |
| return result | |
| def translate_endpoint(): | |
| """ | |
| Эндпоинт для обработки POST запросов. | |
| Ожидает текст в теле запроса и возвращает перевод или оригинал в формате JSON. | |
| """ | |
| if request.is_json: | |
| try: | |
| data = request.get_json() | |
| text = data.get('text') | |
| if not text: | |
| return jsonify({"error": "No text provided in request body"}), 400 | |
| translation_result = translate_text(text) | |
| return jsonify(translation_result), 200 | |
| except Exception as e: | |
| app.logger.error(f"Error processing request: {e}") | |
| return jsonify({"error": f"Error processing request: {e}"}), 500 | |
| else: | |
| return jsonify({"error": "Request must be in json format"}), 400 | |
| if __name__ == '__main__': | |
| app.run(host='0.0.0.0', port=7860, debug=True) |