Remote Model Context Protocol (MCP) server for cross-platform ad management. Create, analyze, and optimize campaigns across Google Ads, Meta Ads, TikTok Ads, and LinkedIn Ads from any MCP-compatible AI assistant.
- MCP Remote URL:
https://mcp.adspirer.com/mcp - Transport: Streamable HTTP
- Registry ID:
com.adspirer/ads - Authentication: OAuth 2.1 with PKCE (dynamic client registration supported)
- Website: https://www.adspirer.com
- Support: abhi@adspirer.com
- Strategy-aware execution — strategic decisions persist to
STRATEGY.mdand guide all future campaign creation, keyword research, and ad copy across sessions and subagents - 100+ tools across 4 ad platforms for campaign creation, performance analysis, and optimization
- Plan and validate campaigns using structured prompts
- Research keywords with real CPC data and competitive analysis
- Create Google Ads Search and Performance Max campaigns end-to-end
- Launch Meta, TikTok, and LinkedIn ad campaigns
- Analyze performance with actionable optimization recommendations
- Manage multiple ad accounts across platforms
| Platform | Tools | Capabilities |
|---|---|---|
| Google Ads | 39 | Search campaigns, Performance Max, keyword research, performance analysis, asset management, ad extensions |
| LinkedIn Ads | 28 | Sponsored content, lead gen forms, audience targeting, campaign analytics |
| Meta Ads | 20 | Image campaigns, carousel campaigns, audience targeting, performance tracking |
| TikTok Ads | 4 | In-feed video/image campaigns, asset validation |
| Total | 100+ | Plus 2 resources and 6 prompts |
See CONNECTING.md for detailed setup instructions for each platform.
- Open Settings > Connectors > Add custom connector
- Name: Ads MCP
- URL:
https://mcp.adspirer.com/mcp - Complete OAuth 2.1 sign-in
- Link your ad accounts on first use
Install the full Adspirer plugin (agent + skills + commands + MCP server):
- Open Claude Code
- Run
/plugin marketplace add amekala/ads-mcp - Run
/plugin install adspirer - Run
/mcp— find plugin:adspirer:adspirer and click to authenticate - Run
/adspirer:setupto pull your campaign data and create your brand workspace
This gives you a brand-aware performance marketing agent with persistent memory, competitive research via web search, campaign creation with ad extensions, and slash commands for common workflows. Enabling subagent usage does not change this installation flow.
MCP-only (no plugin): If you just want the raw MCP tools without the agent:
claude mcp add --transport http adspirer https://mcp.adspirer.com/mcp- Open Settings > Connectors > Add custom connector
- Name: Ads MCP
- URL:
https://mcp.adspirer.com/mcp - Follow OAuth 2.1 sign-in flow
Add to ~/.cursor/mcp.json:
{
"mcpServers": {
"adspirer": {
"url": "https://mcp.adspirer.com/mcp"
}
}
}Add to ~/.codex/config.toml:
[mcp_servers.adspirer]
url = "https://mcp.adspirer.com/mcp"openclaw plugins install openclaw-adspirer
openclaw adspirer login
openclaw adspirer connectOr install from ClawHub.
Keyword Research:
Research keywords for my emergency plumbing business in Chicago.
Show me high-intent keywords with real CPC data and budget recommendations.
Performance Analysis:
Show me campaign performance for the last 30 days across all platforms.
Which campaigns are converting best and what should I optimize?
Campaign Creation:
Create a Google Performance Max campaign for luxury watches targeting
New York with a $50/day budget.
Multi-Platform Strategy:
I want to advertise my handmade jewelry business across Google and LinkedIn.
Research keywords for Google Ads and create a LinkedIn sponsored content campaign
targeting small business owners.
- Protocol: MCP 2025-03-26 (with fallback to 2024-11-05)
- Transport: Streamable HTTP
- OAuth: RFC 8252 (Authorization Code + PKCE) with RFC 7591 (Dynamic Client Registration) and RFC 9728 (Protected Resource Metadata)
- Tool Annotations: All tools include MCP safety metadata (
readOnlyHint,destructiveHint)
- HTTPS/TLS for all data transmission
- OAuth 2.1 with PKCE for authentication
- Dynamic client registration for CLI tools (Claude Code, Cursor, Codex)
- Encrypted token storage
- No conversation logging -- only tool requests are processed
See SECURITY.md for vulnerability reporting.
- Email: abhi@adspirer.com
- Issues: https://github.com/amekala/ads-mcp/issues
- Website: https://www.adspirer.com
- Server Status: https://mcp.adspirer.com/health
This repo distributes plugins for 4 AI platforms from a single monorepo:
| Platform | Directory | Skills | Install Method |
|---|---|---|---|
| Claude Code | Repo root | 1 generated + 5 slash commands | /plugin marketplace add |
| Cursor | plugins/cursor/adspirer/ |
5 generated from templates | install.sh (one-command) |
| Codex | plugins/codex/adspirer/ |
5 generated from templates | install.sh (one-command) |
| OpenClaw | plugins/openclaw/ |
1 standalone (self-contained) | openclaw plugins install |
Skills for Claude Code, Cursor, and Codex are authored once in shared/skills/ as templates, then compiled into IDE-specific versions by scripts/sync-skills.sh.
The performance marketing agent prompt is also authored once in shared/agents/performance-marketing-agent/PROMPT.md and compiled into Claude Code, Cursor, and Codex agent files by the same sync script.
OpenClaw uses its own standalone skill. See Architecture for the full design.
Edit once (source of truth)
├─ shared/skills/adspirer-*/SKILL.md
└─ shared/agents/performance-marketing-agent/PROMPT.md
|
v
./scripts/sync-skills.sh
|
+--> Claude Code outputs
| ├─ skills/ad-campaign-management/SKILL.md
| └─ agents/performance-marketing-agent.md
|
+--> Cursor outputs
| ├─ plugins/cursor/adspirer/.cursor/skills/adspirer-*/SKILL.md
| └─ plugins/cursor/adspirer/.cursor/agents/performance-marketing-agent.md
|
+--> Codex outputs
| ├─ plugins/codex/adspirer/skills/adspirer-*/SKILL.md
| └─ plugins/codex/adspirer/agents/performance-marketing-agent.toml
|
└--> OpenClaw (standalone, not generated)
└─ plugins/openclaw/SKILL.md
| AI Client | Repo Source Root | Generated/Runtime Root in Repo | User Installation Path/Method |
|---|---|---|---|
| Claude Code | Repo root + shared/skills/ + shared/agents/ |
skills/, agents/, commands/, .claude-plugin/ |
/plugin marketplace add amekala/ads-mcp then /plugin install adspirer |
| Cursor | plugins/cursor/adspirer/ + shared sources |
plugins/cursor/adspirer/.cursor/skills/, plugins/cursor/adspirer/.cursor/agents/ |
bash <(curl -fsSL https://raw.githubusercontent.com/amekala/ads-mcp/main/plugins/cursor/adspirer/install.sh) |
| Codex | plugins/codex/adspirer/ + shared sources |
plugins/codex/adspirer/skills/, plugins/codex/adspirer/agents/ |
bash <(curl -fsSL https://raw.githubusercontent.com/amekala/ads-mcp/main/plugins/codex/adspirer/install.sh) |
| OpenClaw | plugins/openclaw/ |
plugins/openclaw/ (standalone, no sync generation) |
openclaw plugins install openclaw-adspirer |
If you're contributing to this repo or adding new ad platforms/IDE support:
- Architecture — Shared skills model, template system, what's done and what's remaining
- Template Syntax & Sync Workflow — Variable substitution, conditional blocks, validation checks
- Adding Ad Platforms — How to add a new ad platform (e.g., Snapchat, Pinterest, YouTube)
- Adding IDEs — How to add support for a new IDE (e.g., Windsurf, Cline)
./scripts/sync-skills.sh # Generate IDE-specific skills from templates
./scripts/sync-skills.sh --check # Verify generated files match committed (CI mode)
./scripts/validate.sh # Run all 48 offline validation checks
./scripts/validate.sh --live # Also test MCP endpoint connectivityNever edit files in plugins/*/skills/, skills/, agents/, or plugins/*/agents/ directly — they will be overwritten by the sync script. Edit templates in shared/skills/ and shared prompts in shared/agents/ instead.
Proprietary -- See Terms of Service for usage terms.