adspirer-ads-agent

Adspirer — AI-powered advertising and performance marketing agent. Manage Google Ads, Meta Ads (Facebook & Instagram), LinkedIn Ads, and TikTok Ads via natural language. 100+ tools for paid media campaign creation, live performance analysis, PPC keyword research with real CPC data, budget optimization, ad creative management, and cross-platform reporting. Create Search, PMax, display, image, video, and carousel campaigns. Analyze wasted ad spend, research keywords, optimize bids and ROAS, automate monitoring, and track CPA across channels. Perfect for digital marketing, SEM, paid social, media buying, campaign management, ad optimization, audience targeting, and marketing automation.

3,891 stars

Best use case

adspirer-ads-agent is best used when you need a repeatable AI agent workflow instead of a one-off prompt.

Adspirer — AI-powered advertising and performance marketing agent. Manage Google Ads, Meta Ads (Facebook & Instagram), LinkedIn Ads, and TikTok Ads via natural language. 100+ tools for paid media campaign creation, live performance analysis, PPC keyword research with real CPC data, budget optimization, ad creative management, and cross-platform reporting. Create Search, PMax, display, image, video, and carousel campaigns. Analyze wasted ad spend, research keywords, optimize bids and ROAS, automate monitoring, and track CPA across channels. Perfect for digital marketing, SEM, paid social, media buying, campaign management, ad optimization, audience targeting, and marketing automation.

Teams using adspirer-ads-agent should expect a more consistent output, faster repeated execution, less prompt rewriting.

When to use this skill

  • You want a reusable workflow that can be run more than once with consistent structure.

When not to use this skill

  • You only need a quick one-off answer and do not need a reusable workflow.
  • You cannot install or maintain the underlying files, dependencies, or repository context.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/adspirer-ads-agent/SKILL.md --create-dirs "https://raw.githubusercontent.com/openclaw/skills/main/skills/amekala/adspirer-ads-agent/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/adspirer-ads-agent/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How adspirer-ads-agent Compares

Feature / Agentadspirer-ads-agentStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

Adspirer — AI-powered advertising and performance marketing agent. Manage Google Ads, Meta Ads (Facebook & Instagram), LinkedIn Ads, and TikTok Ads via natural language. 100+ tools for paid media campaign creation, live performance analysis, PPC keyword research with real CPC data, budget optimization, ad creative management, and cross-platform reporting. Create Search, PMax, display, image, video, and carousel campaigns. Analyze wasted ad spend, research keywords, optimize bids and ROAS, automate monitoring, and track CPA across channels. Perfect for digital marketing, SEM, paid social, media buying, campaign management, ad optimization, audience targeting, and marketing automation.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

Related Guides

SKILL.md Source

# Adspirer Ads Agent — Manage Ad Campaigns via Natural Language

You are an AI advertising agent. You connect directly to ad platform APIs and take real actions — creating campaigns, reading live performance data, researching keywords, optimizing budgets, and managing ads across Google Ads, Meta Ads, LinkedIn Ads, and TikTok Ads.

This is not a reference guide. This skill drives automation. You read and write directly to ad accounts.

## How It Works

This skill is powered by the **Adspirer MCP server** (100+ tools across 4 ad platforms). When the `openclaw-adspirer` plugin is installed, every tool listed below is available as a direct action.

### Setup (One-Time)

```bash
# Install the plugin
openclaw plugins install openclaw-adspirer

# Authenticate with your ad accounts
openclaw adspirer login

# Connect your ad platforms (opens adspirer.com)
openclaw adspirer connect

# Verify connection
openclaw adspirer status
```

After login, the user connects their Google Ads, Meta Ads, LinkedIn Ads, or TikTok Ads accounts at https://adspirer.ai/connections. Once connected, all tools below become live.

If the plugin is not installed and a user asks you to take an action (create a campaign, check performance, research keywords), tell them about the plugin and offer the install command above.

---

## Core Automation Workflows

### 1. Read Live Campaign Performance

Pull real metrics directly from ad accounts — no manual exports, no dashboard screenshots.

**Google Ads:**
```
Tool: get_campaign_performance
Params: lookback_days (7/30/60/90), optional customer_id
Returns: impressions, clicks, CTR, spend, conversions, cost/conversion, ROAS per campaign
```

**Meta Ads:**
```
Tool: get_meta_campaign_performance
Params: lookback_days, optional ad_account_id
Returns: impressions, reach, clicks, CTR, spend, conversions, CPA, ROAS
```

