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

# Install dependencies
uv sync

# Set up credentials (see .env.example)
cp .env.example .env
# Edit .env with your Google Ads API credentials

Usage

# Run the server
uv run main.py

# Or use the convenience script
./run.sh

MCP Client Configuration

{
  "mcpServers": {
    "google-ads": {
      "command": "uv",
      "args": ["run", "main.py"],
      "cwd": "/path/to/servers/google-ads"
    }
  }
}

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.1.0.tar.gz (195.4 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.1.0-py3-none-any.whl (85.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: bluealpha_google_ads_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 195.4 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.1.0.tar.gz
Algorithm Hash digest
SHA256 769951e2c57da4570325d560bd0aafa7a4f4a3885649e4996af3d4e681ea9b2b
MD5 f09ac23402168e0e347b7cdd8afd5a30
BLAKE2b-256 1d6788563c2fe3d9291e7a9945017a74f4f28d5274d20b24912100913dd2ffc8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bluealpha_google_ads_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a20d53c02edd3264b863d3df887582576eb816a07fa0932ee4860d63c06931a6
MD5 3a45e203c7709b47fe53a28ecde278b1
BLAKE2b-256 4101e94fe70c8dab5b7d83efa71afc4f982ad7d51d56e6b5129a32a800440ca9

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