MCP Weather Aggregator
AI-powered weather aggregation from 6 sources with intelligent deduction, working as both a REST API and MCP Server for AI assistants like Claude and Cursor.
README
MCP Weather Aggregator
AI-powered weather aggregation from 6 sources with intelligent deduction using GPT-5-mini. Works as both a REST API for web apps and an MCP Server for AI assistants (Claude, Cursor, etc.).
โจ Features
- ๐ค๏ธ Multi-source aggregation - Open-Meteo, OpenWeatherMap, WeatherAPI, Visual Crossing, MET Norway (Yr.no), DWD (Bright Sky)
- ๐ค AI-powered deduction - GPT-5-mini analyzes differences and deduces most accurate values
- ๐ Dual Mode - Runs as REST API (FastAPI) or MCP Server (FastMCP)
- ๐จ Ambient theming - Dynamic gradients based on weather/time (sunny, rainy, storm, night, fog, sandstorm, blizzard, aurora...)
- ๐ง Advanced Data Processing - Uses EWMA (Exponential Smoothing) for forecast curves and Kalman Filter for sensor fusion
- ๐ Confidence scores - Based on source agreement (0-1)
- ๐ Forecasts - Daily (up to 16 days) + Hourly (24 hours)
- ๐ Astronomy - Sunrise/sunset, moon phases
- ๐ Multi-language - EN, CZ
- ๐ Geolocation - Automatic location detection with reverse geocoding (shows city name, not coordinates)
- ๐ Smart Caching - Redis-backed caching for geocoding (24h), weather data (30m), and aurora (1h)
- ๐ก๏ธ Security - Rate limiting, security headers, and input sanitization
- ๐ Aurora forecast - Real-time aurora borealis visibility prediction from NOAA data
๐ Quick Start
1. Configure API Keys
cp .env.example .env
Edit .env:
# Required for AI deduction
OPENAI_API_KEY=sk-...
# Weather providers (add keys to enable more sources)
OPENWEATHERMAP_API_KEY=your_key # openweathermap.org
WEATHERAPI_KEY=your_key # weatherapi.com
VISUALCROSSING_KEY=your_key # visualcrossing.com
2. Install Dependencies
This project uses uv for dependency management.
# Windows
curl -LsSf https://astral.sh/uv/install.ps1 | powershell -c -
# Install project dependencies
uv sync
3. Run Application
Option A: Run as MCP Server (for AI Assistants)
Connect this server to your MCP client (Cursor, Claude Desktop, etc.).
# Run directly
uv run mcp-weather
# OR via python module
uv run python -m src.server
#### Option C: Run with Docker (Recommended)
Full stack (Backend + Frontend + Redis) in one command:
```bash
docker-compose up --build
- Frontend: http://localhost:3000
- API: http://localhost:8000
- Redis: localhost:6379
### 5. Configure Claude Desktop
To use this server with Claude Desktop, edit your config file:
- **Windows**: `C:\Users\USERNAME\AppData\Roaming\Claude\claude_desktop_config.json`
- **Mac/Linux**: `~/Library/Application Support/Claude/claude_desktop_config.json`
Add the following configuration (adjust path to your project):
```json
{
"mcpServers": {
"weather": {
"command": "C:\\Path\\To\\mcp-weather\\.venv\\Scripts\\python.exe",
"args": [
"-m",
"src.server"
],
"cwd": "C:\\Path\\To\\mcp-weather",
"env": {
"PYTHONPATH": "C:\\Path\\To\\mcp-weather"
}
}
}
}
Note: The
PYTHONPATHenvironment variable is crucial for the server to find thesrcmodule correctly.
Available MCP Tools:
search_location(query)- Find coordinates for a cityget_current_weather(location_name)- Get current weather + AI summaryget_weather_forecast(location_name, days)- Full forecast + AI deductionget_weather_by_coordinates(lat, lon)- Weather for exact locationget_ambient_theme(location_name)- Get UI theme colors for current weatherget_aurora_forecast(location_name)- Aurora Borealis forecast & visibility
Option B: Run as REST API (for Frontend)
Starts the FastAPI server on http://localhost:8000.
# Run directly
uv run mcp-weather-api
# OR via python module
uv run python -m src.api
4. Run Frontend
cd frontend
npm install
npm run dev
Open http://localhost:3000 ๐
๐ก API Endpoints (REST Mode)
| Endpoint | Method | Description |
|---|---|---|
/search |
POST | Search locations by name |
/weather/current |
POST | Current weather + AI summary |
/weather/forecast |
POST | Full forecast + AI analysis |
/weather/coordinates |
POST | Weather by lat/lon (auto-resolves city name) |
/aurora |
POST | Aurora borealis forecast from NOAA |
/theme |
POST | Get ambient theme colors |
Example Request
curl -X POST http://localhost:8000/weather/forecast \
-H "Content-Type: application/json" \
-d '{"location_name": "Prague"}'
Response includes:
current- Aggregated current weatherdaily_forecast- 7-day forecasthourly_forecast- 24-hour forecastai_summary- AI reasoning about the weatherconfidence- 0-1 score based on source agreementsources- List of providers usedambient_theme- Theme name + gradient colors
๐๏ธ Tech Stack
| Component | Technology |
|---|---|
| Backend | Python 3.14+, uv |
| API Framework | FastAPI (REST) |
| MCP Framework | FastMCP (MCP Server) |
| Frontend | Next.js 16.1.4, Tailwind v4, shadcn/ui |
| AI | OpenAI GPT-5-mini |
| Weather | Open-Meteo (free), OpenWeatherMap, WeatherAPI, Visual Crossing |
๐ Project Structure
mcp-weather/
โโโ src/
โ โโโ api.py # FastAPI REST server
โ โโโ server.py # MCP Server (FastMCP)
โ โโโ aggregator.py # AI weather aggregation logic
โ โโโ models.py # Pydantic data models
โ โโโ providers/ # Weather API providers
โโโ frontend/ # Next.js app
โ โโโ src/
โ โโโ app/
โ โโโ components/weather/
โ โโโ lib/
โโโ .env # API keys
โโโ pyproject.toml # Python dependencies
โโโ uv.lock # Lock file
๐ฎ Future Plans
- NOAA Aviation Weather - METARs, TAFs, aviation advisories
- NOAA Marine Weather - Ocean/coastal forecasts
- NOAA Solar/Space - Enhanced UV index and solar radiation data
License
Copyright (c) 2026 Tomรกลก Stark
All rights reserved.
This code is provided for viewing purposes only. You may not copy, modify, distribute, or use this code, in whole or in part, without explicit written permission from the author.
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
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.