Skip to main content

Apple Search Ads Integration for Nodus

1. Introduction to the Apple Search Ads Integration

What Is This Integration?

The Apple Search Ads integration connects your Apple Search Ads 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 Apple Search Ads data into the Nodus ecosystem for advanced analytics and business intelligence.

Prerequisites:

  • An Apple Search Ads Advanced account with Account Admin or API Account Manager role
  • Apple Search Ads credentials: Client ID, Team ID, Key ID, and Organization ID
  • Permission to upload a public key to your Apple Search Ads account

Connection Overview:

The integration uses Apple Search Ads Reporting API to extract advertising performance data and metrics. Authentication is handled through Apple's client credentials with a public/private key pair system, and the connector extracts data based on predefined report templates.

2. Platform Setup Documentation (Setup Form for Apple Search Ads)

Purpose & Scope

This section covers how to set up the initial connection between Nodus and Apple Search 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 Apple Search Ads integration within your Nodus account.
  • Validation Rules & Format: Text string, required field.
  • Examples: "Apple Search Ads - iOS App", "ASA - Main Account"
  • Troubleshooting Tips: Use a descriptive name that clearly identifies the specific Apple Search Ads account or app.

Nodus Apple Search Ads Public Key

  • Field Name & Label: Nodus Apple Search Ads Public Key
  • Description & Purpose: The public key you'll need to upload to your Apple Search Ads account for authentication.
  • Validation Rules & Format: Pre-filled text field with copy option.
  • Troubleshooting Tips: This key is automatically generated. You'll need to copy this key and upload it to your Apple Search Ads account in the Account Settings > API section.

Apple Search Ads Client ID

  • Field Name & Label: Apple Search Ads Client ID
  • Description & Purpose: The client identifier used for authenticating with Apple Search Ads API.
  • Validation Rules & Format: Alphanumeric string, required field.
  • Examples: "SEARCHADS.27a4f510-f5ef-9820-87f1-219s74ztr99c"
  • Troubleshooting Tips: You can find this value in Apple Search Ads dashboard under Account Settings > API after uploading the public key.

Apple Search Ads Team ID

  • Field Name & Label: Apple Search Ads Team ID
  • Description & Purpose: The team identifier for your Apple Developer account.
  • Validation Rules & Format: Alphanumeric string, required field.
  • Examples: "ABCD1234EF"
  • Troubleshooting Tips: Available in Account Settings > API after uploading the public key.

Apple Search Ads Key ID

  • Field Name & Label: Apple Search Ads Key ID
  • Description & Purpose: The identifier associated with the key pair used for authentication.
  • Validation Rules & Format: Alphanumeric string, required field.
  • Examples: "a1b2c3d4e5"
  • Troubleshooting Tips: Available in Account Settings > API after uploading the public key.

Apple Search Ads Organization ID

  • Field Name & Label: Apple Search Ads Organization ID
  • Description & Purpose: The unique identifier for your organization in Apple Search Ads.
  • Validation Rules & Format: Numeric string, required field.
  • Examples: "123456789"
  • Troubleshooting Tips: Found in the URL when viewing your organization in the Apple Search Ads dashboard or in the Account Settings.

Step-by-Step Guide:

  1. Log in to Apple Search Ads Advanced with an account administrator role
  2. Go to Users menu in the top-right corner and select your account
  3. Select Account Settings > User Management
  4. Click Invite Users and invite a user with API Account Manager role
  5. Copy the Public Key from the Nodus setup form
  6. In the Search Ads dashboard, go to Account Settings > API for the invited user
  7. Paste the public key in the Public Key field and click Save
  8. Copy the clientId, teamId, and keyId values displayed in the code block
  9. Enter these values along with your Organization ID and a meaningful Integration Name in the Nodus setup form
  10. Validate and save the connection

3. Extraction/Query Configuration (Extraction Form for Apple Search Ads)

Purpose & Overview

This section explains how to configure data extraction from Apple Search Ads. The platform offers various templates for extracting different types of performance reports.

Template & Field Documentation:

Template Selection

  • Field Name & Label: Select a template
  • Description & Purpose: Defines which type of Apple Search Ads data to extract
  • Validation Rules & Format: Dropdown selection, required field
  • Available Options:
    • AdGroup Report Template - Performance metrics for ad groups including impressions, taps, and installs
    • Campaign Report Template - Campaign-level performance metrics and spend
    • Ad Report Template - Creative-level performance data including tap through rates
    • Keyword Report Template - Keyword performance and bidding metrics

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
  • Troubleshooting Tips: Apple Search Ads API may have limitations on historical data retrieval for certain metrics.

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: Apple Search Ads typically maintains historical data but older data may have limitations.

Workflow & Examples:

  1. Select the appropriate template (e.g., "Campaign Report Template" for campaign-level data)
  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 Report Template
  • Metrics: Impressions, taps, installs, spend
  • Lookback: 28-day Range

Keyword Optimization:

  • Template: Keyword Report Template
  • Metrics: Keyword performance, bid amounts, conversions
  • Lookback: 90-day Range

Ad Creative Analysis:

  • Template: Ad Report Template
  • Metrics: Creative performance, tap-through rates, conversion rates
  • Lookback: 28-day Range

4. Data Mapping & Underlying Models for Apple Search Ads

Data Model Overview

The Apple Search Ads API returns structured report data based on the selected template. Each template corresponds to specific report types and data structures within the Apple Search Ads Reporting API.

Schema & Field Mapping

Ad Report Schema

