Skip to main content

The Trade Desk Integration for Nodus

1. Introduction to The Trade Desk Integration

What Is This Integration?

The Trade Desk integration connects your Trade Desk advertising platform with Nodus, allowing you to extract, analyze, and transform campaign data, performance metrics, and audience insights. This integration functions as a source connector, bringing your Trade Desk data into the Nodus ecosystem for advanced analytics and business intelligence.

Prerequisites:

  • An active Trade Desk account
  • API credentials (username and password)
  • Advertiser ID for the account you want to extract data from
  • Optional: Long-lived API Access Token for more secure authentication

Connection Overview:

The integration uses The Trade Desk's API to extract advertising data and performance metrics. Authentication is handled through standard API credentials or Long-lived Access Token, and data is extracted based on predefined report templates.

2. Platform Setup Documentation (Setup Form for The Trade Desk)

Purpose & Scope

This section covers how to set up the initial connection between Nodus and The Trade Desk by providing the necessary authentication credentials and account details.

Field-by-Field Breakdown:

Integration Name

  • Field Name & Label: Integration Name
  • Description & Purpose: A descriptive name to identify this Trade Desk integration within your Nodus account.
  • Validation Rules & Format: Text string, required field.
  • Examples: "Trade Desk - Agency Account", "Performance Marketing Data"
  • Troubleshooting Tips: Use a descriptive name that clearly identifies the specific Trade Desk account or purpose.

Advertiser ID

  • Field Name & Label: Advertiser ID
  • Description & Purpose: The unique identifier for your Trade Desk advertiser account.
  • Validation Rules & Format: Alphanumeric string, required field.
  • Examples: "a1b2c3d4"
  • Troubleshooting Tips: This is the alpha-numeric ID generated for each of your Trade Desk Advertiser Seats. You can find this in your Trade Desk account settings or from your account manager.

API Username

  • Field Name & Label: API Username
  • Description & Purpose: The username used for API authentication.
  • Validation Rules & Format: Email address, required field.
  • Examples: "api.user@company.com"
  • Troubleshooting Tips: This is the email address associated with your advertiser's API Login Email, not your personal Trade Desk login email. Contact your Trade Desk account manager if you're unsure which email to use.

API Password

  • Field Name & Label: API Password
  • Description & Purpose: The password used for API authentication.
  • Validation Rules & Format: Text string, required field.
  • Troubleshooting Tips: This is the password associated with your advertiser's API login, not your personal Trade Desk login password.

Long-Lived API Access Token

  • Field Name & Label: Long-Lived API Access Token (Optional)
  • Description & Purpose: An alternative authentication method that provides more secure, long-term access.
  • Validation Rules & Format: Text string, optional field.
  • Troubleshooting Tips: You can generate a long-lived token in the Trade Desk Partner Portal. This is recommended for production environments as it's more secure than username/password authentication.

Step-by-Step Guide:

  1. Gather your Trade Desk credentials:
    • Obtain your Advertiser ID from your Trade Desk account dashboard or from your account manager
    • Ensure you have API username and password credentials
    • Optionally, generate a Long-Lived API Access Token in the Partner Portal for enhanced security
  2. Enter your integration details in the Nodus setup form:
    • Provide a meaningful Integration Name
    • Enter your Advertiser ID
    • Enter your API Username
    • Enter your API Password
    • Optionally, enter your Long-Lived API Access Token
  3. Save the configuration and test the connection

3. Extraction/Query Configuration (Extraction Form for The Trade Desk)

Purpose & Overview

This section explains how to configure data extraction from The Trade Desk. The form allows you to select specific report templates and define date ranges for data extraction.

Template & Field Documentation:

Template Selection

  • Field Name & Label: Select a template
  • Description & Purpose: Defines which type of Trade Desk data to extract
  • Validation Rules & Format: Dropdown selection, required field
  • Available Options:
    • Trade Desk Ad Dimensions - Metadata and attributes for ads/creatives
    • Trade Desk Ad Group Dimensions - Metadata and attributes for ad groups
    • Trade Desk Campaign Dimensions - Metadata and attributes for campaigns
    • Trade Desk Ad Group Performance - Performance metrics at the ad group level
    • Trade Desk All Metric Performance - Comprehensive performance metrics across all levels
  • Troubleshooting Tips: Select the template that best aligns with your analytics goals.

Lookback Range

  • Field Name & Label: Lookback Range
  • Description & Purpose: Specifies how many days back to extract data
  • Validation Rules & Format: Dropdown selection, required field
  • Available Options:
    • 3-day Range
    • 7-day Range
    • 28-day Range (recommended)
    • 90-day Range (Optimal if 90-day DDA is used)
    • Custom Range
  • Troubleshooting Tips: Larger date ranges will result in more data being extracted but may take longer to process. The recommended range is 28 days for most use cases.