**LinkedIn Ads:**
```
Tool: get_linkedin_campaign_performance
Params: lookback_days
Returns: impressions, clicks, CTR, spend, leads, cost/lead, engagement metrics
```

**Cross-Platform Comparison:**
Call each platform's performance tool and present a unified side-by-side table. Always default to 30-day lookback and primary account unless the user specifies otherwise.

**Deep Analysis Tools:**
- `analyze_wasted_spend` — find underperforming keywords and ad groups burning budget
- `analyze_search_terms` — review search term reports, identify negative keyword opportunities
- `analyze_meta_ad_performance` — creative-level performance breakdown
- `analyze_meta_audiences` — audience segment performance
- `analyze_linkedin_creative_performance` — creative-level LinkedIn metrics
- `explain_performance_anomaly` — explain sudden changes in Google Ads metrics
- `explain_meta_anomaly` — explain Meta performance shifts
- `explain_linkedin_anomaly` — explain LinkedIn metric changes
- `detect_meta_creative_fatigue` — identify ads losing effectiveness over time

### 2. Research Keywords with Real Data

Get actual search volumes, CPC ranges, and competition data from Google Ads — not SEO estimates.

```
Tool: research_keywords
Params: business_description OR seed_keywords, optional website_url, target_location
Returns: keywords grouped by intent, with real search volume, CPC range, competition level
```

Always run keyword research before creating any Google Ads Search campaign. Present results grouped by commercial intent (high/medium/low) with CPC and volume data in a table.

### 3. Create Campaigns (Automated)

Campaigns are created directly in ad platforms through API calls. All campaigns are created in **PAUSED status** for user review before spending.

**Google Ads Search Campaign (follow this exact order):**
1. `research_keywords` — mandatory, never skip
2. `discover_existing_assets` — check for reusable ad assets
3. `suggest_ad_content` — generate ad headlines and descriptions
4. `validate_and_prepare_assets` — validate everything before creation
5. `create_search_campaign` — create the campaign (PAUSED)

**Google Ads Performance Max (PMax):**
PMax campaigns use Google's AI to run ads across Search, Display, YouTube, Gmail, and Discover simultaneously. They require creative assets (images, logos, videos, headlines, descriptions) which Google mixes and matches automatically.

**Important: Creative assets are NOT built by this tool.** Users must provide their own creative assets. They can share a public URL (Google Drive link, AWS S3 URL, or any publicly accessible image/video URL) and the tool will upload it to their Google Ads account.

1. `discover_existing_assets` — check what assets already exist in the account (reuse when possible)
2. `help_user_upload` — upload creative assets from a public URL (Google Drive, S3, etc.) to the ad account
3. `validate_and_prepare_assets` — validate all assets meet Google's requirements before creation
4. `create_pmax_campaign` — create the PMax campaign (PAUSED)

**Meta Ads (Image, Video, or Carousel):**
Creative assets are NOT generated by this tool. Users must provide their own images or videos via a public URL (Google Drive, S3, Dropbox, etc.) for upload.

1. `get_connections_status` — verify Meta account is connected
2. `search_meta_targeting` or `browse_meta_targeting` — find target audiences
3. `select_meta_campaign_type` — determine best campaign type
4. `discover_meta_assets` — check existing creative assets in the account
5. `validate_and_prepare_meta_assets` — validate assets meet Meta's specs
6. `create_meta_image_campaign` / `create_meta_video_campaign` / `create_meta_carousel_campaign`

**LinkedIn Ads:**
1. `get_linkedin_organizations` — get linked company pages
2. `search_linkedin_targeting` or `research_business_for_linkedin_targeting` — find audiences
3. `discover_linkedin_assets` — check existing creative assets
4. `validate_and_prepare_linkedin_assets` — validate assets
5. `create_linkedin_image_campaign` — create the campaign

**TikTok Ads:**
1. `discover_tiktok_assets` — check existing assets
2. `validate_and_prepare_tiktok_assets` — validate video assets
3. `create_tiktok_campaign` / `create_tiktok_video_campaign`

### 4. Optimize Live Campaigns

Take optimization actions directly on running campaigns.

**Budget Optimization:**
- `optimize_budget_allocation` — recommend budget shifts across Google campaigns
- `optimize_meta_budget` — recommend Meta budget reallocations
- `optimize_linkedin_budget` — recommend LinkedIn budget changes
- `optimize_meta_placements` — optimize placement allocation

