Source code for autogen_core.base._agent

from typing import Any, Mapping, Protocol, runtime_checkable

from ._agent_id import AgentId
from ._agent_metadata import AgentMetadata
from ._message_context import MessageContext


[docs] @runtime_checkable class Agent(Protocol): @property def metadata(self) -> AgentMetadata: """Metadata of the agent.""" ... @property def id(self) -> AgentId: """ID of the agent.""" ...
[docs] async def on_message(self, message: Any, ctx: MessageContext) -> Any: """Message handler for the agent. This should only be called by the runtime, not by other agents. Args: message (Any): Received message. Type is one of the types in `subscriptions`. ctx (MessageContext): Context of the message. Returns: Any: Response to the message. Can be None. Raises: asyncio.CancelledError: If the message was cancelled. CantHandleException: If the agent cannot handle the message. """ ...
[docs] def save_state(self) -> Mapping[str, Any]: """Save the state of the agent. The result must be JSON serializable.""" ...
[docs] def load_state(self, state: Mapping[str, Any]) -> None: """Load in the state of the agent obtained from `save_state`. Args: state (Mapping[str, Any]): State of the agent. Must be JSON serializable. """ ...