Historic Date

  • Field Name & Label: Historic Date
  • Description & Purpose: For custom date range extraction, specifies the start and end dates
  • Validation Rules & Format: Date picker, required when Custom Range is selected
  • Troubleshooting Tips: The Trade Desk typically maintains historical data for up to 13 months, but there may be limitations on how far back you can extract certain metrics.

Workflow & Examples:

  1. Select the appropriate template (e.g., "Trade Desk Campaign Dimensions" for campaign metadata)
  2. Choose a lookback period or select "Custom Range" and specify start and end dates
  3. Preview the query to confirm configuration
  4. Execute extraction

Example Use Cases:

Campaign Analysis:

  • Template: Trade Desk Campaign Dimensions
  • Lookback: 28-day Range
  • Purpose: Analyze campaign settings, budget information, and flight dates

Ad Group Performance Analysis:

  • Template: Trade Desk Ad Group Performance
  • Lookback: 90-day Range
  • Purpose: Review performance metrics at the ad group level including impressions, clicks, conversions, and video completion rates

Comprehensive Performance Review:

  • Template: Trade Desk All Metric Performance
  • Historic Date: Custom range for specific campaign periods
  • Purpose: Deep dive into all available performance metrics including device-level breakdowns

Data Mapping & Underlying Models for The Trade Desk

Data Model Overview

The Trade Desk integration extracts data using predefined query templates that map to specific endpoints and data structures in The Trade Desk API.

Schema & Field Mapping

Ad Group Performance Schema

FieldDescription
DateDate for the metrics
Partner_IDThe partner identifier
Advertiser_IDThe advertiser account identifier
Campaign_IDThe campaign identifier
Ad_Group_IDThe ad group identifier
Ad_FormatFormat of the ad (Display, Video, etc.)
Creative_IDThe creative identifier
FrequencyFrequency cap number
AdvertiserName of the advertiser
CampaignName of the campaign
Ad_GroupName of the ad group
Ad_Group_Budget_In_ImpressionsAd group budget expressed in impressions
Ad_Group_Daily_Cap_In_ImpressionsDaily impression cap for the ad group
Ad_Group_Daily_Target_In_ImpressionsDaily impression target for the ad group
Ad_Group_Base_Bid_CPM_Adv_CurrencyBase CPM bid in advertiser's currency
Ad_Group_Budget_Adv_CurrencyAd group budget in advertiser's currency
Ad_Group_Daily_Cap_Adv_CurrencyDaily cap in advertiser's currency
Ad_Group_Daily_Target_Adv_CurrencyDaily target in advertiser's currency
Advertiser_Currency_CodeCurrency code of the advertiser
Partner_Currency_CodeCurrency code of the partner
CreativeName of the creative
ImpressionsNumber of impressions served
ClicksNumber of clicks received
TTD_Cost_Adv_CurrencyCost in advertiser's currency
TTD_Cost_Partner_CurrencyCost in partner's currency
TTD_Cost_USDCost in USD
Player_ViewsNumber of video player views
Player_StartsNumber of video playback starts
Player_25_Percent_CompleteNumber of videos viewed to 25% completion
Player_50_Percent_CompleteNumber of videos viewed to 50% completion
Player_75_Percent_CompleteNumber of videos viewed to 75% completion
Player_Completed_ViewsNumber of videos viewed to completion
Player_MuteNumber of player mute actions
Player_UnmuteNumber of player unmute actions
Player_PauseNumber of player pause actions
Player_ResumeNumber of player resume actions
Player_Full_ScreenNumber of full screen expansions
Player_ErrorsNumber of player errors
Player_SkipNumber of video skips
Player_Engaged_ViewsNumber of engaged video views
Player_RewindNumber of rewind actions
Player_ExpansionNumber of player expansions
Player_CollapseNumber of player collapses
Player_Invitation_AcceptNumber of accepted invitations
Player_CloseNumber of player closes
Sampled_Tracked_ImpressionsNumber of sampled tracked impressions
Sampled_Viewed_ImpressionsNumber of sampled viewed impressions
Deal_IDIdentifier for the deal
Ad_Server_NameName of the ad server
Ad_Server_Creative_Placement_IDAd server placement ID
BidsNumber of bids placed
Total_Bid_Amount_Adv_CurrencyTotal bid amount in advertiser's currency
Total_Bid_Amount_Partner_CurrencyTotal bid amount in partner's currency
Total_Bid_Amount_USDTotal bid amount in USD
Conversion_Touch_01Number of conversion touches for conversion type 1
Conversion_Touch_Revenue_01Revenue from conversion touches for type 1
Click_Conversion_01Number of click conversions for type 1
Click_Conversion_Revenue_01Revenue from click conversions for type 1
View_Through_Conversion_01Number of view-through conversions for type 1
View_Through_Conversion_Revenue_01Revenue from view-through conversions for type 1
Click_Conversion_02Number of click conversions for type 2
Click_Conversion_Revenue_02Revenue from click conversions for type 2
View_Through_Conversion_02Number of view-through conversions for type 2
View_Through_Conversion_Revenue_02Revenue from view-through conversions for type 2
Click_Conversion_03Number of click conversions for type 3
Click_Conversion_Revenue_03Revenue from click conversions for type 3
View_Through_Conversion_03Number of view-through conversions for type 3
View_Through_Conversion_Revenue_03Revenue from view-through conversions for type 3
Click_Conversion_04Number of click conversions for type 4
Click_Conversion_Revenue_04Revenue from click conversions for type 4
View_Through_Conversion_04Number of view-through conversions for type 4
View_Through_Conversion_Revenue_04Revenue from view-through conversions for type 4
Click_Conversion_05Number of click conversions for type 5
Click_Conversion_Revenue_05Revenue from click conversions for type 5
View_Through_Conversion_05Number of view-through conversions for type 5
View_Through_Conversion_Revenue_05Revenue from view-through conversions for type 5
Click_Conversion_06Number of click conversions for type 6
Click_Conversion_Revenue_06Revenue from click conversions for type 6
View_Through_Conversion_06Number of view-through conversions for type 6
View_Through_Conversion_Revenue_06Revenue from view-through conversions for type 6

