flin-google-ads-mcp
This is a read-only MCP server for Google Ads — no create, update, or delete operations are allowed. Here's what you can do:
Account & Customer Management
List all accessible customer accounts via OAuth credentials
Retrieve subaccounts under a manager (MCC) account, with optional name-based search
Campaign & Ad Structure
Get campaigns and ad groups, filterable by status or campaign ID
Retrieve ads including RSA content (headlines, descriptions, paths, final URLs)
Performance Insights
Get metrics (impressions, clicks, CTR, CPC, cost) at the campaign, ad group, ad, or account level
Supports preset date ranges (
TODAY,LAST_30_DAYS,THIS_MONTH, etc.) and customYYYY-MM-DDranges
Conversion Insights
View conversion-specific reporting segmented by day or conversion action
Keywords & Search Terms
Retrieve keyword-level entities with performance metrics
Fetch actual user search terms from the search term view
Change History
View recent account changes (resource, operation, old/new values) within a 30-day window
Authentication
Check OAuth status, generate an authorization URL, save a refresh token from an auth code, and clear stored tokens
Health Check
Verify server configuration and connectivity to the Google Ads API
Read-only access to Google Ads, providing tools for listing customers, campaigns, ad groups, ads, keywords, and insights (metrics) at various levels such as campaign, ad group, ad, customer, and account.
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., "@flin-google-ads-mcpget yesterday's account-level insights"
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.
flin-google-ads-mcp
Read-only MCP server for Google Ads, built for simple public use via uvx.
Why this server
Read-only by design
No create/update/delete campaign operations
Refresh token can be generated and stored through MCP auth tools
Easy local testing with MCP Inspector
Related MCP server: Google Ads MCP Server
Exposed MCP tools
health_checklist_accessible_customersget_customer_clientsfind_customer_clientsget_campaignsget_ad_groupsget_adsget_insightsget_conversion_insightsget_keywordsget_search_termsget_change_eventsauth_statusget_auth_urlsave_refresh_token_from_codeclear_auth_token
get_ads includes RSA content fields (headlines/descriptions/paths/final URLs) when available.
get_insights supports:
campaignad_groupadcustomer(account-level metrics)account(alias ofcustomer)
get_search_terms is backed by search_term_view, so it returns actual user search terms rather than configured keywords.
get_change_events is backed by the Google Ads change_event resource. It returns recent account changes with user, client type, changed resource, operation, changed field paths, and old/new values where the API returns them. Google Ads requires a finite change_event.change_date_time window within the past 30 days and a LIMIT; pass start_date and end_date as YYYY-MM-DD.
Example:
{
"tool": "get_change_events",
"args": {
"customer_id": "2054139041",
"login_customer_id": "6050181535",
"start_date": "2026-06-01",
"end_date": "2026-06-15",
"resource_type": "CAMPAIGN",
"limit": 50
}
}Conversion insights
Use get_conversion_insights when you need conversion-only reporting by day or conversion action, for example "which campaigns had lead conversions each day last week."
It supports the same levels as get_insights:
campaignad_groupadcustomer(account-level metrics)account(alias ofcustomer)
Optional segmentation:
segment_by_datesegment_by_conversion_action
Optional conversion-action filters:
conversion_action_idconversion_action_name
Rules:
pass at most one of the two parameters
conversion_action_idmust be a Google Ads resource name such ascustomers/1234567890/conversionActions/555conversion_action_namematchessegments.conversion_action_nameget_conversion_insightsreturns onlymetrics.conversionsandmetrics.conversions_value
Use get_insights for general performance metrics such as impressions, clicks, CTR, CPC, and cost. Use get_conversion_insights for conversion-action or daily conversion breakdowns.
Requirements
Python 3.10+
Node.js v25.8.1+ (only for MCP Inspector testing)
Google Ads API credentials:
GOOGLE_ADS_DEVELOPER_TOKENGOOGLE_ADS_CLIENT_IDGOOGLE_ADS_CLIENT_SECRET
Optional:
GOOGLE_ADS_REFRESH_TOKEN(backwards-compatible override; normally generated with MCP auth tools)GOOGLE_ADS_AUTH_FILE(defaults to~/.config/flin-google-ads-mcp/auth.json)GOOGLE_ADS_OAUTH_REDIRECT_URI(defaults tohttp://127.0.0.1:8080/)GOOGLE_ADS_LOGIN_CUSTOMER_IDGOOGLE_ADS_CUSTOMER_ID(default customer if nocustomer_idargument is passed)GOOGLE_ADS_USE_PROTO_PLUS(trueby default)
For MCC flows, you can also pass login_customer_id directly per tool call.
Auth flow
The MCP client config no longer needs GOOGLE_ADS_REFRESH_TOKEN.
Configure
GOOGLE_ADS_DEVELOPER_TOKEN,GOOGLE_ADS_CLIENT_ID, andGOOGLE_ADS_CLIENT_SECRET.Run
auth_status.If it reports
missing_refresh_token, runget_auth_url.Open the returned Google URL, sign in, and copy either the
codevalue or the full redirected URL.Run
save_refresh_token_from_codewith that value.Run
health_check.
The stored refresh token is written to ~/.config/flin-google-ads-mcp/auth.json by default and is never returned by MCP tools.
Quick flow: "Avesco spend yesterday"
Find the subaccount by name under the manager:
{
"tool": "find_customer_clients",
"args": {
"manager_customer_id": "6050181535",
"login_customer_id": "6050181535",
"name_query": "Avesco",
"direct_only": false,
"include_hidden": false,
"include_self": false,
"status": "ALL",
"limit": 50
}
}Use the returned
client_customer_idwith account-level insights:
{
"tool": "get_insights",
"args": {
"customer_id": "2054139041",
"login_customer_id": "6050181535",
"level": "account",
"date_range": "YESTERDAY",
"limit": 10
}
}Date ranges
get_insights, get_conversion_insights, get_keywords, and get_search_terms support:
TODAYYESTERDAYTHIS_WEEK_MON_TODAYTHIS_WEEK_SUN_TODAYLAST_WEEK_MON_SUNLAST_WEEK_SUN_SATLAST_7_DAYSLAST_14_DAYSLAST_30_DAYSLAST_60_DAYSLAST_90_DAYSTHIS_MONTHLAST_MONTHCUSTOM(requiresstart_dateandend_dateinYYYY-MM-DD)
Quickstart (from source)
uv sync --extra dev
cp .env.example .env
# Fill .env values
uv run flin-google-ads-mcpQuickstart (as published package)
uvx flin-google-ads-mcp@latestClaude integration (published via uvx)
{
"mcpServers": {
"flin-google-ads-mcp": {
"command": "uvx",
"args": ["flin-google-ads-mcp@latest"],
"env": {
"GOOGLE_ADS_DEVELOPER_TOKEN": "xxx",
"GOOGLE_ADS_CLIENT_ID": "xxx",
"GOOGLE_ADS_CLIENT_SECRET": "xxx",
"GOOGLE_ADS_CUSTOMER_ID": "1234567890",
"GOOGLE_ADS_LOGIN_CUSTOMER_ID": "1234567890"
}
}
}
}Claude integration (local development)
{
"mcpServers": {
"flin-google-ads-mcp-local": {
"command": "uv",
"args": [
"run",
"--directory",
"/Users/nicolasg/Antigravity/flin-google-ads-mcp",
"flin-google-ads-mcp"
],
"env": {
"GOOGLE_ADS_DEVELOPER_TOKEN": "xxx",
"GOOGLE_ADS_CLIENT_ID": "xxx",
"GOOGLE_ADS_CLIENT_SECRET": "xxx",
"GOOGLE_ADS_CUSTOMER_ID": "1234567890",
"GOOGLE_ADS_LOGIN_CUSTOMER_ID": "0987654321"
}
}
}
}How to test
Detailed guide: docs/testing.md
Release checklist: docs/release.md
Operational usage guide:
Fast path:
uv sync --extra dev
python3 -m pytest
python3 -m compileall srcThen run live smoke tests with MCP Inspector (see the testing guide).
Release on GitHub + PyPI
This repository publishes automatically with GitHub Actions:
CI:
.github/workflows/ci.ymlRelease:
.github/workflows/release.yml(triggered by git tagsv*)
1) Configure PyPI Trusted Publisher (one-time)
In PyPI project settings for flin-google-ads-mcp, add a Trusted Publisher with:
Owner:
flin-agencyRepository:
flin-google-ads-mcpWorkflow:
release.ymlEnvironment:
pypi
2) Cut a release
# bump version in pyproject.toml first, then:
git add -A
git commit -m "release: v0.1.0"
git tag v0.1.0
git push origin main --tagsThe Release workflow builds, tests, and publishes to PyPI using OIDC (no PyPI API token in GitHub secrets).
CI
GitHub Actions validates:
unit tests
import/compile checks
package build
Maintenance
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/flin-agency/flin-google-ads-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server