MCP server for Google Search Console. Query search analytics, inspect URLs, and monitor SEO performance from any MCP-compatible client.
Project description
gsc-mcp
Google Search Console as MCP tools — query search analytics, inspect URLs, and monitor SEO performance from any MCP-compatible AI client (Claude Desktop, Claude Code, Claude.ai, Gemini CLI, Cursor, etc.).
Zero vendor middleware. Zero ongoing cost. Each user authenticates with their own Google account against Google's free Search Console API.
Why this exists
Pulling GSC data into an AI client normally means either (a) manual CSV exports, (b) a paid data-pipeline vendor like Windsor or Coupler, or (c) building your own script and glue. This is option (d): a small, self-contained MCP server you install once and use from anywhere. Pairs naturally with Google's Analytics MCP for a complete SEO + user behavior picture.
Tools
All tools are read-only. No writes in v1.
| Tool | What it does |
|---|---|
gsc_list_sites |
Enumerate every verified Search Console property for the authenticated user |
gsc_query_search_analytics |
Flexible analytics query — any combination of dimensions (query, page, country, device, date, searchAppearance) and filters |
gsc_top_queries |
Convenience: top N search queries for a site over a recent window |
gsc_top_pages |
Convenience: top N landing pages for a site over a recent window |
gsc_inspect_url |
URL inspection — indexing verdict, coverage state, Google-chosen canonical, last crawl, mobile usability, rich results |
gsc_list_sitemaps |
List registered sitemaps with status, errors, warnings, last submitted date |
gsc_health_check |
Auth + API reachability diagnostic (use this first when something breaks) |
Setup
Three steps. ~15 minutes total.
1. Google Cloud — create an OAuth client
- Open Google Cloud Console.
- Create (or reuse) a project. Name it something like
gsc-mcp. - Enable the Search Console API: one-click link.
- Go to APIs & Services → Credentials.
- If you haven't already, configure the OAuth consent screen:
- User type: External.
- App name:
gsc-mcp, support email: your email, developer email: your email. - Add yourself as a Test user (under "Audience" / "Test users").
- Click Create Credentials → OAuth client ID.
- Application type: Desktop app.
- Name:
gsc-mcp-local.
- Download JSON. Move the downloaded file to:
(Create the directory if it doesn't exist:~/.config/gsc-mcp/credentials.jsonmkdir -p ~/.config/gsc-mcp)
2. Install the server
# From this repository:
pip install --user .
# Or, once published to PyPI:
pipx install gsc-mcp
This installs the gsc-mcp console command and the gsc_mcp Python module.
3. Authenticate once
gsc-mcp auth
A browser window opens. Sign in with the Google account that owns your Search Console properties. You'll see a "Google hasn't verified this app" screen — that's expected because the app is for your personal use; click Advanced → Go to gsc-mcp (unsafe) and continue.
The token is saved to ~/.config/gsc-mcp/token.json (chmod 600) and refreshed automatically from here on.
Verify everything works:
gsc-mcp info
# gsc-mcp version: 0.1.0
# Credentials path: /Users/you/.config/gsc-mcp/credentials.json (exists: True)
# Token path: /Users/you/.config/gsc-mcp/token.json (exists: True)
Connect it to a client
Claude Desktop
Edit ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or the equivalent path on Linux/Windows, and add:
{
"mcpServers": {
"gsc": {
"command": "gsc-mcp"
}
}
}
Restart Claude Desktop. Type /mcp in a chat — you should see gsc listed with 7 tools.
Claude Code
claude mcp add gsc -- gsc-mcp
Or edit ~/.claude.json / the project .claude/mcp.json directly:
{
"mcpServers": {
"gsc": {
"command": "gsc-mcp"
}
}
}
Claude.ai
- Settings → Connectors → Add custom connector.
- Name:
GSC. Command:gsc-mcp. - Enable it.
Cursor, Windsurf, Gemini CLI, etc.
Any MCP-compatible client accepts the same stdio server config. Command: gsc-mcp. No args.
Example prompts once connected
What verified sites do I have in Search Console?
Show me the top 20 search queries for defusely.com over the last 30 days.
Which pages on defusely.app have the biggest impression-to-click gap?
Inspect https://defusely.com/pricing — is it indexed, what's the canonical, when
was it last crawled?
List all sitemaps registered for defusely.com and flag any with errors.
Compare CTR on mobile vs desktop for the top 10 queries on defusely.com this month.
Configuration
All paths are overrideable via environment variables:
| Variable | Default | Purpose |
|---|---|---|
GSC_MCP_CREDENTIALS |
~/.config/gsc-mcp/credentials.json |
OAuth client JSON from Google Cloud |
GSC_MCP_TOKEN |
~/.config/gsc-mcp/token.json |
Cached access token (auto-managed) |
Troubleshooting
Error 403 on every call — the Search Console API isn't enabled on your Google Cloud project, or the authenticated Google account doesn't own the property. Enable the API at the Search Console API library page and verify site ownership in Search Console.
Error 401 / token refresh fails — your refresh token was revoked (Google does this after ~6 months of non-use or on password change). Delete the token and re-auth:
rm ~/.config/gsc-mcp/token.json
gsc-mcp auth
Site not found — call gsc_list_sites first to see the exact siteUrl format. Domain properties use sc-domain:example.com; URL-prefix properties use https://example.com/ with the trailing slash.
URL inspection returns "quota exceeded" — the URL Inspection API is capped at ~2000 calls per property per day. Wait 24 hours or use bulk URL inspection sparingly.
Data looks stale — Search Console data typically lags real-time by 2-3 days. The default date range in this server ends 3 days ago for this reason. Don't query end_date = today and expect full data.
License
Apache 2.0 — see LICENSE.
Contributing
Issues and PRs welcome. This is deliberately small; keep changes focused on the GSC API surface.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gsc_mcp-0.1.0.tar.gz.
File metadata
- Download URL: gsc_mcp-0.1.0.tar.gz
- Upload date:
- Size: 17.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
88f788c72702a6b64f6a765913e36a9af3191b92a7d7044ad795c0da71c02d43
|
|
| MD5 |
5ba58d61541c72735cb690003c9f2668
|
|
| BLAKE2b-256 |
8cc033beaefb63b1157154823f6b202f85f33808c783f8c8262d0e21c3c5c44e
|
File details
Details for the file gsc_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: gsc_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 18.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a2758277f1b2f9d82314f93f6851f6997ee9fbe5e91a6b85fcf6fde97952ea72
|
|
| MD5 |
81cb5d476768b21eaf93f971c138de1a
|
|
| BLAKE2b-256 |
012cc1341fa2315c4669350985d820b769fb39ec5236fc8075427e19fc397647
|