Skip to main content

MCP server providing tools for weather and iceland

Project description

Axians MCP Server A Model Context Protocol (MCP) server that provides weather information tools using the National Weather Service API.

Features 🌦️ Weather Alerts: Get active weather alerts for any US state 📊 Weather Forecast: Get detailed weather forecasts for any location (latitude/longitude) 🚀 FastMCP Framework: Built on the efficient FastMCP framework 🔧 Multiple Transports: Supports stdio, SSE, and streamable HTTP transports Installation Using uvx (Recommended) bash uvx axians-mcp --transport=stdio Using pip bash pip install axians-mcp axians-mcp --transport=stdio Development Installation bash git clone cd axians-mcp uv pip install -e . Usage Basic Usage bash

Start the MCP server with stdio transport

axians-mcp --transport=stdio

Start with verbose logging

axians-mcp --verbose --transport=stdio

Start with custom environment file

axians-mcp --env-file=.env.custom --transport=stdio Available Transports stdio: Standard input/output (default, recommended for MCP clients) sse: Server-Sent Events streamable-http: HTTP streaming Environment Configuration Create a .env file in your project directory:

env TRANSPORT=stdio LOG_LEVEL=INFO Tools Available Weather Alerts Get active weather alerts for a US state:

python

Example usage in MCP client

await call_tool("get_alerts", {"state": "CA"}) Parameters:

state (string): Two-letter US state code (e.g., "CA", "NY", "TX") Weather Forecast Get detailed weather forecast for a specific location:

python

Example usage in MCP client

await call_tool("get_forecast", { "latitude": 37.7749, "longitude": -122.4194 }) Parameters:

latitude (float): Latitude coordinate longitude (float): Longitude coordinate Command Line Options Usage: axians-mcp [OPTIONS]

Options: -v, --verbose Increase verbosity (can be used multiple times) --env-file PATH Path to .env file --transport [stdio|sse|streamable-http] Transport type (default: stdio) --help Show this message and exit Examples Getting Weather Alerts for California bash

Start the server

axians-mcp --transport=stdio

In your MCP client, call:

{ "jsonrpc": "2.0", "id": 1, "method": "tools/call", "params": { "name": "get_alerts", "arguments": { "state": "CA" } } } Getting Forecast for San Francisco bash

In your MCP client, call:

{ "jsonrpc": "2.0", "id": 2, "method": "tools/call", "params": { "name": "get_forecast", "arguments": { "latitude": 37.7749, "longitude": -122.4194 } } } Integration with MCP Clients This server is compatible with any MCP client, including:

Claude Desktop: Add to your MCP configuration Custom Applications: Use the MCP protocol to integrate weather data Development Tools: Great for testing and development workflows Claude Desktop Configuration Add to your MCP settings:

json { "mcpServers": { "axians-weather": { "command": "uvx", "args": ["axians-mcp", "--transport=stdio"] } } } API Data Source This server uses the National Weather Service (NWS) API, which provides:

Real-time weather alerts Detailed forecasts High-quality, government-sourced weather data Free access (no API key required) All data is sourced from https://api.weather.gov and follows NWS API guidelines.

Development Project Structure src/axians_mcp/ ├── init.py # CLI entry point and main configuration ├── servers/ │ ├── init.py # Server exports │ ├── main.py # FastMCP server setup │ └── weather.py # Weather tools implementation Running Tests bash

Install development dependencies

uv pip install -e ".[dev]"

Run tests (when available)

pytest Building the Package bash uv run python -m build Contributing Fork the repository Create a feature branch (git checkout -b feature/amazing-feature) Commit your changes (git commit -m 'Add amazing feature') Push to the branch (git push origin feature/amazing-feature) Open a Pull Request Requirements Python 3.10+ Internet connection (for NWS API access) Dependencies fastmcp>=2.3.4: FastMCP framework httpx>=0.28.0: HTTP client for API requests click>=8.1.7: Command-line interface python-dotenv>=1.0.1: Environment variable management pydantic>=2.10.6: Data validation License This project is licensed under the MIT License - see the LICENSE file for details.

Support For issues and questions:

Check the Issues page Create a new issue with detailed information Include logs and configuration details Changelog v0.1.0 Initial release Weather alerts tool Weather forecast tool Multiple transport support FastMCP integration

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

axians_mcp-1.2.0.tar.gz (92.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

axians_mcp-1.2.0-py3-none-any.whl (8.6 kB view details)

Uploaded Python 3

File details

Details for the file axians_mcp-1.2.0.tar.gz.

File metadata

  • Download URL: axians_mcp-1.2.0.tar.gz
  • Upload date:
  • Size: 92.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.4

File hashes

Hashes for axians_mcp-1.2.0.tar.gz
Algorithm Hash digest
SHA256 86661af75a1a7c51595f3850a950281527295413d7e0a10a3a185819535ecb71
MD5 f3af638f1785373faa973519e07d5b5b
BLAKE2b-256 67c5f1dc07739e6b5d0c5e9dcfb1b29beda3ad03cd7742c55e9a8cbb6f693d35

See more details on using hashes here.

File details

Details for the file axians_mcp-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: axians_mcp-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 8.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.4

File hashes

Hashes for axians_mcp-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5454231c5622231a4e278c87d69e6187c5bac19dc881e23d552bf675d55fc82c
MD5 32563fd2c427d0c62ebf088ae6a51c33
BLAKE2b-256 ebae1e968a1cb78d69a7f72adb5e72efff36f86746c2c2a9f29e4accb2fb7eea

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page