
Pydantic AI Documentation Server
Provides programmatic access to Pydantic-AI documentation as an MCP server, enabling retrieval of specific documents, listing of topics, and access to changelog information.
README
Pydantic AI Documentation Server
Overview
This server provides programmatic access to the Pydantic-AI documentation, including cloning/updating the documentation repository, retrieving specific documents, listing documentation topics, and accessing changelog information. It operates as a Model Context Protocol (MCP) server, exposing its functionalities as tools.
Note: This is primarily for personal use and requires cloning the repository and using the update tool to keep the documentation up to date.
Features
The server exposes the following tools via MCP:
update_documentation(force_clone: bool = False)
: Clones the Pydantic-AI repository (if not already present) or pulls the latest updates. Ifforce_clone
is true, it will delete any existing repository and clone fresh.get_document_by_path(path: str)
: Retrieves a specific documentation file by its path relative to thedocs/
directory (e.g.,usage/models.md
).list_topics(path: Optional[str] = None)
: Lists files and directories within the Pydantic-AIdocs/
directory. If apath
is provided, it lists contents of that subdirectory.list_available_changelogs()
: Lists all available changelog files found in the Pydantic-AI repository (typically underdocs/history/
).get_changelog_content(path: str)
: Retrieves the content of a specific changelog file (e.g.,history/0.2.0.md
).
Setup
-
Clone this repository:
git clone <repository_url> # Replace <repository_url> with the actual URL of this server's repository cd pydantic-ai-docs-server
-
Create and activate a Python virtual environment: It's recommended to use Python 3.12 or newer. Using
python -m venv
:python -m venv .venv source .venv/bin/activate # On Windows use: .venv\Scripts\activate
Alternatively, using
uv
:uv venv .venv source .venv/bin/activate # On Windows use: .venv\Scripts\activate
-
Install dependencies: This project uses
uv
for fast package management, butpip
can also be used.uv pip install -e . # Or, if you don't have uv: # pip install -e .
This installs the package in editable mode along with its dependencies specified in
pyproject.toml
.
Running the Server
Once the setup is complete, you can run the server using the script installed by pip install -e .
, or by running the module directly:
pydantic-ai-docs-server
Or:
python -m pydantic_ai_docs_server
The server will start and listen for MCP requests over standard input/output (stdio).
Using the Server
This application is an MCP server designed to communicate over standard input/output (stdio) using newline-delimited JSON messages. To interact with it, you would typically use an MCP client library or tool that can manage this communication channel. However, you can also interact with it directly by sending and receiving the raw JSON messages if you are developing a client or for testing purposes.
Interaction Protocol:
- You send a JSON request object on a single line to the server's stdin.
- The server processes the request and sends a JSON response object on a single line to its stdout.
Common MCP Request Types:
-
Listing Available Tools (
list-tools
)To ask the server what tools it provides, send a JSON message like this:
{"type": "list-tools"}
The server will respond with a JSON object containing a list of available tools and their schemas.
-
Calling a Tool (
call-tool
)To execute a specific tool, send a JSON message like this:
{"type": "call-tool", "tool_name": "<tool_name_here>", "tool_args": {"<arg_name>": "<value>", ...}}
Example: Calling
update_documentation
{"type": "call-tool", "tool_name": "update_documentation", "tool_args": {"force_clone": false}}
Example: Calling
get_document_by_path
{"type": "call-tool", "tool_name": "get_document_by_path", "tool_args": {"path": "usage/models.md"}}
Example: Calling
list_topics
(no arguments){"type": "call-tool", "tool_name": "list_topics", "tool_args": {}}
The server will respond with a JSON object containing the result of the tool execution or an error if something went wrong.
Refer to the Model Context Protocol specification for more details on the message formats and protocol. The tools available on this server are defined in pydantic_ai_docs_server/server.py
.
Integration with MCP Clients (e.g., Cursor)
To use this server with an MCP client application like Cursor, you need to configure it in the client's MCP settings file. For Cursor, this is typically a file named .cursor/mcp.json
located in your project root.
.cursor/mcp.json
Configuration:
Add or update the mcpServers
section in your .cursor/mcp.json
as follows. This configuration uses uv
to run the server module from the specified project directory.
{
"mcpServers": {
"pydantic-ai-docs": {
"command": "uv",
"args": [
"--directory",
"/path/to/your/pydantic-ai-docs-server",
"run",
"-m",
"pydantic_ai_docs_server"
]
}
}
}
Key points for this configuration:
"pydantic-ai-docs"
: This is a name you assign to this server configuration. Your MCP client (e.g., Cursor) will use this name to identify and communicate with this server."command": "uv"
: Specifies thatuv
should be used to launch the server."args"
: Defines the arguments passed touv
:"--directory"
: Instructsuv
to operate as if it were launched from the specified directory. Replace/path/to/your/pydantic-ai-docs-server
with the actual absolute path to the root of thispydantic-ai_docs_server
project on your system. This is critical for the server to correctly locate its internal modules and the cloned documentation repository."run"
: Theuv
command to execute a project."-m"
,"pydantic_ai_docs_server"
: Tellsuv run
to execute thepydantic_ai_docs_server
package as a module (which runs its__main__.py
file).
Ensure your virtual environment (created with uv venv
or python -m venv
) is active, or that uv
is installed globally and can find the project's environment when the MCP client starts the server.
Once configured, your MCP client should be able to discover and call the tools provided by this server (e.g., PyDanticAIDocs.update_documentation
).
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.