Clarify MCP Server
Enables AI agents to ask clarification questions and receive structured user input through a Human-in-the-Loop interface.
README
Clarify MCP Server
A minimal Model Context Protocol (MCP) server that enables AI agents to ask clarification questions and receive structured user input through a simple Human-in-the-Loop interface.
Overview
This MCP server exposes a single tool ask_clarification that allows AI agents to ask structured questions and receive user input via MCP elicitation. It's compatible with MCP clients like Cursor, VS Code, Claude Desktop, and other MCP-enabled tools.
DEMO VIDEO:
Features
- Simple Question-Answer Interface: Ask clarification questions and get concise answers
- Multiple Choice Support: Optionally provide predefined choices for users to select from
- Cross-Client Compatibility: Works with various MCP clients through adaptive elicitation strategies
- Pydantic Integration: Uses Pydantic models for structured data validation
Installation
Prerequisites
- Python 3.8 or higher
uvpackage manager (recommended) orpip
Using uv (Recommended)
# Create virtual environment
uv venv
# Activate virtual environment
source .venv/bin/activate # On Linux/macOS
# or
.venv\Scripts\activate # On Windows
# Install dependencies
uv pip install fastmcp pydantic
Using pip
# Create virtual environment
python -m venv .venv
# Activate virtual environment
source .venv/bin/activate # On Linux/macOS
# or
.venv\Scripts\activate # On Windows
# Install dependencies
pip install fastmcp pydantic
Usage
Running the Server
The server runs using stdio transport for local MCP client integration:
python hitl_server.py
Client Configuration
Register this server in your MCP-enabled client configuration. The exact configuration varies by client:
Cursor
Add to your Cursor MCP configuration (typically in settings):
{
"mcpServers": {
"mcp-clarify": {
"command": "python",
"args": ["/absolute/path/to/hitl_server.py"],
"transport": "stdio"
}
}
}
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or equivalent on other platforms:
{
"mcpServers": {
"mcp-clarify": {
"command": "python",
"args": ["/absolute/path/to/hitl_server.py"]
}
}
}
VS Code with MCP Extension
Configure through the MCP extension settings, pointing to the server executable.
Tool Reference
ask_clarification
Ask a single clarification question and capture a concise answer.
Parameters:
prompt(string, required): The human-visible question to askchoices(list of strings, optional): Suggested answers for selection
Returns:
JSON object with fields:
{
"question": "The original question text",
"answer": "User's answer"
}
Example Usage in AI Agent:
# Simple question
result = await ask_clarification(
prompt="What is the target latency SLA for this API?"
)
# Multiple choice question
result = await ask_clarification(
prompt="Which environment should we deploy to?",
choices=["development", "staging", "production"]
)
How It Works
- Question Elicitation: The server uses FastMCP's elicitation capabilities to present questions to the user
- Schema Generation: When choices are provided, generates JSON schemas with enums for client-side rendering
- Answer Parsing: Handles various response formats including numeric selection ("1", "2") and text matching
- Cross-SDK Compatibility: Tries multiple elicitation signatures to work across different FastMCP versions
Development
Project Structure
mcp-clarify/
├── hitl_server.py # Main server implementation
├── README.md # This file
├── requirements.txt # Python dependencies
├── pyproject.toml # Python project metadata
├── LICENSE # MIT License
├── CONTRIBUTING.md # Contribution guidelines
├── CODE_OF_CONDUCT.md # Code of conduct
├── SECURITY.md # Security policy
└── .github/ # GitHub-specific files
├── workflows/ # CI/CD workflows
├── ISSUE_TEMPLATE/ # Issue templates
└── PULL_REQUEST_TEMPLATE.md
Running Tests
# Install test dependencies
pip install pytest pytest-asyncio
# Run tests (if implemented)
pytest
Contributing
Contributions are welcome! Please ensure your code:
- Follows PEP 8 style guidelines
- Includes appropriate error handling
- Works across different MCP client implementations
- Maintains backward compatibility with existing integrations
Compatibility
- Python: 3.8+
- MCP SDK: Compatible with various FastMCP versions through adaptive signatures
- Pydantic: Supports both v1 and v2 with compatibility shims
- Clients: Tested with Cursor, Claude Desktop, and VS Code MCP extension
Troubleshooting
Server Not Starting
- Ensure all dependencies are installed:
pip install fastmcp pydantic - Check Python version:
python --version(should be 3.8+) - Verify the virtual environment is activated
Client Can't Connect
- Ensure the path in client configuration points to the correct
hitl_server.pylocation - Use absolute paths in configuration files
- Check that Python is available in the PATH when the client launches the server
Elicitation Not Working
- Verify your MCP client supports elicitation (check client documentation)
- Try with a simpler question first (no choices parameter)
- Check client logs for error messages
License
MIT License - See LICENSE file for details
Support
For issues and questions:
- Open an issue on GitHub
- Check existing issues for similar problems
- Review the MCP specification for protocol details
Contributing
Contributions are welcome! Please read our Contributing Guidelines and Code of Conduct before submitting pull requests.
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.