Spend
This page describes the usage of our Spend API
What is the Spend API?
As briefly covered in the Getting Started page, our Spend API enables our customers to programmatically upload daily spend, clicks, and impressions metrics at the ad level of their choice (Campaign, Adset, Ad) for Ad platform integrations that we do not natively support.
Functionality
The Spend API allows for
- upload of new entries,
- updating of existing entries,
- deletion of existing entries,
- listing of uploaded entries
With this flexiblity, our customers can programmatically modify their spend data for platforms we do not yet natively support!
When to use the Spend API instead of the Spend Sheets
Spend Sheets allow you to share spend data for ad platforms that we do not natively support via a Google Sheet. This can be rather cumbersome when there are either:
- a lot of ad platforms to support via sheets, or
- a lot of campaigns (deeper levels) of hierarchy per platform. Spend API was developed to address these difficulties.
Consider using the Spend API instead if:
- you have developer resources that can assist you for implementation, and
- your spend is complex enough that manually updating the sheet periodically will be burdensome.
Spend Sheet | Spend API | |
---|---|---|
Import ad spend data from any platform | ✅ | ✅ |
No dev resources required | ✅ | ❌ |
Minimal ongoing overhead to support | ❌ | ✅ |
Supports Hourly data | ❌ | ✅ |
Spend Attributes
Each spend entry has a set of **required attributes as well as _optional attributes that can be submitted for each spend entry. These fields are also documented in the API Reference, albeit in much more detail here.
Day by Day Data
Most users will only need day by day data for their custom spend. This will spread out the data across the entire day linearly (For example if you send $240 dollars for a day it will be attributed as 10 dollars for every hour of the day).
Required Attributes
Certain metadata is required for a spend entry to be submitted. Without these fields, an API call will return an error as part of our validation check to make sure the spend entries contained in an API call pass muster. The following attributes are required:
date
- The date the spend was committed, in a YYYY-MM-DD fashion.platform_name
- This field denotes the platform name the spend object will appear under in the dashboard. This must be supplied as a non-empty string.campaign_id
- While the ad hierarchies of each ad platform are different, each platform has a least one level of ads to enumerate over. Within northbeam, we consider campaigns to be the highest level ad object. Use this field to capture the ID of the ad object you are spending oncampaign_name
- This field denotes the campaign name the spend object will appear under in the dashboard.spend
- This captures how much was spent on an ad object on a given day. If no spend was made on an ab object, consider not sending an entry for that ad object.spend_currency
- This field captures the currency that was used for the spend, per ISO-4217 standards (a 3 letter denomination)
Hour by Hour Data
If you need to specify data on a finer grain than day by day we can also support hourly custom spend data. Please only send full hours and leave minutes and seconds as zero for the hour_start_iso
field (The API will not accept data with minutes and/or seconds)
Required Attributes
Certain metadata is required for a spend entry to be submitted. Without these fields, an API call will return an error as part of our validation check to make sure the spend entries contained in an API call pass muster. The following attributes are required:
hour_start_iso
- The hour the spend was committed, in an ISO 8601 format. This does require a timezone offset. The minutes, seconds and microseconds must be zero. (Ex:2024-01-01T00:00:00-07:00
)platform_name
- This field denotes the platform name the spend object will appear under in the dashboard. This must be supplied as a non-empty string.campaign_id
- While the ad hierarchies of each ad platform are different, each platform has a least one level of ads to enumerate over. Within northbeam, we consider campaigns to be the highest level ad object. Use this field to capture the ID of the ad object you are spending oncampaign_name
- This field denotes the campaign name the spend object will appear under in the dashboard.spend
- This captures how much was spent on an ad object on a given day. If no spend was made on an ab object, consider not sending an entry for that ad object.spend_currency
- This field captures the currency that was used for the spend, per ISO-4217 standards (a 3 letter denomination)
Optional Attributes
The following spend attributes are optional for Hourly and Daily data:
platform_account_id
- Each Ad Platform has an account id. In the event that a customer has multiple account IDs associated with a particular ad platform, this is useful for segregating which ad platform spend was made on. If only using one account and the account ID is unknown, use a number or your choosing, but please remain consistent in using that number!adset_id
- This field denotes the adset id for the ad object spend was made on (if applicable). If not supplied, the default will be set to""
(Blank string)adset_name
- This field denotes the adset name the spend object will appear under in the dashboard. If not supplied, the default will be set to""
(Blank string)ad_id
- This field denotes the ad id for the ad object spend was made on (if applicable). If not supplied, the default will be set to""
(Blank string)ad_name
- This field denotes the ad name the spend object will appear under in the dashboard. If not supplied, the default will be set to""
(Blank string)impressions
- Along with Spend, the Spend API can track additional metrics that can be gathered from the ad platform, such as impressions, these will default to0
if not specifiedclicks
- Along with Spend, the Spend API can track additional metrics that can be gathered from the ad platform, such as clicks, these will default to0
if not specified.
Notes
One of the motivations for development of this API was to avoid using Spend sheets. Spend sheets exist at Northbeam to allow Northbeam to capture spend that we do not have native connections for. This can be rather cumbersome when there are either (i) a lot of ad platforms to support via sheets, or (ii) a lot of campaigns (deeper levels) of heirarchy per platform. Consider using the Spend API if developer resources are available and the time spent using the sheets is burdensome and can be leveraged otherwise!
Further Help
If you have any questions reach out to Customer Success at [email protected]!
Updated 4 months ago