Skip to main content

Google Ads Integration for Nodus

1. Introduction to the Google Ads Integration

What Is This Integration?

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

Prerequisites:

  • An active Google Ads account (standard or manager account)
  • Google Ads Customer ID
  • Login Customer ID (required if your account is managed by a Google Ads Manager Account)
  • Appropriate access permissions to the Google Ads account
  • Google account with access to your Google Ads account for OAuth authentication

Connection Overview:

The integration uses Google Ads API to extract advertising data and performance metrics. Authentication is handled through OAuth 2.0 with Google, and the connector can extract data based on predefined templates or custom GAQL (Google Ads Query Language) queries.

2. Platform Setup Documentation (Setup Form for Google Ads)

Purpose & Scope

This section covers how to set up the initial connection between Nodus and Google Ads by providing the necessary authentication credentials and account identifiers.

Field-by-Field Breakdown:

Integration Name

  • Field Name & Label: Integration Name
  • Description & Purpose: A descriptive name to identify this Google Ads integration within your Nodus account.
  • Validation Rules & Format: Text string, required field.
  • Examples: "Google Ads - Main Account", "Marketing Team Google Ads"
  • Troubleshooting Tips: Use a descriptive name that clearly identifies the specific Google Ads account or purpose.
  • Field Name & Label: Google Ads Customer ID
  • Description & Purpose: The unique identifier for your Google Ads account, used to access campaign data.
  • Validation Rules & Format: Numeric string without dashes, required field.
  • Examples: "1234567890"
  • Troubleshooting Tips: You can find your Customer ID in the top right corner of your Google Ads interface, next to your account name. It's a 10-digit number.
  • Field Name & Label: Google Ads Login Customer ID
  • Description & Purpose: The Customer ID of the manager account (MCC) if your account is managed by one.
  • Validation Rules & Format: Numeric string without dashes, required field.
  • Examples: "9876543210"
  • Troubleshooting Tips: Only input a Login Customer ID if your Ad Account belongs to a larger Management Account (MCC). If not, enter the same value as Customer ID.

Step-by-Step Guide:

  1. Log in to your Google Ads account
  2. Locate your Customer ID in the top right corner of the Google Ads interface
  3. If your account is part of a Google Ads Manager Account, locate the Manager Account Customer ID as well
  4. Enter your Customer ID, Login Customer ID (if applicable), and a meaningful Integration Name in the Nodus setup form
  5. Click Authorize to launch the Google OAuth authentication flow
  6. Grant permissions when prompted by Google
  7. Verify connection and save the configuration

3. Extraction/Query Configuration (Extraction Form for Google Ads)

Purpose & Overview

This section explains how to configure data extraction from Google Ads. The platform offers various templates for extracting different types of advertising data and performance reports, as well as the ability to write custom GAQL queries.

Template & Field Documentation:

Template Selection

  • Field Name & Label: Select a template
  • Description & Purpose: Defines which type of Google Ads data to extract
  • Validation Rules & Format: Dropdown selection, required field
  • Available Options:
    • Ad Dimensions Template - Metadata about ads including titles, descriptions, and creative attributes
    • Ad Dimensions Metadata Template - Additional metadata for ads
    • Ad Performance Template - Performance metrics for ads including impressions, clicks, and conversions
    • Asset Dimensions Template - Metadata about ad assets
    • Asset Performance Template - Performance metrics for ad assets
    • Campaign Dimensions Template - Campaign configuration data including status, type, and budget settings
    • Campaign Dimensions Metadata Template - Additional metadata for campaigns
    • Campaign Performance Template - Performance metrics aggregated at the campaign level
    • Keyword Performance Template - Performance data for individual keywords including quality scores
    • Source of Truth Template - Core account data for reference
    • UAC Performance Template - Performance data for Universal App Campaigns

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)
  • Troubleshooting Tips: Larger date ranges may result in longer processing times. Some metrics may have limitations on historical data retrieval.