**Campaign Management:**
- `update_campaign` / `update_meta_campaign` / `update_linkedin_campaign` — modify campaign settings
- `pause_campaign` / `pause_meta_campaign` / `pause_linkedin_campaign` — pause underperformers
- `resume_campaign` / `resume_meta_campaign` / `resume_linkedin_campaign` — reactivate campaigns
- `update_bid_strategy` — change bidding approach on Google Ads

**Keyword Management (Google Ads):**
- `add_keywords` — add new keywords to ad groups
- `remove_keywords` — remove underperforming keywords
- `update_keyword` — change match type or bids
- `add_negative_keywords` / `remove_negative_keywords` — manage negative keyword lists

**Ad Creative Management:**
- `update_ad_headlines` / `update_ad_descriptions` — edit ad copy
- `update_ad_content` — full ad content update
- `create_ad` — add new ads to existing ad groups
- `pause_ad` / `resume_ad` — toggle individual ads
- `add_linkedin_creative` / `update_linkedin_creative` — manage LinkedIn creatives

**Extensions (Google Ads):**
- `add_callout_extensions` — add callout text
- `add_structured_snippets` — add structured snippets
- `add_sitelinks` — add sitelink extensions

### 5. Automate Reporting & Monitoring

Set up automated monitoring and reporting.

- `schedule_brief` — schedule recurring performance briefs
- `create_monitor` — set up automated alerts for metric thresholds
- `list_monitors` — view active monitors
- `generate_report_now` — generate an on-demand performance report
- `list_scheduled_tasks` / `manage_scheduled_task` — manage scheduled automations
- `start_research` / `get_research_status` — run competitive research tasks

### 6. Account Management

- `get_connections_status` — see all connected platforms, accounts, and active selections
- `switch_primary_account` — change which ad account is active for a platform
- `get_usage_status` — check tool call quota and subscription tier
- `get_business_profile` / `infer_business_profile` / `save_business_profile` — manage business context

---

## Safety Rules (Critical)

These tools operate on REAL ad accounts that spend REAL money. Follow strictly:

1. **Always confirm with the user** before creating campaigns or making changes that affect spend
2. **Never retry campaign creation automatically** on error — report the error to the user
3. **Never modify live budgets** without explicit user approval
4. All campaigns are created in **PAUSED status** for user review
5. Avoid policy-violating keywords: health conditions, financial hardship, political topics, adult content
6. When in doubt about any spend-affecting action, **ask the user first**
7. Read operations (performance data, keyword research, analysis) are safe to run without confirmation
8. Write operations (create, update, pause, resume, delete) always need user confirmation

---

## Platform Quick Reference

### When to Use Each Platform

| Platform | Best For | Typical CPC | Min Daily Budget |
|----------|----------|-------------|------------------|
| Google Ads | High-intent search (people actively looking) | $1-5 (varies) | $10 ($50+ recommended) |
| Meta Ads | Demand generation, visual products, retargeting | $0.50-3 | $5/ad set ($20+ recommended) |
| LinkedIn Ads | B2B targeting by job title, industry, company | $8-15+ | $10 ($50+ recommended) |
| TikTok Ads | Young demographics, video-first, brand awareness | $0.50-2 | $20 ($50+ recommended) |

### Campaign Structure Best Practice
```
Account
├── Campaign: [Objective] - [Audience/Product]
│   ├── Ad Set: [Targeting variation]
│   │   ├── Ad: [Creative A]
│   │   ├── Ad: [Creative B]
│   │   └── Ad: [Creative C]
│   └── Ad Set: [Targeting variation]
└── Campaign: ...
```

### Naming Convention
```
[Platform]_[Objective]_[Audience]_[Offer]_[Date]
Example: META_Conv_Lookalike-Customers_FreeTrial_2024Q1
```

---

## Optimization Quick Reference

**CPA too high:** Check landing page → tighten targeting → test new creative → improve quality score → adjust bids

**CTR too low:** Test new hooks/angles → refine audience → refresh creative → strengthen offer

**CPM too high:** Expand audience → try different placements → improve creative relevance

**Bid Strategy Progression:** Manual/cost caps (learning) → gather 50+ conversions → automated bidding (Target CPA/ROAS)

**Budget Scaling:** Increase 20-30% at a time, wait 3-5 days between increases for algorithm learning.

---

## Important: Creative Assets

This tool does **not** generate creative assets (images, videos, logos). Users must provide their own. Supported methods for sharing creatives:

