Connects Claude to the Google Maps Places API (New) for searching locations and fetching business information. Exposes two tools: places_text_search for query-based lookups like "coffee shops near King's Cross" and places_photo_get for retrieving place images. Built as an OAuth proxy that handles the Google authentication flow while staying stateless. The server itself holds no tokens, just forwards credentials and requests between your MCP client and Google's APIs. Useful when you need Claude to look up addresses, verify business hours, find nearby spots with specific criteria, or grab location details for calendar entries and trip planning.
MCP server for Google Maps Places API - search for places and get photos.
Meeting coordination: Someone emails "Let's meet at Nando's near the office - what time works best for you?" → your AI assistant looks up the location, checks opening hours, and adds it to your calendar with the address.
Local recommendations: Ask "find a quiet café with WiFi near King's Cross for a 2-hour work session" → get places with ratings, hours, and photos to help you decide.
Address validation: Confirm or autocomplete partial addresses before sending mail or booking deliveries.
(These are just examples - any workflow that needs place search or business info can use this.)
http://localhost:3000/callback to Authorized redirect URIsGOOGLE_CLIENT_ID='your-client-id' \
GOOGLE_CLIENT_SECRET='your-client-secret' \
MCP_TRANSPORT=http \
npm start
The server runs on http://localhost:3000 by default. Change with PORT=3001.
claude mcp add --transport http google-maps-places-mcp http://localhost:3000/mcp
This server acts as an OAuth proxy to Google:
graph LR
A[MCP client] <--> B[google-maps-places-mcp] <--> C[Google OAuth/API]
/.well-known/oauth-authorization-server/register returns the Google OAuth client credentials/authorize redirects to Google, encoding the client's callback URL in state/callback receives the code from Google and forwards to the client's callback/token proxies token requests to Google, injecting client credentials/mcp handles MCP requests, using the bearer token to call Places APIThe server holds no tokens or state - it just proxies OAuth to Google.
| Tool | Description |
|---|---|
places_text_search | Search for places by text query (e.g., "coffee shops near me") |
places_photo_get | Get a photo URL for a place |
cloud-platform - Access to Google Cloud APIs (required for Places API New)Pull requests are welcomed on GitHub! To get started:
npm installnpm run test to run testsnpm run buildVersions follow the semantic versioning spec.
To release:
npm version <major | minor | patch> to bump the versiongit push --follow-tags to push with tagsGOOGLE_ACCESS_TOKEN*secretGoogle OAuth access token with cloud-platform scope.
MCP_TRANSPORT*Transport type.
GOOGLE_CLIENT_ID*Google OAuth client ID.
GOOGLE_CLIENT_SECRET*secretGoogle OAuth client secret.
com.mcparmory/google-search
io.github.pipeworx-io/brave-search
marcopesani/mcp-server-serper
brave/brave-search-mcp-server
com.mcparmory/google-search-console
acamolese/google-search-console-mcp