Historic Date Selection

  • Field Name & Label: Historic Date
  • Description & Purpose: For historical data extraction, specifies a custom date range
  • Validation Rules & Format: Date picker, required field
  • Troubleshooting Tips: Google Ads typically maintains historical data but older data may have limitations. Very old data might not be available through the API.

Custom GAQL Query Editor

  • Field Name & Label: Code Editor
  • Description & Purpose: Allows writing custom Google Ads Query Language (GAQL) queries for specialized data extraction needs
  • Validation Rules & Format: Text editor that validates GAQL syntax
  • Examples:
    SELECT
    campaign.name,
    metrics.impressions,
    metrics.clicks,
    metrics.cost_micros
    FROM campaign
    WHERE segments.date DURING LAST_30_DAYS
  • Troubleshooting Tips: Test your query in the Google Ads Query Builder before using it in Nodus.

Workflow & Examples:

  1. Select the appropriate template (e.g., "Campaign Performance Template" for campaign-level metrics)
  2. Choose a lookback period or specific historic date range
  3. Preview the query to confirm configuration
  4. Execute extraction

Example Use Cases:

Campaign Performance Analysis:

  • Template: Campaign Performance Template
  • Metrics: Impressions, clicks, spend, conversions
  • Lookback: 28-day Range

Keyword Optimization:

  • Template: Keyword Performance Template
  • Metrics: Clicks, conversions, quality score, average position
  • Lookback: 90-day Range

Ad Creative Analysis:

  • Template: Ad Dimensions + Ad Performance templates (as a package)
  • Metrics: Ad creative details with performance metrics
  • Lookback: 28-day Range

Custom Reporting:

  • Using the Code Editor to write custom GAQL queries for specialized reporting needs
  • Extracting specific combinations of dimensions and metrics not available in standard templates

4. Underlying Models for Google Ads

Data Model Overview

The Google Ads API returns structured data based on the selected template or custom GAQL query. Each template corresponds to specific report types and data structures within the Google Ads API.

Schema & Field Mapping

Data Mapping & Underlying Models for Google Ads

Schema & Field Mapping

Ad Dimensions Schema

