A Model Context Protocol (MCP) server that provides comprehensive access to Google Maps Platform APIs. This server enables LLMs to perform geocoding, places search, routing, and other geospatial operations through a standardized interface.
- 🗺️ Comprehensive Google Maps Integration - Access to Places, Routes, Geocoding, and utility APIs
- 🔍 Advanced Places Search - Text search, nearby search, autocomplete, and detailed place information
- 🛣️ Smart Routing - Route computation with real-time traffic, tolls, and alternative routes
- 📍 Precise Geocoding - Forward and reverse geocoding with international support
- 🌐 Geolocation Services - IP-based and WiFi/cellular location estimation
- 📊 Rich Resources - Built-in documentation and examples accessible via MCP resources
- 🔒 Security First - Input validation, rate limiting, and secure API key handling
- Visit the Google Cloud Console
- Create a new project or select an existing one
- Enable the required APIs (see API requirements by tool below)
- Create an API key and restrict it to the enabled APIs
- Important: This server uses the new Google Maps Platform APIs (Places API (New) and Routes API), not the legacy versions
| Tool | Required Google Cloud Console API |
|---|---|
geocode_search, geocode_reverse |
Geocoding API |
places_search_text, places_nearby, places_autocomplete, places_details, places_photos |
Places API (New) |
routes_compute, routes_matrix |
Routes API |
elevation_get |
Elevation API |
timezone_get |
Time Zone API |
geolocation_estimate |
Geolocation API |
roads_nearest |
Roads API |
ip_geolocate, nearby_find |
Geolocation API + Places API (New) |
Add the server to your MCP client configuration:
Add to your Cursor MCP settings (~/.cursor/mcp.json or through Command Palette > Open MCP Settings > New MCP Server):
{
"mcpServers": {
"google-maps": {
"command": "npx",
"args": ["-y", "google-maps-mcp-server"],
"env": {
"GOOGLE_MAPS_API_KEY": "your-api-key-here"
}
}
}
}With custom rate limiting:
{
"mcpServers": {
"google-maps": {
"command": "npx",
"args": ["-y", "google-maps-mcp-server"],
"env": {
"GOOGLE_MAPS_API_KEY": "your-api-key-here",
"GOOGLE_MAPS_RATE_LIMIT_ENABLED": "true",
"GOOGLE_MAPS_RATE_LIMIT_WINDOW_MS": "120000",
"GOOGLE_MAPS_RATE_LIMIT_MAX_REQUESTS": "200"
}
}
}
}Add to claude_desktop_config.json:
{
"mcpServers": {
"google-maps": {
"command": "npx",
"args": ["google-maps-mcp-server"],
"env": {
"GOOGLE_MAPS_API_KEY": "your-api-key-here"
}
}
}
}With rate limiting disabled:
{
"mcpServers": {
"google-maps": {
"command": "npx",
"args": ["google-maps-mcp-server"],
"env": {
"GOOGLE_MAPS_API_KEY": "your-api-key-here",
"GOOGLE_MAPS_RATE_LIMIT_ENABLED": "false"
}
}
}
}# Set environment variable
export GOOGLE_MAPS_API_KEY="your-api-key-here"
# Run the server
npx google-maps-mcp-servergeocode_search- Convert addresses to coordinatesgeocode_reverse- Convert coordinates to addresses
places_search_text- Search places with natural languageplaces_nearby- Find places within a radiusplaces_autocomplete- Get place suggestionsplaces_details- Get detailed place informationplaces_photos- Get place photo URLs
routes_compute- Calculate optimal routesroutes_matrix- Compute distance matrices
elevation_get- Get elevation datatimezone_get- Get timezone informationgeolocation_estimate- Estimate location from WiFi/cell dataroads_nearest- Find nearest roads
nearby_find- Find nearby cities, towns, or POIsip_geolocate- Geolocate using IP address
{
"tool": "places_nearby",
"arguments": {
"location": {"lat": 37.7749, "lng": -122.4194},
"radius_meters": 1000,
"included_types": ["restaurant"],
"max_results": 10
}
}{
"tool": "routes_compute",
"arguments": {
"origin": {"address": "San Francisco, CA"},
"destination": {"address": "Los Angeles, CA"},
"travel_mode": "DRIVE",
"routing_preference": "TRAFFIC_AWARE"
}
}{
"tool": "geocode_search",
"arguments": {
"query": "1600 Amphitheatre Parkway, Mountain View, CA",
"language": "en"
}
}{
"tool": "ip_geolocate",
"arguments": {
"reverse_geocode": true
}
}The ip_geolocate tool also supports an optional ip_override parameter for testing with different IP addresses:
{
"tool": "ip_geolocate",
"arguments": {
"ip_override": "8.8.8.8",
"reverse_geocode": true
}
}Note: The ip_override parameter accepts public IPv4 or IPv6 addresses. Private and reserved IP ranges (10.0.0.0/8, 172.16.0.0/12, 192.168.0.0/16, 127.0.0.0/8) are rejected. The IP override is best-effort and Google's Geolocation API may not always honor the request.
GOOGLE_MAPS_API_KEY(required) - Your Google Maps Platform API key
GOOGLE_MAPS_RATE_LIMIT_ENABLED(optional, default:true) - Enable/disable rate limiting- Set to
falseto disable rate limiting entirely
- Set to
GOOGLE_MAPS_RATE_LIMIT_WINDOW_MS(optional, default:60000) - Rate limit window in milliseconds- Controls the time window for rate limiting (e.g., 60000 = 1 minute)
GOOGLE_MAPS_RATE_LIMIT_MAX_REQUESTS(optional, default:100) - Maximum requests per window- Maximum number of requests allowed per endpoint within the time window
# Default rate limiting (100 requests per minute per endpoint)
GOOGLE_MAPS_API_KEY="your-api-key-here"
# Disable rate limiting entirely
GOOGLE_MAPS_API_KEY="your-api-key-here"
GOOGLE_MAPS_RATE_LIMIT_ENABLED=false
# Custom rate limiting (200 requests per 2 minutes per endpoint)
GOOGLE_MAPS_API_KEY="your-api-key-here"
GOOGLE_MAPS_RATE_LIMIT_WINDOW_MS=120000
GOOGLE_MAPS_RATE_LIMIT_MAX_REQUESTS=200
# Stricter rate limiting (50 requests per 30 seconds per endpoint)
GOOGLE_MAPS_API_KEY="your-api-key-here"
GOOGLE_MAPS_RATE_LIMIT_WINDOW_MS=30000
GOOGLE_MAPS_RATE_LIMIT_MAX_REQUESTS=50This server uses Google Maps Platform APIs which require billing to be enabled. Monitor your usage in the Google Cloud Console to avoid unexpected charges. Consider implementing usage limits in your application.
The server provides built-in MCP resources with documentation and examples:
google-maps://docs/api-overview- API overview and capabilitiesgoogle-maps://docs/place-types- Complete place types referencegoogle-maps://docs/travel-modes- Available travel modesgoogle-maps://docs/field-masks- Places API field optimizationgoogle-maps://examples/common-queries- Example queries and patterns
Access these through your MCP client's resource interface.
git clone <repository-url>
cd google-maps-mcp-server
npm install
npm run buildnpm testnpm run build
GOOGLE_MAPS_API_KEY="your-api-key-here" npx @modelcontextprotocol/inspector ./dist/index.jsThe server returns structured errors with helpful context:
{
"error": {
"code": "QUOTA_EXCEEDED",
"message": "API quota exceeded",
"context": {
"endpoint": "/places/textsearch",
"status": 429
}
}
}Common error codes:
INVALID_REQUEST- Invalid input parametersAPI_KEY_INVALID- Invalid or missing API keyQUOTA_EXCEEDED- API quota exceededREQUEST_FAILED- Network or API request failed
- API keys are never logged or exposed
- Input validation prevents injection attacks
- Rate limiting protects against abuse
- IP addresses are hashed in logs for privacy
Contributions are welcome! Please submit pull requests to our GitHub repository.
MIT License - see LICENSE file for details.