Google Business Profile Review MCP Server
Enables AI assistants to fetch, analyze, and respond to Google Business Profile reviews with AI-generated replies through secure OAuth integration with Google's My Business API.
README
Google Business Profile Review MCP Server
A Model Context Protocol (MCP) server that enables AI assistants to manage Google Business Profile reviews through intelligent automation.
Features
- Review Management: Fetch and analyze Google Business Profile reviews
- AI-Powered Responses: Generate contextually appropriate replies using LLM sampling
- Automated Posting: Post replies back to Google Business Profile
- OAuth Integration: Secure authentication with Google APIs
- Rate Limiting: Respectful API usage with built-in rate limiting
- Structured Logging: Comprehensive logging for debugging and monitoring
Prerequisites
- Node.js 18.0.0 or higher
- Google Cloud Platform account with My Business API enabled
- Google OAuth 2.0 credentials
- Google Business Profile API Access (see requirements below)
Google Business Profile API Access Requirements
Before you can use this MCP server, you must request and be approved for Google Business Profile API access. Google requires all applicants to:
- Manage a verified Google Business Profile that has been active for 60+ days
- This can be your own business or a client's business you manage
- Have a website representing the business listed on the Google Business Profile
- Complete Google Business Profile with current, up-to-date information
To request API access:
- Go to the Google Cloud Console and note your Project Number from the Project info card
- Submit your request using the GBP API contact form
- Select "Application for Basic API Access" from the dropdown
- Provide your Project Number and all requested information
- Use an email address listed as an owner/manager on your business's GBP
- Wait for review - you'll receive a follow-up email with the decision
Check approval status by viewing quotas in Google Cloud Console:
- 0 QPM (Queries Per Minute) = Not yet approved
- 300 QPM = Approved ✓
For complete prerequisites, see the official GBP API documentation.
Setup
1. Google Cloud Configuration
- Go to the Google Cloud Console
- Create a new project or select an existing one
- Request GBP API access (see requirements above - this step is critical and may take time for approval)
- Enable the following APIs (after your project is approved):
- Go to "APIs & Services" > "Library"
- Search for and enable "Google My Business API"
- Search for and enable "My Business Account Management API"
- Create OAuth 2.0 credentials:
- Go to "Credentials" in the API & Services section
- Click "Create Credentials" > "OAuth 2.0 Client IDs"
- Set application type to "Web application"
- Add authorized redirect URI:
http://localhost:3000/auth/callback - Note down the Client ID and Client Secret
- Configure OAuth Consent Screen:
- Go to "APIs & Services" > "OAuth consent screen"
- Add test users (your Google account email that has access to the business profile)
- Add required scopes:
business.manage,userinfo.email,userinfo.profile
2. Installation
# Clone the repository
git clone <repository-url>
cd review-mcp
# Install dependencies
npm install
# Build the project
npm run build
3. Configuration
# Copy the environment template
cp .env.example .env
# Edit .env with your credentials
# Add your Google OAuth credentials and other settings
Required environment variables:
GOOGLE_CLIENT_ID: Your Google OAuth 2.0 Client IDGOOGLE_CLIENT_SECRET: Your Google OAuth 2.0 Client SecretGOOGLE_REDIRECT_URI: OAuth redirect URI (default: http://localhost:3000/auth/callback)
4. Authentication
Before running the server, you need to authenticate with Google:
# Run the authentication helper
npm run auth
This will:
- Open your browser to Google's authentication page
- Ask you to grant permissions to access your Google Business Profile
- Save the authentication tokens locally
- These tokens will be automatically used by the MCP server
5. Running the Server
# Start the server with your authenticated credentials
npm start
# Or in development/mock mode for testing
npm run start:mock
The server will start with STDIO transport for MCP communication.
Usage
Connecting to MCP Clients
You can connect to this server using any MCP-compatible client:
VS Code (GitHub Copilot)
Add to your VS Code MCP settings file (mcp.json):
Windows: %APPDATA%\Code\User\profiles\<profile-id>\mcp.json
macOS/Linux: ~/.config/Code/User/profiles/<profile-id>/mcp.json
{
"servers": {
"google-business-reviews": {
"type": "stdio",
"command": "node",
"args": [
"C:\\path\\to\\review-mcp\\build\\index.js"
],
"cwd": "C:\\path\\to\\review-mcp",
"env": {
"NODE_ENV": "production",
"GOOGLE_CLIENT_ID": "your-client-id.apps.googleusercontent.com",
"GOOGLE_CLIENT_SECRET": "your-client-secret",
"GOOGLE_REDIRECT_URI": "http://localhost:3000/auth/callback",
"LOG_LEVEL": "info"
},
"description": "Google Business Profile Review MCP Server - Manage reviews with AI-powered responses"
}
}
}
Important Notes:
- Replace
C:\\path\\to\\review-mcpwith the actual path to your project - Use double backslashes (
\\) in Windows paths - Replace
your-client-idandyour-client-secretwith your actual OAuth credentials - Make sure to run
npm run authfirst to authenticate before using in VS Code - Restart VS Code after adding the configuration
Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"google-business-reviews": {
"command": "node",
"args": ["/path/to/review-mcp/build/index.js"],
"env": {
"GOOGLE_CLIENT_ID": "your-client-id.apps.googleusercontent.com",
"GOOGLE_CLIENT_SECRET": "your-client-secret",
"GOOGLE_REDIRECT_URI": "http://localhost:3000/auth/callback"
}
}
}
}
HTTP Clients
Connect to: http://localhost:3000/mcp
Available Tools
list_locations: Get all business locations associated with your accountget_reviews: Fetch reviews for a specific locationgenerate_reply: Generate an AI response to a reviewpost_reply: Post a reply to a review on Google Business Profile
Available Resources
business_profile: Business profile information and settingsreview_templates: Pre-defined response templates
Available Prompts
review_response: Generate professional review responsessentiment_analysis: Analyze review sentiment
Development
Project Structure
src/
├── index.ts # Main server entry point
├── server/ # MCP server implementation
│ ├── mcpServer.ts # Core MCP server setup
│ ├── tools/ # Tool implementations
│ ├── resources/ # Resource implementations
│ └── prompts/ # Prompt implementations
├── services/ # Business logic services
│ ├── googleAuth.ts # Google OAuth handling
│ ├── reviewService.ts # Review management
│ └── llmService.ts # LLM interaction
├── types/ # TypeScript type definitions
└── utils/ # Utility functions
Scripts
npm run dev: Start development server with hot reloadnpm run build: Build the TypeScript projectnpm run lint: Run ESLintnpm run test: Run testsnpm run clean: Clean build directory
API Documentation
Authentication Flow
- User initiates OAuth flow through the MCP client
- Server redirects to Google OAuth consent screen
- User grants permissions for Google My Business access
- Server receives authorization code and exchanges for access token
- Token is stored securely for subsequent API calls
Rate Limiting
The server implements rate limiting to respect Google API quotas:
- 60 requests per minute per user (configurable)
- Exponential backoff for failed requests
- Graceful error handling for quota exceeded
Security Considerations
- All Google API calls use OAuth 2.0 authentication
- Access tokens are stored securely and refreshed automatically
- Input validation and sanitization for all user inputs
- Rate limiting to prevent abuse
- Comprehensive logging for security monitoring
Troubleshooting
Common Issues
- OAuth Error: Ensure redirect URI matches exactly what's configured in Google Cloud Console
- API Quota Exceeded: Check your Google Cloud Console for API usage and limits
- Permission Denied: Verify the Google account has access to the business profile
Logging
Enable debug logging by setting LOG_LEVEL=debug in your .env file.
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for new functionality
- Run the test suite
- Submit a pull request
License
MIT License - see LICENSE file for details.
Support
For issues and questions:
- Check the troubleshooting section
- Review the logs with debug level enabled
- Open an issue on GitHub with detailed information about the problem
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.