MCP Weather Aggregator

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.

Category
Visit Server

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 PYTHONPATH environment variable is crucial for the server to find the src module correctly.

Available MCP Tools:

  • search_location(query) - Find coordinates for a city
  • get_current_weather(location_name) - Get current weather + AI summary
  • get_weather_forecast(location_name, days) - Full forecast + AI deduction
  • get_weather_by_coordinates(lat, lon) - Weather for exact location
  • get_ambient_theme(location_name) - Get UI theme colors for current weather
  • get_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 weather
  • daily_forecast - 7-day forecast
  • hourly_forecast - 24-hour forecast
  • ai_summary - AI reasoning about the weather
  • confidence - 0-1 score based on source agreement
  • sources - List of providers used
  • ambient_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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured