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
POST https://api.adspirer.ai/api/v1/tools/update_pmax_audience_signal/execute
Authorization: Bearer sk_live_... โ your Adspirer API key (required)Content-Type: application/json (required)Idempotency-Key: <uuid> โ recommended for write operations to make retries safeAll tool arguments are wrapped in an arguments object.
| Field | Type | Description |
|---|---|---|
audience_resource_name | string required | The audience resource name to update. Get from get_pmax_audience_signals โ it's the `audience` field on each signal (NOT the signal's own resource_name). Example: 'customers/1234567890/audiences/12345' |
audience_config | object optional | REPLACES the audience's segment composition. Same shape as add_pmax_audience_signal: keys 'in_market_audience_ids' (List[int]), 'affinity_audience_ids' (List[int]), 'custom_audience_ids' (List[str]), 'user_list_ids' (List[str]). Shape-tolerant (#559): synonym keys, flat, and nested 'segments' shapes are normalized for you. To MERGE rather than replace, fetch the current composition from get_pmax_audience_signals first and combine with the new segments. Example: {'in_market_audience_ids': [80432, 80210], 'user_list_ids': ['customers/123/userLists/456']} |
customer_id | string optional | Google Ads customer ID. Required for multi-account users. Get from get_connections_status. |
{
"arguments": {
"audience_resource_name": "string",
"audience_config": {},
"customer_id": "string"
}
}
{
"success": true,
"data": {
"text": "(tool-specific textual output for update_pmax_audience_signal)",
"quota": {
"used": 42,
"limit": 150,
"tier": "plus",
"period_end": "2026-05-01"
}
},
"tool": "update_pmax_audience_signal"
}
{
"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_pmax_audience_signal"
}
{
"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_pmax_audience_signal",
"quota": {
"used": 150,
"limit": 150,
"tier": "plus",
"period_end": "2026-05-01",
"upgrade_url": "https://adspirer.ai"
}
}
Interactive: Swagger UI
Machine-readable: OpenAPI 3.1 spec ยท llms-full.txt
More tools: Google Ads ยท All tools
Adspirer REST API โ get an API key at adspirer.ai/keys ยท adspirer.ai