MCP Tools Server
An MCP server providing tools for weather, calculations, currency conversion, timezone queries, and unit conversions.
README
MCP Tools Server
A Model Context Protocol (MCP) server providing 5 essential tools for weather information, calculations, currency conversion, timezone queries, and unit conversions.
Built with Python and FastMCP for AI Engineering applications.
๐ Features
This MCP server provides the following tools:
1. Weather Tool
Retrieve current weather conditions for any city or location worldwide.
- Supports city names, ZIP codes, and "City,Country" format
- Returns temperature, humidity, wind speed, and weather description
- Uses OpenWeatherMap API
2. Calculator Tool
Perform basic arithmetic operations with proper error handling.
- Operations: addition, subtraction, multiplication, division
- Handles division by zero gracefully
- Returns formatted expressions
3. Currency Converter Tool
Convert amounts between different currencies using live exchange rates.
- Supports 150+ currencies
- Real-time exchange rates
- Uses ExchangeRate-API
4. Time Zone Tool
Get current time and timezone information for major cities.
- Supports 20+ major cities worldwide
- Returns current time, UTC offset, day of week
- Uses WorldTimeAPI (no API key required)
5. Unit Converter Tool
Convert between common units of measurement.
- Length: meters, kilometers, miles, feet, inches, yards, centimeters, millimeters
- Weight: kilograms, grams, pounds, ounces, tons
- Temperature: Celsius, Fahrenheit, Kelvin
๐ Prerequisites
- Python 3.11 or higher
- pip (Python package manager)
- API keys for:
- OpenWeatherMap (free tier)
- ExchangeRate-API (free tier)
๐ ๏ธ Installation
Step 1: Clone the Repository
git clone https://github.com/yourusername/mcp-tools-server.git
cd mcp-tools-server
Step 2: Create Virtual Environment
# Create virtual environment
python -m venv venv
# Activate virtual environment
# On Windows PowerShell:
.\venv\Scripts\Activate.ps1
# On Windows Command Prompt:
.\venv\Scripts\activate.bat
# On macOS/Linux:
source venv/bin/activate
Step 3: Install Dependencies
pip install -r requirements.txt
Step 4: Configure API Keys
-
Copy the
.env.examplefile to.env:cp .env.example .env -
Edit
.envand add your API keys:OPENWEATHER_API_KEY=your_actual_api_key_here EXCHANGERATE_API_KEY=your_actual_api_key_here
๐ Usage
Running the Server
python server.py
The server will start and be available for MCP client connections.
Connecting with Claude Desktop
-
Open your Claude Desktop configuration file:
- Windows:
%APPDATA%\Claude\claude_desktop_config.json - macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
- Windows:
-
Add the server configuration:
{ "mcpServers": { "tools-server": { "command": "python", "args": ["C:/path/to/your/mcp-tools-server/server.py"], "env": {} } } } -
Restart Claude Desktop
Using MCP Inspector
# Install MCP Inspector globally
npm install -g @modelcontextprotocol/inspector
# Run inspector with your server
mcp-inspector python server.py
๐ Tool Documentation
Weather Tool
Function: get_weather(location: str)
Description: Retrieves current weather conditions for a specified location.
Parameters:
location(string): City name, ZIP code, or "City,Country" format
Example Request:
{
"tool": "get_weather",
"arguments": {
"location": "London"
}
}
Example Response:
{
"location": "London",
"country": "GB",
"temperature": "12ยฐC",
"feels_like": "10ยฐC",
"description": "Scattered Clouds",
"humidity": "76%",
"wind_speed": "4.5 m/s",
"status": "success"
}
Calculator Tool
Function: calculate(operation: str, num1: float, num2: float)
Description: Performs basic arithmetic operations.
Parameters:
operation(string): One of "add", "subtract", "multiply", "divide"num1(float): First numbernum2(float): Second number
Example Request:
{
"tool": "calculate",
"arguments": {
"operation": "multiply",
"num1": 15,
"num2": 4
}
}
Example Response:
{
"operation": "multiply",
"num1": 15,
"num2": 4,
"result": 60,
"expression": "15 multiply 4 = 60",
"status": "success"
}
Currency Converter Tool
Function: convert_currency(amount: float, from_currency: str, to_currency: str)
Description: Converts an amount from one currency to another using live exchange rates.
Parameters:
amount(float): Amount to convertfrom_currency(string): Source currency code (e.g., "USD", "EUR")to_currency(string): Target currency code
Example Request:
{
"tool": "convert_currency",
"arguments": {
"amount": 100,
"from_currency": "USD",
"to_currency": "EUR"
}
}
Example Response:
{
"amount": 100,
"from_currency": "USD",
"to_currency": "EUR",
"conversion_rate": 0.92,
"converted_amount": 92.0,
"formatted": "100 USD = 92.00 EUR",
"last_updated": "Wed, 08 Jan 2025 00:00:01 +0000",
"status": "success"
}
Time Zone Tool
Function: get_timezone_info(city: str)
Description: Gets current time and timezone information for a given city.
Parameters:
city(string): City name (e.g., "Tokyo", "New York")
Supported Cities: London, Paris, New York, Los Angeles, Tokyo, Sydney, Dubai, Singapore, Mumbai, Toronto, Berlin, Moscow, Beijing, Hong Kong, Chicago, Mexico City, Sao Paulo, Cairo, Lagos, Johannesburg
Example Request:
{
"tool": "get_timezone_info",
"arguments": {
"city": "Tokyo"
}
}
Example Response:
{
"city": "Tokyo",
"timezone": "Asia/Tokyo",
"current_time": "2026-01-10 15:30:45",
"utc_offset": "+09:00",
"day_of_week": "Saturday",
"day_of_year": 10,
"week_number": 2,
"status": "success"
}
Unit Converter Tool
Function: convert_units(value: float, from_unit: str, to_unit: str, category: str)
Description: Converts between common units of measurement.
Parameters:
value(float): Numeric value to convertfrom_unit(string): Source unitto_unit(string): Target unitcategory(string): One of "length", "weight", "temperature"
Example Request (Length):
{
"tool": "convert_units",
"arguments": {
"value": 100,
"from_unit": "km",
"to_unit": "miles",
"category": "length"
}
}
Example Response:
{
"value": 100,
"from_unit": "km",
"to_unit": "miles",
"category": "length",
"result": 62.1371,
"formatted": "100 km = 62.1371 miles",
"status": "success"
}
Example Request (Temperature):
{
"tool": "convert_units",
"arguments": {
"value": 32,
"from_unit": "fahrenheit",
"to_unit": "celsius",
"category": "temperature"
}
}
Example Response:
{
"value": 32,
"from_unit": "fahrenheit",
"to_unit": "celsius",
"category": "temperature",
"result": 0.0,
"formatted": "32 fahrenheit = 0.0 celsius",
"status": "success"
}
๐งช Testing
Manual Testing with MCP Inspector
-
Install MCP Inspector:
npm install -g @modelcontextprotocol/inspector -
Run the inspector:
mcp-inspector python server.py -
Test each tool through the inspector interface
Testing with Claude Desktop
- Configure Claude Desktop (see Usage section)
- In a conversation, ask Claude to use the tools:
- "What's the weather in Paris?"
- "Convert 100 USD to EUR"
- "What time is it in Tokyo?"
- "Calculate 25 multiplied by 4"
- "Convert 100 kilometers to miles"
๐ Project Structure
mcp-tools-server/
โ
โโโ server.py # Main MCP server implementation
โโโ requirements.txt # Python dependencies
โโโ .env # Environment variables (API keys) - not in git
โโโ .env.example # Example environment file
โโโ .gitignore # Git ignore file
โโโ README.md # This file
โโโ venv/ # Virtual environment (not in git)
๐ Security Notes
- Never commit your
.envfile to Git - The
.gitignorefile is configured to exclude sensitive files - API keys are stored securely in environment variables
- All API requests include timeout protection
๐ Error Handling
All tools include comprehensive error handling for:
- Invalid inputs
- Missing API keys
- Network failures
- API errors
- Division by zero (calculator)
- Invalid currency codes
- Unknown cities/locations
Errors are returned in a consistent format:
{
"error": "Descriptive error message",
"status": "error"
}
๐ Dependencies
fastmcp- FastMCP framework for building MCP serversrequests- HTTP library for API callspython-dotenv- Environment variable management
๐ค Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
๐ License
This project is open source and available under the MIT License.
๐ค Author
Your Name - Habeeb Temitope Lawal
๐ Acknowledgments
- FastMCP framework
- OpenWeatherMap API
- ExchangeRate-API
- WorldTimeAPI
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.