au-weather-mcp
Provides access to Australian weather data from the Bureau of Meteorology, enabling location search, forecasts, and current observations.
README
Australian Weather MCP Server
An MCP (Model Context Protocol) server that provides access to Australian weather data from the Bureau of Meteorology (BOM). This server allows AI assistants and other MCP clients to search for locations and retrieve weather forecasts and current observations for locations across Australia.
Features
This MCP server provides the following tools:
- search_location: Search for Australian locations by suburb name or postcode
- get_daily_forecast: Get multi-day weather forecast for a location
- get_three_hourly_forecast: Get detailed 3-hourly forecast data
- get_observations: Get current weather observations
- get_weather_for_location: Get comprehensive weather info (convenience tool that combines search + forecast + observations)
Installation
Using pip
pip install -e /path/to/au-weather-mcp
Using uv (recommended)
uv pip install -e /path/to/au-weather-mcp
Using Docker Desktop
If you prefer to use Docker, you can build and run the server in a container:
# Clone the repository
git clone git@github.com:craigles75/au-weather-mcp.git
cd au-weather-mcp
# Build the Docker image
docker build -t au-weather-mcp .
# Or use docker compose
docker compose build
Configuration
Claude Desktop
Add this to your Claude Desktop configuration file:
MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%/Claude/claude_desktop_config.json
{
"mcpServers": {
"au-weather": {
"command": "python",
"args": ["/path/to/au-weather-mcp/server.py"]
}
}
}
Or if you're using uv:
{
"mcpServers": {
"au-weather": {
"command": "uv",
"args": ["--directory", "/path/to/au-weather-mcp", "run", "server.py"]
}
}
}
Or if you're using Docker:
{
"mcpServers": {
"au-weather": {
"command": "docker",
"args": ["run", "-i", "--rm", "au-weather-mcp"]
}
}
}
Note: When using Docker, make sure you've built the image first with docker build -t au-weather-mcp . or docker compose build.
Other MCP Clients
For other MCP clients, configure them to run:
Python:
python /path/to/au-weather-mcp/server.py
Docker:
docker run -i --rm au-weather-mcp
The server communicates over stdio (standard input/output).
Usage Examples
Once configured, you can use the tools through your MCP client (like Claude Desktop):
Search for a location
Use the search_location tool to find "Melbourne"
This returns a list of locations matching "Melbourne" with their geohash identifiers.
Get weather for a location
Use the get_weather_for_location tool for "Sydney"
This searches for Sydney and returns both the daily forecast and current observations.
Get detailed forecast
First search for "Parkdale 3195", then use the geohash to get the daily forecast
This gives you more control over which specific location you want when there are multiple matches.
Tool Reference
search_location
Search for Australian locations by suburb name or postcode.
Parameters:
query(string, required): Suburb name (e.g., "Parkdale", "Sydney") or postcode (e.g., "3195", "2000")
Returns: List of matching locations with geohash identifiers
get_daily_forecast
Get daily weather forecast for a location.
Parameters:
geohash(string, required): Location geohash identifier (get from search_location)
Returns: Multi-day forecast with temperatures, conditions, rain predictions
get_three_hourly_forecast
Get detailed three-hourly weather forecast.
Parameters:
geohash(string, required): Location geohash identifier (get from search_location)
Returns: Detailed 3-hourly forecast data
get_observations
Get current weather observations.
Parameters:
geohash(string, required): Location geohash identifier (get from search_location)
Returns: Current weather conditions including temperature, humidity, wind, etc.
get_weather_for_location
Get comprehensive weather information (convenience tool).
Parameters:
location(string, required): Suburb name or postcode
Returns: Location info, daily forecast, and current observations
Development
Running Tests
# Install dev dependencies
pip install -e ".[dev]"
# Run tests
pytest
Testing the Server Manually
You can test the server by running it directly:
Python:
python server.py
Docker:
docker run -i --rm au-weather-mcp
The server will start and communicate over stdio. You can send MCP protocol messages to test the tools.
Building and Running with Docker
# Build the image
docker build -t au-weather-mcp .
# Run the server
docker run -i --rm au-weather-mcp
# Or using docker compose
docker compose build
docker compose run --rm au-weather-mcp
Data Source
This server retrieves data from the Bureau of Meteorology's public API at https://api.weather.bom.gov.au/v1.
License
MIT
Contributing
Contributions are welcome! Please feel free to submit issues or pull requests.
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.