ad-campaign-management
Manage ad campaigns across Google Ads, Meta Ads, LinkedIn Ads, and TikTok Ads. Use when the user wants to analyze campaign performance, research keywords, create campaigns, optimize budgets, or manage ad accounts via the Adspirer MCP server.
From adspirernpx claudepluginhub amekala/ads-mcp --plugin adspirerThis skill uses the workspace's default tool permissions.
Manage advertising campaigns across Google Ads, Meta Ads, LinkedIn Ads, and TikTok Ads using the Adspirer MCP server (100+ tools).
When to Use This Skill
Activate when the user:
- Asks about ad campaign performance ("How are my Google Ads doing?")
- Wants to research keywords ("Find keywords for my plumbing business")
- Needs to create campaigns ("Launch a Google Search campaign for...")
- Wants budget optimization ("Where am I wasting ad spend?")
- Mentions advertising platforms (Google Ads, Meta, LinkedIn, TikTok)
- Asks about ad accounts or connections ("Which ad platforms are connected?")
Required Workflow
Follow these steps in order. Do not skip steps.
Step 1: Check Connected Platforms
Always start here before any ad operation:
- Call
get_connections_status - Shows connected platforms, primary/secondary accounts, account IDs
- If the target platform is not connected, direct the user to https://www.adspirer.com
Step 2: Identify the Task
| User goal | Workflow | Key tools |
|---|---|---|
| View campaign metrics | Performance Analysis | get_campaign_performance, get_meta_campaign_performance, get_linkedin_campaign_performance |
| Cross-platform overview | Cross-Platform Dashboard | See Cross-Platform section below |
| Find keywords | Keyword Research | research_keywords |
| Research before new campaign | Campaign Research | WebSearch, WebFetch + Adspirer tools (see Campaign Research section) |
| Research competitors | Competitive Intelligence | WebSearch, WebFetch, analyze_search_terms, research_keywords |
| Create a campaign | Campaign Creation | Campaign Research first, then platform-specific flows below |
| Reduce wasted spend | Budget Optimization | optimize_budget_allocation, analyze_wasted_spend, analyze_search_terms |
| Switch accounts | Account Management | switch_primary_account |
| Compare platforms | Cross-Platform | Call each platform's performance tool, present side-by-side |
| Check ad fatigue | Creative Management | detect_meta_creative_fatigue, analyze_linkedin_creative_performance |
| Understand audiences | Audience Analysis | get_meta_audience_insights, get_linkedin_audience_insights, search_audiences |
| Manage PMax search themes | PMax Search Themes | add_pmax_search_themes, get_pmax_search_themes, remove_pmax_search_themes |
| Manage PMax audience signals | PMax Audience Signals | add_pmax_audience_signal, get_pmax_audience_signals, remove_pmax_audience_signal, search_audiences |
| Create Demand Gen campaign | Demand Gen Creation | discover_existing_assets, search_audiences, create_demandgen_campaign |
| Create YouTube campaign | YouTube Creation | discover_existing_assets, validate_video, search_audiences, create_youtube_campaign |
| Add ad extensions | Ad Extensions | add_sitelinks, add_callout_extensions, add_structured_snippets, list_campaign_extensions |
| Change bidding strategy | Bidding Strategy | update_bid_strategy, get_campaign_structure |
| Add/manage keywords | Keyword Management | add_keywords, remove_keywords, update_keyword, add_negative_keywords, remove_negative_keywords |
| Set up alerts | Monitoring | create_monitor, list_monitors |
| Schedule reports | Reporting | schedule_brief, generate_report_now |
Step 3: Execute Tools
Follow the workflow patterns below. Always read first (performance, status), then act (create, optimize).
Step 4: Summarize and Recommend
Present results in tables with key metrics. Highlight top and underperforming items. Propose actionable next steps.
Performance Analysis
- Google Ads:
get_campaign_performance— params:lookback_days(7/30/60/90, default 30), optionalcustomer_id - Meta Ads:
get_meta_campaign_performance— params:lookback_days, optionalad_account_id - LinkedIn Ads:
get_linkedin_campaign_performance— params:lookback_days - TikTok Ads:
get_tiktok_campaign_performance— params:lookback_days
Present: impressions, clicks, CTR, spend, conversions, cost/conversion, ROAS. Default to 30-day lookback.
Cross-Platform Performance Dashboard
When the user asks for overall performance, a weekly review, or cross-platform comparison:
- Call
get_connections_statusto identify active platforms - For each connected platform, pull performance:
- Google:
get_campaign_performance - LinkedIn:
get_linkedin_campaign_performance - Meta:
get_meta_campaign_performance
- Google:
- For each platform, pull waste analysis:
- Google:
analyze_wasted_spend - LinkedIn:
analyze_linkedin_wasted_spend - Meta:
analyze_meta_wasted_spend
- Google:
- Present a unified scorecard:
| Platform | Campaigns | Spend | CTR | CPA | ROAS | Waste | Health |
|---|---|---|---|---|---|---|---|
| ... | ... | ... | ... | ... | ... | ... | |
| ... | ... | ... | ... | ... | ... | ... | |
| Meta | ... | ... | ... | ... | ... | ... | ... |
| Total | ... | ... | ... |
- Highlight:
- Best performing platform and campaign
- Worst performing platform and campaign
- Total wasted spend and top waste sources
- Budget pacing (on track, under, over)
- Recommend top 3 actions across all platforms
Campaign Research (run before creating ANY new campaign)
Before creating a campaign on any platform, research the brand's market position and competitive landscape. This combines web research (native tools) with ad platform data (Adspirer MCP) to inform every campaign decision — targeting, messaging, differentiation, and bidding.
Step 0: Load Strategy Directives
Read STRATEGY.md — ## Active Directives and skim ## Decision Log. If directives exist, note them
as context that will inform (not skip) the research steps that follow. Directives shape
which competitors to focus on and what positioning angles to explore.
Do NOT skip Campaign Research just because directives exist. Directives may be stale, incomplete, or based on exploratory conversations. Fresh research validates and enriches them. However, avoid fully redundant research — if a comprehensive analysis was done recently (check Decision Log dates), tell the user: "Strategy directives from [date] are available. I'll use them as a starting point and validate with fresh data. Want me to do a full re-analysis instead?"
Step 1: Understand the brand's own website
Use WebFetch to crawl the brand's website. Extract:
- What they sell (products, services, pricing tiers)
- Key value propositions and differentiators
- Target audience language (how they describe their customers)
- Pricing (plans, tiers, free trial availability)
- Trust signals (customer logos, testimonials, case studies, awards)
- CTAs used on the site (what actions they push visitors toward)
Step 2: Research the competitive landscape
Use WebSearch to search for:
"[brand's product category] competitors"— find who they compete with"[competitor name] vs [brand name]"— find comparison content"[competitor name] pricing"— understand competitor price points"best [product category] [current year]"— find review/comparison sites
Then use WebFetch to crawl the top 3-5 competitor websites. Extract:
- Their positioning and messaging (how they describe themselves)
- Their pricing (cheaper? more expensive? different model?)
- Their unique claims (what do they say they do better?)
- Their target audience (who are they speaking to?)
Step 3: Identify differentiation
Combine brand website + competitor research to answer:
- What does this brand do that competitors don't? (unique features, approach, pricing)
- What language resonates in this market? (common pain points, desired outcomes)
- Where are the gaps? (underserved audiences, unaddressed pain points)
- What should ad copy emphasize to stand out?
Step 4: Pull existing ad intelligence from Adspirer
get_campaign_performance— what's already running and how it performsanalyze_search_terms— what real users search for (Google Ads)get_campaign_structure— current ad copy and targetingget_benchmark_context— industry benchmarks for this vertical
Step 5: Create a research brief
Present findings to the user before proceeding with campaign creation:
- Market overview (key competitors, price ranges, positioning)
- Recommended differentiation angles (what to emphasize in ads)
- Suggested audiences based on competitive gaps
- Messaging direction (informed by competitor weaknesses and brand strengths)
Get user input on the direction before proceeding to keyword research and campaign creation.
Keyword Research (Google Ads)
Always run before creating Search campaigns. Never use generic SEO keywords.
- Tool:
research_keywords - Params:
business_descriptionorseed_keywords, optionalwebsite_url,target_location - Group results by intent (high/medium/low), show search volume, CPC ranges, competition
- Use insights from Campaign Research to inform seed keywords — include competitor brand terms, differentiation keywords, and pain-point language discovered during research
- Strategy directive filter (MANDATORY): After
research_keywordsreturns results, cross-reference against STRATEGY.md > Google Ads directives:- Deprioritize keywords matching AVOID directives. Note these to the user.
- Highlight keywords matching PREFER directives.
- Apply CONSTRAINT directives (match type rules, budget caps).
- Flag conflicts: "Keyword '[term]' returned by research but conflicts with active directive: '[text]'. Deprioritizing it."
Bidding Strategy
Before creating ANY Google Ads campaign, discuss bidding strategy with the user.
- Pull past performance:
get_campaign_performance(lookback_days: 90) - Review existing strategies:
get_campaign_structureto see what bidding strategies current campaigns use - Recommend a strategy based on data:
| Scenario | Recommended Strategy | Reasoning |
|---|---|---|
| New advertiser (no conversion data) | Maximize Clicks | Build traffic data first. Switch to Maximize Conversions after 30+ conversions. |
| Has conversion data (30+ conversions/month) | Maximize Conversions or Target CPA | Enough data for Smart Bidding to optimize. |
| Known target CPA | Target CPA | Set CPA at or slightly above historical average. |
| E-commerce with ROAS goals | Target ROAS | Set ROAS target based on margins and historical performance. |
| Brand campaign | Manual CPC or Maximize Clicks | Control spend on branded terms. Low CPCs expected. |
| High-value B2B leads | Target CPA | Long sales cycles need CPA control. Start 20% above current CPA, tighten over time. |
- Present recommendation with reasoning to the user
- Get explicit approval before setting the strategy
- To change strategy on existing campaigns:
update_bid_strategy
Important: Never silently pick a bidding strategy. Always explain the trade-offs and let the user decide.
Campaign Creation
For ALL new campaigns: Run Campaign Research first (see section above) unless the user has already provided competitive context or this is a follow-up campaign for an existing brand workspace with research already done.
Google Ads Search (exact order):
- Campaign Research — crawl brand + competitor websites via
WebFetch/WebSearch, present research brief 1.5. Apply strategy directives — load STRATEGY.md. Use as context for keyword selection, bidding, targeting, and ad copy throughout this creation flow. research_keywords— mandatory, informed by competitive research- Discuss bidding strategy with user (see Bidding Strategy section above)
discover_existing_assets— check for existing ad assetsvalidate_and_prepare_assets— validate before creation (use differentiation angles from research in ad copy)create_search_campaign— create the campaign (PAUSED status)- Add ad extensions (see Ad Extensions section below):
- Crawl user's website with
WebFetchto find real page URLs add_sitelinks— add 10+ validated sitelinksadd_callout_extensions— add 4+ callouts (use value props from research)add_structured_snippets— add relevant structured snippets
- Crawl user's website with
list_campaign_extensions— verify all extensions were added- Run post-create verification on this campaign using
get_campaign_structure:- confirm ad groups exist
- confirm keywords exist with expected match-type profile
- confirm at least one RSA exists
- If any required asset is missing, run one targeted remediation pass for the missing asset class only, then re-verify.
- Do not report success until this campaign passes Launch Definition of Done.
Google Ads Performance Max:
- Campaign Research — crawl brand + competitor websites via
WebFetch/WebSearch, present research brief 1.5. Apply strategy directives — load STRATEGY.md. Use as context for bidding, targeting, and creative direction throughout this creation flow. - Discuss bidding strategy with user (see Bidding Strategy section above)
discover_existing_assets— check existing assetsvalidate_and_prepare_assets— validate creative assets (see PMax Asset Limits below)validate_video— validate YouTube videos if user provides them (see PMax Asset Limits)create_pmax_campaign— create the campaign- Add ad extensions (same as Search — sitelinks, callouts, snippets)
list_campaign_extensions— verify all extensions were added- Add search themes (recommended) — see PMax Search Themes & Audience Signals section below:
- Ask user for search themes or derive from keyword research + brand context
add_pmax_search_themes— add up to 50 themes per asset groupget_pmax_search_themes— verify themes were added
- Add audience signals (recommended) — see PMax Search Themes & Audience Signals section below:
search_audiences— find relevant in-market, affinity, and custom audiences- Present audience recommendations to user for approval
add_pmax_audience_signal— add audience signal combining selected segments
Google Ads Demand Gen (exact order):
Demand Gen campaigns run across YouTube (In-Feed, In-Stream, Shorts), Gmail, Discover, and Display. They support two ad formats: multi_asset (image ads) and video_responsive (video ads). Demand Gen is ideal for awareness and consideration campaigns with visual, entertainment-focused creatives.
- Campaign Research — crawl brand + competitor websites via
WebFetch/WebSearch, present research brief - Discuss bidding strategy with user:
- Maximize Clicks (default, no conversion tracking needed)
- Target CPA (requires conversion tracking)
- Maximize Conversions (requires conversion tracking)
- Target ROAS (requires conversion value tracking)
discover_existing_assets— check existing images, logos, videos- For multi_asset format: need landscape (1.91:1) OR square (1:1) images + logo
- For video_responsive format: need YouTube video IDs (validate with
validate_video) + logo search_audiences— find relevant in-market, affinity audiences foraudience_segmentsparametercreate_demandgen_campaign— create the campaign with:target_locations: supports countries, states, cities globally (e.g.,["India"],["Bangalore, India"])audience_segments:{"in_market_audience_ids": [80463], "affinity_audience_ids": [92913]}channels: optional channel controls (e.g.,{"display": false}for YouTube + Gmail + Discover only)call_to_action: e.g.,"LEARN_MORE","SIGN_UP","SHOP_NOW"existing_images: reuse fromdiscover_existing_assets(preferred)
- Add ad extensions (sitelinks, callouts, snippets)
list_campaign_extensions— verify extensions added
Key Demand Gen details:
- Budget: minimum ~$20/day recommended
- All campaigns created PAUSED
- Location and audience targeting are set at the ad group level (not campaign level)
- Audience targeting uses grouped Audience resources with in-market, affinity, and remarketing segments
- Channel controls: all channels ON by default. Disable specific channels via
channelsparameter
Google Ads YouTube Video (exact order):
YouTube campaigns are Demand Gen campaigns with YouTube-only channel controls (Gmail, Discover, Display disabled). They require at least one YouTube video.
- Get user's YouTube video URL or ID
validate_video— validate the video (must be public or unlisted)discover_existing_assets— find existing logossearch_audiences— find relevant audiencescreate_youtube_campaign— create with:youtube_video_id: primary video (11 chars)target_locations: city/state/country levelaudience_segments: in-market + affinity targetinglogo_asset_idORasset_bundle_idfor logoadditional_video_ids: up to 4 more videos
- Add ad extensions (sitelinks, callouts, snippets)
YouTube placements enabled: In-Feed, In-Stream, Shorts YouTube placements disabled: Gmail, Discover, Display
Meta Ads:
- Campaign Research — crawl brand + competitor websites, understand audience positioning 1.5. Apply strategy directives — load STRATEGY.md > Meta Ads and Cross-Platform sections. Use as context for audience targeting and creative direction.
get_connections_status— verify Meta account connectedsearch_meta_targetingorbrowse_meta_targeting— find audiences (informed by competitive gaps)- Create campaign — created in PAUSED status
LinkedIn Ads:
- Campaign Research — crawl brand + competitor websites, understand B2B positioning 1.5. Apply strategy directives — load STRATEGY.md > LinkedIn Ads and Cross-Platform sections. Use as context for targeting, messaging, and budget allocation.
get_linkedin_organizations— get linked company pagesdiscover_linkedin_assets— check existing assetsvalidate_and_prepare_linkedin_assets— validate assetscreate_linkedin_image_campaign— create the campaign
TikTok Ads:
- Campaign Research — crawl brand website, research competitor video ad strategies via
WebSearch1.5. Apply strategy directives — load STRATEGY.md > TikTok Ads and Cross-Platform sections. Use as context for creative direction and audience targeting. discover_tiktok_assets— check existing assetsvalidate_and_prepare_tiktok_assets— validate video assetscreate_tiktok_campaignorcreate_tiktok_video_campaign— create the campaign
Ad Extensions (Google Ads)
Ad extensions improve Quality Score, increase ad real estate, and boost CTR. Always add extensions after creating a Google Ads campaign.
Before Adding Extensions
Call list_campaign_extensions to check what already exists on the campaign. Never duplicate existing extensions.
Sitelinks (add_sitelinks)
Sitelinks are the most impactful extension. Target 10+ sitelinks (more is better — Google rotates the best performers).
Workflow:
- Use
WebFetchto crawl the user's website homepage — extract all navigation links and key pages - Build a candidate list of pages to include:
- Homepage, Pricing/Plans, About Us, Contact, Key product/service pages, Blog, Case Studies/Testimonials, FAQ/Help, Free Trial/Demo, Careers
- Validate each URL — use
WebFetchon each candidate URL to confirm it loads (no 404s, no redirects to error pages) - For each valid sitelink, prepare:
- Link text: max 25 characters, descriptive (e.g., "View Pricing Plans")
- Description line 1: max 35 characters (e.g., "Plans starting at $29/month")
- Description line 2: max 35 characters (e.g., "Free 14-day trial included")
- Final URL: the validated page URL
- If fewer than 8 valid pages found → ask the user for additional URLs or pages to include
- Present the full sitelink list to the user for review before adding
- Call
add_sitelinkswith the approved list
Callout Extensions (add_callout_extensions)
Callouts highlight value propositions. Target 8+ callouts (minimum 4).
Workflow:
- Extract value propositions from:
- Website content (crawled via
WebFetch) - Brand docs (CLAUDE.md if it exists)
- Existing ad copy in the account
- Website content (crawled via
- Each callout: max 25 characters
- Examples: "Free Shipping", "24/7 Support", "No Setup Fee", "Cancel Anytime", "Money-Back Guarantee", "Same-Day Delivery", "Award-Winning", "Trusted by 10K+"
- Present to user for approval, then call
add_callout_extensions
Structured Snippets (add_structured_snippets)
Snippets show predefined categories of offerings. Pick headers relevant to the business.
Available headers: Brands, Courses, Destinations, Featured Hotels, Insurance Coverage, Models, Neighborhoods, Service Catalog, Shows, Styles, Types
Workflow:
- Review the user's website and business type to pick relevant headers
- Extract 3-10 values per header from website content
- Example: SaaS company → Header "Types" with values "Analytics, Reporting, Dashboards, API Access"
- Example: E-commerce → Header "Brands" with values "Nike, Adidas, Puma, New Balance"
- Present to user, then call
add_structured_snippets
Price Extensions
If the user's website has a pricing page:
- Use
WebFetchto crawl the pricing page - Extract plan names, prices, and descriptions
- Present to user for confirmation before adding
- Useful for SaaS, services with tiered pricing, or e-commerce with featured products
Call Extensions
If the business has a phone number:
- Ask the user for their business phone number
- Discuss call tracking preferences (use Google forwarding number or direct?)
- Set call hours if business has limited availability
Extension Verification
After adding all extensions, always call list_campaign_extensions to verify:
- All sitelinks were added and have correct URLs
- Callouts are present
- Structured snippets are showing
- Report back to the user what was added
If list_campaign_extensions fails:
- Retry once with a corrected payload or narrower scope.
- Cross-check extension state with
get_campaign_structure. - If extension state is still unverifiable, report
PARTIAL_SUCCESSand explicitly list what could not be confirmed.
Launch Definition of Done (Required before reporting success)
For each created campaign, all checks below must pass:
- Campaign exists and status is
PAUSED(unless user explicitly approved activation). - Expected ad group count exists.
- Expected keywords exist, with the planned match-type profile (EXACT/PHRASE/BROAD as specified).
- At least one RSA exists with expected headline/description counts.
- Required extensions exist (sitelinks, callouts, structured snippets for Google Ads campaigns).
- Requested-vs-actual bidding strategy matches, or any drift is explicitly called out.
Status protocol (mandatory)
SUCCESS: all Launch Definition of Done checks pass for all targeted campaigns.PARTIAL_SUCCESS: campaign shell exists, but one or more required assets are missing/unverifiable after one targeted remediation pass.FAILED: campaign creation itself failed.
Never report SUCCESS when any verification check failed or could not be confirmed.
Per-campaign action ledger (mandatory)
For every campaign you create or edit, log and return:
- campaign name + campaign_id
- ad_group_id values touched
- keyword add/update counts
- RSA counts (headlines/descriptions)
- extension counts (sitelinks/callouts/snippets)
- verification result per campaign (
PASS/FAIL)
Ad Quality Guardrails (Google Ads)
Keyword-to-headline coverage
For each ad group, include unique high-intent target keywords in RSA headlines. At minimum:
- cover top 3-5 keyword themes from the ad group's keyword list
- avoid generic headline sets that omit core search intent terms
- when competitive terms are targeted, keep competitor names in keywords only if required by strategy and avoid naming competitors in ad copy unless user explicitly approves
Asset length validation checklist (before submission)
- RSA headline: <= 30 characters
- RSA description: <= 90 characters
- Path fields: <= 15 characters each
- Sitelink text: <= 25 characters
- Sitelink description lines: <= 35 characters each
- Callout text: <= 25 characters
- Structured snippet values: follow platform limits and keep concise
Validate lengths before create_* or add_* calls. If limits are exceeded, rewrite and re-validate before submitting.
PMax Asset Limits (CRITICAL — enforce before every PMax campaign)
Google Ads Performance Max enforces strict asset limits per asset group. Exceeding these limits causes campaign creation to fail with ENABLED_IMAGE_ASSET_LINKS_PER_ASSET_GROUP or similar errors. The agent MUST enforce these limits before calling validate_and_prepare_assets or create_pmax_campaign.
Image Asset Limits
| Asset type | Minimum | Maximum | Notes |
|---|---|---|---|
| Landscape images (1.91:1) | 1 | 20 | Required — at least 1 |
| Square images (1:1) | 1 | 20 | Required — at least 1 |
| Portrait images (4:5) | 0 | 20 | Optional |
| TOTAL marketing images | 2 | 20 | Across ALL ratios combined |
| Square logos (1:1) | 1 | 5 | Required — at least 1 |
| Landscape logos (4:1) | 0 | 5 | Optional |
CRITICAL: The 20-image limit is TOTAL across landscape + square + portrait, NOT 20 per ratio. If a user provides 10 landscape + 15 square + 13 portrait = 38 images, you must reduce to 20 total.
When user provides more than 20 total marketing images:
- Inform the user: "Google Ads allows max 20 marketing images total per PMax asset group across all ratios. You provided [N]. I'll select the best 20."
- Distribute proportionally across ratios while respecting minimums (at least 1 landscape, at least 1 square)
- Prefer keeping variety across ratios over loading up one ratio
validate_and_prepare_assetshandles this automatically, but you should inform the user proactively
When user provides fewer than minimums:
- Missing landscape images: Ask the user to provide at least 1 landscape image (1.91:1 ratio, 1200x628px recommended)
- Missing square images: Ask the user to provide at least 1 square image (1:1 ratio, 1200x1200px recommended)
- Missing square logo: Ask the user to provide at least 1 square logo (1:1 ratio, 128x128px minimum)
- Do NOT proceed with campaign creation until minimums are met
Text Asset Limits
| Asset type | Minimum | Maximum | Max characters |
|---|---|---|---|
| Headlines | 3 | 15 | 30 chars each |
| Long headlines | 1 | 5 | 90 chars each |
| Descriptions | 2 | 5 | 90 chars each |
| Business name | 1 | 1 | 25 chars |
When user provides more than the maximum:
- Truncate to the limit, keeping the first N items
- Inform the user: "PMax allows max [N] [asset type]. Using the first [N]."
When user provides fewer than minimums:
- Ask for the missing assets. Example: "PMax requires at least 3 headlines. You provided 1. Please provide 2 more headlines (max 30 characters each)."
- Do NOT proceed until minimums are met
Video Asset Limits
| Asset type | Minimum | Maximum | Requirements |
|---|---|---|---|
| YouTube videos | 0 | 5 | Must be YouTube video IDs/URLs |
Video validation workflow:
- Call
validate_videowithplatform="pmax"for each video - This validates the YouTube video ID format only (11 chars, alphanumeric)
- Google Ads API will verify the video exists, is public/unlisted, and embeddable during campaign creation
- If user provides more than 5 videos, use only the first 5 and inform them
- Videos are optional — campaigns can be created without them (Google will auto-generate video ads from images)
Asset Limit Enforcement Checklist (before calling create_pmax_campaign)
Before creating any PMax campaign, verify:
- At least 1 landscape image provided
- At least 1 square image provided
- Total marketing images (landscape + square + portrait) <= 20
- At least 1 square logo provided
- At least 3 headlines (max 30 chars each)
- At least 1 long headline (max 90 chars)
- At least 2 descriptions (max 90 chars each)
- Business name provided (max 25 chars)
- Videos (if any) validated via
validate_video - Videos count <= 5
If any check fails, ask the user for the missing/corrected assets before proceeding.
PMax Search Themes & Audience Signals
Search themes and audience signals are PMax-only features — they do not apply to Search, Display, or other campaign types. Both are configured at the asset group level.
Search Themes
Search themes are short phrases (max 50 per asset group) that tell Google which search queries your PMax campaign should target. They supplement Google's automated targeting with explicit intent signals.
When to add search themes:
- During PMax campaign creation (step 9 above)
- When user wants to refine PMax targeting ("add search themes to my PMax campaign")
- When search term analysis reveals high-performing queries not yet covered
- When expanding into new market segments
Workflow:
get_pmax_search_themes— check existing themes on the campaign (requirescampaign_id)- Derive theme candidates from:
- Keyword research results (
research_keywords) - Search term reports (
analyze_search_terms) - Brand context and product categories
- Competitive research findings
- Keyword research results (
- Present candidate themes to user for approval
add_pmax_search_themes— add approved themes (params:campaign_id,search_themeslist)get_pmax_search_themes— verify themes were added
Limits and rules:
- Max 50 search themes per asset group (Google's limit)
- Duplicates are filtered automatically (case-insensitive)
- Empty/whitespace themes are filtered automatically
- Search themes only support add and remove — no update (remove + re-add instead)
- To remove:
remove_pmax_search_themeswith the theme resource names fromget_pmax_search_themes
Audience Signals
Audience signals tell Google which audience segments are most likely to convert. They are signals, not hard targeting — Google uses them as starting points and expands from there. Only one audience signal is allowed per asset group (containing multiple segments).
When to add audience signals:
- During PMax campaign creation (step 10 above)
- When user wants to add targeting to a PMax campaign
- When audience analysis reveals high-value segments
- When launching PMax for a specific product/audience niche
Supported segment types:
| Type | Tool parameter | Description |
|---|---|---|
| In-market audiences | in_market_audience_ids | Users actively researching/comparing products in a category |
| Affinity audiences | affinity_audience_ids | Users with sustained interests and habits |
| Custom audiences | custom_audience_ids | Account-level custom audience segments |
| User lists (remarketing) | user_list_ids | First-party data — website visitors, customer lists, CRM uploads |
Workflow:
get_pmax_audience_signals— check existing signals on the campaign (requirescampaign_id)- Discover available audiences:
search_audiences— search by keyword across all audience types (in-market, affinity, custom)- Use brand context and competitive research to inform search terms
- Present audience recommendations organized by type with rationale
- Get user approval for segment selection
add_pmax_audience_signal— add signal with selected segment IDsget_pmax_audience_signals— verify signal was added
Limits and rules:
- Only one audience signal per asset group — it must combine all desired segments
- To change:
remove_pmax_audience_signal(with resource name), thenadd_pmax_audience_signalwith updated segments - Audience signals only support add and remove — no update
- Use
search_audiencesto find audience IDs — do not guess or hardcode IDs
Conversion Tracking Limitation
Adspirer MCP currently does not configure Google Ads conversion action settings (primary vs secondary) directly.
When campaign goals depend on conversion action priority:
- create campaigns in PAUSED status
- tell the user exact Google Ads UI path to configure conversion actions manually
- report campaign creation as complete only after clarifying this manual step
Budget Optimization (Google Ads)
optimize_budget_allocation— suggest budget reallocationsanalyze_wasted_spend— find underperforming keywords and ad groupsanalyze_search_terms— review search terms for negative keyword opportunities
Creative Fatigue Detection & Refresh
When reviewing creative performance or user asks about ad fatigue:
- Meta: Call
detect_meta_creative_fatiguefor fatigue scores - LinkedIn: Call
analyze_linkedin_creative_performancefor per-creative metrics - Google: Call
get_campaign_structureto see ad-level performance - Identify ads with:
- High frequency + declining CTR (fatigued)
- More than 30 days running with no refresh
- Below-average CTR for their campaign
- For fatigued ads:
- Call
suggest_ad_contentfor new headline/description ideas - Call
generate_linkedin_ad_creativesfor LinkedIn variations - Present new creative options (filtered through brand voice if CLAUDE.md exists)
- On approval: update via
update_ad_headlines,update_ad_descriptions,add_linkedin_creative, etc.
- Call
A/B Testing Workflow
When creating new ad variations for testing:
- Read current top-performing ad copy (from campaign structure)
- Generate 3-5 variations testing ONE variable:
- Headline variation (keep description same)
- Description variation (keep headline same)
- CTA variation
- Audience variation (same ad, different targeting)
- Present test plan with hypothesis: "Testing: 'Headline A' vs 'Headline B' Hypothesis: [why we think one may outperform] Duration: 2 weeks, split budget 50/50 Success metric: CTR and conversion rate"
- On approval, create test variants via platform-specific tools
- Log test for follow-up analysis
Audience Analysis & Optimization
When analyzing or optimizing audiences:
- Pull audience data:
- Meta:
get_meta_audience_insights+analyze_meta_audiences - LinkedIn:
get_linkedin_audience_insights - Google: Review campaign targeting from
get_campaign_structure
- Meta:
- Identify:
- Which audience segments convert best (by age, gender, job title, interest)
- Audience overlap/saturation
- Underperforming segments (high spend, low conversion)
- For LinkedIn B2B specifically:
- Call
research_business_for_linkedin_targetingwith brand's website - Compare AI-recommended targeting vs current targeting
- Identify gaps (seniority levels, industries, company sizes not covered)
- Call
- For Meta:
- Call
optimize_meta_placementsfor placement-level performance - Identify which placements to scale/reduce
- Call
- Present findings with recommendations:
- Segments to expand (high ROAS, low spend)
- Segments to cut (low ROAS, high spend)
- New segments to test
Monitoring & Alerts
When user wants alerts or ongoing monitoring:
- Understand what they want to monitor:
- Budget pacing (approaching monthly limit)
- Performance drops (ROAS below target, CPA above target)
- Opportunity alerts (keyword with sudden volume increase)
- Call
create_monitorwith appropriate:- Metric (ROAS, CTR, CPC, CPA, spend, conversions)
- Threshold and direction (below 3.0, above $150)
- Delivery (email, Slack, SMS)
- Call
list_monitorsto confirm setup - To modify:
manage_scheduled_taskwith monitor ID
Reporting
When user wants performance reports:
- Ask: frequency (one-time, weekly, monthly) and format preference
- For one-time: Call
generate_report_now - For recurring: Call
schedule_briefwith:- Frequency (daily, weekly)
- Delivery method (email, Slack, webhook)
- Content scope (all platforms or specific)
- Call
list_scheduled_tasksto confirm
Competitive Intelligence
When analyzing competitors or adjusting competitive strategy:
Step 1: Identify competitors
- Read CLAUDE.md for known competitors (check Competitors section)
- Use
WebSearchto search"[brand product category] competitors [current year]"and"[brand name] alternatives" - Use
WebSearchto find review/comparison sites:"best [product category] [current year]"
Step 2: Research competitor positioning
For each key competitor (top 3-5):
- Use
WebFetchto crawl their website homepage — extract messaging, value props, positioning - Use
WebFetchto crawl their pricing page — extract plans, pricing model, free tier - Use
WebSearchto search"[competitor] ads"or"[competitor] Google Ads"— find their ad copy if visible - Use
WebFetchto crawl competitor landing pages found in search results — analyze their conversion approach
Step 3: Analyze ad platform data
analyze_search_terms— find competitor brand terms appearing in our search queriesresearch_keywords— get search volume and CPC for competitor brand + product termsget_campaign_structure— check if we already bid on competitor terms
Step 4: Assess competitive position
- Are competitors bidding on our brand terms? (defensive strategy needed)
- Which competitor keywords have high volume + reasonable CPC?
- Where do we differentiate? (pricing, features, audience, positioning)
- What messaging do competitors use that we should counter or avoid?
- Are there underserved niches competitors ignore?
Step 5: Recommend actions
- Brand defense campaigns: exact match on own brand terms (if competitors are bidding on them)
- Competitor conquest campaigns: bid on competitor brand terms with ad copy emphasizing our differentiators
- Differentiation messaging: specific claims based on competitive gaps (e.g., "50% cheaper than [competitor]", "No setup fee unlike [competitor]")
- Negative keywords: exclude competitor terms where intent doesn't match (e.g., "[competitor] login" — existing customers, not prospects)
- Update CLAUDE.md Competitors section with findings
Safety Rules
These tools create REAL campaigns that spend REAL money.
- Always confirm with the user before creating campaigns or changing spend
- Never retry campaign creation automatically on error
- Never modify live budgets without explicit user approval
- All campaigns created in PAUSED status when possible
- When in doubt about any spend-affecting action, ask the user first
Critical: Input Format Requirements
Follow these rules EXACTLY when calling Adspirer tools to avoid validation errors:
IDs Must Be Strings
All IDs (campaign_id, ad_account_id, video_id, image_hash, ad_group_id, keyword_id, organization_id, creative_id) MUST be passed as quoted strings, never as bare integers.
- ✅
"existing_video_id": "1333064875515942" - ❌
"existing_video_id": 1333064875515942
Never Modify IDs
Copy IDs exactly as returned by list/discover tools. Do not round, truncate, or change any digits. If list_campaigns returns campaign_id: "120240129373510507", use that exact value.
Always Call List/Discover Before Create/Update
Many tools require IDs from prior tool calls:
list_campaigns→ getcampaign_idbefore update/pause/structureget_campaign_structure→ getad_group_idbefore keyword operationsdiscover_existing_assets→ getimage_hash,video_idbefore campaign creationget_linkedin_organizations→ getorganization_idandaccount_id
Text Length Limits
Respect character limits — the server will reject text that's too long:
- Google Ads headline: max 30 characters
- Google Ads description: max 90 characters
- Google Ads sitelink text: max 25 characters
- Google Ads callout: max 25 characters
- Meta primary_text: max 125 characters (supports emojis, line breaks, bullet points)
- Meta headline: max 40 characters
Meta Ad Copy Formatting
Meta primary_text supports rich formatting for higher engagement:
- Use emojis strategically: 🔥 ✅ 🎯 💰 ⚡ 🚀 👉 ⭐
- Use line breaks (\n) and bullet points (•, ✅, ▸) for readability
- Example: "🔥 Limited Time Offer!\n\n✅ Free Shipping\n✅ 30-Day Returns\n\n👉 Shop now!"
- Bold/italic/HTML are NOT supported — plain text with emojis only
Enum Values Are Case-Insensitive
The server auto-normalizes casing, but these are the expected values:
- status: ENABLED, PAUSED, ACTIVE, ARCHIVED
- objective: OUTCOME_TRAFFIC, OUTCOME_SALES, OUTCOME_LEADS, etc.
- match_type: EXACT, PHRASE, BROAD
- call_to_action: LEARN_MORE, SHOP_NOW, SIGN_UP, etc.
- date_range: last_7_days, last_30_days, last_90_days, etc.
- campaign_type: search, pmax, image, video, carousel, etc.
Budgets Are Numbers
Pass budget fields (budget_daily, budget_amount, target_cpa) as numbers, not strings:
- ✅
"budget_daily": 50 - ❌
"budget_daily": "50"
Budget is in the account's local currency (not cents). Meta minimum varies by currency.
Keywords Format
For add_negative_keywords, each keyword must be an object:
- ✅
"keywords": [{"text": "free", "match_type": "BROAD"}] - ❌
"keywords": ["free", "cheap"]
Platform Guidance
| Platform | Min Daily | Recommended | Best for |
|---|---|---|---|
| Google Ads Search | $10 | $50+ | High-intent search traffic |
| Google Ads PMax | $10 | $50+ | Broad reach with automation |
| Google Ads Demand Gen | $10 | $20+ | YouTube, Gmail, Discover — visual awareness + consideration |
| Google Ads YouTube | $10 | $20+ | YouTube-only video ads (In-Feed, In-Stream, Shorts) |
| Meta Ads | $5/ad set | $20+ | Awareness and retargeting |
| LinkedIn Ads | $10 | $50+ | B2B targeting (job titles, industries) |
| TikTok Ads | $20 | $50+ | Younger demographics, video-first |
Available Tools — Complete Reference
Google Ads Tools
Performance & Analytics:
get_campaign_performance— campaign metrics (impressions, clicks, CTR, spend, conversions, ROAS). Params:lookback_days(default 30), optionalcustomer_idanalyze_wasted_spend— find underperforming keywords and ad groups burning budgetoptimize_budget_allocation— suggest budget reallocations across campaignsanalyze_search_terms— review search terms, identify negative keyword opportunitiesexplain_performance_anomaly— explain sudden changes in campaign metricsget_benchmark_context— industry benchmarks for the vertical
Campaign Creation:
select_google_campaign_type— interactive campaign type selection wizardresearch_keywords— keyword research with search volumes, CPC, competition. Params:business_descriptionorseed_keywords, optionalwebsite_url,target_locationdiscover_existing_assets— check existing images, videos, logos in the accountvalidate_and_prepare_assets— validate creative assets before campaign creationvalidate_video— validate YouTube video IDs for PMax/YouTube campaignscreate_search_campaign— create Google Search campaign (PAUSED)create_pmax_campaign— create Performance Max campaigncreate_demandgen_campaign— create Demand Gen campaign (YouTube, Gmail, Discover)create_youtube_campaign— create YouTube video campaignadd_demandgen_ad_group— add ad group to existing Demand Gen campaign
Campaign Management:
list_campaigns— list all campaigns with status, budget, performance summaryget_campaign_structure— detailed campaign structure (ad groups, keywords, ads, extensions)update_campaign— update campaign settingspause_campaign— pause a campaignresume_campaign— resume a paused campaignupdate_bid_strategy— change bidding strategy (Maximize Clicks, Target CPA, Target ROAS, etc.)
Keyword Management:
add_keywords— add keywords to ad group. Params:campaign_id,ad_group_id,keywords(array of{"text": "...", "match_type": "EXACT|PHRASE|BROAD"})remove_keywords— remove keywords from ad groupupdate_keyword— update keyword bid, match type, or statusadd_negative_keywords— add negative keywords. Params:campaign_id,keywords(array of{"text": "...", "match_type": "BROAD|PHRASE|EXACT"})remove_negative_keywords— remove negative keywords
Ad Management:
suggest_ad_content— AI-generated headline/description suggestions from real datacreate_ad— create new responsive search adupdate_ad_headlines— update RSA headlinesupdate_ad_descriptions— update RSA descriptionsupdate_ad_content— update ad content (headlines + descriptions)pause_ad— pause an adresume_ad— resume a paused ad
Ad Extensions:
add_sitelinks— add sitelink extensions (target 10+). Params:campaign_id,sitelinks(array of{"link_text": "...", "final_url": "...", "description1": "...", "description2": "..."})add_callout_extensions— add callout extensions (target 8+). Params:campaign_id,callouts(array of strings, max 25 chars each)add_structured_snippets— add structured snippet extensions. Params:campaign_id,snippets(array of{"header": "...", "values": ["...", "..."]})list_campaign_extensions— verify extensions on a campaign
PMax Search Themes & Audience Signals:
add_pmax_search_themes— add search themes (max 50 per asset group). Params:campaign_id,search_themes(array of strings)get_pmax_search_themes— list existing search themesremove_pmax_search_themes— remove search themes by resource nameadd_pmax_audience_signal— add audience signal with segment IDsget_pmax_audience_signals— list existing audience signalsremove_pmax_audience_signal— remove audience signal by resource namesearch_audiences— search for in-market, affinity, and custom audiences by keyword
Business Profile:
get_business_profile— saved brand profileinfer_business_profile— AI-inferred profile from ad datasave_business_profile— save/update brand profilehelp_user_upload— help user upload creative assets
LinkedIn Ads Tools
Performance & Analytics:
get_linkedin_campaign_performance— campaign metrics. Params:lookback_days(default 30)get_linkedin_engagement_metrics— engagement metrics (likes, shares, comments, follows)get_linkedin_audience_insights— audience demographics and segment performanceanalyze_linkedin_wasted_spend— find underperforming campaigns burning budgetoptimize_linkedin_budget— budget reallocation recommendationsexplain_linkedin_anomaly— explain sudden metric changesanalyze_linkedin_creative_performance— per-creative performance metrics
Campaign Creation:
select_linkedin_campaign_type— interactive campaign type selection wizardget_linkedin_organizations— get linked company pages and account IDs (CALL FIRST before any LinkedIn operation)discover_linkedin_assets— check existing images/videos in the account. Params:account_id(fromget_linkedin_organizations)validate_and_prepare_linkedin_assets— validate/upload assets before campaign creationcreate_linkedin_image_campaign— create image ad campaign. Params:campaign_name,daily_budget(min $10),organization_id,introductory_text(max 600 chars),landing_page_url(HTTPS),locations(array of location URNs), plus optional targeting (industries,seniorities,job_titles,company_sizes)create_linkedin_video_campaign— create video ad campaigncreate_linkedin_carousel_campaign— create carousel ad campaigncreate_linkedin_text_campaign— create text ad campaignexplain_linkedin_objectives— explain available campaign objectives and when to use each
Campaign Management:
list_linkedin_campaigns— list all campaigns with status and metricsget_linkedin_campaign_structure— detailed campaign structure (creatives, targeting, settings). Params:campaign_idpause_linkedin_campaign— pause a campaign. Params:campaign_idresume_linkedin_campaign— resume a paused campaign. Params:campaign_idupdate_linkedin_campaign— update campaign settings (name, status, objective, etc.)update_linkedin_campaign_budget— update daily/total budget. Params:campaign_id,daily_budgetand/ortotal_budgetupdate_linkedin_campaign_schedule— update start/end dates. Params:campaign_id,start_date,end_dateupdate_linkedin_campaign_targeting— update targeting criteria. Params:campaign_id, plus targeting facets (locations,industries,seniorities,job_titles,company_sizes, etc.)clone_linkedin_campaign— clone a campaign with optional modifications. Params:campaign_id, optional overridesbatch_update_linkedin_campaigns— bulk update multiple campaigns at once
Creative Management:
list_linkedin_creatives— list all creatives for a campaign. Params:campaign_idadd_linkedin_creative— add image creative to campaignadd_linkedin_text_creative— add text creative to campaignadd_linkedin_video_creative— add video creative to campaignupdate_linkedin_creative— update creative content. Params:creative_iddelete_linkedin_creative— delete a creative. Params:creative_idpause_linkedin_creative— pause a creative. Params:creative_idresume_linkedin_creative— resume a paused creative. Params:creative_idgenerate_linkedin_ad_creatives— AI-generated ad creative variations
Targeting & Audiences:
get_linkedin_campaign_targeting— get current targeting for a campaign. Params:campaign_idsearch_linkedin_targeting— search for targeting facets. Params:query,facet_type(e.g.,"job_titles","industries","seniorities","company_sizes","skills")research_business_for_linkedin_targeting— AI-recommended targeting based on business website
Campaign Groups & Conversions:
list_linkedin_campaign_groups— list campaign groups (folders). Params:account_idupdate_linkedin_campaign_group— update campaign group settingslist_linkedin_conversions— list conversion tracking rules. Params:account_idassociate_linkedin_conversion— link conversion to campaign. Params:campaign_id,conversion_idmanage_linkedin_conversions— create/update/delete conversion tracking rules
Meta Ads Tools
Performance & Analytics:
get_meta_campaign_performance— campaign metrics. Params:lookback_days(default 30), optionalad_account_idanalyze_meta_ad_performance— ad-level performance breakdownget_meta_audience_insights— audience demographics and segment performanceanalyze_meta_wasted_spend— find underperforming ads/ad sets burning budgetoptimize_meta_budget— budget reallocation recommendationsdetect_meta_creative_fatigue— identify ads losing effectiveness over timeoptimize_meta_placements— placement-level performance analysis (Feed, Stories, Reels, etc.)explain_meta_anomaly— explain sudden metric changesanalyze_meta_audiences— audience segment performance analysis
Campaign Creation:
select_meta_campaign_type— interactive campaign type selection wizarddiscover_meta_assets— check existing images/videos in the accountvalidate_and_prepare_meta_assets— validate/upload assets before campaign creationcreate_meta_image_campaign— create image ad campaigncreate_meta_video_campaign— create video ad campaigncreate_meta_carousel_campaign— create carousel ad campaignadd_meta_ad_set— add ad set to existing campaign
Campaign Management:
list_meta_campaigns— list all campaigns with status and metricsget_meta_campaign_details— detailed campaign structureupdate_meta_campaign— update campaign settingspause_meta_campaign— pause a campaignresume_meta_campaign— resume a paused campaignduplicate_meta_campaign— duplicate a campaign with optional modificationslist_meta_ad_sets— list ad sets in a campaignupdate_meta_ad_set— update ad set targeting, budget, schedulelist_meta_ads— list ads in an ad setupdate_meta_ad— update ad creative/contentadd_meta_ad— add new ad to ad setget_meta_ad_creatives— get creative details for ads
Targeting & Audiences:
search_meta_targeting— search for targeting options (interests, behaviors, demographics). Params:query, optionaltarget_typebrowse_meta_targeting— browse targeting categorieslist_meta_instagram_accounts— list connected Instagram accountslist_meta_pixels— list Meta pixels for conversion tracking
Lead Forms:
list_meta_lead_forms— list lead gen formsget_meta_lead_form_submissions— get lead form submissions
TikTok Ads Tools
discover_tiktok_assets— check existing assetsvalidate_and_prepare_tiktok_assets— validate video assetscreate_tiktok_campaign— create campaigncreate_tiktok_video_campaign— create video campaign
Account & Utility Tools
get_connections_status— show connected platforms, account IDsswitch_primary_account— change active ad accountget_usage_status— check tool call quota and subscription tierecho_test— test MCP connectivity
Monitoring & Reporting Tools
create_monitor— set up metric alerts (ROAS, CPA, CTR thresholds)list_monitors— list active monitorsschedule_brief— schedule recurring performance reportsgenerate_report_now— generate one-time performance reportlist_scheduled_tasks— list all scheduled tasksmanage_scheduled_task— update/delete scheduled tasksstart_research— start async research taskget_research_status— check research task statusaudit_conversion_tracking— audit conversion tracking setup
Research (native)
WebSearch— search the web for competitors, market data, trendsWebFetch— crawl websites for pricing, messaging, sitelink URLs, value props
Output Formatting
- Performance: Table with impressions, clicks, CTR, spend, conversions, CPC, ROAS. Order by spend descending.
- Keywords: Group by intent, show search volume and CPC ranges.
- Campaign creation: Confirm all settings with user before execution, show campaign ID after.
- Cross-platform: Side-by-side comparison table.
- Errors: Report full error message. Never retry creation tools automatically.
Troubleshooting
- Auth errors: Reconnect via your AI assistant's connector settings
- No data: Verify ad platform is connected at https://www.adspirer.com. Try longer lookback (60/90 days).
- Wrong account: Use
switch_primary_accountto change active account - Rate limits: Adspirer enforces tool call quotas by tier (Free: 15/mo, Plus: 150/mo, Pro: 600/mo, Max: 3,000/mo)