FieldDescription
ad_idThe unique identifier of the ad
ad_nameThe name of the ad
ad_group_idThe parent ad group identifier
campaign_idThe parent campaign identifier
creative_idThe creative identifier
creative_typeThe type of creative
statusThe status of the ad
impressionsNumber of ad impressions
tapsNumber of ad taps (clicks)
ttrTap-through rate (taps/impressions)
avg_cptAverage cost per tap (JSON object with currency and amount)
local_spendAmount spent in local currency (JSON object with currency and amount)
total_installsTotal number of app installs
total_new_downloadsNumber of new app downloads
total_redownloadsNumber of app redownloads
view_installsNumber of installs from ad views (without taps)
tap_installsNumber of installs following ad taps
tap_new_downloadsNumber of new downloads following taps
tap_redownloadsNumber of redownloads following taps
view_new_downloadsNumber of new downloads from views
view_redownloadsNumber of redownloads from views
total_install_rateOverall installation rate
tap_install_cpiCost per install for tap installs (JSON object with currency and amount)
tap_install_rateInstallation rate from taps
dateThe date for the metrics

Ad Group Report Schema

FieldDescription
ad_group_idThe unique identifier of the ad group
ad_group_nameThe name of the ad group
ad_group_statusThe status of the ad group
campaign_idThe parent campaign identifier
device_classDevice type (iPhone, iPad, etc.)
impressionsNumber of ad impressions
tapsNumber of ad taps
ttrTap-through rate (taps/impressions)
avg_cptAverage cost per tap (JSON object with currency and amount)
avg_cpmAverage cost per thousand impressions (JSON object with currency and amount)
local_spendAmount spent in local currency (JSON object with currency and amount)
total_installsTotal number of app installs
total_new_downloadsNumber of new app downloads
total_redownloadsNumber of app redownloads
total_avg_cpiAverage cost per install (JSON object with currency and amount)
ad_group_serving_statusCurrent serving status of the ad group
ad_group_display_statusDisplay status of the ad group
pricing_modelPricing model used (CPT, etc.)
default_bidDefault bid amount (JSON object with currency and amount)
start_timeStart time of the ad group
end_timeEnd time of the ad group (null if ongoing)
dateThe date for the metrics

Campaign Report Schema

FieldDescription
campaign_idThe unique identifier of the campaign
campaign_nameThe name of the campaign
campaign_statusThe status of the campaign
country_or_regionThe country or region targeted
org_idThe organization identifier
impressionsNumber of ad impressions
tapsNumber of ad taps (clicks)
ttrTap-through rate (taps/impressions)
avg_cptAverage cost per tap (JSON object with currency and amount)
avg_cpmAverage cost per thousand impressions (JSON object with currency and amount)
local_spendAmount spent in local currency (JSON object with currency and amount)
total_installsTotal number of app installs
total_new_downloadsNumber of new app downloads
total_redownloadsNumber of app redownloads
total_avg_cpiAverage cost per install (JSON object with currency and amount)
dateThe date for the metrics

Keyword Report Schema

FieldDescription
keyword_idThe unique identifier of the keyword
keywordThe keyword text
keyword_statusThe status of the keyword
match_typeMatch type (exact, broad, etc.)
bid_amountThe bid amount for the keyword (JSON object with currency and amount)
ad_group_idThe parent ad group identifier
ad_group_nameThe name of the parent ad group
impressionsNumber of ad impressions
tapsNumber of ad taps
ttrTap-through rate (taps/impressions)
avg_cptAverage cost per tap (JSON object with currency and amount)
local_spendAmount spent in local currency (JSON object with currency and amount)
total_installsTotal number of app installs
total_new_downloadsNumber of new app downloads
total_redownloadsNumber of app redownloads
view_installsNumber of installs from ad views (without taps)
tap_installsNumber of installs following ad taps
tap_new_downloadsNumber of new downloads following taps
tap_redownloadsNumber of redownloads following taps
view_new_downloadsNumber of new downloads from views
view_redownloadsNumber of redownloads from views
total_avg_cpiAverage cost per install (JSON object with currency and amount)
total_install_rateOverall installation rate
tap_install_cpiCost per install for tap installs (JSON object with currency and amount)
tap_install_rateInstallation rate from taps
dateThe date for the metrics

5. Troubleshooting & FAQs for Apple Search Ads

Common Issues & Error Messages

Authentication Failures

  • Error: "Invalid authentication credentials" or "Unauthorized access"
  • Solution: Verify your Client ID, Team ID, Key ID, and Organization ID. Ensure the public key is properly uploaded to Apple Search Ads.

Permission Issues

  • Error: "Insufficient permissions" or "Access denied"
  • Solution: Ensure the user you've invited has the API Account Manager role. The API Read Only role doesn't always provide sufficient permissions.

Missing Data

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

Organization Access

  • Error: "Organization not found" or "Invalid organization ID"
  • Solution: Verify that the Organization ID is correct and that your API user has access to that organization.

Logging & Diagnostic Tools

  • Apple Search Ads dashboard provides UI reports that can be used to verify data
  • Enable verbose logging in Nodus to capture API request/response details
  • Use the Apple Search Ads Reporting API documentation for reference

Contact & Support Information

API Key Management

Apple Search Ads uses a client credentials with certificate authentication:

  • Public keys must be uploaded to Apple Search Ads Account Settings
  • Credentials include Client ID, Team ID, and Key ID
  • Organization ID is required to specify which organization to access
  • Credentials don't expire but can be revoked at any time

Data Retention & Limitations

  • Apple Search Ads typically retains report data for up to 24 months
  • Some reports may have shorter retention periods
  • The API has limits on the number of concurrent requests
  • Daily reporting is the most granular time period available for most report types