MCP Utility Kit
Provides utility tools including random jokes, current weather, and name-based age prediction.
README
MCP Utility Kit
An MCP (Model Context Protocol) server built with FastMCP that provides three useful daily utility tools:
Tools Provided
- Random Joke - Get a random joke of the day
- Weather Data - Get current weather using latitude and longitude
- Age Prediction - Predict age based on a person's name
Features
- š Daily jokes from the Official Joke API
- š¤ļø Real-time weather data from Open-Meteo
- š¤ Name-based age prediction from Agify
- š Fast and lightweight MCP server
- š¦ Published on PyPI - ready to use
- ā” No installation needed with
uvx
Quick Start
No installation or cloning required! Just add to your MCP configuration and start using.
Prerequisites
- uv package manager
Install uv:
curl -LsSf https://astral.sh/uv/install.sh | sh
Installation & Setup
Quick Command (Claude CLI)
If you have the Claude CLI installed, add the server with one command:
claude mcp add daily-utils uvx mcp-utility-kit
Option 1: Direct Use with uvx (Recommended)
Use directly without installation:
Add this configuration to your MCP settings file:
VSCode: ~/Library/Application Support/Code/User/mcp.json (Mac) or %APPDATA%\Code\User\mcp.json (Windows)
Claude Desktop: ~/Library/Application Support/Claude/claude_desktop_config.json (Mac)
{
"mcpServers": {
"daily-utils": {
"command": "uvx",
"args": ["mcp-utility-kit"],
"type": "stdio"
}
}
}
Then reload your MCP client:
- VSCode: Press
Cmd+Shift+P(Mac) orCtrl+Shift+P(Windows) ā "Developer: Reload Window" - Claude Desktop: Restart the application
That's it! The server will automatically download and run.
Option 2: Install via pip
If you prefer traditional installation:
pip install mcp-utility-kit
Then run directly:
python -m mcp_utility_kit
Option 3: Local Development Setup
For contributing or modifying the code:
- Clone the repository:
git clone https://github.com/thananauto/mcp-utility-kit.git
cd mcp-utility-kit
- Install dependencies:
uv sync
- Use local configuration in
mcp.json:
{
"mcpServers": {
"daily-utils": {
"command": "uv",
"args": [
"run",
"--directory",
"/full/path/to/mcp-utility-kit",
"python",
"-m",
"mcp_utility_kit"
],
"type": "stdio"
}
}
}
Replace /full/path/to/mcp-utility-kit with your local clone path
Usage
Once configured in your MCP client, you can use these tools through your AI assistant:
- "Tell me a joke" - Gets a random joke
- "What's the weather in New York?" (provide latitude: 40.7128, longitude: -74.0060)
- "Predict the age for the name Michael"
Running Standalone in Terminal
# Run directly with uvx (no install needed)
uvx mcp-utility-kit
# Or if installed via pip
python -m mcp_utility_kit
# From local development
uv run python -m mcp_utility_kit
Testing with MCP Inspector
The MCP Inspector provides a web UI for testing:
# Test published version
npx @modelcontextprotocol/inspector uvx mcp-utility-kit
# Test local version
npx @modelcontextprotocol/inspector uv run python -m mcp_utility_kit
This opens a browser interface where you can test all tools interactively.
Available Tools
1. get_joke_of_the_day()
Gets a random joke from the Official Joke API.
Returns: A formatted joke with setup and punchline
Example:
Why did the chicken cross the road?
To get to the other side!
2. get_weather(latitude: float, longitude: float)
Gets current weather data for a location.
Parameters:
latitude- Latitude of the location (e.g., 52.52 for Berlin)longitude- Longitude of the location (e.g., 13.41 for Berlin)
Returns: Formatted weather summary with temperature, wind speed, humidity, and weather code
Example:
get_weather(latitude=40.7128, longitude=-74.0060) # New York City
3. predict_age_by_name(name: str)
Predicts the age associated with a given name using the Agify API.
Parameters:
name- First name to predict age for (e.g., "Michael", "Sarah")
Returns: Predicted age and confidence count
Example:
predict_age_by_name(name="Michael")
APIs Used
This server integrates with the following free APIs:
- Official Joke API - Random jokes
- Open-Meteo Weather API - Weather data (no API key required)
- Agify Age Prediction API - Name-based age prediction
Updating the Package
This package is published on PyPI at: https://pypi.org/project/mcp-utility-kit/
Publishing Updates
To publish a new version:
- Update version in pyproject.toml:
version = "0.2.0" # Increment version number
- Build the package:
uv build
- Install publishing tools (if not already installed):
uv pip install twine
- Upload to PyPI:
uv run twine upload -u __token__ -p YOUR_PYPI_TOKEN dist/*
Get your PyPI token from: https://pypi.org/manage/account/token/
Test Before Publishing
Test on Test PyPI first (optional):
uv run twine upload --repository testpypi -u __token__ -p YOUR_TEST_TOKEN dist/*
Sharing with Team Members
Team members can use this server immediately with no installation:
1. Install uv (if needed)
curl -LsSf https://astral.sh/uv/install.sh | sh
2. Add MCP Configuration
Add to mcp.json (VSCode) or claude_desktop_config.json (Claude Desktop):
{
"mcpServers": {
"daily-utils": {
"command": "uvx",
"args": ["mcp-utility-kit"],
"type": "stdio"
}
}
}
3. Reload MCP Client
That's it! No cloning, no manual installation needed.
Package Link: https://pypi.org/project/mcp-utility-kit/ Repository: https://github.com/thananauto/mcp-utility-kit
Project Structure
mcp-utility-kit/
āāā mcp_utility_kit/
ā āāā __init__.py # Package initialization
ā āāā server.py # MCP server implementation with tools
ā āāā __main__.py # Entry point
āāā pyproject.toml # Project configuration and dependencies
āāā uv.lock # Dependency lock file
āāā README.md # This file
Development
Built With
- FastMCP - Framework for building MCP servers
- httpx - Async HTTP client for API requests
- uv - Fast Python package manager
Adding New Tools
To add a new tool to the server:
- Open mcp_utility_kit/server.py
- Add a new function decorated with
@mcp.tool():
@mcp.tool()
async def your_new_tool(param: str) -> str:
"""Tool description for LLM context.
Args:
param: Parameter description
Returns:
What the tool returns
"""
# Your implementation here
return "result"
- Test locally with MCP Inspector
- Rebuild and republish if deploying to PyPI
Troubleshooting
Server Won't Start
-
Check uv is installed:
uv --versionIf not installed:
curl -LsSf https://astral.sh/uv/install.sh | sh -
Test the server directly:
uvx mcp-utility-kit -
Check MCP configuration: Ensure
mcp.jsonhas the correct format (see Installation section) -
View logs: In VS Code, open Output panel (View ā Output) and select "MCP" from dropdown
Tools Not Appearing
- Reload MCP client: In VS Code, press
Cmd+Shift+Pā "Developer: Reload Window" - Check server status: Look for "daily-utils" in the MCP Output logs
- Verify configuration: Double-check the JSON syntax in your
mcp.json
Package Version Issues
To force update to the latest version:
uvx --refresh mcp-utility-kit
API Errors
- Check internet connection: All three APIs require internet access
- Rate limits: Free tier APIs may have rate limits
- Regional restrictions: Verify APIs are accessible from your location
Getting Help
- Check logs: VS Code Output panel ā MCP section shows detailed error messages
- GitHub Issues: https://github.com/thananauto/mcp-utility-kit/issues
- MCP Documentation: https://modelcontextprotocol.io/
License
MIT License - see LICENSE file for details
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Support
For issues and questions:
- Open an issue in the repository
- Check existing issues for solutions
- Review the MCP documentation
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.