seo-mcp
This MCP server provides AI assistants with direct access to SEO tools across Google Search Console, the Google Indexing API, and Bing Webmaster Tools.
Google Search Console (GSC)
gsc_search_performance— Retrieve clicks, impressions, CTR, and position data with filtering (query, page, device, country) and multi-dimension groupinggsc_striking_distance— Identify queries ranking in positions 4–20 (quick-win opportunities), sorted by impressionsgsc_traffic_drop— Compare two date periods to surface pages/queries with the largest click declines (useful for diagnosing algorithm updates or content decay)gsc_url_inspection— Inspect a URL's indexing status, crawl date, canonical URL, rich results eligibility, and mobile usabilitygsc_sitemap_list— List all submitted sitemaps with status, URL counts, indexed counts, and error summariesgsc_brand_nonbrand— Split search traffic into branded vs. non-branded segments with aggregated metrics and top queries per segment
Google Indexing API
request_indexing— Request indexing or re-indexing of a single URLrequest_indexing_batch— Submit batches of up to 200 URLs for indexing/re-indexing
Bing Webmaster Tools
bing_keyword_research— Get monthly search volume and related keywords from Bing, with country and language filteringbing_crawl_health— View crawl statistics and error counts by type (4xx, timeouts, DNS failures, blocked) plus specific crawl issuesbing_url_inspection— Inspect a URL's HTTP status, indexing state, crawl date, page title, link counts, and redirect info in Bingbing_sitemap_list— List sitemaps registered in Bing with URL counts, indexed counts, errors, and last crawl time
Together, these 12 tools enable content optimization, traffic analysis, indexing audits, keyword research, and programmatic URL submission — all directly within the chat.
Provides tools for Google Search Console including search performance data (clicks, impressions, CTR, position), striking distance query identification, traffic drop analysis, URL inspection for indexing status and mobile usability, sitemap listing, and brand vs non-brand traffic segmentation.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@seo-mcpshow my Google Search Console clicks and impressions for last week"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
@patchwindow/seo-mcp
MCP server for Google Search Console, Bing Webmaster Tools, and the Google Indexing API. Give your AI assistant live access to search performance data, indexing status, keyword research, crawl health, and programmatic URL submission — directly in the chat.
Features
12 SEO tools across Google Search Console, Google Indexing API, and Bing Webmaster Tools
Keyword research via Bing — search volume and related keywords not available in GSC
Traffic drop analysis — automatically compare two periods and surface the biggest drops
Striking distance finder — identify queries in positions 4–20 ready for quick ranking gains
Brand vs. non-brand split — segment traffic without leaving your AI chat
Dual URL inspection — inspect any URL in both Google and Bing simultaneously
Google Indexing API — request indexing or re-indexing for individual URLs or batches of up to 200
Simple auth — Bing needs one env var; GSC uses a one-time OAuth2 flow with auto-refreshing tokens
Config file defaults — set your site URL once, skip it on every tool call
Installation
Install globally:
npm install -g @patchwindow/seo-mcpOr run without installing:
npx @patchwindow/seo-mcpSetup
Bing Webmaster Tools
Bing uses an API key. No OAuth required.
Go to Bing Webmaster Tools
Navigate to Settings → API Access
Generate an API key
Set the environment variable:
export BING_WEBMASTER_API_KEY="your-api-key"That's it.
Google Search Console
GSC requires OAuth2. Service accounts do not work with the Search Console API — user credentials are required.
Step 1: Create a Google Cloud project
Go to Google Cloud Console
Create a new project (or select an existing one)
Go to APIs & Services → Library
Search for Google Search Console API and enable it
Search for Web Search Indexing API and enable it (required for
request_indexingandrequest_indexing_batch)
Step 2: Create OAuth2 credentials
Go to APIs & Services → Credentials → Create Credentials → OAuth 2.0 Client ID
Choose Web application as the application type
Under Authorized redirect URIs, add:
http://localhost:3847/callbackCopy the Client ID and Client Secret
Step 3: Authenticate (one-time)
Set your credentials as environment variables, then run the auth command:
export GSC_CLIENT_ID="your-client-id.apps.googleusercontent.com"
export GSC_CLIENT_SECRET="your-client-secret"
npx @patchwindow/seo-mcp auth gscA browser window opens for Google login. After approving, the token is saved to ~/.seo-mcp/gsc-token.json. You only need to do this once — the token refreshes automatically.
Re-auth required for v0.2.0: The Indexing API scope (
https://www.googleapis.com/auth/indexing) was added in v0.2.0. If you authenticated with an older version, runnpx @patchwindow/seo-mcp auth gscagain to grant the new scope. Your existing token will be replaced.
Config File (optional)
Create ~/.seo-mcp/config.json to set default site URLs. This lets you skip the site_url parameter on every tool call:
{
"gsc": {
"default_site": "sc-domain:example.com"
},
"bing": {
"default_site": "https://example.com/"
},
"output": {
"max_rows": 500
}
}GSC site URL format: Use sc-domain:example.com for domain properties or https://example.com/ for URL prefix properties. Check which type you have in Search Console under your property settings.
Claude Desktop Integration
Add the following to your claude_desktop_config.json (typically at ~/Library/Application Support/Claude/claude_desktop_config.json on macOS or %APPDATA%\Claude\claude_desktop_config.json on Windows):
{
"mcpServers": {
"seo": {
"command": "npx",
"args": ["@patchwindow/seo-mcp"],
"env": {
"BING_WEBMASTER_API_KEY": "your-bing-api-key",
"GSC_CLIENT_ID": "your-client-id.apps.googleusercontent.com",
"GSC_CLIENT_SECRET": "your-client-secret"
}
}
}
}Cursor / Windsurf (.cursor/mcp.json or mcp.json):
{
"seo-mcp": {
"command": "npx",
"args": ["@patchwindow/seo-mcp"],
"env": {
"BING_WEBMASTER_API_KEY": "your-bing-api-key",
"GSC_CLIENT_ID": "your-client-id.apps.googleusercontent.com",
"GSC_CLIENT_SECRET": "your-client-secret"
}
}
}Restart your AI client after saving the config.
Tools Reference
* = not required if default_site is set in ~/.seo-mcp/config.json.
Google Search Console
Tool | Description | Required params | Optional params |
| Clicks, impressions, CTR, and position. Supports grouping by query, page, country, device, or date. |
|
|
| Queries in positions 4–20 sorted by impressions — best candidates for quick ranking improvements. |
|
|
| Compare two date periods and surface pages or queries with the largest click drops. |
|
|
| Indexing status, crawl date, canonical URL, page fetch state, rich results, and mobile usability for a specific URL. |
|
|
| All sitemaps submitted to GSC with status, URL counts, indexed counts, and error summary. | — |
|
| Split search traffic into branded and non-branded segments with aggregated clicks, impressions, CTR, and position. |
|
|
| Ask Google to index or re-index a single URL via the Indexing API. Returns confirmation and |
| — |
| Ask Google to index or re-index a batch of URLs (max 200 — daily quota). Returns a per-URL report of successes and failures. |
|
|
Bing Webmaster Tools
Tool | Description | Required params | Optional params |
| Monthly search volume and related keywords from Bing. This data is exclusive to Bing — not available in GSC. |
|
|
| Crawl statistics (total crawled, errors by type: 4xx, timeouts, DNS failures, blocked) and a list of specific crawl issues. | — |
|
| HTTP status, indexing state, crawl date, page title, internal/external link counts, and redirect target for a URL. |
|
|
| Sitemaps registered in Bing Webmaster Tools with URL counts, indexed counts, errors, and last crawl time. | — |
|
Parameter details
Parameter | Type | Description |
| string | GSC site URL ( |
| string | Start date, YYYY-MM-DD |
| string | End date, YYYY-MM-DD |
| array | Group by: |
| string | Filter to queries containing this string |
| string | Filter to this exact page URL |
| string |
|
| string | ISO 3166-1 alpha-3 country code, e.g. |
| number | Max rows. Default: 100. Max: 25000 |
Parameter | Type | Description |
| string | GSC site URL |
| string | Start date, YYYY-MM-DD |
| string | End date, YYYY-MM-DD |
| number | Min position to include. Default: 4 |
| number | Max position to include. Default: 20 |
| number | Min impressions to include. Default: 10 |
| number | Max results. Default: 50 |
Parameter | Type | Description |
| string | GSC site URL |
| string | Current period start, YYYY-MM-DD |
| string | Current period end, YYYY-MM-DD |
| string | Previous period start, YYYY-MM-DD |
| string | Previous period end, YYYY-MM-DD |
| string |
|
| number | Minimum drop % to flag. Default: 20 |
| number | Minimum clicks in previous period. Default: 5 |
| number | Max results. Default: 25 |
Parameter | Type | Description |
| string | GSC site URL |
| string | Start date, YYYY-MM-DD |
| string | End date, YYYY-MM-DD |
| array | Brand terms to match, case-insensitive. E.g. |
| boolean | Include top 10 queries per segment. Default: true |
Parameter | Type | Description |
| string | The keyword to research |
| string | Bing site URL |
| string | Two-letter country code, e.g. |
| string | Language code, e.g. |
| boolean | Include related keywords. Default: true |
Parameter | Type | Description |
| string | Bing site URL |
| boolean | Include specific crawl issues. Default: true |
| number | Max issues to show. Default: 20 |
Parameter | Type | Description |
| string | The publicly accessible URL to request indexing for |
Requires the https://www.googleapis.com/auth/indexing scope. If you receive a 403, re-run npx @patchwindow/seo-mcp auth gsc and ensure the Web Search Indexing API is enabled in your Google Cloud project.
Parameter | Type | Description |
| string[] | Array of publicly accessible URLs (min 1, max 200) |
| number | Milliseconds between requests. Default: 10. Max: 10000 |
The Google Indexing API has a default quota of 200 URL notifications per day. The batch tool sends requests in series with the configured delay to stay within Google's recommended rate of 100 req/s.
Examples
Ask your AI assistant:
Find quick wins for content optimization:
"Show me my top striking distance queries for the last 90 days. I want queries where I'm ranking between 5 and 15 with at least 50 impressions."
Diagnose a traffic drop:
"Compare my search traffic for April 2025 vs April 2024 by page. Flag anything that dropped more than 30%."
Research a topic before writing:
"Research the keyword 'typescript performance' in Bing. Show me monthly search volume and the top related keywords."
Audit indexing:
"Inspect the URL https://example.com/blog/my-post and tell me its indexing status, canonical URL, and whether it's eligible for rich results."
Understand brand exposure:
"Split my search traffic for Q1 2025 into branded and non-branded. My brand terms are 'acme' and 'acmecorp'. Show me the top 10 queries for each segment."
Request indexing after a publish:
"I just published three new blog posts. Request indexing for https://example.com/blog/post-1, /post-2, and /post-3."
Bulk re-index after a site migration:
"Here are 150 URLs that moved during our migration. Request indexing for all of them."
Roadmap
Planned for a future release:
gsc_top_pages— top pages by traffic with trend comparisonbing_link_counts— inbound link data (not available in GSC API)bing_url_submit— trigger reindexing for new or updated URLs in Binggsc_batch_url_inspection— inspect a list of URLs with rate-limit handlingbing_crawl_settings— read and update Bing crawl frequency settingsMulti-site support — switch between properties without reconfiguring
Building from Source
git clone https://github.com/patchwindow/seo-mcp
cd seo-mcp
npm install
npm run buildContributing
Issues and pull requests are welcome. Please open an issue before starting work on a significant change.
License
MIT — Patch Window
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/patchwindow/seo-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server