openai-agents-python/examples/mcp/filesystem_example
Rohan Mehta bd47a41d0b
MCP example for SSE (#354)
Simple example with a local SSE server.
2025-03-26 12:56:35 -04:00
..
sample_files [3/n] Add an MCP stdio example 2025-03-25 13:24:18 -04:00
main.py [5/n] MCP tracing 2025-03-25 19:28:48 -04:00
README.md MCP example for SSE (#354) 2025-03-26 12:56:35 -04:00

MCP Filesystem Example

This example uses the filesystem MCP server, running locally via npx.

Run it via:

uv run python  python examples/mcp/filesystem_example/main.py

Details

The example uses the MCPServerStdio class from agents.mcp, with the command:

npx -y "@modelcontextprotocol/server-filesystem" <samples_directory>

It's only given access to the sample_files directory adjacent to the example, which contains some sample data.

Under the hood:

  1. The server is spun up in a subprocess, and exposes a bunch of tools like list_directory(), read_file(), etc.
  2. We add the server instance to the Agent via mcp_agents.
  3. Each time the agent runs, we call out to the MCP server to fetch the list of tools via server.list_tools().
  4. If the LLM chooses to use an MCP tool, we call the MCP server to run the tool via server.run_tool().