Ad Group Dimensions Schema

FieldDescription
AdBrainHouseholdCrossDeviceEnabledWhether household cross-device targeting is enabled
AdGroupIdThe unique identifier of the ad group
AdGroupNameThe name of the ad group
AreFutureKoaFeaturesEnabledWhether future KOA features are enabled
AssociatedBidListsList of associated bid lists
AvailabilityAvailability status of the ad group
CampaignIdThe parent campaign identifier
ChannelIdThe channel identifier
ComscoreSettingsJSON object with Comscore measurement settings
ContractTargetingJSON object with contract targeting settings
CreatedAtUTCTimestamp when the ad group was created
CreativeIdsList of creative IDs associated with the ad group
CurrentAndFutureAdditionalFeeCardsList of additional fee cards
CustomLabelsList of custom labels applied to the ad group
DescriptionDescription of the ad group
DimensionalBiddingAutoOptimizationSettingsList of bidding optimization settings
DisplayViewabilityStandardIntegralStandard for display viewability
FunnelLocationLocation in the marketing funnel
IncrementsList of bidding increments
IndustryCategoryIdIndustry category identifier
IsEnabledWhether the ad group is enabled
IsHighFillRateWhether high fill rate is enabled
IsUseClicksAsConversionsEnabledWhether clicks are counted as conversions
IsUseSecondaryConversionsEnabledWhether secondary conversions are enabled
KoaOptimizationSettingsJSON object with KOA optimization settings
KoaOptimizationsVersionVersion of KOA optimizations
LastUpdatedAtUTCTimestamp when the ad group was last updated
NielsenSettingsJSON object with Nielsen measurement settings
PredictiveClearingEnabledWhether predictive clearing is enabled
QualityAllianceViewabilityProfileViewability profile for quality alliance
ROIGoalJSON object with ROI goal settings
RTBAttributesJSON object with real-time bidding attributes
UseIdentityAllianceWhether identity alliance is used
VideoViewabilityStandardIntegralStandard for video viewability

Campaign Dimensions Schema

