MCP Chat CLI
A command-line chat interface that connects to an MCP server for reading and editing documents. It provides tools for document manipulation, resource access, and prompts for formatting and summarization.
README
MCP Chat CLI
A command-line chat interface that connects to an MCP server using the Anthropic API. Built while working through Anthropic's Introduction to Model Context Protocol course, extended with custom tools, resources, and prompts.
What this is
MCP (Model Context Protocol) is an open standard for connecting AI models to external tools and data sources. This project implements both sides of that connection — a FastMCP server that exposes documents as resources and defines tools for reading and editing them, and a client that connects to the server and makes those capabilities available inside a chat interface.
The server defines:
- Tools — read and edit documents
- Resources — list all documents or fetch a specific one by URI
- Prompts — reformat a document to markdown, or summarize its contents
The client implements the full MCP client session, including tool calls, resource reads, prompt retrieval, and command autocompletion.
What I worked through
Starting from a course starter pack, I implemented the missing pieces on both sides:
read_resource,list_prompts, andget_prompton the client- Resource endpoints (
docs://documentsanddocs://documents/{doc_id}) on the server - Two prompts (
formatandsummarize) that instruct the model to use the available tools
The main thing this project made concrete for me is the separation between the server (which defines what's available) and the client (which knows how to call it) — and how prompts are just structured messages that give the model a starting context, not magic.
Prerequisites
- Python 3.9+
- Anthropic API key
Setup
-
Clone the repo and navigate into the project folder.
-
Create a virtual environment and activate it:
uv venv
.venv\Scripts\activate # Windows
source .venv/bin/activate # Mac/Linux
- Install dependencies:
uv pip install -e .
- Create a
.envfile in the project root:
ANTHROPIC_API_KEY="your-key-here"
- Run the app:
uv run main.py
Usage
Type a message to chat. Use @doc_id to include a document in your query, and /command to trigger a prompt. Tab autocompletes available commands.
> Tell me about @deposition.md
> /summarize report.pdf
> /format plan.md
To add your own documents, edit the docs dictionary in mcp_server.py.
Testing the server directly
mcp dev mcp_server.py
This opens the MCP Inspector in your browser where you can test tools, resources, and prompts without the chat interface.
Project structure
mcp_chat_cli/
├── main.py # entrypoint
├── mcp_server.py # FastMCP server — tools, resources, prompts
├── mcp_client.py # MCP client session wrapper
├── core/
│ ├── chat.py # chat loop logic
│ ├── claude.py # Anthropic API integration
│ ├── cli.py # CLI setup and input handling
│ ├── cli_chat.py # connects CLI and chat
│ └── tools.py # tool call handling
├── .env # API key (not committed)
└── pyproject.toml # dependencies
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.