create_chatgpt_ad

ChatGPT Ads Write

Create a chat_card ad under an existing ad group

Endpoint

POST https://api.adspirer.ai/api/v1/tools/create_chatgpt_ad/execute

Headers

Description

Create a chat_card ad under an existing ad group. Needs ad_group_id, title (3-50 chars), body (≤100 chars), target_url, and an image — pass file_id (from upload_chatgpt_creative) or a public image_url (uploaded for you). Created PAUSED. Returns the real review status — OpenAI rejects third-party-AI-service ads.

Request body

All tool arguments are wrapped in an arguments object.

FieldTypeDescription
ad_group_idstring requiredParent ad group ID (adgrp_...)
titlestring requiredCreative title / headline (3–50 chars).
bodystring requiredCreative body text (≤100 chars).
target_urlstring requiredDestination URL (http/https).
file_idstring optionalImage file_id from upload_chatgpt_creative. Provide this or image_url.
image_urlstring optionalPUBLIC image URL — uploaded for you to get a file_id (square PNG/JPG ≥256px).
namestring optionalOptional ad name (defaults to the title).
statusstring optional'paused' (default) or 'active'.

Example request

{
  "arguments": {
    "ad_group_id": "string",
    "title": "string",
    "body": "string",
    "target_url": "https://example.com",
    "file_id": "string",
    "image_url": "string",
    "name": "string",
    "status": "string"
  }
}

Example responses

200 — Success

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

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

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