synter-mcp-server
MCP server for AI agents to manage ad campaigns across Google, Meta, LinkedIn, Microsoft, Reddit, TikTok, and more
README
Synter MCP Server
The MCP extension Claude doesn't want you to use.
Because once you install it, your AI agent can spend real money.
Create campaigns. Adjust budgets. Pause underperformers. Generate creatives. Pull performance data. All through natural conversation—across Google, Meta, LinkedIn, Microsoft, Reddit, TikTok, and more.
This is the first MCP server that gives AI agents a credit card.
⚠️ Fair Warning
Your AI agent will be able to:
- Create campaigns that immediately start spending your budget
- Adjust bids that affect how much you pay per click
- Pause campaigns (sometimes that's a good thing)
- Add keywords that change who sees your ads
- Generate creatives and upload them to your accounts
We built in confirmations for destructive actions. But still—maybe don't give this to an agent you just met.
Quick Start
1. Get Your API Key
Sign up at syntermedia.ai and create an API key in the Developer Settings.
2. Configure Your AI Client
For Claude Desktop — Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"synter": {
"command": "npx",
"args": ["@syntermedia/mcp-server"],
"env": {
"SYNTER_API_KEY": "syn_your_api_key_here"
}
}
}
}
For Cursor — Add to .cursor/mcp.json in your project:
{
"mcpServers": {
"synter": {
"command": "npx",
"args": ["@syntermedia/mcp-server"],
"env": {
"SYNTER_API_KEY": "syn_your_api_key_here"
}
}
}
}
For Amp — Add to .amp/settings.json:
{
"mcpServers": {
"synter": {
"command": "npx",
"args": ["@syntermedia/mcp-server"],
"env": {
"SYNTER_API_KEY": "syn_your_api_key_here"
}
}
}
}
3. Start Using It
Restart your AI client and start chatting:
"Show me all my Google Ads campaigns"
"Create a search campaign for 'project management software' with a $50/day budget"
"Pause the campaign that's overspending"
What Can Your Agent Do?
📊 Campaign Management
| Tool | Description |
|---|---|
list_campaigns |
List campaigns across all connected platforms |
create_search_campaign |
Create a Google Search campaign with keywords and ads |
create_display_campaign |
Create a Google Display campaign with images |
create_pmax_campaign |
Create a Performance Max campaign |
create_meta_campaign |
Create a Facebook/Instagram campaign |
create_linkedin_campaign |
Create a LinkedIn campaign for B2B |
create_reddit_campaign |
Create a Reddit campaign |
pause_campaign |
Pause any campaign |
update_campaign_budget |
Change daily budget |
📈 Performance & Analytics
| Tool | Description |
|---|---|
get_performance |
Get impressions, clicks, spend, conversions, ROAS |
get_daily_spend |
Daily spend breakdown by platform |
🎯 Keywords & Targeting
| Tool | Description |
|---|---|
add_keywords |
Add keywords to a campaign or ad group |
add_negative_keywords |
Block unwanted search terms |
🔄 Conversion Tracking
| Tool | Description |
|---|---|
create_conversion |
Set up a conversion action |
list_conversions |
List existing conversion actions |
diagnose_tracking |
Check if tracking is installed correctly |
🎨 Creative Generation
| Tool | Description |
|---|---|
generate_image |
AI-generate ad images (Imagen 4, Flux, SDXL) |
generate_video |
AI-generate video ads (Veo, Runway, Luma) |
upload_image |
Upload images as ad assets |
🔧 Utility
| Tool | Description |
|---|---|
list_ad_accounts |
List all connected ad accounts |
run_tool |
Run any of 140+ Synter tools directly |
No Ads Experience? No Problem.
If you've never run ads before, here's what you need to know:
What is a Campaign?
A campaign is like a project folder. It contains your ads, who sees them, and how much you spend.
Campaign: "Q1 Lead Generation"
├── Budget: $50/day
├── Targeting: USA, people searching "project management"
└── Ads: Headlines, descriptions, images
What Platforms Can I Use?
| Platform | Best For | Min Budget |
|---|---|---|
| Google Ads | People actively searching for your product | $10/day |
| Meta (Facebook/Instagram) | Visual products, broad audiences | $5/day |
| B2B, enterprise, job seekers | $25/day | |
| Niche communities, tech-savvy users | $5/day | |
| Microsoft (Bing) | Older demographics, B2B | $10/day |
| TikTok | Gen Z, entertainment, e-commerce | $20/day |
Campaign Types Explained
Search Campaigns — Your ad shows when someone Googles specific keywords.
- Example: Someone searches "best CRM software" → Your ad appears
Display Campaigns — Image ads shown across websites and apps.
- Example: Banner ad on a news site
Performance Max (PMax) — Google's AI shows your ads everywhere (Search, YouTube, Display, Gmail, Maps).
- Example: Google figures out the best placements for you
Video Campaigns — Video ads on YouTube and partner sites.
- Example: 15-second ad before a YouTube video
Common Terms
| Term | What It Means |
|---|---|
| Impressions | How many times your ad was shown |
| Clicks | How many people clicked your ad |
| CTR | Click-through rate (clicks ÷ impressions × 100) |
| CPC | Cost per click |
| Conversions | Desired actions (signups, purchases, etc.) |
| ROAS | Return on ad spend (revenue ÷ spend) |
First Campaign Checklist
Before creating your first campaign, you'll need:
- ✅ A landing page URL where people will go when they click
- ✅ An idea of who you want to reach (location, interests)
- ✅ A daily budget you're comfortable with ($10-50 to start)
- ✅ Some headlines and descriptions for your ad
Pro tip: Start with a Search campaign on Google. It's the easiest to understand and shows ads to people already looking for what you offer.
Example Conversations
Create Your First Campaign
You: Create a Google Search campaign for my SaaS product. Target people searching for "team collaboration software" and "project management tools". Budget is $25/day. Landing page is https://myapp.com/signup
Agent: I'll create a Search campaign with those keywords. What headlines should I use? Here are some suggestions:
- "Team Collaboration Made Simple"
- "Project Management for Modern Teams"
- "Start Free - No Credit Card"
Check Performance
You: How are my campaigns doing this week?
Agent: Here's your performance for the last 7 days:
Campaign Spend Clicks Conversions ROAS Brand Search $142 89 12 4.2x Competitor Keywords $98 45 3 1.5x Display Retargeting $67 234 8 2.8x The "Competitor Keywords" campaign is underperforming. Want me to pause it or adjust the targeting?
Add Negative Keywords
You: I'm getting clicks for "free project management" but we don't have a free tier. Block those.
Agent: Added "free" as a negative keyword to your campaign. This will stop your ads from showing for any search containing "free".
Generate Ad Creative
You: I need a display ad image for a marketing automation product. Dark theme, professional, 1200x628.
Agent: Generating your image with Imagen 4...
Created: "Marketing automation dashboard with data visualization on dark background" Asset saved and ready to use in your next Display campaign.
Connect Your Ad Accounts
To manage ads on each platform, you'll need to connect your accounts in Synter:
- Go to syntermedia.ai/credentials
- Click "Connect" next to each platform
- Complete the OAuth flow
- Your agent can now manage that platform
Supported Platforms:
- Google Ads ✅
- Meta (Facebook/Instagram) ✅
- LinkedIn Ads ✅
- Microsoft Ads (Bing) ✅
- Reddit Ads ✅
- TikTok Ads ✅
- X (Twitter) Ads ✅
- Amazon Ads ✅
- The Trade Desk ✅
- Amazon DSP ✅
Advanced: Direct Tool Access
For power users, you can call any of 140+ Synter tools directly:
> Use run_tool to call google_ads_list_audiences
See the full tool list at docs.syntermedia.ai/tools or ask your agent:
> What tools are available for LinkedIn Ads?
Environment Variables
| Variable | Required | Description |
|---|---|---|
SYNTER_API_KEY |
Yes | Your Synter API key |
SYNTER_API_URL |
No | API URL override (default: https://syntermedia.ai) |
Local Development
# Clone and install
git clone https://github.com/jshorwitz/synter-mcp-server.git
cd mcp-server
npm install
# Build
npm run build
# Run locally
SYNTER_API_KEY=syn_xxx node dist/index.js
Troubleshooting
"SYNTER_API_KEY not set"
Make sure your API key is in the env section of your MCP config. The key should start with syn_.
"Invalid or expired API key"
- Check that you copied the full key (they're long!)
- Verify the key is active at syntermedia.ai/developer
- Make sure the key has
tools:writescope
"No ad accounts connected"
You need to connect at least one ad platform:
- Go to syntermedia.ai/credentials
- Click "Connect" next to Google Ads (or another platform)
- Complete the OAuth authorization
Tools aren't showing in Claude/Cursor
- Restart your AI client completely (not just refresh)
- Check the MCP server logs for errors
- Verify the config file path and JSON syntax
Resources
- Synter Manual: syntermedia.ai/manual
- API Documentation: docs.syntermedia.ai
- Tool Reference: docs.syntermedia.ai/tools
- Support: hello@syntermedia.ai
License
MIT License - see LICENSE for details.
<p align="center"> <a href="https://syntermedia.ai"> <img src="https://syntermedia.ai/logo.svg" alt="Synter" width="120" /> </a> <br /> <strong>The MCP extension they don't want you to use.</strong> <br /> <em>Because AI agents with ad budgets change everything.</em> </p>
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.