-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathmain.py
More file actions
58 lines (51 loc) · 2.11 KB
/
main.py
File metadata and controls
58 lines (51 loc) · 2.11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
import asyncio
from workflow.debate_workflow import DebateWorkflow
import os
import logging
from rich.console import Console
from rich.logging import RichHandler
def setup_logging():
console = Console(width=100)
logging.basicConfig(
level=logging.INFO,
format='%(message)s',
handlers=[
RichHandler(
console=console,
show_time=True,
show_level=True,
markup=True,
show_path=False
)
]
)
logging.getLogger("httpx").setLevel(logging.WARNING)
def validate_env():
required_var = "OPENAI_API_KEY"
if not os.getenv(required_var):
raise EnvironmentError(f"Missing environment variable: {required_var}")
async def main():
setup_logging()
validate_env()
logger = logging.getLogger("main")
try:
logger.info("[bold green]Starting debate workflow...[/]")
workflow = DebateWorkflow()
workflow_result = await workflow.run()
final_message = workflow_result["messages"][-1]["content"]
logger.info("\n[bold]━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━[/]")
if "WINNER: PRO" in final_message:
logger.info("[bold green] DEBATE VERDICT[/]")
logger.info("[cyan] %s[/]", final_message.replace("WINNER: PRO", "🏆 [bold]WINNER:[/] [cyan]PRO"))
elif "WINNER: CON" in final_message:
logger.info("[bold green] DEBATE VERDICT[/]")
logger.info("[magenta] %s[/]", final_message.replace("WINNER: CON", "🏆 [bold]WINNER:[/] [magenta]CON"))
else:
logger.info("[yellow] %s[/]", final_message)
logger.info("[bold]━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━[/]\n")
logger.info("[green]Workflow completed successfully | Status: [bold]SUCCESS[/][/]")
except Exception as e:
logger.error("Workflow failed: %s", str(e), exc_info=True)
raise
if __name__ == "__main__":
asyncio.run(main())