AdButler
Manage AdButler campaigns, zones, ad items, VAST, and reports from Claude, ChatGPT, and Cursor.
Ask AI about AdButler
Powered by Claude Β· Grounded in docs
I know everything about AdButler. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
AdButler MCP Server
Manage your entire AdButler account from any AI assistant β Claude, ChatGPT, Cursor, Windsurf, Cline, and any other Model Context Protocol client.
This MCP server exposes the full AdButler v2 API β 600+ tools covering advertisers, campaigns, zones, creatives, placements, VAST video ads, programmatic / RTB, reporting, targeting, drafts, contracts, product catalogs, and more β plus 9 pre-built workflow prompts that walk an AI through common tasks like launching a campaign or setting up retail media.
What you can ask
"Create a new campaign for Pepsi targeting users in Canada with a $5,000 lifetime budget, and assign it to my Homepage Banner zone."
"Show me the top 10 underperforming ad items in the last 7 days by CTR."
"Set up a VAST 4.2 pre-roll campaign with a 30-second skippable creative and three companion banners."
"Walk me through creating a new programmatic deal."
"Audit my ad units β which zones have no active placements?"
The AI translates these into the right sequence of AdButler API calls, runs them, and shows you the result.
Install
You have two options. Most users want the hosted version β zero setup, just paste a URL.
Option A β Hosted (recommended)
Use AdButler's hosted MCP server. No install, no Node, no npm.
The hosted server speaks both modern Streamable HTTP (/mcp) and legacy SSE (/sse) transports. New clients should prefer Streamable HTTP; SSE remains for backward compatibility.
| Client | Configuration |
|---|---|
| Claude Desktop / Code | Add an MCP server with URL https://mcp.adbutler.com/mcp (or /sse for older clients) and header Authorization: Bearer YOUR_ADBUTLER_API_KEY |
| Cursor | Settings β Features β Model Context Protocol β Add server with the URL + auth header above |
| Any MCP client | Streamable HTTP: https://mcp.adbutler.com/mcp Β Β·Β SSE: https://mcp.adbutler.com/sse β pass your API key via Authorization: Bearer β¦ or ?api_key=β¦ |
Option B β Local stdio (npm)
Run the server locally as a Node process. Useful if you want to keep your API key out of any external service or run against a self-hosted AdButler.
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"adbutler": {
"command": "npx",
"args": ["-y", "@adbutler/mcp-server"],
"env": {
"ADBUTLER_API_KEY": "your_api_key_here"
}
}
}
}
Claude Code
claude mcp add adbutler --env ADBUTLER_API_KEY=your_api_key_here -- npx -y @adbutler/mcp-server
Cursor / Windsurf / Cline
Add to the client's MCP config:
{
"mcpServers": {
"adbutler": {
"command": "npx",
"args": ["-y", "@adbutler/mcp-server"],
"env": { "ADBUTLER_API_KEY": "your_api_key_here" }
}
}
}
Get your AdButler API key
AdButler Dashboard β Settings β API Keys β create a new key. It's the same key the AdButler v2 REST API uses.
Authentication
The AdButler MCP works for both new and existing customers. What you see depends on whether you've already configured an API key.
Already an AdButler customer? (existing API key)
Use one of these:
Option 1 β set the API key in your client config (recommended for hosted)
Add an Authorization: Bearer YOUR_ADBUTLER_API_KEY header on the SSE connection. Examples:
- Claude Desktop β edit
claude_desktop_config.jsonβ addheaders: { "Authorization": "Bearer YOUR_API_KEY" }next to the SSE URL - Cursor β MCP server settings β Headers β add
Authorization: Bearer YOUR_API_KEY - Any client β pass the header on the SSE GET to
https://mcp.adbutler.com/sse
Reconnect β all 600+ tools become available immediately.
Option 2 β configure inside the chat (works in any MCP client)
If your client doesn't support custom headers, just connect to the hosted MCP without auth and you'll see four onboarding tools. Then in the chat say:
"Configure my AdButler API key:
your_api_key_here"
Your AI will call the setup_api_key tool, validate the key against your account, and unlock all the AdButler tools. You may need to disconnect and reconnect to refresh your client's tool list after.
New to AdButler? (no account yet)
Connect to the hosted MCP without auth. The chat will guide you through a free trial signup using create_trial_account β check your email β verify_trial_email with the code. The API key is configured automatically.
Local stdio install
If you're running locally via npx, set ADBUTLER_API_KEY in the env block of your client's MCP config (see Option B above). The setup tools also work β and on local the key is remembered between sessions.
What's included
9 workflow prompts
Pre-built skill prompts that guide the AI through complete workflows end-to-end. Invoke them as MCP prompts (/launch-campaign etc.) from your client.
| Prompt | What it does |
|---|---|
launch-campaign | Walks an end-to-end campaign launch β advertiser β campaign β ad items β creatives β targeting β placements |
retail-media-setup | Sets up sponsored products / retail media for an e-commerce site |
reporting | Generates a custom report with the right dimensions and filters |
vast-video | Builds a VAST video ad with linear + companion creatives |
programmatic | Configures programmatic deals, bidders, and demand sources |
targeting | Builds geo / platform / data-key / list targets |
contracts | Creates IO contracts and assigns them to campaigns |
channels | Bundles zones into a channel and assigns campaigns |
drafts | Stages a complete campaign as drafts before going live |
3 fallback meta-tools (search, describe, call)
When you need an endpoint that no specific tool wraps β or when the user asks about a field (e.g. "priority", "frequency cap") rather than a resource β three escape-hatch tools cover the gap:
| Tool | What it does |
|---|---|
search_adbutler_api | Keyword-search the full AdButler OpenAPI spec for matching endpoints |
describe_adbutler_api | Get the full schema (params, body, response) for one endpoint |
call_adbutler_api | Invoke any endpoint by method+path, with the session's auth applied automatically |
These complement (don't replace) the specific tools below β the LLM continues to prefer specific tools when they obviously match.
600+ tools across the full AdButler API
| Domain | Tools | Examples |
|---|---|---|
| Display ads | 100+ | list_advertisers, create_campaign, create_image_ad_item, create_native_ad_item, create_placement, create_schedule, create_campaign_assignment |
| VAST 2/3/4 video | 156 | vast_create_creative, vast_create_linear_media, vast_create_companion, vast_create_placement, vast_create_schedule, plus full VAST 4.2 sub-resource coverage |
| Zones & publishing | 50+ | create_zone, create_zone_catalog, create_zone_email, create_native_template, create_publisher, ORTB native assets |
| Targeting | 37 | create_geo_target, create_platform_target, create_data_key, create_data_list, create_postal_code_target |
| Reporting | 39 | get_display_report, get_vast_report, get_event_logs, custom report configs, scheduled reports |
| Programmatic / RTB | 25 | create_demand_source, create_demand_endpoint, create_bidder, create_pmp_deal |
| Product catalogs | 20 | create_product_db_catalog, bulk_upload_products, ad item β catalog item linking |
| Drafts | 48 | Stage campaigns/ad items/placements/schedules as drafts; publish atomically |
| Contracts | 43 | Insertion orders, contract documents, signature requests, payments |
| Account & security | 27 | Users, roles, redirect domains, beacon signing keys, SFTP connections |
| Ad serving | 2 | serve_ad, live_website_preview |
100% coverage of the AdButler v2 OpenAPI spec (604/604 endpoints).
Telemetry
The hosted server at mcp.adbutler.com collects usage analytics so we can understand which tools are popular, prioritize improvements, and diagnose failures. We capture, per tool call:
- Tool name (e.g.
list_zones,create_campaign) β never tool arguments - Account ID (derived once per session from
/self) - API-key fingerprint (SHA-256, truncated to 16 hex chars) β identifies which key was used without storing the key itself
- Transport (HTTP or SSE), MCP client name and version (e.g. Claude Desktop), call duration, success/error status
- On errors: upstream HTTP status code, a categorical error class (e.g.
forbidden,network), and the error message text (truncated to 1000 characters)
We never collect: tool arguments, response bodies, your raw API key, IP addresses, request bodies. The instrumentation only sees the tool name, timing, and (on failure) the error message produced by the MCP server or AdButler API.
Self-installed copies β npm package, stdio, your own deployment β collect zero data. The instrumentation only fires when the ANALYTICS_INGEST_URL environment variable is set, which is only true for the hosted endpoint at mcp.adbutler.com.
If you'd prefer to opt out of analytics on the hosted server, run your own copy via stdio or self-host the SSE/HTTP server.
Development
Local source for contributors:
git clone https://github.com/adbutler/mcp-server
cd mcp-server
npm install
npm run build
ADBUTLER_API_KEY=your_key node dist/index.js
Inspect with the official MCP inspector:
npx @modelcontextprotocol/inspector node dist/index.js
Resources
- AdButler API documentation β https://api.adbutler.com/openapi.json
- MCP Protocol β https://modelcontextprotocol.io
- Hosted server status β https://mcp.adbutler.com/health
- Issues / feature requests β https://github.com/adbutler/mcp-server/issues
License
MIT
