loading…
Search for a command to run...
loading…
A command-line chat interface that connects to an MCP server for reading and editing documents. It provides tools for document manipulation, resource access, an
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.
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.
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:
The client implements the full MCP client session, including tool calls, resource reads, prompt retrieval, and command autocompletion.
Starting from a course starter pack, I implemented the missing pieces on both sides:
read_resource, list_prompts, and get_prompt on the clientdocs://documents and docs://documents/{doc_id}) on the serverformat and summarize) that instruct the model to use the available toolsThe 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.
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
uv pip install -e .
.env file in the project root:ANTHROPIC_API_KEY="your-key-here"
uv run main.py
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.
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.
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
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"mcp-chat-cli": {
"command": "npx",
"args": []
}
}
}