remove_callouts

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/remove_callouts/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 Remove callout extensions from a campaign. Unlinks callouts from THIS campaign. The underlying Asset stays in your account and can be re-linked elsewhere. **Why this matters:** - Old callouts containing words like "Doctor Reviewed" / "Medical" / "Clinical" can flag a campaign for policy issues - Stale promotional callouts (e.g. "Summer Sale 2024") look bad to users - Must remove old callouts before fresh ones take their place **Parameters:** - campaign_id: Campaign whose callouts to remove (REQUIRED) - asset_ids: Optional list of asset IDs (or full resource_names) to remove specifically. Get IDs from `list_campaign_extensions`. If omitted, ALL callouts on this campaign are removed. - customer_id: Optional (uses connected account if omitted) **Workflow:** 1. Call `list_campaign_extensions(campaign_id)` to see what's currently linked 2. Identify which callouts to remove by their asset_id or text 3. Call this tool with those asset_ids (or omit to clear ALL) 4. Use `add_callout_extensions` to add fresh ones if needed **Example:** User: "Remove all my callouts and add new ones" Agent: 1. Confirms: "I'll remove all 4 current callouts and let you add new ones. Proceed?" 2. Calls remove_callouts(campaign_id) โ€” clears all 3. Then add_callout_extensions with new list

Request body

All tool arguments are wrapped in an arguments object.

FieldTypeDescription
campaign_idstring requiredThe campaign ID to remove callouts from. Use list_campaigns first to find campaigns.
asset_idsarray optionalOptional list of asset IDs (or full resource_names) to remove. Get IDs from list_campaign_extensions. If omitted, ALL callouts linked to this campaign are removed.
customer_idstring optionalGoogle Ads customer ID. Required for multi-account users. Get from list_connected_accounts.

Example request

{
  "arguments": {
    "campaign_id": "<campaign_id>",
    "asset_ids": [
      "string"
    ],
    "customer_id": "string"
  }
}

Example responses

200 โ€” Success

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

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": "remove_callouts"
}

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": "remove_callouts",
  "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