This guide shows you how to use the Google Mobile Ads SDK to load and display ads from Pangle using mediation, covering both waterfall and bidding integrations. It covers how to add Pangle to an ad unit's mediation configuration, and how to integrate the Pangle SDK and adapter into an iOS app.
Supported integrations and ad formats
The mediation adapter for Pangle has the following capabilities:
Integration | |
---|---|
Bidding | |
Waterfall | 1 |
Formats | |
App open | 2 |
Banner | |
Interstitial | |
Rewarded | |
Rewarded Interstitial | |
Native |
2 Bidding integration for this format is in closed beta.
Requirements
- iOS deployment target of 10.0 or higher
Latest Google Mobile Ads SDK
Complete the mediation Get started guide
Step 1: Set up configurations in Pangle UI
Sign up or Log in to your Pangle account.
Add a new application
Navigate to the Applications tab and click the Add App button.
Select the Operating System you wish to create an application for and fill out the rest of the form. Then, click Submit.
Take note of your application's App ID.
Create an ad placement
Once your application has been created, click the Add button to create your ad placement.
Bidding
Select your Ad Format and Ad Placement Name, and select In-App Bidding as the Pricing Type. Fill out the rest of the form and click Submit.
Once your ad placement is created, take note of the Ad Placement ID.
Waterfall
Select your Ad Format and Ad Placement Name, and Global CPM as the Pricing Type. Fill out the rest of the form and click Submit.
Once your ad placement is created, take note of the Ad Placement ID.
Locate Pangle Reporting API key
Bidding
This step isn't required for bidding integrations.
Waterfall
Take note of the User ID at the bottom left corner of the page.
Click Integrations > SDK & API > Pangle Reporting API 2.0. Take note of Role ID and Security Key.
Turn on test mode
Follow the instructions in Pangle's How to add a Test Ad guide on how to enable Pangle test ads.
Step 2: Set up Pangle demand in Ad Manager UI
Sign in to your Ad Manager account.
Add Pangle in Companies
Bidding
This step isn't required for bidding integrations.
Waterfall
Navigate to Admin > Companies, then click the New company button in the All companies tab. Select Ad network.
Select Pangle as the Ad network, enter a unique Name and enable Mediation.
You don't need to enter a Username or Password. Click Save when done.
Enable secure signal sharing
Bidding
Navigate to Admin > Global settings. Go to the Ad Exchange account settings tab and review and toggle on Secure signal sharing. Click Save.
Waterfall
This step isn't required for waterfall integrations.
Configure Pangle bidding
Bidding
Navigate to Delivery > Bidders, and click New bidder under the SDK Bidding tab.
Select Pangle as the bidder.
Toggle on Add this bidder's signal library to the list of allowed signals and Allow signals to be shared with this bidder. Then, click Continue.
Click Continue.
Click Done.
Waterfall
This step isn't required for waterfall integrations.
Configure ad unit mapping
Bidding
Navigate to Delivery > Bidders, and select the company for Pangle under the SDK Bidding tab.
Go to the Ad unit mapping tab and click New ad unit mapping.
Choose Specific ad unit. Select an ad unit and format, Mobile app as the Inventory type, and your Mobile application. Then, enter App ID and Ad Placement ID obtained in the previous section. Finally, click Save.
Waterfall
Navigate to Delivery > Yield groups and click the New yield group button. Select your Mobile application.
Scroll down and click Add yield partner.
Select the company you created for Pangle in the previous section. Choose Mobile SDK mediation as the Integration type, iOS as the Platform, and Active as the Status.
Enter the App ID and Ad Placement ID obtained in the previous section, and the Default CPM value. Click Save.
Step 3: Import the Pangle SDK and adapter
Using CocoaPods (recommended)
Add the following line to your project's Podfile:
pod 'GoogleMobileAdsMediationPangle'
From the command line run:
pod install --repo-update
Manual integration
- Download the latest version of the
Pangle SDK for iOS
and link all the
.framework
files and bundles in your project. - Download the latest version of the Pangle adapter from the download link in
the Changelog and link
PangleAdapter.xcframework
in your project.
Step 4: Add required code
SKAdNetwork integration
Follow Pangle's documentation
to add the SKAdNetwork identifiers to your project's Info.plist
file.
Step 5: Test your implementation
Enable test ads
Make sure you register your test device for AdMob and enable test mode in Pangle UI.
Verify test ads
To verify that you are receiving test ads from Pangle, enable single ad source testing in ad inspector using the Pangle (Bidding) and Pangle (Waterfall) ad source(s).
Optional Steps
Native ads
Ad rendering
The Pangle adapter returns its native ads as
GADNativeAd
objects. It populates the following
fields
for a
GADNativeAd
.
Field | Assets always included by Pangle adapter |
---|---|
Headline | |
Image | 1 |
Body | |
Icon | |
Call to action | |
Star rating | |
Store | |
Price | |
Advertiser |
1 The Pangle adapter does not
provide direct access to the main image asset for its native ads. Instead, the
adapter populates the
GADMediaView
with a video or an image.
Error codes
If the adapter fails to receive an ad from Pangle, you can check the
underlying error from the ad response using
GADResponseInfo.adNetworkInfoArray
under the following classes:
GADMediationAdapterPangle
Here are the codes and accompanying messages thrown by the Pangle adapter when an ad fails to load:
Error code | Domain | Reason |
---|---|---|
101 | com.google.ads.mediation.pangle | Invalid server parameters (e.g. Missing app ID or placement ID). |
102 | com.google.ads.mediation.pangle | The requested ad size does not match a Pangle supported banner size. |
-1-60000 | Sent by Pangle SDK | Pangle SDK returned an error. See Pangle's documentation for more details. |
Pangle iOS Mediation Adapter Changelog
Version 6.3.0.8.0
- Verified compatibility with Pangle SDK version 6.3.0.8.
Built and tested with:
- Google Mobile Ads SDK version 11.11.0.
- Pangle SDK version 6.3.0.8.
Version 6.3.0.6.0
- Verified compatibility with Pangle SDK version 6.3.0.6.
Built and tested with:
- Google Mobile Ads SDK version 11.11.0.
- Pangle SDK version 6.3.0.6.
Version 6.2.0.9.0
- Verified compatibility with Pangle SDK version 6.2.0.9.
Built and tested with:
- Google Mobile Ads SDK version 11.10.0.
- Pangle SDK version 6.2.0.9.
Version 6.2.0.8.0
- Verified compatibility with Pangle SDK version 6.2.0.8.
Built and tested with:
- Google Mobile Ads SDK version 11.10.0.
- Pangle SDK version 6.2.0.8.
Version 6.2.0.7.0
- Verified compatibility with Pangle SDK version 6.2.0.7.
Built and tested with:
- Google Mobile Ads SDK version 11.8.0.
- Pangle SDK version 6.2.0.7.
Version 6.2.0.6.0
- Verified compatibility with Pangle SDK version 6.2.0.6.
Built and tested with:
- Google Mobile Ads SDK version 11.8.0.
- Pangle SDK version 6.2.0.6.
Version 6.2.0.5.0
- Verified compatibility with Pangle SDK version 6.2.0.5.
Built and tested with:
- Google Mobile Ads SDK version 11.8.0.
- Pangle SDK version 6.2.0.5.
Version 6.1.0.6.0
- Verified compatibility with Pangle SDK version 6.1.0.6.
Built and tested with:
- Google Mobile Ads SDK version 11.7.0.
- Pangle SDK version 6.1.0.6.
Version 6.1.0.5.0
- Verified compatibility with Pangle SDK version 6.1.0.5.
Built and tested with:
- Google Mobile Ads SDK version 11.6.0.
- Pangle SDK version 6.1.0.5.
Version 6.1.0.4.0
- Verified compatibility with Pangle SDK version 6.1.0.4.
Built and tested with:
- Google Mobile Ads SDK version 11.6.0.
- Pangle SDK version 6.1.0.4.
Version 6.0.0.6.0
- Verified compatibility with Pangle SDK version 6.0.0.6.
Built and tested with:
- Google Mobile Ads SDK version 11.6.0.
- Pangle SDK version 6.0.0.6.
Version 6.0.0.5.0
- Verified compatibility with Pangle SDK version 6.0.0.5.
Built and tested with:
- Google Mobile Ads SDK version 11.5.0.
- Pangle SDK version 6.0.0.5.
Version 6.0.0.4.0
- Verified compatibility with Pangle SDK version 6.0.0.4.
Built and tested with:
- Google Mobile Ads SDK version 11.5.0.
- Pangle SDK version 6.0.0.4.
Version 5.9.0.9.0
- Verified compatibility with Pangle SDK version 5.9.0.9.
Built and tested with:
- Google Mobile Ads SDK version 11.5.0.
- Pangle SDK version 5.9.0.9.
Version 5.9.0.8.0
- Verified compatibility with Pangle SDK version 5.9.0.8.
Built and tested with:
- Google Mobile Ads SDK version 11.4.0.
- Pangle SDK version 5.9.0.8.
Version 5.9.0.7.0
- Verified compatibility with Pangle SDK version 5.9.0.7.
Built and tested with:
- Google Mobile Ads SDK version 11.3.0.
- Pangle SDK version 5.9.0.7.
Version 5.8.0.8.0
- Verified compatibility with Pangle SDK version 5.8.0.8.
- Updated adapter to use new Pangle SDK signal collection API.
Built and tested with:
- Google Mobile Ads SDK version 11.2.0.
- Pangle SDK version 5.8.0.8.
Version 5.8.0.7.0
- Verified compatibility with Pangle SDK version 5.8.0.7.
- Now requires minimum iOS version 12.0.
- Now requires Google Mobile Ads SDK version 11.0 or higher.
- Included
Info.plist
in the frameworks withinPangleAdapter.xcframework
.
Built and tested with:
- Google Mobile Ads SDK version 11.0.1.
- Pangle SDK version 5.8.0.7.
Version 5.7.0.7.0
- Verified compatibility with Pangle SDK version 5.7.0.7.
Built and tested with:
- Google Mobile Ads SDK version 10.14.0.
- Pangle SDK version 5.7.0.7.
Version 5.7.0.6.0
- Verified compatibility with Pangle SDK version 5.7.0.6.
Built and tested with:
- Google Mobile Ads SDK version 10.14.0.
- Pangle SDK version 5.7.0.6.
Version 5.6.0.8.0
- Verified compatibility with Pangle SDK version 5.6.0.8.
- Refactored the
+setCOPPA
method by replacing the deprecatedadConfiguration.childDirectedTreatment
property with the newGADMobileAds.sharedInstance.requestConfiguration.tagForChildDirectedTreatment
property.
Built and tested with:
- Google Mobile Ads SDK version 10.14.0.
- Pangle SDK version 5.6.0.8.
Version 5.5.0.9.0
- Verified compatibility with Pangle SDK version 5.5.0.9.
Built and tested with:
- Google Mobile Ads SDK version 10.13.0.
- Pangle SDK version 5.5.0.9.
Version 5.5.0.7.0
- Verified compatibility with Pangle SDK version 5.5.0.7.
Built and tested with:
- Google Mobile Ads SDK version 10.12.0.
- Pangle SDK version 5.5.0.7.
Version 5.5.0.5.0
- Verified compatibility with Pangle SDK version 5.5.0.5.
Built and tested with:
- Google Mobile Ads SDK version 10.11.0.
- Pangle SDK version 5.5.0.5.
Version 5.4.1.1.0
- Added bidding support for app open ad format.
- Verified compatibility with Pangle SDK version 5.4.1.1.
Built and tested with:
- Google Mobile Ads SDK version 10.10.0.
- Pangle SDK version 5.4.1.1.
Version 5.4.0.9.0
- Verified compatibility with Pangle SDK version 5.4.0.9.
Built and tested with:
- Google Mobile Ads SDK version 10.9.0.
- Pangle SDK version 5.4.0.9.
Version 5.4.0.8.0
- Fixed an issue where
GADPangleNetworkExtras
did not conform toGADAdNetworkExtras
protocol. - Implemented
adDidShowFail
protocol method in interstitial, rewarded, and app open ads. - Verified compatibility with Pangle SDK version 5.4.0.8.
Built and tested with:
- Google Mobile Ads SDK version 10.9.0.
- Pangle SDK version 5.4.0.8.
Version 5.3.1.2.0
- Verified compatibility with Pangle SDK version 5.3.1.2.
Built and tested with:
- Google Mobile Ads SDK version 10.8.0.
- Pangle SDK version 5.3.1.2.
Version 5.3.1.0.0
- Verified compatibility with Pangle SDK version 5.3.1.0.
Built and tested with:
- Google Mobile Ads SDK version 10.8.0.
- Pangle SDK version 5.3.1.0.
Version 5.2.1.1.0
- Verified compatibility with Pangle SDK version 5.2.1.1.
Built and tested with:
- Google Mobile Ads SDK version 10.7.0.
- Pangle SDK version 5.2.1.1.
Version 5.2.0.9.0
- Verified compatibility with Pangle SDK version 5.2.0.9.
Built and tested with:
- Google Mobile Ads SDK version 10.5.0.
- Pangle SDK version 5.2.0.9.
Version 5.2.0.8.0
- Verified compatibility with Pangle SDK version 5.2.0.8.
Built and tested with:
- Google Mobile Ads SDK version 10.5.0.
- Pangle SDK version 5.2.0.8.
Version 5.2.0.7.0
- Added waterfall support for app open, banner (includes MREC), interstitial, rewarded and native ad formats.
- Verified compatibility with Pangle SDK version 5.2.0.7.
Built and tested with:
- Google Mobile Ads SDK version 10.5.0.
- Pangle SDK version 5.2.0.7.
Version 5.2.0.6.0
- Verified compatibility with Pangle SDK version 5.2.0.6.
Built and tested with:
- Google Mobile Ads SDK version 10.5.0.
- Pangle SDK version 5.2.0.6.
Version 5.1.1.0.0
- Verified compatibility with Pangle SDK version 5.1.1.0.
- Added support for the
arm64
simulator architecture. - Now requires Google Mobile Ads SDK version 10.4.0 or higher.
Built and tested with:
- Google Mobile Ads SDK version 10.4.0.
- Pangle SDK version 5.1.1.0.
Version 5.1.0.6.0
- Verified compatibility with Pangle SDK version 5.1.0.6.
Built and tested with:
- Google Mobile Ads SDK version 10.3.0.
- Pangle SDK version 5.1.0.6.
Version 5.0.1.0.0
- Verified compatibility with Pangle SDK version 5.0.1.0.
Built and tested with:
- Google Mobile Ads SDK version 10.2.0.
- Pangle SDK version 5.0.1.0.
Version 5.0.0.8.0
- Verified compatibility with Pangle SDK version 5.0.0.8.
Built and tested with:
- Google Mobile Ads SDK version 10.2.0.
- Pangle SDK version 5.0.0.8.
Version 5.0.0.7.0
- Verified compatibility with Pangle SDK version 5.0.0.7.
Built and tested with:
- Google Mobile Ads SDK version 10.1.0.
- Pangle SDK version 5.0.0.7.
Version 5.0.0.6.0
- Verified compatibility with Pangle SDK version 5.0.0.6.
Built and tested with:
- Google Mobile Ads SDK version 10.1.0.
- Pangle SDK version 5.0.0.6.
Version 4.9.1.0.0
- Removed support for the
armv7
architecture. - Verified compatibility with Pangle SDK version 4.9.1.0.
- Now requires minimum iOS version of 12.0.
- Now requires Google Mobile Ads SDK version 10.0.0 or higher.
Built and tested with:
- Google Mobile Ads SDK version 10.0.0.
- Pangle SDK version 4.9.1.0.
Version 4.9.0.8.0
- Verified compatibility with Pangle SDK version 4.9.0.8.
Built and tested with:
- Google Mobile Ads SDK version 9.14.0.
- Pangle SDK version 4.9.0.8.
Version 4.9.0.7.0
- Verified compatibility with Pangle SDK version 4.9.0.7.
Built and tested with:
- Google Mobile Ads SDK version 9.14.0.
- Pangle SDK version 4.9.0.7.
Version 4.9.0.6.0
- Verified compatibility with Pangle SDK version 4.9.0.6.
Built and tested with:
- Google Mobile Ads SDK version 9.14.0.
- Pangle SDK version 4.9.0.6.
Version 4.8.1.0.0
- Verified compatibility with Pangle SDK version 4.8.1.0.
Built and tested with:
- Google Mobile Ads SDK version 9.14.0.
- Pangle SDK version 4.8.1.0.
Version 4.8.0.9.0
- Verified compatibility with Pangle SDK version 4.8.0.9.
Built and tested with:
- Google Mobile Ads SDK version 9.13.0.
- Pangle SDK version 4.8.0.9.
Version 4.8.0.7.0
- Verified compatibility with Pangle SDK version 4.8.0.7.
Built and tested with:
- Google Mobile Ads SDK version 9.13.0.
- Pangle SDK version 4.8.0.7.
Version 4.8.0.6.0
- Verified compatibility with Pangle SDK version 4.8.0.6.
- Fixed an issue where the main thread was blocked when loading native ad icon image.
Built and tested with:
- Google Mobile Ads SDK version 9.13.0.
- Pangle SDK version 4.8.0.6.
Version 4.7.0.7.0
- Verified compatibility with Pangle SDK version 4.7.0.7.
Built and tested with:
- Google Mobile Ads SDK version 9.11.0.
- Pangle SDK version 4.7.0.7.
Version 4.7.0.6.0
- Verified compatibility with Pangle SDK version 4.7.0.6.
Built and tested with:
- Google Mobile Ads SDK version 9.11.0.
- Pangle SDK version 4.7.0.6.
Version 4.7.0.5.0
- Verified compatibility with Pangle SDK version 4.7.0.5.
Built and tested with:
- Google Mobile Ads SDK version 9.11.0.
- Pangle SDK version 4.7.0.5.
Version 4.7.0.4.0
- Verified compatibility with Pangle SDK version 4.7.0.4.
Built and tested with:
- Google Mobile Ads SDK version 9.10.0.
- Pangle SDK version 4.7.0.4.
Version 4.6.2.2.0
- Renamed the
setGDPR()
andsetCCPA()
methods from theGADMediationAdapterPangle
class tosetGDPRConsent()
andsetDoNotSell
respectively. - Verified compatibility with Pangle SDK version 4.6.2.2.
Built and tested with:
- Google Mobile Ads SDK version 9.10.0.
- Pangle SDK version 4.6.2.2.
Version 4.6.1.8.0
- Verified compatibility with Pangle SDK version 4.6.1.8.
- Added bidding support for native ad format.
- Updated the adapter to use the
didRewardUser
API. - Now requires Google Mobile Ads SDK version 9.8.0 or higher.
Built and tested with:
- Google Mobile Ads SDK version 9.9.0.
- Pangle SDK version 4.6.1.8.
Version 4.5.2.8.0
- Verified compatibility with Pangle SDK version 4.5.2.8.
Built and tested with:
- Google Mobile Ads SDK version 9.7.0.
- Pangle SDK version 4.5.2.8.
Version 4.5.2.7.0
- Verified compatibility with Pangle SDK version 4.5.2.7.
Built and tested with:
- Google Mobile Ads SDK version 9.7.0.
- Pangle SDK version 4.5.2.7.
Version 4.5.2.5.0
- Verified compatibility with Pangle SDK version 4.5.2.5.
Built and tested with:
- Google Mobile Ads SDK version 9.6.0.
- Pangle SDK version 4.5.2.5.
Version 4.5.2.4.0
- Verified compatibility with Pangle SDK version 4.5.2.4.
Built and tested with:
- Google Mobile Ads SDK version 9.6.0.
- Pangle SDK version 4.5.2.4.
Version 4.5.2.3.0
- Verified compatibility with Pangle SDK version 4.5.2.3.
Built and tested with:
- Google Mobile Ads SDK version 9.6.0.
- Pangle SDK version 4.5.2.3.
Version 4.5.1.3.0
- Verified compatibility with Pangle SDK version 4.5.1.3.
Built and tested with:
- Google Mobile Ads SDK version 9.5.0.
- Pangle SDK version 4.5.1.3.
Version 4.3.1.9.0
- Verified compatibility with Pangle SDK version 4.3.1.9.
Built and tested with:
- Google Mobile Ads SDK version 9.3.0.
- Pangle SDK version 4.3.1.9.
Version 4.3.0.5.0
- Verified compatibility with Pangle SDK version 4.3.0.5.
Built and tested with:
- Google Mobile Ads SDK version 9.2.0.
- Pangle SDK version 4.3.0.5.
Version 4.3.0.4.0
- Initial release!
- Added bidding support for banner (includes MREC), interstitial and rewarded ad formats.
Built and tested with:
- Google Mobile Ads SDK version 9.1.0.
- Pangle SDK version 4.3.0.4.