Content
# 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](https://github.com/google-ads/google-ads-mcp-python) 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`](https://github.com/astral-sh/uv) for dependency management.
Install `uv` and then run the following command to install the required Python packages:
```bash
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](https://github.com/googleads/google-ads-python/blob/main/examples/authentication/generate_user_credentials.py)
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:
```json5
{
// 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:
```json5
{
// 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:
```bash
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](CONTRIBUTING.md) guide for details.
## License
Google Ads MCP Server is an open-source project licensed under the [APACHE-2.0 License](LICENSE).
## Contact
If you have any questions, suggestions, or feedback, please feel free to open an issue.
Connection Info
You Might Also Like
valuecell
Valuecell is a Python project for efficient data management.
hexstrike-ai
HexStrike AI is an AI-powered MCP cybersecurity automation platform with 150+ tools.
Vibe-Trading
Vibe-Trading: Your Personal Trading Agent
tradingview-mcp
AI-assisted TradingView chart analysis — connect Claude Code to your...
AP2
AP2 provides code samples and demos for the Agent Payments Protocol.
tradingview-mcp
TradingView MCP Server offers real-time market analysis for crypto and stocks.