Casual MCP
Casual MCP is a Python framework for building, evaluating, and serving LLMs with tool-calling capabilities using Model Context Protocol (MCP)
Installation
npx casual-mcpAsk AI about Casual MCP
Powered by Claude Β· Grounded in docs
I know everything about Casual MCP. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
Casual MCP
Casual MCP is a Python framework for building, evaluating, and serving LLMs with tool-calling capabilities using Model Context Protocol (MCP).
Features
- Multi-server MCP client using FastMCP
- OpenAI, Ollama, and Anthropic provider support (via casual-llm)
- Recursive tool-calling chat loop
- Toolsets for selective tool filtering per request
- Tool discovery -- defer tool loading and let the LLM search for tools on demand via BM25
- Usage statistics tracking (tokens, tool calls, LLM calls)
- System prompt templating with Jinja2
- CLI and API interfaces
Installation
The base package includes the core framework. Install with the extras for the LLM provider(s) you need:
# Using uv
uv add casual-mcp[openai]
uv add casual-mcp[anthropic]
uv add casual-mcp[ollama]
# Multiple providers
uv add casual-mcp[openai,anthropic]
# All providers
uv add casual-mcp[all]
# Using pip
pip install casual-mcp[openai]
For development:
git clone https://github.com/casualgenius/casual-mcp.git
cd casual-mcp
uv sync --group dev
Quick Start
- Create
casual_mcp_config.json:
{
"clients": {
"openai": { "provider": "openai" }
},
"models": {
"gpt-4.1": { "client": "openai", "model": "gpt-4.1" }
},
"servers": {
"time": { "command": "python", "args": ["mcp-servers/time/server.py"] }
}
}
-
Set your API key:
export OPENAI_API_KEY=your-key -
Start the server:
casual-mcp serve -
Make a request:
curl -X POST http://localhost:8000/chat \
-H "Content-Type: application/json" \
-d '{"model": "gpt-4.1", "messages": [{"role": "user", "content": "What time is it?"}]}'
Configuration
Configure clients, models, MCP servers, and toolsets in casual_mcp_config.json.
{
"clients": {
"openai": { "provider": "openai" }
},
"models": {
"gpt-4.1": { "client": "openai", "model": "gpt-4.1" }
},
"servers": {
"time": { "command": "python", "args": ["server.py"] },
"weather": { "url": "http://localhost:5050/mcp" }
},
"tool_sets": {
"basic": { "description": "Basic tools", "servers": { "time": true } }
}
}
See Configuration Guide for full details on models, servers, toolsets, and templates.
Tool Discovery
When connecting many MCP servers, the combined tool definitions can consume significant context and degrade tool selection accuracy. Tool discovery solves this by deferring tool loading -- instead of sending all tools to the LLM on every call, deferred tools are made available through a search-tools meta-tool that the LLM can invoke on demand.
Add tool_discovery to your config and mark servers with defer_loading:
{
"servers": {
"core-tools": { "command": "python", "args": ["servers/core.py"] },
"research-tools": {
"command": "python",
"args": ["servers/research.py"],
"defer_loading": true
}
},
"tool_discovery": {
"enabled": true,
"defer_all": false,
"max_search_results": 5
}
}
How it works:
- Tools from servers with
defer_loading: trueare held back from the LLM - A
search-toolstool is injected with a compressed manifest of available servers and tools - The LLM calls
search-toolswith a keyword query, server name, or exact tool names - Matched tools are loaded into the active set for the remainder of the conversation
- Set
defer_all: trueto defer all servers without marking each individually
The CLI tools command shows which tools are loaded vs deferred when discovery is enabled. Stats include search_calls and tools_discovered counts.
CLI
casual-mcp serve # Start API server
casual-mcp servers # List configured servers
casual-mcp clients # List configured clients
casual-mcp models # List configured models
casual-mcp toolsets # Manage toolsets interactively
casual-mcp tools # List available tools
casual-mcp migrate-config # Migrate legacy config to new format
See CLI & API Reference for all commands and options.
API
| Endpoint | Description |
|---|---|
POST /chat | Send message history |
GET /toolsets | List available toolsets |
See CLI & API Reference for request/response formats.
Programmatic Usage
from casual_llm import SystemMessage, UserMessage
from casual_mcp import McpToolChat, load_config
config = load_config("casual_mcp_config.json")
async with McpToolChat.from_config(config) as chat:
messages = [
SystemMessage(content="You are a helpful assistant."),
UserMessage(content="What time is it?")
]
response = await chat.chat(messages, model="gpt-4.1")
For full control you can still construct McpToolChat manually β see the Programmatic Usage Guide for details on from_config(), model selection at call time, usage statistics, toolsets, and common patterns.
Examples
The examples/ directory contains runnable scripts organised by feature:
- tool_calling -- basic tool-calling with
McpToolChat, including manual construction - tool_discovery -- deferred tool loading with the
search-toolsmeta-tool - tool_sets -- restricting available tools per request with toolsets
Each subfolder has its own config.json. To run an example:
cd examples/tool_calling
uv run python chat_weather.py
See the examples README for full details.
Architecture
Casual MCP orchestrates LLMs and MCP tool servers in a recursive loop:
βββββββββββββββ ββββββββββββββββ βββββββββββββββ
β MCP Servers βββββββΆβ Tool Cache βββββββΆβ Tool Converterβ
βββββββββββββββ ββββββββββββββββ βββββββββββββββ
β β
βΌ βΌ
ββββββββββββββββββββββββββββββββ
β McpToolChat Loop β
β β
β LLM βββΆ Tool Calls βββΆ MCP β
β β² β β
β βββββββββ Results ββββββ β
ββββββββββββββββββββββββββββββββ
- MCP Client connects to tool servers (local stdio or remote HTTP/SSE)
- Tool Cache fetches and caches tools from all servers
- ModelFactory creates LLM clients and models from casual-llm
- McpToolChat runs the recursive loop until the LLM provides a final answer
Environment Variables
| Variable | Default | Description |
|---|---|---|
{CLIENT_NAME}_API_KEY | - | API key lookup: tries {CLIENT_NAME.upper()}_API_KEY first, falls back to provider default (e.g. OPENAI_API_KEY, ANTHROPIC_API_KEY) |
TOOL_RESULT_FORMAT | result | result, function_result, or function_args_result |
MCP_TOOL_CACHE_TTL | 30 | Tool cache TTL in seconds (0 = indefinite) |
LOG_LEVEL | INFO | Logging level |
Troubleshooting
Common issues and solutions are covered in the Troubleshooting Guide.
