> ## Documentation Index
> Fetch the complete documentation index at: https://docs.foxreach.io/llms.txt
> Use this file to discover all available pages before exploring further.

# Delete Campaign

> Delete a draft campaign. Only campaigns in draft status can be deleted.

## Path Parameters

<ParamField path="campaign_id" type="string" required>
  The unique identifier of the campaign.
</ParamField>

<RequestExample>
  ```bash cURL theme={null}
  curl -X DELETE "https://api.foxreach.io/api/v1/campaigns/cmp_abc123" \
    -H "X-API-Key: otr_your_key"
  ```

  ```python Python SDK theme={null}
  from foxreach import FoxReach

  client = FoxReach(api_key="otr_your_key")
  result = client.campaigns.delete("cmp_xyz789")
  ```

  ```typescript TypeScript SDK theme={null}
  import { FoxReach } from "foxreach";

  const client = new FoxReach({ apiKey: "otr_your_key" });
  const result = await client.campaigns.delete("cmp_xyz789");
  ```
</RequestExample>

<ResponseExample>
  ```json theme={null}
  {
    "data": {
      "id": "cmp_abc123",
      "deleted": true
    }
  }
  ```
</ResponseExample>

## Errors

| Status | Description                         |
| ------ | ----------------------------------- |
| `400`  | Only draft campaigns can be deleted |
| `404`  | Campaign not found                  |

<Warning>
  Only campaigns in `draft` status can be deleted. Pause active campaigns first, or archive them through the dashboard.
</Warning>

## Rate Limit

* **100 requests per minute, per API key.** Fixed 60-second window.
* Every response includes `X-RateLimit-Limit`, `X-RateLimit-Remaining`, and `X-RateLimit-Reset` (unix epoch seconds).
* A `429` response includes a `Retry-After` header (seconds until the bucket resets).

For client-side patterns (`Retry-After`, exponential backoff, monitoring `X-RateLimit-Remaining`), see [Rate Limiting](/rate-limiting).
