update_display_ad_group

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_display_ad_group/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 one or more editable settings on a Display ad group in a single API call. At least one of the following must be provided. Any field omitted is not touched. **Fields:** - `name`: New ad group name (string) - `status`: ENABLED | PAUSED | REMOVED (REMOVED is a soft-delete โ€” use `remove_display_ad_group` for clarity) - `cpc_bid`: Max CPC in account currency (MANUAL_CPC campaigns) - `cpm_bid`: Max viewable CPM in account currency (MANUAL_CPM campaigns) - `ad_rotation_mode`: OPTIMIZE (Google picks best ad) | ROTATE_FOREVER (even rotation) - `optimized_targeting_enabled`: Let Google expand targeting beyond your chosen audiences Note: `exclude_demographic_expansion` is Search-only and not editable on Display. **Execution time:** 2-4 seconds.

Request body

All tool arguments are wrapped in an arguments object.

FieldTypeDescription
ad_group_idstring requiredAd group ID.
namestring optionalNew ad group name.
statusstring optionalENABLED | PAUSED | REMOVED.
cpc_bidnumber optionalNew max CPC bid in account currency (MANUAL_CPC campaigns).
cpm_bidnumber optionalNew max viewable CPM bid in account currency (MANUAL_CPM campaigns).
ad_rotation_modestring optionalOPTIMIZE (Google chooses best ad) or ROTATE_FOREVER (even rotation).
optimized_targeting_enabledboolean optionalEnable Google's optimized targeting expansion. Default Google behavior varies.
customer_idstring optionalRequired for multi-account users.

Example request

{
  "arguments": {
    "ad_group_id": "string",
    "name": "string",
    "status": "string",
    "cpc_bid": 0.01,
    "cpm_bid": 0.01,
    "ad_rotation_mode": "string",
    "optimized_targeting_enabled": false
  }
}

Example responses

200 โ€” Success

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

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_display_ad_group"
}

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_display_ad_group",
  "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