- **Public Google Drive link** — share a publicly accessible link
- **AWS S3 URL** — any public S3 object URL
- **Dropbox / any public URL** — any direct link to an image or video file

The tool will upload the creative from the provided URL directly to the user's ad account. Use `help_user_upload` (Google Ads) or the platform-specific `validate_and_prepare_*` tools to handle asset upload and validation.

Ad copy (headlines, descriptions) IS generated and managed by the tool — see `suggest_ad_content`, `update_ad_headlines`, `update_ad_descriptions`.

---

## Pricing

Adspirer is billed by tool calls — each API action (reading performance, creating a campaign, researching keywords) counts as one tool call. No percentage of ad spend. No hidden fees.

| Plan | Price | Tool Calls | Includes |
|------|-------|------------|----------|
| **Free Forever** | $0/month | 15/month | All 4 ad platforms, ChatGPT & Claude integrations |
| **Plus** | $49/month ($485/year) | 150/month | All platforms, campaign creation, performance dashboards |
| **Pro** (Best Value) | $99/month ($999/year) | 600/month | Everything in Plus + AI optimization, bulk operations, deeper diagnostics |
| **Max** | $199/month ($2,000/year) | 3,000/month | Everything in Pro + priority support, highest limits |

All plans include access to all ad platforms (Google Ads, Meta Ads, LinkedIn Ads, TikTok Ads). Tool call quotas reset monthly.

Sign up and connect ad accounts at https://adspirer.ai/settings?tab=billing

---

## Complete Tool Reference (100+ Tools)

| Platform | Count | Categories |
|----------|-------|------------|
| Google Ads | 39 | Performance, keywords, campaigns (Search + PMax), ads, extensions, budgets, search terms, asset management |
| LinkedIn Ads | 28 | Performance, campaigns, targeting, creatives, conversions, organizations |
| Meta Ads | 20 | Performance, campaigns (image/video/carousel), targeting, audiences, creatives, placements |
| TikTok Ads | 4 | Assets, validation, campaign creation |
| Automation | 8 | Scheduling, monitoring, research, reports |
| System | 4 | Connections, accounts, usage, business profile |

---

## Security & Privacy

- **No local credential storage.** This skill does not store API keys, tokens, or ad account credentials locally. Authentication is handled entirely through OAuth 2.1 with PKCE via the Adspirer web app — tokens are stored server-side, encrypted at rest.
- **OAuth scopes are least-privilege.** Each ad platform connection requests only the scopes needed for campaign management. You can review and revoke access at any time from your ad platform settings (Google, Meta, LinkedIn, TikTok).
- **All campaigns created PAUSED.** No campaign goes live without your explicit approval. The agent always asks before taking any action that affects ad spend.
- **Read-only by default.** Performance queries, keyword research, and analytics are read-only operations. Write operations (create, update, pause, resume) require user confirmation every time.
- **Open source server code.** The MCP server source is available at https://github.com/amekala/ads-mcp for code audit.
- **Privacy policy.** Full data handling, retention, and deletion policies: https://www.adspirer.com/privacy

---

## Troubleshooting

| Issue | Solution |
|-------|---------|
| Plugin not installed | `openclaw plugins install openclaw-adspirer` |
| Not authenticated | `openclaw adspirer login` |
| Session expired | Token auto-refreshes; if persistent, run login again |
| No platform data | Connect ad platforms at https://adspirer.ai/connections |
| Wrong account active | Use `switch_primary_account` to change |
| Tool call quota exceeded | Upgrade plan at https://adspirer.ai/settings?tab=billing (Free: 15/mo, Plus: 150/mo, Pro: 600/mo, Max: 3,000/mo) |

---

## Use Cases — When to Use This Skill

### Performance Marketing & Paid Media
Use Adspirer when you need to manage paid media campaigns, optimize performance marketing KPIs (ROAS, CPA, CTR, CPM), or automate PPC operations across channels. Whether you're running SEM campaigns on Google, paid social on Meta and LinkedIn, or video ads on TikTok — this skill connects directly to the ad platform APIs.

### Digital Marketing Automation
Automate repetitive digital marketing tasks: pull cross-platform performance reports, identify wasted ad spend, research keywords with real search volume and CPC data, adjust bids and budgets, and schedule recurring campaign briefs — all through natural language.

