| 
									
										
										
										
											2024-11-16 03:51:04 +00:00
										 |  |  | import asyncio | 
					
						
							|  |  |  | import logging | 
					
						
							|  |  |  | import warnings | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import chainlit as cl  # type: ignore [reportUnknownMemberType] # This dependency is installed through instructions | 
					
						
							|  |  |  | from _agents import MessageChunk, UIAgent | 
					
						
							|  |  |  | from _types import AppConfig, GroupChatMessage, RequestToSpeak | 
					
						
							|  |  |  | from _utils import get_serializers, load_config, set_all_log_levels | 
					
						
							| 
									
										
										
										
											2024-12-03 17:00:44 -08:00
										 |  |  | from autogen_core import ( | 
					
						
							| 
									
										
										
										
											2024-11-16 03:51:04 +00:00
										 |  |  |     TypeSubscription, | 
					
						
							|  |  |  | ) | 
					
						
							| 
									
										
										
										
											2024-12-04 16:23:20 -08:00
										 |  |  | from autogen_ext.runtimes.grpc import GrpcWorkerAgentRuntime | 
					
						
							| 
									
										
										
										
											2024-11-16 03:51:04 +00:00
										 |  |  | from chainlit import Message  # type: ignore [reportAttributeAccessIssue] | 
					
						
							|  |  |  | from rich.console import Console | 
					
						
							|  |  |  | from rich.markdown import Markdown | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | set_all_log_levels(logging.ERROR) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | message_chunks: dict[str, Message] = {}  # type: ignore [reportUnknownVariableType] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | async def send_cl_stream(msg: MessageChunk) -> None: | 
					
						
							|  |  |  |     if msg.message_id not in message_chunks: | 
					
						
							|  |  |  |         message_chunks[msg.message_id] = Message(content="", author=msg.author) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if not msg.finished: | 
					
						
							|  |  |  |         await message_chunks[msg.message_id].stream_token(msg.text)  # type: ignore [reportUnknownVariableType] | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         await message_chunks[msg.message_id].stream_token(msg.text)  # type: ignore [reportUnknownVariableType] | 
					
						
							|  |  |  |         await message_chunks[msg.message_id].update()  # type: ignore [reportUnknownMemberType] | 
					
						
							|  |  |  |         await asyncio.sleep(3) | 
					
						
							|  |  |  |         cl_msg = message_chunks[msg.message_id]  # type: ignore [reportUnknownVariableType] | 
					
						
							|  |  |  |         await cl_msg.send()  # type: ignore [reportUnknownMemberType] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | async def main(config: AppConfig): | 
					
						
							|  |  |  |     set_all_log_levels(logging.ERROR) | 
					
						
							| 
									
										
										
										
											2024-12-04 16:23:20 -08:00
										 |  |  |     ui_agent_runtime = GrpcWorkerAgentRuntime(host_address=config.host.address) | 
					
						
							| 
									
										
										
										
											2024-11-16 03:51:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ui_agent_runtime.add_message_serializer(get_serializers([RequestToSpeak, GroupChatMessage, MessageChunk]))  # type: ignore[arg-type] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Console().print(Markdown("Starting **`UI Agent`**")) | 
					
						
							| 
									
										
										
										
											2025-02-12 16:40:52 -05:00
										 |  |  |     await ui_agent_runtime.start() | 
					
						
							| 
									
										
										
										
											2024-11-16 03:51:04 +00:00
										 |  |  |     set_all_log_levels(logging.ERROR) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ui_agent_type = await UIAgent.register( | 
					
						
							|  |  |  |         ui_agent_runtime, | 
					
						
							|  |  |  |         "ui_agent", | 
					
						
							|  |  |  |         lambda: UIAgent( | 
					
						
							|  |  |  |             on_message_chunk_func=send_cl_stream, | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     await ui_agent_runtime.add_subscription( | 
					
						
							|  |  |  |         TypeSubscription(topic_type=config.ui_agent.topic_type, agent_type=ui_agent_type.type) | 
					
						
							|  |  |  |     )  # TODO: This could be a great example of using agent_id to route to sepecific element in the ui. Can replace MessageChunk.message_id | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     await ui_agent_runtime.stop_when_signal() | 
					
						
							|  |  |  |     Console().print("UI Agent left the chat!") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @cl.on_chat_start  # type: ignore | 
					
						
							|  |  |  | async def start_chat(): | 
					
						
							|  |  |  |     set_all_log_levels(logging.ERROR) | 
					
						
							|  |  |  |     warnings.filterwarnings("ignore", category=UserWarning, message="Resolved model mismatch.*") | 
					
						
							|  |  |  |     asyncio.run(main(load_config())) |