arxiv_audio_summary/vibe/server.py

63 lines
2.2 KiB
Python
Raw Normal View History

2025-03-02 03:28:36 +00:00
from flask import Flask, send_file, request, jsonify, render_template
2025-03-02 03:22:35 +00:00
import logging
2025-03-02 03:53:46 +00:00
from vibe.orchestrator import process_articles
from vibe.config import CACHE_DIR
from flask_socketio import SocketIO, emit
2025-03-02 03:22:35 +00:00
logger = logging.getLogger(__name__)
2025-03-02 03:53:46 +00:00
app = Flask(__name__, template_folder="../templates")
socketio = SocketIO(app)
2025-03-02 03:22:35 +00:00
@app.route("/process", methods=["POST"])
def process_endpoint():
data = request.get_json()
user_info = data.get("user_info", "")
if not user_info:
logger.error("user_info not provided in request.")
return jsonify({"error": "user_info not provided"}), 400
max_articles = data.get("max_articles", 5)
new_only = data.get("new_only", False)
logger.info("Processing request with user_info: %s, max_articles: %s, new_only: %s", user_info, max_articles, new_only)
2025-03-02 03:53:46 +00:00
# Define trace_callback to emit trace messages via WebSockets
def trace_callback(message):
socketio.emit("trace", {"message": message})
2025-03-02 12:47:03 +00:00
final_summary = process_articles(
user_info,
arxiv_url=None,
max_articles=max_articles,
new_only=new_only,
trace_callback=trace_callback,
llm_level="medium" # hard-coded here; could be user-configurable
)
2025-03-02 03:22:35 +00:00
if not final_summary.strip():
logger.error("No summaries generated.")
return jsonify({"error": "No summaries generated."}), 500
2025-03-02 03:53:46 +00:00
import uuid, os
mp3_filename = f"final_{uuid.uuid4().hex}.mp3"
output_mp3 = os.path.join(CACHE_DIR, mp3_filename)
2025-03-02 03:22:35 +00:00
try:
2025-03-02 03:53:46 +00:00
from vibe.tts import text_to_speech
2025-03-02 03:22:35 +00:00
text_to_speech(final_summary, output_mp3)
2025-03-02 03:53:46 +00:00
trace_callback("Text-to-Speech conversion complete. MP3 file generated.")
2025-03-02 03:22:35 +00:00
except Exception as e:
logger.exception("TTS conversion failed: %s", e)
return jsonify({"error": f"TTS conversion failed: {e}"}), 500
logger.info("Process complete. Returning MP3 file.")
return send_file(output_mp3, as_attachment=True)
2025-03-02 03:28:36 +00:00
@app.route("/")
def index():
return render_template("index.html")
2025-03-02 03:53:46 +00:00
@socketio.on("connect")
def handle_connect():
emit("trace", {"message": "Connected to server. Ready to process your request."})
2025-03-02 03:22:35 +00:00
if __name__ == "__main__":
2025-03-02 03:53:46 +00:00
socketio.run(app, debug=True)