49 lines
2.4 KiB
Python
49 lines
2.4 KiB
Python
|
|
import argparse
|
||
|
|
import logging
|
||
|
|
from vibe.orchestrator import process_articles
|
||
|
|
from vibe.tts import text_to_speech
|
||
|
|
from vibe.config import DEFAULT_ARXIV_URL, DEFAULT_LLM_URL, DEFAULT_MODEL_NAME
|
||
|
|
|
||
|
|
logging.basicConfig(
|
||
|
|
level=logging.DEBUG, format="%(asctime)s - %(levelname)s - %(message)s"
|
||
|
|
)
|
||
|
|
logger = logging.getLogger(__name__)
|
||
|
|
|
||
|
|
def main():
|
||
|
|
parser = argparse.ArgumentParser(description="vibe: Article Summarization & TTS Pipeline")
|
||
|
|
parser.add_argument("--serve", action="store_true", help="Run as a Flask server.")
|
||
|
|
parser.add_argument("--generate", action="store_true", help="Run the pipeline once and generate a summary MP3, then exit.")
|
||
|
|
parser.add_argument("--prompt", type=str, default="", help="User info for LLM filtering & summaries.")
|
||
|
|
parser.add_argument("--max-articles", type=int, default=5, help="Maximum articles to process in the pipeline.")
|
||
|
|
parser.add_argument("--new-only", action="store_true", help="Only process articles newer than cached.")
|
||
|
|
parser.add_argument("--arxiv-url", type=str, default=DEFAULT_ARXIV_URL, help="URL for fetching arXiv articles.")
|
||
|
|
parser.add_argument("--llm-url", type=str, default=DEFAULT_LLM_URL, help="URL of the LLM endpoint.")
|
||
|
|
parser.add_argument("--model-name", type=str, default=DEFAULT_MODEL_NAME, help="Name of model to pass to the LLM endpoint.")
|
||
|
|
parser.add_argument("--output", type=str, default="final_output.mp3", help="Output path for the generated MP3 file.")
|
||
|
|
|
||
|
|
args = parser.parse_args()
|
||
|
|
|
||
|
|
if args.serve:
|
||
|
|
from vibe.server import app
|
||
|
|
logger.info("Starting Flask server.")
|
||
|
|
app.run(debug=True)
|
||
|
|
elif args.generate:
|
||
|
|
logger.info("Running pipeline in CLI mode.")
|
||
|
|
user_info = args.prompt
|
||
|
|
final_summary = process_articles(user_info, arxiv_url=args.arxiv_url, llm_url=args.llm_url, model_name=args.model_name, max_articles=args.max_articles, new_only=args.new_only)
|
||
|
|
if not final_summary.strip():
|
||
|
|
logger.error("No summaries generated.")
|
||
|
|
exit(1)
|
||
|
|
try:
|
||
|
|
text_to_speech(final_summary, args.output)
|
||
|
|
logger.info(f"Generated MP3 at: {args.output}")
|
||
|
|
except Exception as e:
|
||
|
|
logger.exception("TTS conversion failed: %s", e)
|
||
|
|
exit(1)
|
||
|
|
else:
|
||
|
|
logger.info("No mode specified; defaulting to Flask server.")
|
||
|
|
from vibe.server import app
|
||
|
|
app.run(debug=True)
|
||
|
|
|
||
|
|
if __name__ == "__main__":
|
||
|
|
main()
|