EMY Weather MCP Server
Provides live Greek weather data from EMY, including forecasts, alerts, marine bulletins, warnings, and climate records. Supports location-based queries by name, ID, or coordinates without requiring an API key.
README
emy-mcp
An MCP server for Greek weather data from EMY — the Hellenic National Meteorological Service (Εθνική Μετεωρολογική Υπηρεσία).
It wraps EMY's public (api.emy.gr) endpoints as MCP tools. No API key is
required, and nothing is hardcoded — locations and data are always fetched
live from EMY.
Tools
| Tool | What it returns |
|---|---|
list_locations |
The live directory of ~1035 forecast locations (id, Greek/English name, prefecture, coordinates). Optional name/prefecture filter. |
get_forecast |
Today + up to 3 days for one location, resolved by name, id, or coordinates (nearest point). Temp max/min (°C), wind, precipitation probability, sky condition. |
get_alerts |
Structured CAP alerts (event, severity, urgency, onset/expiry, area). |
get_marine |
Marine bulletin for Greek seas (METAREA 3): forecast + warnings text. |
get_warnings |
National emergency weather bulletins (text, Greek only — EMY publishes no English variant). |
get_climate_records |
All-time Greek climate extremes (temperature, precipitation, wind). |
Resolving a location
This is the tricky part. EMY stores names transliterated from Greek with a
prefecture suffix, e.g. KORINTHOS (M. KORINTHIAS). Three independent problems:
- Exonyms vs transliteration — "Corinth" ≠ "Korinthos", "Corfu" ≠ "Kerkyra".
- Prefecture suffix on every name —
(m. Korinthias). - Greek script + accents —
ΚόρινθοςvsKORINTHOS.
How they're handled:
- Greek or Latin name →
get_forecast(location=...)orlist_locations(query=...). Names are accent-folded, suffix-stripped, and Greek is transliterated to Latin using EMY's own scheme, soΚόρινθος,korinthosandKORINTHOSall match. Fuzzy ranking handles typos and returns alternatives. - English exonyms / anything ambiguous → resolve the place to coordinates
and call
get_forecast(latitude=..., longitude=...). This returns the nearest forecast point regardless of spelling or language (e.g. Corinth's coordinates → Korinthos, 5 km away). An LLM client typically knows the coordinates already.
Live data, caching & resilience
Everything is fetched live. Per endpoint:
- Fresh window — cached payload is served without refetch for 30 minutes (EMY's forecasts update ~twice daily).
- After the window, a refetch is attempted.
- If EMY is unreachable, the last-known-good copy is served for up to
24 hours, flagged
stalewith its age. - After 24 hours with no successful fetch, the call fails with a clear error.
Every tool response includes a source block with fetched_at, age_minutes
and stale.
TLS note
api.emy.gr serves a valid *.emy.gr certificate but omits the intermediate CA
from the handshake, so standard clients fail with "unable to get local issuer
certificate". The client fetches the intermediate (RapidSSL TLS RSA CA G1)
from the certificate's own AIA URL on first use and caches it under
~/.cache/emy-mcp/. Because a fetched cert is installed as a trusted anchor,
it is pinned by SHA-256 fingerprint — a fetched or cached cert is only
trusted if its fingerprint matches the known-good value, which makes the fetch
safe against tampering and self-heals a corrupt cache. Certificate verification
is not disabled; if EMY ever rotates this CA the pin must be updated.
Data caveats
- Sky condition comes from a small icon set (6 values): Sunny, Hot, Partly cloudy, Scattered showers, Cloudy with rain, Thunderstorms — so it's coarse.
- Wind speed units are reported by EMY as a bare number; they appear to be m/s and are labelled as such, but EMY does not document this.
- There is no live "current observations" feed in EMY's public API — only forecasts, alerts, marine and climate. This server reflects that.
Install & run
pip install -e . # or: pip install httpx certifi "mcp>=1.2"
# stdio (Claude Desktop, Claude Code, local assistants)
python -m emy_mcp
# streamable-HTTP (hostable)
python -m emy_mcp --http --host 0.0.0.0 --port 8000
Claude Desktop / Claude Code config (stdio)
{
"mcpServers": {
"emy-weather": {
"command": "python",
"args": ["-m", "emy_mcp"]
}
}
}
License
MIT
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.