Integrations
Allows listing repository commits and authenticates using GitHub Personal Access Token.
Enables place search functionality with configurable search radius using the Google Maps API.
MCP (Model Context Protocol) Integration Examples
This repository demonstrates the usage of Model Context Protocol (MCP) with various integrations including a custom calculator server, GitHub, and Google Maps.
What is MCP?
Model Context Protocol (MCP) is a protocol that enables AI models to interact with external tools and services. It provides a standardized way for AI models to:
- Execute tools and functions
- Access resources
- Generate prompts
- Interact with external services
Project Structure
├── server.py # MCP server (custom creation)
├── client_server.py # MCP Client
├── 1)maps.py # Google Maps MCP integration
├── 2)github.py # GitHub MCP integration
└── requirements.txt # Project dependencies
Features
1. Custom Calculator Server
- Implements basic arithmetic operations
- Demonstrates MCP tool creation
- Shows resource and prompt handling
2. GitHub Integration
- List repository commits
- Uses GitHub Personal Access Token for authentication
- Demonstrates environment variable handling
3. Google Maps Integration
- Search for places using Google Maps API
- Configurable search radius
- Environment variable based API key management
Setup
- Install dependencies:
pip install -r requirements.txt
MCP Tools Types
- Tools: Functions that perform specific actions
- Defined using
@mcp.tool
decorator - Can accept parameters and return values
- Defined using
- Resources: Static or dynamic data sources
- Defined using
@mcp.resource
decorator - Accessed using resource URLs
- Defined using
- Prompts: Template-based text generation
- Defined using
@mcp.prompt
decorator - Can include dynamic content
- Defined using
Best Practices
- Always use environment variables for sensitive data
- Implement proper error handling
- Use type hints for better code clarity
- Document your tools with clear docstrings
- Keep API keys secure and never commit them to version control
Usage Examples
Calculator
Server side ( initialize )
@mcp.tool(name="add")
def add(a: int, b: int):
return a + b
Running server.py file, it will up and run the MCP server.
Client side ( utilize )
result = await session.call_tool("add", arguments={"a": 5, "b": 3})
Running client_server.py file, it will connect to the MCP server.
This server cannot be installed
A server implementation demonstrating how AI models can interact with external tools and services through Model Context Protocol, featuring integrations for calculator functions, GitHub repositories, and Google Maps searches.
Related MCP Servers
- -securityFlicense-qualityA server that enables AI systems to browse, retrieve content from, and interact with web pages through the Model Context Protocol.Last updated -
- -securityFlicense-qualityA demonstration implementation of the Model Context Protocol server that facilitates communication between AI models and external tools while maintaining context awareness.Last updated -Python
- -securityFlicense-qualityA comprehensive Model Context Protocol server implementation that enables AI assistants to interact with file systems, databases, GitHub repositories, web resources, and system tools while maintaining security and control.Last updated -16TypeScript
- -securityAlicense-qualityA customizable Model Context Protocol server implementation that enables AI models to interact with external tools including weather queries, Google search, and camera control functionality.Last updated -8PythonApache 2.0