mirror of
https://github.com/microsoft/autogen.git
synced 2025-07-13 12:01:04 +00:00

* Update tool use examples to use inner agents rather than subclassing * fix * Merge remote-tracking branch 'origin/main' into ekzhu-update-tool-use-example
87 lines
3.1 KiB
Python
87 lines
3.1 KiB
Python
"""
|
|
This example show case how to intercept the tool execution using
|
|
intervention hanlder.
|
|
The intervention handler is used to intercept the FunctionCall message
|
|
before it is sent out, and prompt the user for permission to execute the tool.
|
|
"""
|
|
|
|
import asyncio
|
|
import os
|
|
import sys
|
|
from typing import Any, List
|
|
|
|
from agnext.application import SingleThreadedAgentRuntime
|
|
from agnext.components import FunctionCall
|
|
from agnext.components.code_executor import LocalCommandLineCodeExecutor
|
|
from agnext.components.models import SystemMessage
|
|
from agnext.components.tool_agent import ToolAgent, ToolException
|
|
from agnext.components.tools import PythonCodeExecutionTool, Tool
|
|
from agnext.core import AgentId
|
|
from agnext.core.intervention import DefaultInterventionHandler, DropMessage
|
|
|
|
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), "..")))
|
|
|
|
from coding_direct import Message, ToolUseAgent
|
|
from common.utils import get_chat_completion_client_from_envs
|
|
|
|
|
|
class ToolInterventionHandler(DefaultInterventionHandler):
|
|
async def on_send(self, message: Any, *, sender: AgentId | None, recipient: AgentId) -> Any | type[DropMessage]:
|
|
if isinstance(message, FunctionCall):
|
|
# Request user prompt for tool execution.
|
|
user_input = input(
|
|
f"Function call: {message.name}\nArguments: {message.arguments}\nDo you want to execute the tool? (y/n): "
|
|
)
|
|
if user_input.strip().lower() != "y":
|
|
raise ToolException(content="User denied tool execution.", call_id=message.id)
|
|
return message
|
|
|
|
|
|
async def main() -> None:
|
|
# Create the runtime with the intervention handler.
|
|
runtime = SingleThreadedAgentRuntime(intervention_handler=ToolInterventionHandler())
|
|
# Define the tools.
|
|
tools: List[Tool] = [
|
|
# A tool that executes Python code.
|
|
PythonCodeExecutionTool(
|
|
LocalCommandLineCodeExecutor(),
|
|
)
|
|
]
|
|
# Register agents.
|
|
tool_executor_agent = await runtime.register_and_get(
|
|
"tool_executor_agent",
|
|
lambda: ToolAgent(
|
|
description="Tool Executor Agent",
|
|
tools=tools,
|
|
),
|
|
)
|
|
tool_use_agent = await runtime.register_and_get(
|
|
"tool_enabled_agent",
|
|
lambda: ToolUseAgent(
|
|
description="Tool Use Agent",
|
|
system_messages=[SystemMessage("You are a helpful AI Assistant. Use your tools to solve problems.")],
|
|
model_client=get_chat_completion_client_from_envs(model="gpt-4o-mini"),
|
|
tool_schema=[tool.schema for tool in tools],
|
|
tool_agent=tool_executor_agent,
|
|
),
|
|
)
|
|
|
|
run_context = runtime.start()
|
|
|
|
# Send a task to the tool user.
|
|
response = await runtime.send_message(
|
|
Message("Run the following Python code: print('Hello, World!')"), tool_use_agent
|
|
)
|
|
print(response.content)
|
|
|
|
# Run the runtime until the task is completed.
|
|
await run_context.stop()
|
|
|
|
|
|
if __name__ == "__main__":
|
|
import logging
|
|
|
|
logging.basicConfig(level=logging.WARNING)
|
|
logging.getLogger("agnext").setLevel(logging.DEBUG)
|
|
asyncio.run(main())
|