Weather-MCP-Server
by JackKuo666
Verified
# Weather MCP Server
This is a Model Context Protocol (MCP) server that provides weather information using the National Weather Service (NWS) API.
## Features
- Get weather alerts for a US state
- Get weather forecast for a specific location (using latitude and longitude)
## Requirements
- Python 3.10+
- FastMCP
- httpx
## Installation
1. Clone this repository
2. Set up a virtual environment:
```
python -m venv .venv
source .venv/bin/activate # On Windows, use `.venv\Scripts\activate`
```
3. Install the required packages using uv:
```
uv add "mcp[cli]" httpx
```
## Configuration
The server uses a configuration file `config.py` with the following settings:
- `NWS_API_BASE`: The base URL for the National Weather Service API
- `USER_AGENT`: The User-Agent string used when making requests to the NWS API
- `LOG_LEVEL`: The logging level (e.g., "INFO", "DEBUG")
- `LOG_FORMAT`: The format string for log messages
- `REQUEST_TIMEOUT`: The timeout for API requests in seconds
You can modify these settings in the `config.py` file to customize the server behavior.
## Usage
### Running the server standalone
To run the server standalone:
1. Activate the virtual environment if not already activated:
```
source .venv/bin/activate # On Windows, use `.venv\Scripts\activate`
```
2. Run the server:
```
python weather.py
```
### Using with Cline
The Weather MCP Server has been added to the Cline configuration. To use it within Cline:
1. Ensure that Cline is properly set up and running.
2. The Weather MCP Server will be available as a tool named "weather".
3. You can use the following tools within Cline:
a. `get_alerts(state: str)`: Get weather alerts for a US state (use two-letter state code, e.g., "CA" for California)
b. `get_forecast(latitude: float, longitude: float)`: Get weather forecast for a specific location
Example usage in Cline:
```
# Get alerts for California
result = await mcp.call_tool("weather.get_alerts", state="CA")
print(result)
# Get forecast for San Francisco (approximate coordinates)
result = await mcp.call_tool("weather.get_forecast", latitude=37.7749, longitude=-122.4194)
print(result)
```
Note: The exact syntax for calling MCP tools may vary depending on your Cline setup. Refer to Cline documentation for the most up-to-date usage instructions.
## Error Handling and Logging
The server includes improved error handling for API requests and logging. If an error occurs during a request, the server will log the error and return an appropriate error message. Logs are printed to the console with the configured log level and format.
## Testing
### Unit Tests
To run the unit tests:
```
python -m unittest test_weather.py
```
These tests cover the basic functionality of the `get_alerts` and `get_forecast` tools.
### Manual Testing
To manually test the server, you can use the MCP client to call the provided tools. Here are some example commands:
```python
# Get alerts for California
result = await mcp.call_tool("get_alerts", state="CA")
print(result)
# Get forecast for San Francisco (approximate coordinates)
result = await mcp.call_tool("get_forecast", latitude=37.7749, longitude=-122.4194)
print(result)
```
## Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
## License
This project is open source and available under the [MIT License](LICENSE).