Airline Flight Delays MCP Server
An AI-powered customer service automation system designed to handle flight disruptions by providing real-time flight status, sentiment-aware passenger communication, and personalized engagement activities. It streamlines rebooking, airport recommendations, and human agent handoffs to improve the passenger experience during delays.
README
Airline Flight Delays MCP Server
AI-Powered Customer Service Automation for Weather-Related Flight Disruptions
π Overview
This project presents a Model Context Protocol (MCP) server-based system designed to reduce customer support costs for Indigo airline during weather-related flight delays. The airline operates a major hub in Mumbai with over 5,000 daily flights and faces peak support demand, long wait times, customer dissatisfaction, and high operational costs during delays.
Key Innovations
- Mood-Aware Communication: Adapts tone based on passenger sentiment (frustrated, concerned, calm, excited)
- Proactive Engagement: Entertainment activities scaled to delay duration (30min to 3+ hours)
- Personalized Service: Prioritizes frequent flyer members and provides customized recommendations
- Seamless Human Handoff: Full conversation context preservation for specialist escalation
- Real-Time Intelligence: Live flight status, rebooking options, and destination insights
Expected Results
- 60-70% reduction in routine customer service inquiries through automation
- Instant response times for common queries
- Intelligent routing of complex cases to human specialists
- Enhanced customer satisfaction through personalized, empathetic service
ποΈ Architecture
The solution uses a microservices architecture with six specialized MCP servers coordinated by a main orchestrator:
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β Main MCP Orchestrator β
β (FastMCP Server - Python) β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β
βββββββββββββββββββββββΌββββββββββββββββββββββ
β β β
βΌ βΌ βΌ
ββββββββββββββββ ββββββββββββββββ ββββββββββββββββ
βAuthenticationβ β Flight β β Mood β
β Server β β Information β β Analysis β
β β β Server β β Server β
ββββββββββββββββ ββββββββββββββββ ββββββββββββββββ
β β β
βΌ βΌ βΌ
ββββββββββββββββ ββββββββββββββββ ββββββββββββββββ
β Engagement/ β β Itinerary/ β β Human β
β Games β β Food β β Agent β
β Server β β Server β β Transfer β
ββββββββββββββββ ββββββββββββββββ ββββββββββββββββ
1. Authentication Server
- Secure passenger login and session management
- PNR/email/frequent flyer number authentication
- JWT token generation
- Passenger profile retrieval
2. Flight Information Server
- Real-time flight status and delay information
- Gate details and terminal navigation
- Alternative flight options for rebooking
- Connection impact analysis
- Weather delay notifications
3. Mood Analysis Server
- Sentiment detection using VADER and TextBlob
- LLM-powered emotional intelligence analysis
- Communication tone recommendations
- Escalation trigger detection
- Sentiment trend tracking
4. Engagement/Games Server
- Delay-appropriate entertainment activities
- Interactive games, trivia, and quizzes
- Destination virtual tours
- Relaxation and mindfulness exercises
- Airport exploration suggestions
5. Itinerary/Food Server
- Airport restaurant recommendations
- Destination dining guides
- Attraction and activity planning
- Personalized itinerary generation
- Dietary restriction handling
6. Human Agent Transfer Server
- Context-aware escalation to specialists
- Complete conversation history preservation
- Priority queue management
- Passenger profile and sentiment handoff
- Intelligent routing based on issue complexity
π Quick Start
Prerequisites
- Python: 3.9 or higher
- PostgreSQL: 12+ with pgvector extension
- Redis: 6+ (optional, for caching)
- LLM API: OpenAI, Azure OpenAI, or Anthropic API key
Installation
- Clone the Repository
cd /path/to/your/workspace
git clone <repository-url>
cd airline-delays-mcp-server
- Create Virtual Environment
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
- Install Dependencies
pip install -r requirements.txt
- Setup Database
-- Connect to PostgreSQL
psql -U postgres
-- Create database
CREATE DATABASE airline_delays_db;
-- Connect to database
\c airline_delays_db
-- Enable pgvector extension (if using vector operations)
CREATE EXTENSION IF NOT EXISTS vector;
- Configure Environment
Create a .env file (copy from env.example):
cp env.example .env
Edit .env with your configuration:
# Database
DB_HOST=localhost
DB_PORT=5432
DB_USER=postgres
DB_PASSWORD=your_password
DB_NAME=airline_delays_db
# OpenAI (or use Azure/Anthropic)
OPENAI_API_KEY=your_openai_api_key
OPENAI_MODEL=gpt-4-turbo-preview
# Server
PORT=3003
TRANSPORT=httpStream
ENVIRONMENT=development
- Initialize Database Schema
python -c "import asyncio; from src.config.database import init_database; asyncio.run(init_database())"
- Run the Server
python run.py
The server will start on http://localhost:3003/mcp
π» Usage
Available Tools
The MCP server exposes 6 tools that can be called by AI assistants:
1. authenticate_passenger
Authenticate a passenger and create a session.
{
"pnr": "ABC123",
"last_name": "Smith",
"email": "smith@example.com"
}
2. get_flight_information
Get real-time flight status and rebooking options.
{
"flight_number": "6E-123",
"passenger_id": "P12345",
"include_alternatives": true
}
3. analyze_mood
Analyze passenger sentiment and get communication recommendations.
{
"session_id": "session_abc123",
"message": "This delay is completely unacceptable!",
"analyze_trend": true
}
4. suggest_engagement
Suggest entertainment activities for delayed passengers.
{
"delay_minutes": 120,
"passenger_mood": "frustrated",
"destination": "DEL",
"activity_type": "any"
}
5. recommend_services
Recommend airport/destination dining and activities.
{
"service_type": "airport_food",
"airport_code": "BOM",
"dietary_restrictions": ["vegetarian"],
"budget": "moderate"
}
6. transfer_to_human
Transfer to human agent with full context.
{
"session_id": "session_abc123",
"reason": "high_frustration",
"urgency": "high",
"summary": "Passenger frustrated with long delay and missed connection"
}
π Project Structure
airline-delays-mcp-server/
βββ src/
β βββ config/
β β βββ __init__.py
β β βββ environment.py # Environment variable management
β β βββ database.py # PostgreSQL connection pool
β β βββ llm.py # LLM client (OpenAI/Azure/Anthropic)
β βββ tools/
β β βββ __init__.py
β β βββ authentication.py # Authentication Server
β β βββ flight_information.py # Flight Information Server
β β βββ mood_analysis.py # Mood Analysis Server
β β βββ engagement_games.py # Engagement/Games Server
β β βββ itinerary_food.py # Itinerary/Food Server
β β βββ human_handoff.py # Human Agent Transfer Server
β βββ utils/
β β βββ __init__.py
β β βββ logger.py # Structured logging
β β βββ helpers.py # Utility functions
β βββ interfaces/
β β βββ __init__.py # Type definitions
β βββ __init__.py
β βββ server.py # Main MCP server orchestrator
βββ docs/
β βββ ARCHITECTURE.md # Detailed architecture documentation
βββ tests/
β βββ (test files)
βββ .env # Environment configuration (create from env.example)
βββ env.example # Example environment configuration
βββ requirements.txt # Python dependencies
βββ run.py # Server startup script
βββ Dockerfile # Docker container definition
βββ docker-compose.yml # Docker Compose configuration
βββ README.md # This file
π§ Configuration
Environment Variables
See env.example for all available configuration options.
Key variables:
| Variable | Description | Default |
|---|---|---|
PORT |
Server port | 3003 |
TRANSPORT |
Transport type (stdio/httpStream) | httpStream |
DB_HOST |
PostgreSQL host | localhost |
OPENAI_API_KEY |
OpenAI API key | - |
MOOD_FRUSTRATION_THRESHOLD |
Frustration threshold for escalation | 0.6 |
DELAY_GAME_THRESHOLD_MINUTES |
Min delay for games | 30 |
FREQUENT_FLYER_MIN_FLIGHTS |
Min flights for FF status | 10 |
Feature Flags
Enable/disable features via environment:
ENABLE_MOOD_ANALYSIS=true
ENABLE_GAMES=true
ENABLE_FOOD_RECOMMENDATIONS=true
ENABLE_HUMAN_HANDOFF=true
π³ Docker Deployment
Build Docker Image
docker build -t airline-delays-mcp-server .
Run with Docker Compose
docker-compose up -d
This starts:
- MCP Server (port 3003)
- PostgreSQL database
- Redis cache
Stop Services
docker-compose down
π§ͺ Testing
Run tests:
pytest tests/ -v
Run with coverage:
pytest tests/ --cov=src --cov-report=html
π Monitoring & Observability
Logging
The server uses structured JSON logging. Set log level via:
LOG_LEVEL=INFO # DEBUG, INFO, WARNING, ERROR, CRITICAL
LOG_FORMAT=json # json or text
Metrics
Key metrics tracked:
- Tool execution times
- Sentiment scores and trends
- Escalation rates
- Response times
- Database query performance
π Security
- JWT Authentication: Secure session management
- Input Sanitization: XSS and injection prevention
- Rate Limiting: Prevent abuse (configure via environment)
- Database SSL: Encrypted connections to database
- API Key Management: Secure credential storage
π― Use Cases
1. Weather Delay Scenario
Passenger: "My flight is delayed. What's happening?"
System Flow:
- β Authenticate passenger (Authentication Server)
- β Get flight status (Flight Information Server)
- β Analyze mood (Mood Analysis Server)
- β Provide alternatives and rebooking options
- β Suggest activities if long delay (Engagement Server)
- β Recommend airport dining (Itinerary/Food Server)
2. Frustrated Passenger Escalation
Passenger: "This is unacceptable! I demand to speak to a manager!"
System Flow:
- β Detect high frustration (Mood Analysis Server)
- β Attempt to de-escalate with empathetic response
- β Offer compensation/alternatives
- β If frustration persists β Transfer to human (Human Handoff Server)
- β Agent receives full context, no repetition needed
3. Multi-Hour Delay
Delay: 3+ hours
System Actions:
- β Proactive engagement with entertainment options
- β Destination planning assistance
- β Airport restaurant recommendations
- β Meal voucher information
- β Regular status updates
- β Hotel arrangements if needed
π€ Integration
Claude Desktop Integration
Add to Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"airline-delays": {
"command": "python",
"args": ["/path/to/airline-delays-mcp-server/run.py"],
"env": {
"TRANSPORT": "stdio"
}
}
}
}
API Integration
For HTTP integration:
import requests
response = requests.post(
"http://localhost:3003/mcp",
json={
"jsonrpc": "2.0",
"id": 1,
"method": "tools/call",
"params": {
"name": "get_flight_information",
"arguments": {
"flight_number": "6E-123"
}
}
}
)
print(response.json())
π Additional Documentation
- Architecture Guide - Detailed system architecture
- API Reference - Complete API documentation
- Deployment Guide - Production deployment
- Troubleshooting - Common issues and solutions
π£οΈ Roadmap
- [ ] Multi-language support (Hindi, regional languages)
- [ ] Voice integration for phone-based support
- [ ] Mobile app integration
- [ ] Advanced analytics dashboard
- [ ] ML-powered delay prediction
- [ ] Integration with more airlines
- [ ] Automated compensation processing
π License
MIT License - see LICENSE file for details
π₯ Contributors
- Development Team
- Airline Operations Team
- Customer Service Specialists
π Support
For issues and questions:
- GitHub Issues: Create an issue
- Email: support@example.com
- Documentation: Full docs
π Acknowledgments
Built with:
- FastMCP - MCP server framework
- OpenAI API - LLM capabilities
- TextBlob - Sentiment analysis
- VADER Sentiment - Social media sentiment
- PostgreSQL - Database
- asyncpg - Async PostgreSQL driver
Made with β€οΈ for better customer experiences during travel disruptions
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.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.