Google Ads MCP Server

Google Ads MCP Server

Enables Large Language Models to interact with Google Ads API for querying campaigns, ad groups, and performing mutations like creating budgets and ads.

Category
Visit Server

README

Google Ads MCP Server

The Google Ads MCP Server is an implementation of the Model Context Protocol (MCP) that enables Large Language Models (LLMs), such as Gemini, to interact directly with the Google Ads API.

[!NOTE] This is NOT an officially supported Google product. It is mainly for experimental purposes and not intended for production use. Consider using the official Google Ads MCP Server instead.

Disclaimer

Copyright Google LLC. Supported by Google LLC and/or its affiliate(s). This solution, including any related sample code or data, is made available on an “as is,” “as available,” and “with all faults” basis, solely for illustrative purposes, and without warranty or representation of any kind. This solution is experimental, unsupported and provided solely for your convenience. Your use of it is subject to your agreements with Google, as applicable, and may constitute a beta feature as defined under those agreements. To the extent that you make any data available to Google in connection with your use of the solution, you represent and warrant that you have all necessary and appropriate rights, consents and permissions to permit Google to use and process that data. By using any portion of this solution, you acknowledge, assume and accept all risks, known and unknown, associated with its usage and any processing of data by Google, including with respect to your deployment of any portion of this solution in your systems, or usage in connection with your business, if at all. With respect to the entrustment of personal information to Google, you will verify that the established system is sufficient by checking Google's privacy policy and other public information, and you agree that no further information will be provided by Google.

Getting Started

Follow these instructions to configure and run the Google Ads MCP Server.

1. Configure Python Environment

For Direct Use

This project needs Python 3.12 with pipx or uv.

For Development

This project uses uv for dependency management.

Install uv and then run the following command to install the required Python packages:

uv pip sync

2. Configure Google Ads credentials

This tool requires you to have a google-ads.yaml file with your Google Ads API credentials. By default, the application will look for this file in your home directory.

If you don't have one, you can generate it by running the following example from the google-ads-python library: authentication example

Make sure your google-ads.yaml file contains the following keys:

  • client_id
  • client_secret
  • refresh_token
  • developer_token
  • login_customer_id (optional, but recommended)

3. Configuration

The server can be configured using the following environment variables:

  • ADS_MCP_ENABLE_MUTATIONS: Set to true to enable mutation tools. Defaults to false.
  • GOOGLE_ADS_CREDENTIALS: Path to the google-ads.yaml file.
  • USE_GOOGLE_OAUTH_ACCESS_TOKEN: Set to enable Google OAuth token verification.

4. Launch MCP Server

For Direct Use with Gemini CLI

Update your Gemini configuration to include the google-ads-mcp server. The following is an example of a local MCP server configuration:

{
  // Other configs...
  mcpServers: {
    GoogleAds: {
      command: "pipx",
      args: [
        "run",
        "--spec",
        "git+https://github.com/google-marketing-solutions/google_ads_mcp.git",
        "run-mcp-server",
      ],
      env: {
        GOOGLE_ADS_CREDENTIALS: "PATH_TO_YAML",
      },
      timeout: 30000,
      trust: false,
    },
  },
}

Once the server is running, you can interact with it using the Gemini CLI. Type /mcp in Gemini to see the Google Ads API server listed in the results.

For Local Development with Gemini CLI

Update your Gemini configuration to include the google-ads-mcp server. [DIRECTORY] will be the absolute path to the project. The following is an example of a local MCP server configuration:

{
  // Other configs...
  mcpServers: {
    GoogleAds: {
      command: "uv",
      args: ["run", "--directory", "[DIRECTORY]", "-m", "ads_mcp.server"],
      cwd: "[DIRECTORY]",
      timeout: 30000,
      trust: false,
    },
  },
}

Once the server is running, you can interact with it using the Gemini CLI. Type /mcp in Gemini to see the Google Ads API server listed in the results.

You can then ask questions like:

  • "list all campaigns"
  • "show me metrics for campaign [CAMPAIGN_ID]"
  • "get all ad groups"

Direct Launch

To start the server directly, in the project path, run the following command:

uv run -m ads_mcp.server

The server will start and be ready to accept requests.

Features and Tools

The server exposes tools for interacting with Google Ads. Some tools are read-only, while others allow mutations (modifications).

Read-Only Tools (Always Available)

  • GAQL Execution: Query Google Ads data using GAQL.
  • Account Management: List accessible accounts.
  • Documentation: Access documentation for GAQL and reporting views.

Mutation Tools (Disabled by Default)

To enable these tools, set ADS_MCP_ENABLE_MUTATIONS=true.

  • Campaign Budgets: Create campaign budgets.
  • Campaigns: Create campaigns.
  • Ad Groups: Create ad groups.
  • Ads: Create ads.
  • Criteria: Create criteria (e.g., keywords).

Contributing

We welcome contributions! Please see our CONTRIBUTING.md guide for details.

License

Google Ads MCP Server is an open-source project licensed under the APACHE-2.0 License.

Contact

If you have any questions, suggestions, or feedback, please feel free to open an issue.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured