add_display_audiences

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/add_display_audiences/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 Add audience targeting to a Display ad group. **audience_segments** keys: - `user_interests` โ€” list of affinity/in-market category IDs (from `search_audiences`) - `custom_audiences` โ€” list of resource names like `"customers/123/customAudiences/456"` - `user_lists` โ€” list of remarketing list resource names like `"customers/123/userLists/789"` - `combined_audiences` โ€” list of combined audience resource names **CRITICAL:** Only use IDs returned by `search_audiences`. NEVER fabricate โ€” wrong IDs waste budget on unrelated audiences. **Example:** ``` audience_segments: { "user_interests": ["80517", "80520"], "user_lists": ["customers/123/userLists/111"] } ``` **Execution time:** 2-5 seconds.

Request body

All tool arguments are wrapped in an arguments object.

FieldTypeDescription
ad_group_idstring requiredTarget Display ad group ID.
customer_idstring optionalRequired for multi-account users.
audience_segmentsobject requiredKeys: user_interests (affinity/in-market IDs), custom_audiences (resource names), user_lists (resource names), combined_audiences (resource names). Use search_audiences to get valid IDs โ€” NEVER fabricate.

Example request

{
  "arguments": {
    "ad_group_id": "string",
    "audience_segments": {},
    "customer_id": "string"
  }
}

Example responses

200 โ€” Success

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

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

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