update_ad_headlines

Google Ads Write

๐Ÿšจ **IF THIS TOOL RETURNS A QUOTA ERROR:** - The error message will include a clickable upgrade link - Show the FULL error message to the user (it contains the upgrade link) - DO NOT attempt to work ar

Endpoint

POST https://api.adspirer.ai/api/v1/tools/update_ad_headlines/execute

Headers

Description

๐Ÿšจ **IF THIS TOOL RETURNS A QUOTA ERROR:** - The error message will include a clickable upgrade link - Show the FULL error message to the user (it contains the upgrade link) - DO NOT attempt to work around the error or use alternative data - DO NOT create campaigns or perform actions without valid tool data - STOP and direct the user to upgrade via the provided link Update headlines for a Responsive Search Ad (RSA) OR Responsive Display Ad (RDA). The backend auto-detects the ad type and enforces per-type count bounds: - RSA (Search): 3-15 headlines - RDA (Display): 1-5 headlines Each headline is max 30 characters, on both types. **MANDATORY WORKFLOW:** 1. Call `get_campaign_structure` to find ad_id and ad_group_id 2. Review current headlines 3. Prepare new headlines: - RSA โ€” 3-15 headlines. Follow the category system (Category A: What It Is, Category B: Benefits, Category C: Pain/Proof/CTA). Headlines must work in ANY combination. - RDA โ€” 1-5 short headlines (max 30 chars each). You'll also likely want to update the `long_headline` via `update_ad_content` (RDA only, max 90 chars). 4. Validate (max 30 chars each, no "!" marks, no unverified superlatives like "Best", "#1") 5. Get user approval 6. Call this tool with ad_id, ad_group_id, headlines **Parameters:** - ad_id (REQUIRED), ad_group_id (REQUIRED), headlines (REQUIRED) - customer_id (optional) **Execution time:** 2-4 seconds. **WARNING:** Updated ads go through Google's review process (24-48 hours).

Request body

All tool arguments are wrapped in an arguments object.

FieldTypeDescription
ad_idstring requiredThe ad ID to update. Get from get_campaign_structure (look in ad_groups -> ads section).
ad_group_idstring requiredThe ad group ID the ad belongs to. Get from get_campaign_structure.
headlinesarray requiredHeadlines (max 30 characters each). RSA requires 3-15 headlines; RDA requires 1-5 headlines. Headlines should work well in any combination. Avoid exclamation marks and unverified superlatives (Best, #1, etc.).
customer_idstring optionalGoogle Ads customer ID. Required for multi-account users. Get from get_connections_status.

Example request

{
  "arguments": {
    "ad_id": "string",
    "ad_group_id": "string",
    "headlines": [
      "string"
    ],
    "customer_id": "string"
  }
}

Example responses

200 โ€” Success

{
  "success": true,
  "data": {
    "text": "(tool-specific textual output for update_ad_headlines)",
    "quota": {
      "used": 42,
      "limit": 150,
      "tier": "plus",
      "period_end": "2026-05-01"
    }
  },
  "tool": "update_ad_headlines"
}

400 โ€” Tool-level error (bad arguments / multi-account selection)

{
  "success": false,
  "error": "You have 25 meta_ads accounts connected. Please specify which account to use by passing the ad_account_id parameter:\n  - Acme Holdings (ad_account_id=\"act_123456789\")\n  - Acme EU (ad_account_id=\"act_987654321\")",
  "is_error": true,
  "tool": "update_ad_headlines"
}

402 โ€” Quota exhausted

{
  "success": false,
  "error": "\ud83d\udea8 Monthly limit reached (150/150 tool calls on Plus tier).\nUpgrade to Pro at https://adspirer.ai to keep building.",
  "is_error": true,
  "tool": "update_ad_headlines",
  "quota": {
    "used": 150,
    "limit": 150,
    "tier": "plus",
    "period_end": "2026-05-01",
    "upgrade_url": "https://adspirer.ai"
  }
}

Try it live


Adspirer REST API โ€” get an API key at adspirer.ai/keys ยท adspirer.ai