flour-ads
Allows managing Google Ads campaigns, including creating, pausing, resuming campaigns, updating budgets, and fetching performance metrics.
Provides integration for Meta (Facebook and Instagram) ad platforms, enabling campaign management (currently a stub).
Planned integration for TikTok advertising platform, will allow campaign management.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@flour-adsShow performance for campaign 12345678 last 7 days"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
flour-ads
CLI + MCP server for managing ad campaigns across Google Ads, Meta, and more.
Deploy campaigns, check performance, and manage budgets — from the terminal or through any MCP-compatible AI assistant (Claude Code, Cursor, etc.).
Install
git clone https://github.com/Wayy-Research/flour-ads.git
cd flour-ads
uv venv && source .venv/bin/activate
uv pip install -e ".[dev]"Related MCP server: agent1st-ads-mcp
Quick Start
CLI
# List available platforms
flour-ads platforms
# Authenticate (uses env vars or stored credentials)
flour-ads auth login --platform google_ads --account-id 123-456-7890
# Deploy a campaign from YAML config
flour-ads campaign create \
--platform google_ads \
--account-id 123-456-7890 \
--config examples/ringgold_campaign.yaml
# List campaigns
flour-ads campaign list --platform google_ads --account-id 123-456-7890
# Check performance
flour-ads campaign performance \
--platform google_ads \
--account-id 123-456-7890 \
--campaign-id 12345678 \
--range LAST_7_DAYS
# Pause/resume
flour-ads campaign pause --platform google_ads --account-id ID --campaign-id CID
flour-ads campaign resume --platform google_ads --account-id ID --campaign-id CID
# Update budget
flour-ads budget update \
--platform google_ads \
--campaign-id 12345678 \
--account-id 123-456-7890 \
--daily-budget 45.00MCP Server
# Start the MCP server (stdio transport)
flour-ads serveAdd to your Claude Code settings (.claude/settings.json):
{
"mcpServers": {
"flour-ads": {
"command": "flour-ads",
"args": ["serve"]
}
}
}MCP Tools:
Tool | Description |
| List available ad platforms |
| Authenticate with a platform |
| Create a campaign from config file or inline params |
| Pause an active campaign |
| Resume a paused campaign |
| List campaigns for an account |
| Update daily budget |
| Get performance metrics with daily breakdown |
Campaign Config (YAML)
Define campaigns as YAML files for reproducible, version-controlled deployments:
name: "My Search Campaign"
platform: google_ads
campaign_type: SEARCH
status: PAUSED # deploy paused, review, then enable
budget:
daily_amount: 50.00
bidding:
strategy: MAXIMIZE_CONVERSIONS
targeting:
locations: ["10001", "10002", "10003"]
languages: ["en"]
networks:
search: true
display: false
ad_groups:
- name: "Core Keywords"
keywords:
- text: "plumber NYC"
match_type: PHRASE
ads:
- headlines:
- "NYC Plumber — Fast Service"
- "Licensed & Insured"
- "Free Estimates Today"
descriptions:
- "Trusted plumber serving NYC. Same-day service. Call now."
- "20+ years experience. No hourly rates. Upfront pricing."
final_url: "https://example.com"
negative_keywords:
- "DIY"
- "jobs"
- "hiring"See examples/ for a complete real-world campaign config.
Credentials
flour-ads looks for credentials in this order:
OS Keyring (macOS Keychain, Linux Secret Service, Windows Credential Locker)
JSON file at
~/.flour-ads/credentials.jsonEnvironment variables
Google Ads
export GOOGLE_ADS_DEVELOPER_TOKEN="..."
export GOOGLE_ADS_CLIENT_ID="..."
export GOOGLE_ADS_CLIENT_SECRET="..."
export GOOGLE_ADS_REFRESH_TOKEN="..."
export GOOGLE_ADS_CUSTOMER_ID="1234567890"See docs/google-ads-setup.md for the full setup guide.
Adding a Platform
flour-ads uses a plugin architecture. To add a new platform:
Create
src/flour_ads/platforms/yourplatform/adapter.pyInherit from
AdPlatformand implement all abstract methods:
from flour_ads.platforms.base import AdPlatform
class YourPlatformAdapter(AdPlatform):
platform_id = "yourplatform"
platform_name = "Your Platform"
async def authenticate(self, account_id, credentials): ...
async def create_campaign(self, account_id, config): ...
async def pause_campaign(self, account_id, campaign_id): ...
async def resume_campaign(self, account_id, campaign_id): ...
async def get_performance(self, account_id, campaign_id, date_range): ...
async def list_campaigns(self, account_id, status=None): ...
async def update_budget(self, account_id, campaign_id, daily_budget): ...Register via entry point in
pyproject.toml:
[project.entry-points."flour_ads.platforms"]
yourplatform = "flour_ads.platforms.yourplatform.adapter:YourPlatformAdapter"Platforms
Platform | Status | Notes |
Google Ads | Ready | Search campaigns, RSA ads, keyword targeting |
Meta (Facebook/Instagram) | Stub | Adapter skeleton in place |
TikTok | Planned | |
Planned | ||
Microsoft Ads | Planned |
Development
uv pip install -e ".[dev]"
pytest tests/ -v
black . && ruff check .
mypy src/License
MIT — see LICENSE.
Built by Wayy Research — Buffalo, NY
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Wayy-Research/flour-ads'
If you have feedback or need assistance with the MCP directory API, please join our Discord server