2024-06-17 17:54:27 -07:00
|
|
|
import argparse
|
2024-05-15 12:31:13 -04:00
|
|
|
import asyncio
|
2024-06-17 17:54:27 -07:00
|
|
|
import logging
|
2024-05-15 12:31:13 -04:00
|
|
|
from dataclasses import dataclass
|
|
|
|
|
2024-06-04 10:00:05 -04:00
|
|
|
from agnext.application import SingleThreadedAgentRuntime
|
2024-06-05 15:48:14 -04:00
|
|
|
from agnext.components import TypeRoutedAgent, message_handler
|
2024-06-18 14:53:18 -04:00
|
|
|
from agnext.core import AgentId, CancellationToken
|
2024-05-15 12:31:13 -04:00
|
|
|
|
|
|
|
|
|
|
|
@dataclass
|
2024-05-20 13:32:08 -06:00
|
|
|
class MessageType:
|
2024-05-17 14:59:00 -07:00
|
|
|
body: str
|
2024-05-15 12:31:13 -04:00
|
|
|
sender: str
|
|
|
|
|
|
|
|
|
2024-06-09 12:11:36 -07:00
|
|
|
class Inner(TypeRoutedAgent): # type: ignore
|
2024-06-18 14:53:18 -04:00
|
|
|
def __init__(self) -> None: # type: ignore
|
|
|
|
super().__init__("The inner agent")
|
2024-05-15 12:31:13 -04:00
|
|
|
|
2024-06-09 12:11:36 -07:00
|
|
|
@message_handler() # type: ignore
|
|
|
|
async def on_new_message(self, message: MessageType, cancellation_token: CancellationToken) -> MessageType: # type: ignore
|
2024-06-17 10:44:46 -04:00
|
|
|
return MessageType(body=f"Inner: {message.body}", sender=self.metadata["name"])
|
2024-05-15 12:31:13 -04:00
|
|
|
|
|
|
|
|
2024-06-09 12:11:36 -07:00
|
|
|
class Outer(TypeRoutedAgent): # type: ignore
|
2024-06-18 14:53:18 -04:00
|
|
|
def __init__(self, inner: AgentId) -> None: # type: ignore
|
|
|
|
super().__init__("The outer agent")
|
2024-05-15 12:31:13 -04:00
|
|
|
self._inner = inner
|
|
|
|
|
2024-06-09 12:11:36 -07:00
|
|
|
@message_handler() # type: ignore
|
|
|
|
async def on_new_message(self, message: MessageType, cancellation_token: CancellationToken) -> MessageType: # type: ignore
|
2024-06-18 15:51:02 -04:00
|
|
|
inner_response = self.send_message(message, self._inner)
|
2024-05-15 12:31:13 -04:00
|
|
|
inner_message = await inner_response
|
2024-05-23 16:00:05 -04:00
|
|
|
assert isinstance(inner_message, MessageType)
|
2024-06-17 10:44:46 -04:00
|
|
|
return MessageType(body=f"Outer: {inner_message.body}", sender=self.metadata["name"])
|
2024-05-15 12:31:13 -04:00
|
|
|
|
|
|
|
|
|
|
|
async def main() -> None:
|
2024-06-17 15:37:46 -04:00
|
|
|
runtime = SingleThreadedAgentRuntime()
|
2024-06-18 14:53:18 -04:00
|
|
|
inner = runtime.register_and_get("inner", Inner)
|
|
|
|
outer = runtime.register_and_get("outer", lambda: Outer(inner))
|
2024-06-17 15:37:46 -04:00
|
|
|
response = runtime.send_message(MessageType(body="Hello", sender="external"), outer)
|
2024-05-15 12:31:13 -04:00
|
|
|
|
|
|
|
while not response.done():
|
2024-06-17 15:37:46 -04:00
|
|
|
await runtime.process_next()
|
2024-05-15 12:31:13 -04:00
|
|
|
|
|
|
|
print(await response)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2024-06-17 17:54:27 -07:00
|
|
|
parser = argparse.ArgumentParser(description="Inner-Outter agent example.")
|
|
|
|
parser.add_argument("--verbose", action="store_true", help="Enable verbose logging.")
|
|
|
|
args = parser.parse_args()
|
|
|
|
if args.verbose:
|
|
|
|
logging.basicConfig(level=logging.WARNING)
|
|
|
|
logging.getLogger("agnext").setLevel(logging.DEBUG)
|
|
|
|
handler = logging.FileHandler("inner_outter.log")
|
|
|
|
logging.getLogger("agnext").addHandler(handler)
|
2024-05-15 12:31:13 -04:00
|
|
|
asyncio.run(main())
|