Duplicate a campaign
Duplicates a campaign, including its ad sets, ads, creatives, and targeting by default (`deepCopy: true`). On Meta, this uses `POST /{campaign-id}/copies`. The copy is created paused by default so callers can review before launching. The platform's duplication is asynchronous from our side; once the copy is created on the platform, we trigger a sync discovery so the new hierarchy shows up in /v1/ads/tree. Set `syncAfter: false` to skip the discovery trigger and poll on your own cadence. Meta-only for now. Other platforms return 501 Not Implemented.
API key authentication - use your Zernio API key as a Bearer token
In: header
Path Parameters
Source platform campaign ID
"facebook" | "instagram"Copy child ad sets + ads + creatives + targeting
true"PAUSED""ACTIVE" | "PAUSED" | "INHERITED_FROM_SOURCE"Reschedule the copied hierarchy's start time
date-timedate-time"DEEP_RENAME" | "ONLY_TOP_LEVEL_RENAME" | "NO_RENAME"Trigger ads discovery on the owning account after the copy succeeds
trueResponse Body
application/json
application/json
import Zernio from '@zernio/node';const zernio = new Zernio({ apiKey: process.env.ZERNIO_API_KEY });const { data } = await zernio.adcampaigns.duplicateAdCampaign({ path: { campaignId: 'campaign_abc123', }, body: { platform: 'facebook', },});console.log(data);{
"copiedCampaignId": "string",
"discovery": "triggered",
"raw": {}
}{
"error": "Unauthorized"
}Pause or resume many campaigns POST
Process up to 50 campaigns in one call. Each campaign is updated concurrently and the response contains a per-campaign result so a single bad row does not fail the whole batch.
List custom audiences GET
Returns custom audiences for the given ad account. Supports Meta, Google, TikTok, and Pinterest.