from flask import Flask, render_template, request, jsonify, after_this_request from io import BytesIO import base64 import subprocess import os import random import string import re app = Flask(__name__) # Define the folder where files are saved file_folder = '/home/app/' import logging model_names = { "es_MX-claude-14947-epoch-high.onnx": { "replacements": { ('(', ','), (')', ','), ('?', ','), ('¿', ','), (':', ','), ('\n', ' ') } }, "kamora": { "replacements": { # Define los reemplazos específicos del modelo 2 aquí } }, # Agrega más modelos si es necesario } def filter_text(text, model_name): if model_name in model_names: replacements = model_names[model_name]["replacements"] # Realizar reemplazos específicos del modelo filtered_text = multiple_replace(text, replacements) # Escapar todos los caracteres especiales dentro de las comillas filtered_text = re.sub(r'(["\'])', lambda m: "\\" + m.group(0), filtered_text) return filtered_text else: logging.error(f"No se encontró el modelo '{model_name}'.") return None def convert_text_to_speech(parrafo, model): # Limit text to 500 characters parrafo = parrafo[:100000] parrafo_filtrado = filter_text(parrafo) random_name = ''.join(random.choices(string.ascii_letters + string.digits, k=8)) + '.wav' output_file = os.path.join(file_folder, random_name) app.logger.info("Audio file created at: %s", output_file) piper_exe = os.path.join(file_folder, 'piper') # Adjusted the path for piper if os.path.isfile(piper_exe): comando = f'echo {parrafo_filtrado} | "{piper_exe}" -m {model} -f {output_file}' subprocess.run(comando, shell=True) return output_file else: return "The piper.exe file was not found in the correct directory." @app.route('/') def index(): model_folder = file_folder # Adjusted the model folder to file_folder model_options = [file for file in os.listdir(model_folder) if file.endswith('.onnx')] # Log the contents of the current folder app.logger.info("Contents of current folder: %s", os.listdir(file_folder)) return render_template('index.html', model_options=model_options) @app.route('/convert', methods=['POST']) def convert_text(): text = request.form['text'] model = request.form['model'] output_file = convert_text_to_speech(text, model) @after_this_request def remove_file(response): try: os.remove(output_file) app.logger.info("Audio file deleted: %s", output_file) except Exception as error: app.logger.error("Error deleting file: %s", error) return response with open(output_file, 'rb') as audio_file: audio_content = audio_file.read() audio_base64 = base64.b64encode(audio_content).decode('utf-8') response = jsonify({'audio_base64': audio_base64}) return response if __name__ == '__main__': app.run(host='0.0.0.0', port=7860, debug=False)