Skip to main content

MCP server for Google Ads API

Project description

Google Ads MCP Server

A Model Context Protocol (MCP) server for Google Ads, built on the official Python SDK (v23+) with FastMCP.

Overview

32 focused tools for LLM interaction with Google Ads accounts. Uses GAQL (Google Ads Query Language) as the universal read mechanism, dedicated tools for write operations, and 7 workflow analysis tools for campaign intelligence.

Architecture

Server Tools Purpose
Read 8 GAQL execution, account discovery, keyword ideas, geo targets, field metadata, recommendations
Write 16 Campaign/budget/ad group/ad/keyword CRUD, targeting, recommendations
Workflow 7 Campaign audit, underspend diagnosis, budget reallocation, creative analysis, fatigue detection, audience analysis, test monitoring
Utility 1 Connection status check

Tools

Read Tools (8)

Tool Description
execute_query Run any GAQL query with pagination
execute_query_stream Stream large GAQL result sets
list_accessible_customers Discover accounts (no customer ID needed)
generate_keyword_ideas Search volume, competition, bid estimates
suggest_geo_targets Location name to geo target ID resolution
get_field_metadata Field schema for building GAQL queries
validate_query_fields Check field compatibility before querying
get_recommendations Google's optimization suggestions

Write Tools (16)

Tool Description
create_campaign / update_campaign Campaign CRUD
create_campaign_budget / update_campaign_budget Budget management
create_ad_group / update_ad_group Ad group CRUD
create_ad / update_ad_status Ad creation and status changes
add_keywords / remove_keyword Keyword management
add_negative_keywords Campaign-level negative keywords
add_location_targeting / add_language_targeting Geo and language targeting
remove_campaign_criterion Remove targeting criteria
apply_recommendation / dismiss_recommendation Act on Google's suggestions

Workflow Tools (7)

Tool Description
audit_campaign_structure Campaign scoring (0-110) across 6 dimensions
diagnose_underspend 5-layer underspend diagnostic
analyze_budget_reallocation Efficiency scoring + constraint checks
analyze_creatives Creative scoring (efficiency, quality, engagement)
detect_creative_fatigue Week-over-week trigger comparison
analyze_audiences Audience efficiency scoring and classification
monitor_incrementality_test Test integrity monitoring with alert tiers

Installation

Via PyPI (recommended)

uvx bluealpha-google-ads-mcp

Claude Desktop

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "bluealpha-google-ads": {
      "command": "uvx",
      "args": ["bluealpha-google-ads-mcp"],
      "env": {
        "GOOGLE_ADS_DEVELOPER_TOKEN": "your-token",
        "GOOGLE_ADS_CLIENT_ID": "your-client-id",
        "GOOGLE_ADS_CLIENT_SECRET": "your-client-secret",
        "GOOGLE_ADS_REFRESH_TOKEN": "your-refresh-token",
        "GOOGLE_ADS_LOGIN_CUSTOMER_ID": "your-mcc-id"
      }
    }
  }
}

Claude Code (CLI)

claude mcp add bluealpha-google-ads -- uvx bluealpha-google-ads-mcp

From source

cd servers/google-ads
uv sync
cp .env.example .env
# Edit .env with your Google Ads API credentials
uv run bluealpha-google-ads-mcp

Development

# Format
uv run ruff format .

# Lint + type check
uv run ruff check --fix .
uv run pyright

# Run tests
uv run pytest tests/ -v

Credentials

Required environment variables (see .env.example):

Variable Required Description
GOOGLE_ADS_DEVELOPER_TOKEN Yes API developer token
GOOGLE_ADS_CLIENT_ID Yes OAuth client ID
GOOGLE_ADS_CLIENT_SECRET Yes OAuth client secret
GOOGLE_ADS_REFRESH_TOKEN Yes OAuth refresh token
GOOGLE_ADS_LOGIN_CUSTOMER_ID No MCC account ID (for managing multiple accounts)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bluealpha_google_ads_mcp-0.2.3.tar.gz (198.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bluealpha_google_ads_mcp-0.2.3-py3-none-any.whl (89.5 kB view details)

Uploaded Python 3

File details

Details for the file bluealpha_google_ads_mcp-0.2.3.tar.gz.

File metadata

  • Download URL: bluealpha_google_ads_mcp-0.2.3.tar.gz
  • Upload date:
  • Size: 198.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for bluealpha_google_ads_mcp-0.2.3.tar.gz
Algorithm Hash digest
SHA256 c0b8e5173f25d72785a11b8c5a4b2731d03f6bb9a44c50a94ab3d74e8b3f4cb6
MD5 d606d4006209ae023fb21394d4588a04
BLAKE2b-256 41f9e60f816d1460dbb1de9f12684d344060051e92316d035c7594b8412903f2

See more details on using hashes here.

File details

Details for the file bluealpha_google_ads_mcp-0.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for bluealpha_google_ads_mcp-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 445744a1b6494c99a4b2980068bb496f34c01e657253de5ea2b605a11ca4527b
MD5 ed310c6af76e6d0282cb50bd8b5777cf
BLAKE2b-256 0d99394531365b6079b9bad8eed3a6088970e2d253c9cf218b2bccc461696181

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page