Weather MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Weather MCP Serverwhat's the 5-day forecast for Tokyo in imperial units?"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Weather MCP Server - Sample Implementation
Reference implementation for ASUS and OEM partners
A simple, production-ready MCP server demonstrating how to integrate external services with AI PCs using the Model Context Protocol.
๐ฏ Purpose
This sample MCP server demonstrates:
โ How to create an MCP server from scratch
โ How to expose tools (functions) to AI clients
โ How to integrate external APIs (OpenWeather API)
โ Production-ready error handling
โ Clean, well-documented code
Perfect for: OEM partners building AI PC features, developers learning MCP, proof-of-concept projects
๐ Features
Available Tools
get_current_weather- Get real-time weather for any cityTemperature, conditions, humidity, wind speed
Supports both Celsius and Fahrenheit
get_weather_forecast- Get 5-day forecastDaily high/low temperatures
Weather conditions per day
๐ Quick Start
Prerequisites
Node.js >= 18.0.0
OpenWeather API key (free tier available)
Installation
# Clone or download this repository
cd weather-mcp-server
# Install dependencies
npm install
# Configure API key
cp .env.example .env
# Edit .env and add your OpenWeather API keyGet API Key
Visit OpenWeather API
Sign up for free account
Generate API key
Add to
.envfile
Run the Server
# Start the server
npm start
# Or with auto-reload during development
npm run dev๐ Usage Examples
Configure in Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"weather": {
"command": "node",
"args": ["/absolute/path/to/weather-mcp-server/index.js"],
"env": {
"OPENWEATHER_API_KEY": "your_api_key_here"
}
}
}
}Test with AI Client
Once configured, you can ask your AI assistant:
"What's the weather like in Taipei?"
"Give me a 5-day forecast for Tokyo"
"What's the temperature in New York in Fahrenheit?"The AI will automatically call the appropriate MCP tools!
๐๏ธ Architecture
โโโโโโโโโโโโโโโโโโโ
โ AI Client โ (Claude, ChatGPT, etc.)
โ (Claude Desktop)โ
โโโโโโโโโโฌโโโโโโโโโ
โ MCP Protocol (stdio)
โ
โโโโโโโโโโโโโโโโโโโ
โ Weather MCP โ โ This server
โ Server โ
โโโโโโโโโโฌโโโโโโโโโ
โ HTTPS
โ
โโโโโโโโโโโโโโโโโโโ
โ OpenWeather API โ
โโโโโโโโโโโโโโโโโโโKey Components
index.js- Main server implementation@modelcontextprotocol/sdk- Official MCP SDKStdioServerTransport- Communicates via stdin/stdoutOpenWeather API- External weather data source
๐ Project Structure
weather-mcp-server/
โโโ package.json # Dependencies and scripts
โโโ index.js # Main MCP server code
โโโ .env.example # Environment variables template
โโโ .env # Your API keys (git-ignored)
โโโ README.md # This file
โโโ README.zh-TW.md # ็น้ซไธญๆ็
โโโ PARTNER-GUIDE.md # Detailed guide for OEM partners
โโโ examples/
โโโ client-example.js # Example client code๐ ๏ธ Development
Code Structure
The server is organized into clear sections:
Configuration - API keys, URLs
WeatherServer Class - Main server logic
Tool Registration - Define available tools
Tool Handlers - Implement tool functionality
Error Handling - Robust error management
Adding New Tools
// 1. Add tool definition in setupToolHandlers()
{
name: 'your_new_tool',
description: 'What this tool does',
inputSchema: {
type: 'object',
properties: {
param1: { type: 'string', description: 'Parameter description' }
},
required: ['param1']
}
}
// 2. Add handler in CallToolRequestSchema
case 'your_new_tool':
return await this.yourNewTool(args.param1);
// 3. Implement the method
async yourNewTool(param1) {
// Your logic here
return {
content: [{
type: 'text',
text: 'Result'
}]
};
}๐งช Testing
Manual Testing
# Test the MCP server directly
npm testIntegration Testing
Use the included examples/client-example.js to test tool calls programmatically.
๐ API Reference
Tool: get_current_weather
Parameters:
city(string, required) - City name (e.g., "Taipei", "Tokyo")units(string, optional) - "metric" (default) or "imperial"
Returns:
๐ค๏ธ Current Weather in Taipei, TW
Temperature: 25.3ยฐC (feels like 26.1ยฐC)
Condition: Clear - clear sky
Humidity: 65%
Wind Speed: 3.2 m/s
Pressure: 1013 hPa
Visibility: 10.0 km
Last updated: 11/14/2025, 10:30:00 AMTool: get_weather_forecast
Parameters:
city(string, required) - City nameunits(string, optional) - "metric" (default) or "imperial"
Returns:
๐
5-Day Weather Forecast for Taipei, TW
11/14/2025:
High: 26.5ยฐC | Low: 22.1ยฐC
Condition: Clear
11/15/2025:
High: 27.2ยฐC | Low: 23.4ยฐC
Condition: Clouds
...๐ Security Best Practices
Implemented in this sample:
โ API keys stored in environment variables (not in code)
โ Input validation for all parameters
โ Proper error handling (no sensitive data leakage)
โ HTTPS for external API calls
โ Minimal dependencies (reduces attack surface)
For production deployments:
๐ Use secrets management system (AWS Secrets Manager, Azure Key Vault)
๐ Implement rate limiting
๐ Add request logging/monitoring
๐ Use TLS for MCP communication if deployed remotely
๐ Localization
This server supports multiple languages through the OpenWeather API:
// Add language parameter to API call
const url = `${API_BASE_URL}/weather?q=${city}&units=${units}&lang=zh_tw&appid=${API_KEY}`;Supported languages: en, zh_tw, zh_cn, ja, ko, and 50+ more
๐ Troubleshooting
Common Issues
"City not found"
Check spelling of city name
Try including country code: "Taipei,TW"
"Weather API error: Unauthorized"
Verify your API key in
.envCheck API key is active at openweathermap.org
"Module not found"
Run
npm installCheck Node.js version >= 18.0.0
MCP server not detected in Claude
Verify
claude_desktop_config.jsonpathRestart Claude Desktop
Check server logs for errors
๐ Learn More
MCP Resources
Weather API
๐ค For OEM Partners
See PARTNER-GUIDE.md for:
Detailed integration guide
Deployment options
Customization examples
Production checklist
Support information
Contact: partners@irisgo.ai
๐ License
MIT License - see LICENSE file
๐ Credits
Created by: IrisGo.AI Team
MCP Protocol: Anthropic
Weather Data: OpenWeather
For: ASUS and AI PC OEM partners
๐ฎ Support
Issues: GitHub Issues
Email: support@irisgo.ai
Documentation: docs.irisgo.ai
Last Updated: 2025-11-14 Version: 1.0.0
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/lmanchu/weather-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server