Source code for autogen_core._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]
    async def save_state(self) -> Mapping[str, Any]:
        """Save the state of the agent. The result must be JSON serializable."""
        ... 
[docs]
    async 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.
        """
        ... 
[docs]
    async def close(self) -> None:
        """Called when the runtime is closed"""
        ...