Get daily aggregate ad metrics for an account
Returns daily aggregate metrics across all ads in a SocialAccount as a single time series — one row per calendar day in the requested range. Use this for dashboards that draw a daily-spend or daily-conversions chart, instead of calling `/v1/ads/tree` once per day. `accountId` is required. The lookup is sibling-expanded so passing the `metaads` ID also includes ads under the linked `facebook` / `instagram` posting account (and vice-versa) — same convention as `/v1/ads/tree` and `/v1/ads`. Date range defaults to the last 90 days. Capped at 730 days. Ranges older than the 90-day cache window trigger an on-demand backfill from the platform before returning.
API key authentication - use your Zernio API key as a Bearer token
In: header
Query Parameters
Social account ID. Sibling-expanded to its linked posting↔ads pair.
Optional platform-native ad account ID (e.g. Meta act_…, TikTok advertiser ID). Use when the connection wraps multiple platform ad accounts and the chart should show one only. Note: rows ingested before 2026-05-13 don't carry this column; the recurring 7-day re-sync repopulates them naturally.
Inclusive start of metrics range (YYYY-MM-DD). Defaults to 90 days ago.
dateInclusive end of metrics range (YYYY-MM-DD). Defaults to today. Max 730-day range.
dateRestrict to one platform.
"facebook" | "instagram" | "tiktok" | "linkedin" | "pinterest" | "google" | "twitter"Response 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.getAdsTimeline({ query: { accountId: 'account_abc123', },});console.log(data);{
"rows": [
{
"date": "2019-08-24",
"spend": 0,
"impressions": 0,
"reach": 0,
"clicks": 0,
"engagement": 0,
"ctr": 0,
"cpc": 0,
"cpm": 0,
"conversions": 0,
"costPerConversion": 0,
"actions": {
"property1": 0,
"property2": 0
},
"actionValues": {
"property1": 0,
"property2": 0
},
"purchaseValue": 0,
"roas": 0
}
]
}{
"error": "Unauthorized"
}Get campaign tree GET
Returns a nested Campaign > Ad Set > Ad hierarchy with rolled-up metrics at each level. Uses a two-stage aggregation: ads are grouped into ad sets, then ad sets into campaigns. Metrics are computed over an optional date range, then rolled up from ad level to ad set and campaign levels. Pagination is at the campaign level. Ads without a campaign or ad set ID are grouped into synthetic "Ungrouped" buckets. If no date range is provided, defaults to the last 90 days. Date range is capped at 730 days max.
Pause or resume a campaign PUT
Updates the status of all ads in a campaign. Makes one platform API call (not per-ad) since status cascades through the campaign hierarchy. Ads in terminal statuses (rejected, completed, cancelled) are automatically skipped.