Airplane.Live MCP Server
MCP server that connects to the Airplanes.live API to provide real-time flight and aircraft data for analysis or visualization.
āļø Airplane Tracker MCP Server
šÆ Overview
This MCP server integrates with the airplanes.live API to provide real-time aircraft tracking capabilities to Claude Desktop. Track flights, find aircraft by callsign, registration, or position - all directly from Claude!
ā ļø Important Notice - Terms of Use
š Educational and Non-Commercial Use Only
This project uses the airplanes.live API which is provided for educational and non-commercial purposes only. Please respect their terms of service.
š Usage Guidelines:
- ā Educational projects - Learning and research
- ā Personal use - Non-commercial tracking
- ā Open source contributions - Community development
- ā Commercial applications - Business/profit purposes
- ā High-volume requests - Respect rate limits
š”ļø Disclaimer:
The author of this MCP server does not assume any responsibility for the use of this software. This is a community contribution intended for educational purposes and to demonstrate MCP server development. Users are responsible for complying with airplanes.live API terms and any applicable regulations.
š Respect for Existing Services:
This project does NOT intend to replace or compete with the official airplanes.live globe viewer. The official globe is the primary and recommended way to visualize flight data. This MCP server is designed as a complementary educational tool for Claude Desktop integration and MCP development learning.
š Full API Terms: https://airplanes.live/api-guide/
š Official Globe Viewer: https://globe.airplanes.live
šø Screenshots
Real-time airplane tracking in Claude Desktop
š Features
- š Search by Callsign - Find specific flights (e.g., UAL123)
- š Registration Lookup - Track by tail number (e.g., N12345)
- šÆ Position-based Search - Aircraft near coordinates
- š·ļø Hex ID Search - Mode S transponder codes
- š”ļø Military Aircraft - Tracked military flights
- š LADD Aircraft - Law enforcement tracking
- ā PIA Aircraft - Private/Interesting aircraft
- š” Squawk Codes - Emergency and special codes
Various API search examples
šļø Architecture
š§ Components
- š Python MCP Server - Async server implementation
- š MCP Framework - Modern server architecture
- ā” httpx Client - High-performance HTTP requests
- š Data Formatter - Clean, readable aircraft information
- š Claude Integration - Direct MCP protocol support
š Data Flow
graph TD
A[Claude Desktop] --> B[MCP Protocol]
B --> C[airplane_server.py]
C --> D[API Functions]
D --> E[airplanes.live API]
E --> F[Aircraft Data]
F --> G[Formatted Response]
G --> A
System architecture and data flow
š Quick Start
š Prerequisites
- š Python 3.8+
- š» Claude Desktop
- š Internet connection
ā” Installation
# 1. Clone the repository
git clone https://github.com/Bellaposa/airplanes-live-mcp.git
cd airplanes-live-mcp
# 2. Create virtual environment (REQUIRED!)
python -m venv .venv
# 3. Activate virtual environment
# macOS/Linux:
source .venv/bin/activate
# Windows:
.venv\Scripts\activate
# 4. Install dependencies
pip install -r requirements.txt
# 5. Test the server
python airplane_server.py
ā ļø Common Issues & Solutions
š„ Virtual Environment is MANDATORY!
- If you skip step 2-3, you'll get
ModuleNotFoundError: No module named 'httpx'
- Claude Desktop needs the full path to the venv Python, not system Python
- Without venv, dependencies aren't isolated and things break
šŖ Windows Users:
- Virtual env creates
.venv\Scripts\
folder (not.venv\bin\
) - Use
Scripts\python.exe
in Claude config, notbin/python
- Always use double backslashes
\\
in JSON paths
š Python Path Issues:
- Make sure Python 3.8+ is installed:
python --version
- If
python
doesn't work, trypython3
orpy
- Virtual environment MUST exist before configuring Claude Desktop
š³ Docker Installation (Alternative)
Skip Python setup headaches - use Docker instead!
š Prerequisites
- š³ Docker Desktop installed and running
- š» Claude Desktop
ā” Docker Setup
# 1. Clone the repository
git clone https://github.com/Bellaposa/airplanes-live-mcp.git
cd airplanes-live-mcp
# 2. Build Docker image
docker build -t airplane-mcp-server .
# 3. Test the container
docker run --rm -it airplane-mcp-server python airplane_server.py
āļø Claude Desktop Configuration for Docker
š macOS/Linux with Docker
Add to ~/Library/Application Support/Claude/claude_desktop_config.json
:
{
"mcpServers": {
"airplanes-live": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"airplane-mcp-server",
"python", "airplane_server.py"
]
}
}
}
šŖ Windows with Docker
Add to %APPDATA%\Claude\claude_desktop_config.json
:
{
"mcpServers": {
"airplanes-live": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"airplane-mcp-server",
"python", "airplane_server.py"
]
}
}
}
š Docker Commands Reference
# Build the image
docker build -t airplane-mcp-server .
# Run interactively for testing
docker run --rm -it airplane-mcp-server bash
# Check if image exists
docker images | grep airplane-mcp-server
# Remove image if needed
docker rmi airplane-mcp-server
# View container logs (if running detached)
docker logs <container_id>
ā Docker Advantages
- š No Python setup required - Everything pre-configured
- š Isolated environment - No dependency conflicts
- š Works everywhere - Same setup on Windows/Mac/Linux
- š¦ Easy updates - Just rebuild the image
- š”ļø Consistent behavior - Eliminates "works on my machine"
ā ļø Docker Troubleshooting
Problem: "docker: command not found"
# Install Docker Desktop first
# macOS: https://docs.docker.com/desktop/install/mac-install/
# Windows: https://docs.docker.com/desktop/install/windows-install/
# Linux: https://docs.docker.com/desktop/install/linux-install/
Problem: "Cannot connect to Docker daemon"
# Start Docker Desktop application
# Wait for Docker to fully start (green icon)
Problem: "Permission denied" (Linux)
# Add user to docker group
sudo usermod -aG docker $USER
# Log out and back in, or:
newgrp docker
Problem: Image build fails
# Clean Docker cache
docker system prune -a
# Try building again
docker build --no-cache -t airplane-mcp-server .
šÆ Even Easier: Docker Compose
For the simplest setup, use Docker Compose:
# 1. Clone and enter directory
git clone https://github.com/Bellaposa/airplanes-live-mcp.git
cd airplanes-live-mcp
# 2. Build and run with one command
docker-compose up --build
# 3. In another terminal, test the server
docker-compose exec airplane-mcp-server python airplane_server.py
Docker Compose Claude Configuration:
{
"mcpServers": {
"airplanes-live": {
"command": "docker-compose",
"args": [
"-f", "/path/to/airplanes-live-mcp/docker-compose.yml",
"exec", "-T", "airplane-mcp-server",
"python", "airplane_server.py"
],
"cwd": "/path/to/airplanes-live-mcp"
}
}
}
š³ How to Use with Claude Desktop
Method 1: Simple Docker Run
Configuration for all platforms:
{
"mcpServers": {
"airplanes-live": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"airplane-mcp-server",
"python", "airplane_server.py"
]
}
}
}
Method 2: Docker Compose (Advanced)
Configuration with full paths:
{
"mcpServers": {
"airplanes-live": {
"command": "docker-compose",
"args": [
"-f", "/full/path/to/your/airplanes-live-mcp/docker-compose.yml",
"exec", "-T", "airplane-mcp-server",
"python", "airplane_server.py"
],
"cwd": "/full/path/to/your/airplanes-live-mcp"
}
}
}
Complete Docker Setup Steps:
# 1. Clone and build
git clone https://github.com/Bellaposa/airplanes-live-mcp.git
cd airplanes-live-mcp
docker build -t airplane-mcp-server .
# 2. Configure Claude Desktop with Method 1 (above)
# 3. Restart Claude Desktop completely
# 4. Test with: "Show me aircraft near New York"
šÆ Docker vs Python Comparison:
Method | Pros | Cons | Best For |
---|---|---|---|
Docker | ā No Python setupā Works everywhereā Isolated | ā Requires Dockerā Slight overhead | Beginners, Windows users |
Python | ā Direct executionā Easy debuggingā No Docker needed | ā Manual Python setupā OS-specific issues | Developers, experienced users |
Docker Compose Commands:
# Start services in background
docker-compose up -d
# View logs
docker-compose logs airplane-mcp-server
# Stop services
docker-compose down
# Rebuild and restart
docker-compose up --build
### āļø Claude Desktop Configuration
#### š **macOS/Linux Configuration**
Add to `~/Library/Application Support/Claude/claude_desktop_config.json` (macOS) or `~/.config/claude-desktop/config.json` (Linux):
```json
{
"mcpServers": {
"airplanes-live": {
"command": "/path/to/airplanes-live-mcp/.venv/bin/python",
"args": ["/path/to/airplanes-live-mcp/airplane_server.py"],
"env": {
"PYTHONPATH": "/path/to/airplanes-live-mcp"
}
}
}
}
šŖ Windows Configuration
Add to %APPDATA%\Claude\claude_desktop_config.json
:
{
"mcpServers": {
"airplanes-live": {
"command": "C:\\Users\\YourUsername\\airplanes-live-mcp\\.venv\\Scripts\\python.exe",
"args": ["C:\\Users\\YourUsername\\airplanes-live-mcp\\airplane_server.py"],
"env": {
"PYTHONPATH": "C:\\Users\\YourUsername\\airplanes-live-mcp"
}
}
}
}
ā ļø Important Windows Notes:
- Use
Scripts\\python.exe
(notbin/python
) - Replace
YourUsername
with your actual Windows username - Use double backslashes
\\
in paths - Make sure the virtual environment is created with
python -m venv .venv
Claude Desktop configuration
š® Usage Examples
Search by Callsign
š Find flight UAL123
Near Position Search
š Show aircraft near 40.7128, -74.0060 within 50nm
Military Aircraft
š”ļø Show all military aircraft
š§ Key Design Decisions
1. Async Implementation
All tools use async
to handle multiple requests efficiently:
@mcp.tool()
async def aircraft_near_position(latitude: str = "", longitude: str = "", radius: str = "250") -> str:
This allows the server to handle concurrent requests without blocking.
2. String-Based Parameters
All parameters are strings because MCP protocols work best with simple types:
# Correct
def tool(param: str = "") -> str:
# Avoid
def tool(param: Optional[int] = None) -> str:
3. Error Handling
Every tool includes comprehensive error handling:
try:
# Main logic
except ValueError:
return f"ā Error: Invalid input"
except Exception as e:
return f"ā Error: {str(e)}"
4. Data Formatting
The format_aircraft_data()
function provides consistent, readable output:
def format_aircraft_data(aircraft_data):
# Handles both single aircraft and lists
# Formats all available fields with emoji indicators
# Returns human-readable strings
5. API Wrapper
The make_api_request()
function centralizes HTTP logic:
async def make_api_request(endpoint):
async with httpx.AsyncClient(timeout=15) as client:
url = f"{API_BASE_URL}{endpoint}"
response = await client.get(url)
response.raise_for_status()
return response.json()
This approach:
- Centralizes error handling
- Manages timeouts
- Logs all requests
- Makes it easy to add authentication later
Tool Reference
aircraft_by_hex(hex_id: str = "")
Purpose: Search for aircraft by Mode S hex identifier
Input: Comma-separated hex IDs (e.g., "45211e,45212f")
Returns: List of matching aircraft with full details
Example:
User: "Show me aircraft with hex 45211e"
Tool: "š Found 1 aircraft: āļø Callsign: RYR123 ..."
aircraft_by_callsign(callsign: str = "")
Purpose: Search for aircraft by flight callsign
Input: Comma-separated callsigns (e.g., "BA387,AA123")
Returns: Aircraft matching the callsign
Example:
User: "Find flight BA387"
Tool: "š Found 1 aircraft: āļø Callsign: BA387 ..."
aircraft_by_registration(reg: str = "")
Purpose: Search for aircraft by tail number/registration
Input: Comma-separated registrations (e.g., "N123AB,G-EUPA")
Returns: Aircraft matching the registration
Example:
User: "Show aircraft with tail N123AB"
Tool: "š Found 1 aircraft: š Registration: N123AB ..."
aircraft_by_type(icao_type: str = "")
Purpose: Search for aircraft by ICAO type code
Input: Type codes (A321, B738, C172, E190, etc.)
Returns: All aircraft of that type currently flying
Example:
User: "Show all Boeing 737s"
Tool: "š Found 247 aircraft of type B738: ..."
aircraft_by_squawk(squawk_code: str = "")
Purpose: Search for aircraft by squawk code
Input: 4-digit squawk code (e.g., "7500", "7600", "7700")
Returns: Aircraft squawking that code
Note: 7700 = Emergency, 7600 = Communications failure, 7500 = Hijacking
Example:
User: "Find aircraft squawking 7700"
Tool: "š Found aircraft in emergency: ..."
aircraft_near_position(latitude: str = "", longitude: str = "", radius: str = "250")
Purpose: Find all aircraft within a radius of coordinates
Input:
- latitude (decimal degrees, -90 to 90)
- longitude (decimal degrees, -180 to 180)
- radius (nautical miles, max 250)
Returns: All aircraft within the radius
Example:
User: "Show aircraft within 50 nm of Madrid (40.4168, -3.7038)"
Tool: "š Found 23 aircraft within 50 nm of 40.4168, -3.7038: ..."
military_aircraft()
Purpose: List all military aircraft
Input: None
Returns: All aircraft tagged as military
Example:
User: "What military aircraft are flying?"
Tool: "šļø Found 12 military aircraft: ..."
ladd_aircraft()
Purpose: List law enforcement and security aircraft
Input: None
Returns: All LADD (Law Enforcement/Security) aircraft
Example:
User: "Show law enforcement aircraft"
Tool: "š Found 8 LADD aircraft: ..."
pia_aircraft()
Purpose: List interesting/special aircraft
Input: None
Returns: All PIA (special interest) aircraft
Example:
User: "Show special/private aircraft"
Tool: "š”ļø Found 156 PIA aircraft: ..."
Output Format
All tools return formatted strings with emoji indicators:
āļø Callsign: BA387
š Registration: G-EUPA
š©ļø Type: A350
š Position: 51.4769, -0.4589
š Altitude: 35000 ft
ā” Ground Speed: 485 knots
š§ Track: 089°
š Mode S Hex: 406ee9
šļø Last Seen: 3 seconds ago
This provides:
- Visual clarity with emojis
- Easy scanning of information
- Consistent formatting
- Professional appearance
Adding New Tools
To add a new tool to this server:
Step 1: Create the Tool Function
@mcp.tool()
async def new_tool(param1: str = "", param2: str = "") -> str:
"""Single-line description of what this tool does."""
if not param1.strip():
return "ā Error: param1 is required"
try:
# Your implementation
result = await make_api_request("/endpoint")
formatted = format_aircraft_data(result.get('ac', []))
return f"ā
Success:\n\n{formatted}"
except Exception as e:
return f"ā Error: {str(e)}"
Step 2: Add to Catalog
Update the tools:
section in custom.yaml:
tools:
- name: new_tool
Step 3: Rebuild Docker Image
docker build -t airplane-mcp-server .
Step 4: Restart Claude Desktop
The new tool will automatically appear.
Testing
Unit Test Pattern
import asyncio
async def test_aircraft_by_callsign():
result = await aircraft_by_callsign("BA387")
assert "āļø" in result
assert "Found" in result
print(result)
# Run with: asyncio.run(test_aircraft_by_callsign())
Integration Test
# Start server
python airplane_server.py
# In another terminal, test via stdin:
echo '{"jsonrpc":"2.0","method":"tools/list","id":1}' | python airplane_server.py
Performance Considerations
API Response Times
- Typical: 500ms - 1s
- Complex queries: 1s - 2s
- Timeout: 15 seconds
Data Limits
- Max 1000 aircraft per query (API limit)
- Radius search: max 250 nautical miles
- Callsign/registration: comma-separated up to 8000 chars
Optimization Tips
- Use specific searches - Narrow searches are faster
- Avoid hammering the API - Reasonable request frequency
- Cache results locally - Consider storing recent queries
- Monitor timeouts - API may be slow during peak traffic
Troubleshooting Guide
Problem: Tools Don't Appear
Solution:
- Verify image built:
docker images | grep airplane
- Check catalog:
cat ~/.docker/mcp/catalogs/custom.yaml
- Verify registry:
cat ~/.docker/mcp/registry.yaml
- Restart Claude: Quit completely, then reopen
Problem: "No Aircraft Found"
Causes:
- Wrong coordinates (verify lat/lon format)
- Radius too small
- No traffic in that area
- Wrong type code (try uppercase)
Solution: Try a broader search or different parameters
Problem: API Timeout
Cause: API is slow or rate-limited
Solution:
- Wait 30 seconds
- Try a simpler query
- Check internet connection
Problem: Docker Permission Denied
Solution:
# Add user to docker group
sudo usermod -aG docker $USER
# Log out and back in
newgrp docker
šŗļø Future Enhancements
ā ļø Important Note: This planned dashboard is intended as an educational complement to the excellent official airplanes.live globe viewer, not a replacement. The goal is to demonstrate web development integration with MCP servers for learning purposes.
- Caching System - Redis cache to reduce API calls
- Rate Limiting - Smart request throttling
- Export Features - Save results as JSON/CSV/KML
- Enhanced Formatting - Better data visualization in Claude
- Flight Alerts - Notify when specific aircraft appear
- Historical Tracking - Store and track aircraft movements
- Statistics Dashboard - Aggregate data and analytics
- API Extensions - Additional airplanes.live endpoints
š¤ AI-Powered Features
- š§ Flight Prediction - ML-based flight path estimation
- š Pattern Analysis - Identify unusual flight patterns
- šØ Anomaly Detection - Automated alerts for interesting events
- š Trend Analysis - Historical data insights
Security
Current Approach
- No authentication required (public API data)
- Consider applying for an API key for production use
- No sensitive credentials stored
- Runs as non-root user
- Input validation on all parameters
Future Considerations
- Add rate limiting if needed
- Implement query logging for monitoring
- Consider caching to reduce API calls
- Add input sanitization for custom endpoints
š Resources
- API Documentation: https://airplanes.live/
- API Terms of Use: https://airplanes.live/api-guide/
- MCP Specification: https://docs.anthropic.com/mcp
- FastMCP Documentation: https://github.com/jlowin/fastmcp
- httpx Documentation: https://www.python-httpx.org/
š¤ Contributing
This is an open-source educational project! Contributions are welcome:
- š Bug Reports - Open an issue
- š” Feature Requests - Suggest improvements
- š§ Pull Requests - Submit code changes
- š Documentation - Improve guides and examples
š License & Disclaimer
MIT License - Feel free to use, modify, and distribute for educational purposes.
āļø Legal Notice:
- This software is provided "AS IS" without warranty
- Author assumes no responsibility for usage or compliance
- Users must respect airplanes.live API terms
- Educational and non-commercial use only
- Not affiliated with airplanes.live
šÆ Project Intent:
This project is a community contribution for educational purposes, demonstrating MCP server development and API integration. The goal is to help developers learn and contribute to the MCP ecosystem, not for commercial gain.
Made with ā¤ļø for the MCP community āļø
Remember: Always respect API terms and use responsibly!
Related Servers
Obenan Review Analyzer
An MCP server for analyzing product or service reviews.
MCP Seat Reservation Server
A server for managing a comprehensive seat reservation system.
MCP-TFT
Provides accurate Teamfight Tactics (TFT) analysis using Data Dragon and community meta insights.
Fulcra Context
Fulcra Context MCP server for accessing your personal health, workouts, sleep, location, and more, all privately. Built around Context by Fulcra.
Image
Fetch and process images from URLs, local file paths, and numpy arrays, returning them as base64-encoded strings.
MCP.science
A collection of open-source MCP servers designed for scientific research applications.
Arithmetic MCP Server
Performs basic arithmetic operations such as addition, subtraction, multiplication, and division.
MCP Epic Free Games
Provides access to information about free games on the Epic Games Store.
NWC MCP Server
Control a Lightning wallet using Nostr Wallet Connect (NWC).
MCP Marvel Rivals
Provides access to Marvel Rivals game data through a standardized interface.