FieldDescription
ad_group_ad_ad_app_ad_descriptionsList of descriptions for app ads
ad_group_ad_ad_app_ad_headlinesList of headlines for app ads
ad_group_ad_ad_app_ad_imagesList of images for app ads
ad_group_ad_ad_app_ad_youtube_videosList of YouTube videos for app ads
ad_group_ad_ad_call_ad_business_nameBusiness name for call ads
ad_group_ad_ad_call_ad_description1First description for call ads
ad_group_ad_ad_call_ad_description2Second description for call ads
ad_group_ad_ad_call_ad_headline1First headline for call ads
ad_group_ad_ad_call_ad_headline2Second headline for call ads
ad_group_ad_ad_call_ad_path1First path component for call ads
ad_group_ad_ad_call_ad_path2Second path component for call ads
ad_group_ad_ad_demand_gen_carousel_ad_business_nameBusiness name for demand generation carousel ads
ad_group_ad_ad_demand_gen_carousel_ad_call_to_action_textCall to action text for demand generation carousel ads
ad_group_ad_ad_demand_gen_carousel_ad_carousel_cardsJSON object containing carousel cards
ad_group_ad_ad_demand_gen_carousel_ad_descriptionJSON object with descriptions for demand generation carousel ads
ad_group_ad_ad_demand_gen_carousel_ad_headlineJSON object with headlines for demand generation carousel ads
ad_group_ad_ad_demand_gen_carousel_ad_logo_imageJSON object with logo image for demand generation carousel ads
ad_group_ad_ad_demand_gen_multi_asset_ad_business_nameBusiness name for demand generation multi-asset ads
ad_group_ad_ad_demand_gen_multi_asset_ad_call_to_action_textCall to action text for demand generation multi-asset ads
ad_group_ad_ad_demand_gen_multi_asset_ad_descriptionsList of descriptions for demand generation multi-asset ads
ad_group_ad_ad_demand_gen_multi_asset_ad_headlinesList of headlines for demand generation multi-asset ads
ad_group_ad_ad_display_urlDisplay URL shown in the ad
ad_group_ad_ad_expanded_dynamic_search_ad_descriptionDescription for expanded dynamic search ads
ad_group_ad_ad_expanded_dynamic_search_ad_description2Second description for expanded dynamic search ads
ad_group_ad_ad_expanded_text_ad_descriptionDescription for expanded text ads
ad_group_ad_ad_expanded_text_ad_description2Second description for expanded text ads
ad_group_ad_ad_expanded_text_ad_headline_part1First headline part for expanded text ads
ad_group_ad_ad_expanded_text_ad_headline_part2Second headline part for expanded text ads
ad_group_ad_ad_expanded_text_ad_headline_part3Third headline part for expanded text ads
ad_group_ad_ad_expanded_text_ad_path1First path component for expanded text ads
ad_group_ad_ad_expanded_text_ad_path2Second path component for expanded text ads
ad_group_ad_ad_final_mobile_urlsList of final mobile URLs
ad_group_ad_ad_final_url_suffixFinal URL suffix
ad_group_ad_ad_final_urlsList of final URLs
ad_group_ad_ad_idThe unique identifier of the ad
ad_group_ad_ad_image_ad_image_urlImage URL for image ads
ad_group_ad_ad_image_ad_pixel_heightPixel height for image ads
ad_group_ad_ad_image_ad_pixel_widthPixel width for image ads
ad_group_ad_ad_nameThe name of the ad
ad_group_ad_ad_text_ad_description1First description for text ads
ad_group_ad_ad_text_ad_description2Second description for text ads
ad_group_ad_ad_text_ad_headlineHeadline for text ads
ad_group_ad_ad_tracking_url_templateTracking URL template for the ad
ad_group_ad_ad_typeThe type of ad
ad_group_ad_ad_url_collectionsList of URL collections
ad_group_ad_ad_url_custom_parametersList of URL custom parameters
ad_group_ad_ad_groupAd group reference
ad_group_ad_statusStatus of the ad (ENABLED, PAUSED, REMOVED)
ad_group_campaignCampaign reference
ad_group_ad_rotation_modeAd rotation mode
ad_group_cpc_bid_microsCPC bid amount in micros
ad_group_cpm_bid_microsCPM bid amount in micros
ad_group_cpv_bid_microsCPV bid amount in micros
ad_group_final_url_suffixFinal URL suffix for the ad group
ad_group_idThe unique identifier of the ad group
ad_group_nameThe name of the ad group
ad_group_statusStatus of the ad group
ad_group_target_cpa_microsTarget CPA in micros
ad_group_target_cpm_microsTarget CPM in micros
ad_group_target_roasTarget ROAS
ad_group_typeType of ad group
ad_group_tracking_url_templateTracking URL template for the ad group
ad_group_url_custom_parametersURL custom parameters for the ad group
campaign_idThe unique identifier of the campaign
customer_idThe unique identifier of the customer account
extracted_atTimestamp when the data was extracted

Ad Dimensions Metadata Schema

FieldDescription
ad_group_ad_ad_final_url_suffixFinal URL suffix for the ad
ad_group_ad_ad_final_urlsList of final URLs for the ad
ad_group_ad_ad_idThe unique identifier of the ad
ad_group_ad_ad_tracking_url_templateTracking URL template for the ad
ad_group_final_url_suffixFinal URL suffix for the ad group
ad_group_idThe unique identifier of the ad group
ad_group_tracking_url_templateTracking URL template for the ad group
campaign_idThe unique identifier of the campaign

Ad Performance Schema

FieldDescription
ad_group_ad_ad_idThe unique identifier of the ad
ad_group_ad_ad_nameThe name of the ad
ad_group_idThe unique identifier of the ad group
ad_group_nameThe name of the ad group
campaign_idThe unique identifier of the campaign
campaign_nameThe name of the campaign
campaign_advertising_channel_sub_typeThe advertising channel subtype
campaign_advertising_channel_typeThe advertising channel type
customer_idThe unique identifier of the customer account
segments_ad_network_typeThe ad network type
segments_dateThe date for the metrics
metrics_impressionsNumber of impressions
metrics_clicksNumber of clicks
metrics_cost_microsAmount spent in micros
metrics_conversionsNumber of conversions
metrics_conversions_valueValue of conversions
metrics_video_viewsNumber of video views
metrics_view_through_conversionsNumber of view-through conversions
metrics_absolute_top_impression_percentagePercentage of impressions shown in the absolute top position
metrics_all_conversionsNumber of all conversions (includes non-reported conversions)
metrics_all_conversions_valueValue of all conversions
metrics_video_quartile_p25_ratePercentage of video views that reached 25% of the video
metrics_video_quartile_p50_ratePercentage of video views that reached 50% of the video
metrics_video_quartile_p75_ratePercentage of video views that reached 75% of the video
metrics_video_quartile_p100_ratePercentage of video views that completed the entire video
extracted_atTimestamp when the data was extracted

Campaign Dimension Schema

FieldDescription
campaign_advertising_channel_typeThe main channel type (e.g., SEARCH, DISPLAY)
campaign_advertising_channel_sub_typeThe sub-channel type
campaign_accessible_bidding_strategyThe accessible bidding strategy
campaign_app_campaign_setting_app_storeApp store setting for app campaigns
campaign_app_campaign_setting_bidding_strategy_goal_typeBidding strategy goal type for app campaigns
campaign_bidding_strategyThe bidding strategy
campaign_campaign_budgetThe campaign budget
campaign_end_dateEnd date of the campaign
campaign_final_url_suffixFinal URL suffix for the campaign
campaign_idThe unique identifier of the campaign
campaign_manual_cpaManual CPA settings
campaign_manual_cpc_enhanced_cpc_enabledWhether enhanced CPC is enabled
campaign_manual_cpmManual CPM settings
campaign_manual_cpvManual CPV settings
campaign_maximize_conversion_value_target_roasTarget ROAS for maximize conversion value strategy
campaign_maximize_conversions_target_cpa_microsTarget CPA in micros for maximize conversions strategy
campaign_nameThe name of the campaign
campaign_bidding_strategy_typeThe type of bidding strategy
campaign_serving_statusThe serving status of the campaign
campaign_start_dateStart date of the campaign
campaign_statusStatus of the campaign
campaign_target_cpa_cpc_bid_ceiling_microsCPC bid ceiling in micros for target CPA strategy
campaign_target_cpa_cpc_bid_floor_microsCPC bid floor in micros for target CPA strategy
campaign_target_cpa_target_cpa_microsTarget CPA in micros
campaign_target_impression_share_cpc_bid_ceiling_microsCPC bid ceiling for target impression share strategy
campaign_target_roas_cpc_bid_ceiling_microsCPC bid ceiling in micros for target ROAS strategy
campaign_target_roas_cpc_bid_floor_microsCPC bid floor in micros for target ROAS strategy
campaign_target_roas_target_roasTarget ROAS value
campaign_tracking_url_templateTracking URL template for the campaign
campaign_url_custom_parametersURL custom parameters for the campaign
campaign_tracking_setting_tracking_urlTracking URL setting
campaign_targeting_setting_target_restrictionsTarget restrictions settings
campaign_target_spend_target_spend_microsTarget spend in micros
campaign_target_spend_cpc_bid_ceiling_microsCPC bid ceiling in micros for target spend strategy
customer_tracking_url_templateCustomer account tracking URL template
customer_final_url_suffixCustomer account final URL suffix
customer_idThe unique identifier of the customer account
extracted_atTimestamp when the data was extracted

Campaign Dimension Metadata Schema

FieldDescription
campaign_final_url_suffixFinal URL suffix for the campaign
campaign_idThe unique identifier of the campaign
campaign_tracking_url_templateTracking URL template for the campaign
customer_tracking_url_templateCustomer account tracking URL template
customer_final_url_suffixCustomer account final URL suffix

Campaign Performance Schema

FieldDescription
campaign_idThe unique identifier of the campaign
campaign_nameThe name of the campaign
campaign_advertising_channel_sub_typeThe advertising channel subtype
campaign_advertising_channel_typeThe advertising channel type
customer_idThe unique identifier of the customer account
segments_ad_network_typeThe ad network type
segments_dateThe date for the metrics
metrics_impressionsNumber of impressions
metrics_clicksNumber of clicks
metrics_cost_microsAmount spent in micros
metrics_conversionsNumber of conversions
metrics_conversions_valueValue of conversions
metrics_video_viewsNumber of video views
metrics_view_through_conversionsNumber of view-through conversions
metrics_absolute_top_impression_percentagePercentage of impressions shown in the absolute top position
metrics_all_conversionsNumber of all conversions
metrics_all_conversions_valueValue of all conversions
metrics_search_absolute_top_impression_shareShare of absolute top impressions for search campaigns
metrics_search_click_shareShare of clicks for search campaigns
metrics_search_impression_shareShare of impressions for search campaigns
metrics_search_top_impression_shareShare of top impressions for search campaigns
metrics_video_quartile_p25_ratePercentage of video views that reached 25% of the video
metrics_video_quartile_p50_ratePercentage of video views that reached 50% of the video
metrics_video_quartile_p75_ratePercentage of video views that reached 75% of the video
metrics_video_quartile_p100_ratePercentage of video views that completed the entire video
extracted_atTimestamp when the data was extracted

Keyword Performance Schema

FieldDescription
keyword_view_resource_nameThe resource name of the keyword view
ad_group_criterion_keyword_textThe keyword text
ad_group_idThe unique identifier of the ad group
ad_group_criterion_negativeWhether this is a negative keyword
ad_group_criterion_typeThe type of criterion
ad_group_criterion_keyword_match_typeThe match type (EXACT, PHRASE, BROAD)
segments_ad_network_typeThe ad network type
segments_dateThe date for the metrics
metrics_impressionsNumber of impressions
metrics_clicksNumber of clicks
metrics_cost_microsAmount spent in micros
metrics_conversionsNumber of conversions
metrics_conversions_valueValue of conversions
metrics_video_viewsNumber of video views
metrics_view_through_conversionsNumber of view-through conversions
metrics_absolute_top_impression_percentagePercentage of impressions shown in the absolute top position
metrics_all_conversionsNumber of all conversions
metrics_all_conversions_valueValue of all conversions
metrics_search_absolute_top_impression_shareShare of absolute top impressions for search campaigns
metrics_search_click_shareShare of clicks for search campaigns
metrics_search_impression_shareShare of impressions for search campaigns
metrics_search_top_impression_shareShare of top impressions for search campaigns
metrics_video_quartile_p25_ratePercentage of video views that reached 25% of the video
metrics_video_quartile_p50_ratePercentage of video views that reached 50% of the video
metrics_video_quartile_p75_ratePercentage of video views that reached 75% of the video
metrics_video_quartile_p100_ratePercentage of video views that completed the entire video
extracted_atTimestamp when the data was extracted

Asset Dimension Schema

