A URL/HTTP-based MCP (Model Context Protocol) server for the AI Phone Agent Platform. This server can be deployed to Railway, Render, Fly.io, or any cloud platform and allows AI assistants (like Claude in Cursor) to interact with your call campaigns via HTTP instead of stdio.
- HTTP/URL-based MCP server using FastMCP
- Cloud-ready deployment with Docker support
- Organization-scoped authentication via API keys
- REST API integration - calls python-server-est API instead of direct imports
- No dependencies on main application code - fully independent deployment
Cursor/Claude Desktop
β (HTTP/HTTPS)
FastMCP Server (this project)
β (REST API calls)
python-server-est API (Railway)
β
Twilio + OpenAI
# Clone or navigate to project
cd python-mcp-est
# Create virtual environment
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install dependencies
pip install -r requirements.txt
# Copy environment template
cp .env.example .env
# Edit .env with your configuration
nano .env
Required environment variables (see .env.example
):
# Organization Authentication
ORGANIZATION_API_KEY=your_api_key_from_org_settings
ORGANIZATION_ID=your_organization_uuid
# API Configuration
API_BASE_URL=https://python-server-est-production.up.railway.app
# Supabase (for API key validation)
SUPABASE_URL=https://your-project.supabase.co
SUPABASE_SERVICE_KEY=your_service_role_key
-
Create new Railway project:
railway login railway init
-
Set environment variables in Railway dashboard:
ORGANIZATION_API_KEY
ORGANIZATION_ID
API_BASE_URL
SUPABASE_URL
SUPABASE_SERVICE_KEY
-
Deploy:
railway up
-
Get your deployment URL:
railway status
Example:
https://python-mcp-est-production.up.railway.app
Edit your Cursor MCP config file (usually ~/.cursor/mcp.json
or workspace .cursor/mcp.json
):
{
"mcpServers": {
"est-call-agent": {
"url": "https://your-mcp-server.railway.app/mcp",
"headers": {
"X-API-Key": "your_organization_api_key"
}
}
}
}
Edit ~/Library/Application Support/Claude/claude_desktop_config.json
(macOS) or equivalent:
{
"mcpServers": {
"est-call-agent": {
"url": "https://your-mcp-server.railway.app/mcp",
"headers": {
"X-API-Key": "your_organization_api_key"
}
}
}
}
Schedule a single outbound call for a specific client at a given time.
Parameters:
campaign_id
(string): Campaign UUIDphone_number
(string): Client number in E.164 formatscheduled_time
(string): ISO 8601 timestamp (campaign timezone respected)first_name
,last_name
,company
,email
,extrainfo
(strings, optional): Metadata stored as contact custom data
Returns: Call ID, scheduled timestamps, and subscription usage details from the API.
Lists all voice agent campaigns for the authenticated organization.
Returns: Array of campaign objects with campaign_id
, name
, status
, campaign_type
, created_at
, and is_active
fields.
Retrieves a single call record from Supabase.
Parameters:
call_id
(string): Supabase call identifier
Returns: Full call JSON when found.
Lists the most recent calls for the organization.
Parameters:
limit
(integer, optional): Number of calls to return (default 25, max 200)
Returns: Array of call records ordered by newest first.
Returns the Twilio phone number configured for the organization.
Returns: twilio_phone_number
string.
Lists inbound client records.
Parameters:
limit
(integer, optional): Number of records to return (default 25, max 200)
Returns: Array of inbound client objects ordered by creation date.
Returns the webhook URL configured for the organization.
Returns: webhook_url
string.
Returns organization members with their name, email, and last login timestamp.
Returns: Array of member objects: { "full_name", "email", "last_login_at" }
.
# Run server
python cloud_mcp_server.py
# Test with curl
curl http://localhost:8000/mcp
The server includes a health check endpoint:
curl https://your-mcp-server.railway.app/health
View logs in Railway:
railway logs
- API Key Authentication: All requests require a valid organization API key
- Organization Scoping: All data is automatically filtered to the authenticated organization
- HTTPS Required: Use HTTPS in production (automatically provided by Railway/Render/Fly)
- Environment Variables: Never commit
.env
file or expose secrets
- Check deployment URL: Ensure the URL in your MCP config matches your deployment
- Verify API key: Check that
ORGANIZATION_API_KEY
is set correctly in both server and client - Check logs: Review Railway/Render logs for error messages
- Validate API base URL: Ensure
API_BASE_URL
points to python-server-est - Check organization ID: Verify
ORGANIZATION_ID
is correct - Review API timeouts: Increase
API_TIMEOUT
if needed
- Regenerate API key: Generate a new key in organization settings
- Verify Supabase config: Check
SUPABASE_URL
andSUPABASE_SERVICE_KEY
- Check database: Verify API key exists in
organization_service_credentials
table
python-mcp-est/
βββ cloud_mcp_server.py # FastMCP server implementation
βββ mcp_handlers.py # Tool handlers (calls REST API)
βββ requirements.txt # Python dependencies
βββ Dockerfile # Container definition
βββ railway.toml # Railway configuration
βββ .env.example # Environment template
βββ README.md # This file
- Add handler function in
mcp_handlers.py
- Add tool definition in
cloud_mcp_server.py
using@mcp.tool()
decorator - Update this README with tool documentation
Same as the parent EST Call Agent Platform project.
For issues or questions:
- Check the logs first
- Review Railway/Render deployment status
- Verify all environment variables are set correctly
- Check python-server-est API is responding
- python-server-est: Main API server for outbound calls
- phone-agent-platform-EST: Next.js frontend application