update_meta_campaign

Meta Ads Write

User wants to update an existing Meta campaign's status, budget, name, or schedule

Endpoint

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

Headers

Description

User wants to update an existing Meta campaign's status, budget, name, or schedule. IMPORTANT: This tool modifies REAL campaigns in Meta Ads Manager. Changes take effect immediately. Returns: - Confirmation of updates applied - Updated campaign details - Ads Manager URL When to use this tool: - "Update my Meta campaign budget" - "Change my Facebook campaign name" - "Pause my Instagram campaign" - "Resume my paused campaign" - "Set a new budget for campaign X" - "Change the end date for my campaign" Parameters: - campaign_id: The Meta Campaign ID to update (required) - status: New status - 'ACTIVE', 'PAUSED' (optional) - name: New campaign name (optional) - daily_budget: New daily budget in USD (optional) - lifetime_budget: New lifetime budget in USD (optional) - start_time: New start time in ISO format (optional) - stop_time: New stop time in ISO format (optional) At least one update field must be provided. Execution time: 2-5 seconds Modifies: Real campaign in Meta Ads

Request body

All tool arguments are wrapped in an arguments object.

FieldTypeDescription
campaign_idstring requiredThe Meta Campaign ID to update (required)
statusstring optionalNew status: 'ACTIVE', 'PAUSED' (optional)
namestring optionalNew campaign name (optional)
daily_budgetnumber optionalNew daily budget in USD (optional, minimum $1)
lifetime_budgetnumber optionalNew lifetime budget in USD (optional)
start_timestring optionalNew start time in ISO format YYYY-MM-DDTHH:MM:SS (optional)
stop_timestring optionalNew stop time in ISO format YYYY-MM-DDTHH:MM:SS (optional)
ad_account_idstring optionalMeta Ad Account ID. Required for multi-account users. Get from list_connected_accounts.

Example request

{
  "arguments": {
    "campaign_id": "<campaign_id>",
    "status": "string",
    "name": "string",
    "daily_budget": 1.0,
    "lifetime_budget": 1.0,
    "start_time": "string",
    "stop_time": "string"
  }
}

Example responses

200 — Success

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

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

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