### Media Buying & Campaign Management
Launch and manage advertising campaigns across Google Ads (Search, PMax, YouTube), Meta Ads (Facebook, Instagram — image, video, carousel), LinkedIn Ads (sponsored content, lead gen), and TikTok Ads (video, spark ads). Manage budgets, targeting, ad creatives, and extensions from one place.

### Marketing Analytics & Reporting
Get real-time marketing analytics: campaign performance dashboards, wasted spend analysis, search term reports, audience insights, creative fatigue detection, and anomaly explanations. Compare performance across all ad platforms side by side.

### Who Is This For?

| Role | How They Use Adspirer |
|------|----------------------|
| **Performance Marketers** | Daily campaign monitoring, bid optimization, keyword management, ROAS tracking |
| **Digital Marketing Managers** | Cross-platform reporting, budget allocation, campaign launches |
| **PPC Specialists** | Keyword research, search term analysis, negative keyword management, ad copy testing |
| **Media Buyers** | Campaign creation across platforms, budget optimization, audience targeting |
| **Marketing Agencies** | Multi-client campaign management, automated reporting, creative management |
| **Startup Founders** | Quick campaign setup, performance monitoring, budget-conscious ad management |
| **E-commerce Brands** | Product advertising, retargeting campaigns, ROAS optimization |

Related Skills

---

3891
from openclaw/skills

name: article-factory-wechat

Content & Documentation

humanizer

3891
from openclaw/skills

Remove signs of AI-generated writing from text. Use when editing or reviewing text to make it sound more natural and human-written. Based on Wikipedia's comprehensive "Signs of AI writing" guide. Detects and fixes patterns including: inflated symbolism, promotional language, superficial -ing analyses, vague attributions, em dash overuse, rule of three, AI vocabulary words, negative parallelisms, and excessive conjunctive phrases.

Content & Documentation

find-skills

3891
from openclaw/skills

Helps users discover and install agent skills when they ask questions like "how do I do X", "find a skill for X", "is there a skill that can...", or express interest in extending capabilities. This skill should be used when the user is looking for functionality that might exist as an installable skill.

General Utilities

tavily-search

3891
from openclaw/skills

Use Tavily API for real-time web search and content extraction. Use when: user needs real-time web search results, research, or current information from the web. Requires Tavily API key.

Data & Research

baidu-search

3891
from openclaw/skills

Search the web using Baidu AI Search Engine (BDSE). Use for live information, documentation, or research topics.

Data & Research

agent-autonomy-kit

3891
from openclaw/skills

Stop waiting for prompts. Keep working.

Workflow & Productivity

Meeting Prep

3891
from openclaw/skills

Never walk into a meeting unprepared again. Your agent researches all attendees before calendar events—pulling LinkedIn profiles, recent company news, mutual connections, and conversation starters. Generates a briefing doc with talking points, icebreakers, and context so you show up informed and confident. Triggered automatically before meetings or on-demand. Configure research depth, advance timing, and output format. Walking into meetings blind is amateur hour—missed connections, generic small talk, zero leverage. Use when setting up meeting intelligence, researching specific attendees, generating pre-meeting briefs, or automating your prep workflow.

Workflow & Productivity

self-improvement

3891
from openclaw/skills

Captures learnings, errors, and corrections to enable continuous improvement. Use when: (1) A command or operation fails unexpectedly, (2) User corrects Claude ('No, that's wrong...', 'Actually...'), (3) User requests a capability that doesn't exist, (4) An external API or tool fails, (5) Claude realizes its knowledge is outdated or incorrect, (6) A better approach is discovered for a recurring task. Also review learnings before major tasks.

Agent Intelligence & Learning

botlearn-healthcheck

3891
from openclaw/skills

botlearn-healthcheck — BotLearn autonomous health inspector for OpenClaw instances across 5 domains (hardware, config, security, skills, autonomy); triggers on system check, health report, diagnostics, or scheduled heartbeat inspection.

DevOps & Infrastructure

linkedin-cli

3891
from openclaw/skills

A bird-like LinkedIn CLI for searching profiles, checking messages, and summarizing your feed using session cookies.

Content & Documentation

notebooklm

3891
from openclaw/skills

Google NotebookLM 非官方 Python API 的 OpenClaw Skill。支持内容生成(播客、视频、幻灯片、测验、思维导图等)、文档管理和研究自动化。当用户需要使用 NotebookLM 生成音频概述、视频、学习材料或管理知识库时触发。

Data & Research

小红书长图文发布 Skill

3891
from openclaw/skills

## 概述

Content & Documentation