https://github.com/google-marketing-solutions/google_ads_mcp
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.
https://github.com/google-marketing-solutions/google_ads_mcp
ai-agents gemini google google-ads google-ads-api mcp mcp-server
Last synced: about 1 month ago
JSON representation
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.
- Host: GitHub
- URL: https://github.com/google-marketing-solutions/google_ads_mcp
- Owner: google-marketing-solutions
- License: apache-2.0
- Created: 2025-08-08T01:05:26.000Z (2 months ago)
- Default Branch: main
- Last Pushed: 2025-09-02T04:08:24.000Z (about 1 month ago)
- Last Synced: 2025-09-02T06:08:21.680Z (about 1 month ago)
- Topics: ai-agents, gemini, google, google-ads, google-ads-api, mcp, mcp-server
- Language: Python
- Homepage: https://ads.google.com
- Size: 126 KB
- Stars: 12
- Watchers: 2
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
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.
**This is not an officially supported Google product.**
## 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. 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.
## 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.