Weather MCP Server
This is a sample MCP (Messaging and Compute Platform) server for a weather application, designed for the Puch AI Hackathon. It provides a basic structure for integrating with a weather API and includes the required validate
and resume
endpoints.
Prerequisites
Before you begin, ensure you have the following installed:
- Python 3.9+
- Docker (for containerized deployment)
- An API key from a weather service provider like OpenWeatherMap.
Getting Started
Follow these steps to get the project up and running on your local machine.
1. Clone the repository
2. Set up environment variables
The application requires a WEATHER_API_KEY
to be set as an environment variable.
On macOS/Linux:
On Windows:
Alternatively, you can create a .env
file in the root of the project and add the following lines. The .gitignore
file is already configured to ignore this file.
Note: The current app.py
does not automatically load .env
files. You would need to add a library like python-dotenv
for that. Also, make sure to replace 919876543210
with your actual phone number in the required format.
3. Install dependencies
It's recommended to use a virtual environment.
4. Run the application
The server will start on http://127.0.0.1:5000
.
Deployment to Render
This project is ready to be deployed to Render using Docker.
- Push your code to a GitHub repository.
- Create a new "Web Service" on Render and connect it to your GitHub repository.
- Choose the "Docker" environment. Render will automatically detect the
Dockerfile
. - Add your
WEATHER_API_KEY
as an environment variable in the Render dashboard. - Deploy! Render will build and deploy your application. You will get a public URL for your service.
API Endpoints
All endpoints are prefixed with /mcp
.
/mcp
- Method:
GET
- Description: A simple endpoint to check if the server is running.
- Response:
/mcp/get_current_weather
- Method:
POST
- Description: Gets the current weather for a city.
- Request Body:
- Response: The JSON response from the OpenWeatherMap API.
/mcp/get_weather_forecast
- Method:
POST
- Description: Gets the weather forecast for a city.
- Request Body:
- Response: The JSON response from the OpenWeatherMap API.
/mcp/validate
- Method:
POST
- Description: A placeholder for the hackathon's
validate
endpoint. - Request Body:
/mcp/resume
- Method:
POST
- Description: A placeholder for the hackathon's
resume
endpoint. - Request Body: (Currently none)
Connecting to Puch AI
Once deployed, you should be able to connect your MCP server to Puch AI using the command mentioned in the hackathon instructions. It will likely be something like this, executed in WhatsApp:
Make sure to replace <your_render_url>
with the URL provided by Render and <your_auth_token>
with the token provided by the hackathon organizers. Always refer to the official hackathon documentation for the exact command and procedure.
This server cannot be installed
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Enables users to get current weather conditions and forecasts for any city through OpenWeatherMap API integration. Designed as a sample MCP server for the Puch AI Hackathon with basic weather querying capabilities.
Related MCP Servers
- -securityFlicense-qualityAn MCP server implementation that allows users to fetch and display weather information for specified cities, including temperature, humidity, wind speed, and weather descriptions.Last updated -1Python
- -securityAlicense-qualityAn MCP server that connects to OpenWeatherMap's API to provide current weather data and multi-day forecasts for locations worldwide in different measurement units.Last updated -9TypeScriptMIT License
- -securityFlicense-qualityA production-ready Model Context Protocol server that provides weather data from OpenWeatherMap API, allowing users to query current weather by city name or coordinates with support for different temperature units.Last updated -Python
- AsecurityFlicenseAqualityA simple MCP server that provides a tool to fetch current weather information for cities using the Open-Meteo API, communicating through stdin/stdout.Last updated -12TypeScript