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/add_pmax_asset_group_image/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 |
|---|---|---|
campaign_id | string required | The PMax campaign ID (numeric). Example: '21854471508' |
image_url | string required | Image to upload. Either a public http(s) URL OR a base64 data URI (`data:image/png;base64,...`). Plain base64 without the data-URI prefix is NOT accepted โ wrap it as `data:image/...;base64,...`. |
field_type | string required | PMax image slot. One of: MARKETING_IMAGE, SQUARE_MARKETING_IMAGE, PORTRAIT_MARKETING_IMAGE, TALL_PORTRAIT_MARKETING_IMAGE, LOGO, LANDSCAPE_LOGO, BUSINESS_LOGO. Per-group caps: 20 marketing images total (across the 4 marketing types), 5 of each logo type. |
asset_group_id | string optional | Required when the campaign has more than one asset group. Auto-resolved when there is exactly one. |
asset_name | string optional | Optional display name for the new asset in the Google Ads Asset Library. |
customer_id | string optional | Google Ads customer ID. Required for multi-account users. Get from get_connections_status. |
{
"arguments": {
"campaign_id": "<campaign_id>",
"image_url": "https://example.com",
"field_type": "string",
"asset_group_id": "string",
"asset_name": "string",
"customer_id": "string"
}
}
{
"success": true,
"data": {
"text": "(tool-specific textual output for add_pmax_asset_group_image)",
"quota": {
"used": 42,
"limit": 150,
"tier": "plus",
"period_end": "2026-05-01"
}
},
"tool": "add_pmax_asset_group_image"
}
{
"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_pmax_asset_group_image"
}
{
"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_pmax_asset_group_image",
"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