Source code for autogen_agentchat.base._chat_agent

from dataclasses import dataclass
from typing import AsyncGenerator, List, Protocol, Sequence, runtime_checkable

from autogen_core.base import CancellationToken

from ..messages import AgentMessage, ChatMessage
from ._task import TaskRunner


[docs] @dataclass(kw_only=True) class Response: """A response from calling :meth:`ChatAgent.on_messages`.""" chat_message: ChatMessage """A chat message produced by the agent as the response.""" inner_messages: List[AgentMessage] | None = None """Inner messages produced by the agent."""
[docs] @runtime_checkable class ChatAgent(TaskRunner, Protocol): """Protocol for a chat agent.""" @property def name(self) -> str: """The name of the agent. This is used by team to uniquely identify the agent. It should be unique within the team.""" ... @property def description(self) -> str: """The description of the agent. This is used by team to make decisions about which agents to use. The description should describe the agent's capabilities and how to interact with it.""" ... @property def produced_message_types(self) -> List[type[ChatMessage]]: """The types of messages that the agent produces.""" ...
[docs] async def on_messages(self, messages: Sequence[ChatMessage], cancellation_token: CancellationToken) -> Response: """Handles incoming messages and returns a response.""" ...
[docs] def on_messages_stream( self, messages: Sequence[ChatMessage], cancellation_token: CancellationToken ) -> AsyncGenerator[AgentMessage | Response, None]: """Handles incoming messages and returns a stream of inner messages and and the final item is the response.""" ...
[docs] async def on_reset(self, cancellation_token: CancellationToken) -> None: """Resets the agent to its initialization state.""" ...