FieldDescription
AdvertiserIdThe advertiser account identifier
AssociatedBidListsList of associated bid lists
AutoAllocatorEnabledWhether auto allocator is enabled
AutoPrioritizationEnabledWhether auto prioritization is enabled
AvailabilityAvailability status of the campaign
BudgetAmountBudget amount for the campaign
BudgetCurrencyCodeCurrency code for the budget
BudgetInImpressionsBudget expressed in impressions
CampaignConversionReportingColumnsJSON object with conversion reporting column settings
CampaignFlightsJSON object with campaign flight settings
CampaignIdThe unique identifier of the campaign
CampaignNameThe name of the campaign
CampaignTypeType of campaign
CreatedAtUTCTimestamp when the campaign was created
CtvTargetingAndAttributionWhether CTV targeting is enabled
CurrentAndFutureAdditionalFeeCardsList of additional fee cards
CustomCPAClickWeightClick weight for custom CPA
CustomCPATypeType of custom CPA
CustomCPAViewthroughWeightView-through weight for custom CPA
CustomLabelsList of custom labels applied to the campaign
CustomROASTypeType of custom ROAS
DailyBudgetAmountDaily budget amount
DailyBudgetCurrencyCodeCurrency code for daily budget
DailyBudgetInImpressionsDaily budget expressed in impressions
DefaultBidListsList of default bid lists
DescriptionDescription of the campaign
EndDateEnd date of the campaign
FrequencySettingsJSON object with frequency cap settings
IncrementsList of bidding increments
IsBallotMeasureWhether campaign is a ballot measure
LastUpdatedAtUTCTimestamp when the campaign was last updated
MinimumAdGroupSpendInAdvertiserCurrencyMinimum ad group spend
ObjectiveCampaign objective
PacingModeMode of budget pacing
PartnerCostPercentageFeePartner cost percentage fee
PartnerCPCFeeJSON object with partner CPC fee settings
PartnerCPMFeeJSON object with partner CPM fee settings
PrimaryChannelPrimary channel for the campaign
PrimaryGoalJSON object with primary goal settings
PurchaseOrderNumberPurchase order number
StartDateStart date of the campaign
TimeZoneTime zone for the campaign

Creative Dimensions Schema

FieldDescription
AdvertiserIdThe advertiser account identifier
AvailabilityAvailability status of the creative
CreatedAtUTCTimestamp when the creative was created
CreativeAuditStatusesList of creative audit statuses
CreativeIdThe unique identifier of the creative
CreativeNameThe name of the creative
CreativeTypeType of creative
DescriptionDescription of the creative
FlightEndDateUTCEnd date of the creative flight
FlightStartDateUTCStart date of the creative flight
ImageAttributesJSON object with image attributes
LastUpdatedAtUTCTimestamp when the creative was last updated
PoliticalDataIdPolitical data identifier
ShareLinkLink for sharing the creative
WillThisBeServedInChinaWhether the creative will be served in China

All Metrics Performance Schema

FieldDescription
DateDate for the metrics
AdvertiserName of the advertiser
Advertiser_IDThe advertiser account identifier
CampaignName of the campaign
Campaign_IDThe campaign identifier
Ad_GroupName of the ad group
Ad_Group_IDThe ad group identifier
Device_TypeType of device (Desktop, Mobile, etc.)
CreativeName of the creative
Creative_IDThe creative identifier
Ad_FormatFormat of the ad
ImpressionsNumber of impressions served
Advertiser_Cost_USDCost in USD
ClicksNumber of clicks received
Sampled_Viewed_ImpressionsNumber of sampled viewed impressions
Sampled_Tracked_ImpressionsNumber of sampled tracked impressions
Player_25_Percent_CompleteNumber of videos viewed to 25% completion
Player_50_Percent_CompleteNumber of videos viewed to 50% completion
Player_75_Percent_CompleteNumber of videos viewed to 75% completion
Player_Completed_ViewsNumber of videos viewed to completion

5. Troubleshooting & FAQs for The Trade Desk

Common Issues & Error Messages

Authentication Failures

  • Error: "Invalid credentials" or "Authentication failed"
  • Solution: Verify your API username and password. Ensure they are correctly entered without any leading or trailing spaces. If you're using a Long-Lived Access Token, verify that it hasn't expired.

Advertiser ID Issues

  • Error: "Advertiser not found" or "Invalid advertiser ID"
  • Solution: Verify that your Advertiser ID is correct. Ensure you have the appropriate permissions to access the specified advertiser account.

Missing Data

  • Common Causes:
    • Date range outside of data availability
    • No activity for the selected template dimensions
    • Permissions issues with specific advertisers or campaigns
  • Solution: Verify that data exists for the selected date range in The Trade Desk UI. Ensure your API credentials have access to the advertisers and campaigns you're trying to extract data from.

Contact & Support Information

Best Practices for The Trade Desk Connections

  • Use a Long-Lived Access Token instead of username/password authentication when possible
  • For Ad Group Performance reports, be aware that conversion metrics are tracked at multiple touchpoints (01-06 suffixes in the data)
  • The All Metric Performance template provides a more streamlined view with key metrics for most analyses
  • Start with smaller date ranges (7-28 days) for initial extractions to validate data quality
  • For video campaigns, focus on the various Player completion metrics (25%, 50%, 75%, 100%) to understand engagement
  • Monitor API usage to avoid hitting rate limits, especially during peak campaign periods