FieldDescription
asset_group_final_urlsList of final URLs for the asset group
asset_group_idThe unique identifier of the asset group
campaign_bidding_strategyThe bidding strategy of the campaign
campaign_campaign_budgetThe campaign budget
campaign_bidding_strategy_typeThe type of bidding strategy
campaign_final_url_suffixFinal URL suffix for the campaign
campaign_idThe unique identifier of the campaign
campaign_nameThe name of the campaign
campaign_tracking_url_templateTracking URL template for the campaign
campaign_url_custom_parametersURL custom parameters for the campaign
customer_final_url_suffixCustomer account final URL suffix
customer_idThe unique identifier of the customer account
customer_time_zoneTime zone of the customer account
customer_tracking_url_templateCustomer account tracking URL template
extracted_atTimestamp when the data was extracted

Asset Performance Schema

FieldDescription
asset_group_campaignCampaign reference for the asset group
asset_group_idThe unique identifier of the asset group
asset_group_nameThe name of the asset group
asset_group_statusStatus of the asset group
asset_group_final_urlsList of final URLs for the asset group
asset_group_final_mobile_urlsList of final mobile URLs for the asset group
asset_group_ad_strengthAd strength rating for the asset group
asset_group_primary_statusPrimary status of the asset group
campaign_idThe unique identifier of the campaign
segments_dateThe date for the metrics
metrics_clicksNumber of clicks
metrics_all_conversions_valueValue of all conversions
metrics_all_conversionsNumber of all conversions
metrics_cost_microsAmount spent in micros
metrics_impressionsNumber of impressions
metrics_view_through_conversionsNumber of view-through conversions
metrics_conversions_valueValue of conversions
metrics_conversionsNumber of conversions
metrics_interactionsNumber of interactions
metrics_revenue_microsRevenue in micros
extracted_atTimestamp when the data was extracted

Source of Truth Schema

FieldDescription
customer_idThe unique identifier of the customer account
customer_managerThe manager account ID
segments_dateThe date for the metrics
metrics_clicksNumber of clicks
metrics_cost_microsAmount spent in micros
metrics_impressionsNumber of impressions
extracted_atTimestamp when the data was extracted

5. Troubleshooting & FAQs for Google Ads

Common Issues & Error Messages

Authentication Failures

  • Error: "Authentication failed" or "Invalid OAuth token"
  • Solution: Re-authorize the integration through Google OAuth. Google OAuth tokens have limited lifetimes and may need to be refreshed.

Permission Issues

  • Error: "Insufficient permissions" or "Access denied"
  • Solution: Ensure the Google account used for authentication has appropriate access to the Google Ads account. You may need to adjust permissions in Google Ads.

Customer ID Issues

  • Error: "Invalid customer ID" or "Customer not found"
  • Solution: Verify that your Customer ID is correct. Make sure to enter the ID without dashes or special characters.

Login Customer ID Issues

  • Error: "Invalid login customer ID"
  • Solution: If your account is part of a Manager Account, ensure the Login Customer ID is correct. If your account is not part of a Manager Account, the Login Customer ID should be the same as your Customer ID.

GAQL Query Errors

  • Error: "Invalid GAQL query" or "Field not found"
  • Solution: Validate your GAQL query syntax. Ensure all fields referenced in the query are available for the entity type. Test your query in the Google Ads Query Builder.

Missing Data

  • Common Causes:
    • Date range outside of data retention period
    • Insufficient account activity to generate data
  • Solution: Adjust template filters, check date ranges, verify account has active campaigns

Contact & Support Information

Manager vs. Client Accounts

  • Manager Accounts (MCC): Umbrella accounts that can access and manage multiple client accounts. If you're using a Manager Account, enter its Customer ID as the Login Customer ID.
  • Client Accounts: Standard Google Ads accounts focused on campaign management and ad operations.

Data Retention & Limitations

  • Google Ads typically retains report data for several years
  • Some report types have specific data retention policies
  • Daily reporting is the most granular time period available for most report types
  • Performance data is generally available up to the previous day, not real-time
  • Universal App Campaigns have limited reporting capabilities compared to standard campaigns