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 a Unity app.
Supported integrations and ad formats
The AdMob mediation adapter for Pangle has the following capabilities:
Integration | |
---|---|
Bidding | |
Waterfall | |
Formats | |
App Open | |
Banner | |
Interstitial | |
Rewarded | |
Rewarded Interstitial |
Requirements
- Latest Google Mobile Ads SDK
- Unity 5.6 or higher
- [For bidding]: To integrate all supported ad formats in bidding, use Google Mobile Ads mediation plugin for Pangle 2.4.0 or higher (latest version recommended)
- To deploy on Android
- Android API level 23 or higher
- To deploy on iOS
- iOS deployment target of 12.0 or higher
- A working Unity project configured with the Google Mobile Ads SDK. See Get Started for details.
- 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.
Android
iOS
Take note of your application's App ID.
Android
iOS
Create an ad placement
Once your application has been created, click the Add button to create your ad placement.
Android
iOS
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.
Android
iOS
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.
Android
iOS
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.
Update your app-ads.txt
Authorized Sellers for Apps app-ads.txt is an IAB Tech Lab initiative that helps ensure your app ad inventory is only sold through channels you've identified as authorized. To prevent a significant loss in ad revenue, you'll need to implement an app-ads.txt
file. If you haven't done so already, create an app-ads.txt file for Ad Manager.
To implement app-ads.txt
for Pangle, see How to add Pangle to your app-ads.txt file.
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 AdMob UI
Configure mediation settings for your ad unit
Android
For instructions, see step 2 in the guide for Android.
iOS
For instructions, see step 2 in the guide for iOS.
Add Pangle DSP to GDPR and US state regulations ad partners list
Follow the steps in European regulations settings and US state regulations settings to add Pangle DSP to the European and US state regulations ad partners list in the AdMob UI.
Step 3: Import the Pangle SDK and adapter
OpenUPM-CLI
If you have OpenUPM-CLI installed, you can install the Google Mobile Ads Pangle Mediation Plugin for Unity to your project by running the following command from your project's root directory:
openupm add com.google.ads.mobile.mediation.pangle
OpenUPM
In your Unity project editor, select Edit > Project Settings > Package Manager to open the Unity Package Manager Settings.
Under the Scoped Registries tab, add OpenUPM as a scoped registry with the following details:
- Name:
OpenUPM
- URL:
https://package.openupm.com
- Scope(s):
com.google
Then, navigate to Window > Package Manager to open the Unity Package Manager and select My Registries from the drop-down menu.
Select the Google Mobile Ads Pangle Mediation package and click Install.
Unity Package
Download the latest version of Google Mobile Ads mediation plugin for Pangle from the download link in the Changelog and extract the GoogleMobileAdsPangleMediation.unitypackage
from the zip file.
In your Unity project editor, select Assets > Import Package > Custom Package and find the GoogleMobileAdsPangleMediation.unitypackage
file you downloaded. Make sure that all the files are selected and click Import.
Then, select Assets > External Dependency Manager > Android Resolver > Force Resolve. The External Dependency Manager library will perform dependency resolution from scratch and copy the declared dependencies into the Assets/Plugins/Android
directory of your Unity app.
Step 4: Implement privacy settings on Pangle SDK
EU Consent and GDPR
Under the Google EU User Consent Policy, you must ensure that certain disclosures are given to, and consents obtained from, users in the European Economic Area (EEA) regarding the use of device identifiers and personal data. This policy reflects the requirements of the EU ePrivacy Directive and the General Data Protection Regulation (GDPR). When seeking consent, you must identify each ad network in your mediation chain that may collect, receive, or use personal data and provide information about each network's use. Google currently is unable to pass the user's consent choice to such networks automatically.
The Google Mobile Ads mediation plugin for Pangle includes the Pangle.SetGDPRConsent()
method. The following sample code shows how to pass consent information to the Pangle SDK. Set consent information before you initialize the Google Mobile Ads SDK to ensure they get forwarded properly to the Pangle SDK.
using GoogleMobileAds.Api.Mediation.Pangle;
// ...
Pangle.SetGDPRConsent(0);
See Pangle's integration guide for more details and the values that can be provided in each method.
US states privacy laws
US states privacy laws require giving users the right to opt out of the "sale" of their "personal information" (as the law defines those terms), with the opt-out offered through a prominent "Do Not Sell My Personal Information" link on the "selling" party's homepage. The US states privacy laws compliance guide offers the ability to enable restricted data processing for Google ad serving, but Google is unable to apply this setting to each ad network in your mediation chain. Therefore, you must identify each ad network in your mediation chain that may participate in the sale of personal information and follow guidance from each of those networks to ensure compliance.
The Google Mobile Ads mediation plugin for Pangle includes the Pangle.SetPAConsent()
method. The following sample code shows how to pass consent information to the Pangle SDK. Set consent information before you initialize the Google Mobile Ads SDK to ensure they get forwarded properly to the Pangle SDK.
using GoogleMobileAds.Api.Mediation.Pangle;
// ...
Pangle.SetPAConsent(0);
See Pangle's integration guide for more details and the values that can be provided in each method.
Step 5: Add required code
Android
No additional code required for Pangle integration.
iOS
SKAdNetwork integration
Follow Pangle's documentation to add the SKAdNetwork identifiers to your project's Info.plist
file.
Step 6: 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).
Error codes
If the adapter fails to receive an ad from Pangle, publishers can check the underlying error from the ad response using ResponseInfo
under the following classes:
Android
com.pangle.ads
com.google.ads.mediation.pangle.PangleMediationAdapter
iOS
GADMediationAdapterPangle
Here are the codes and accompanying messages thrown by the Pangle adapter when an ad fails to load:
Android
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. |
103 | com.google.ads.mediation.pangle | Missing or invalid bid response. |
-1-60000 | com.pangle.ads | Pangle SDK returned an error. See Pangle's documentation for more details. |
iOS
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 Unity Mediation Plugin Changelog
Version 5.0.0
- Replaced
SetDoNotSell()
withSetPAConsent()
from thePangle
class.- The value passed in for
SetDoNotSell()
may not the be the right value forSetPAConsent()
. Please ensure the right value is passed in toSetPAConsent()
. Refer to https://www.pangleglobal.com/integration/android-initialize-pangle-sdk for what values can be set for PA consent.
- The value passed in for
- Supports Pangle Android adapter version 7.1.0.8.0.
- Supports Pangle iOS adapter version 7.1.1.1.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 10.1.0.
Version 4.6.2
- Supports Pangle Android adapter version 6.5.0.9.0.
- Supports Pangle iOS adapter version 6.5.0.9.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 10.1.0.
Version 4.6.1
- Supports Pangle Android adapter version 6.5.0.8.0.
- Supports Pangle iOS adapter version 6.5.0.9.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 10.0.0.
Version 4.6.0
- Supports Pangle Android adapter version 6.5.0.6.0.
- Supports Pangle iOS adapter version 6.5.0.9.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 10.0.0.
Version 4.5.4
- Supports Pangle Android adapter version 6.4.0.6.0.
- Supports Pangle iOS adapter version 6.4.1.1.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.5.0.
Version 4.5.3
- Supports Pangle Android adapter version 6.4.0.5.0.
- Supports Pangle iOS adapter version 6.4.1.0.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.5.0.
Version 4.5.2
- Supports Pangle Android adapter version 6.4.0.4.0.
- Supports Pangle iOS adapter version 6.4.0.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.5.0.
Version 4.5.1
- Supports Pangle Android adapter version 6.4.0.3.0.
- Supports Pangle iOS adapter version 6.4.0.7.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.5.0.
Version 4.5.0
- Supports Pangle Android adapter version 6.4.0.2.0.
- Supports Pangle iOS adapter version 6.4.0.6.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.5.0.
Version 4.4.2
- Supports Pangle Android adapter version 6.3.0.4.0.
- Supports Pangle iOS adapter version 6.3.1.0.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.4.0.
Version 4.4.1
- Supports Pangle Android adapter version 6.3.0.4.0.
- Supports Pangle iOS adapter version 6.3.0.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.3.0.
Version 4.4.0
- Supports Pangle Android adapter version 6.3.0.2.0.
- Supports Pangle iOS adapter version 6.3.0.6.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.3.0.
Version 4.3.3
- Supports Pangle Android adapter version 6.2.0.7.0.
- Supports Pangle iOS adapter version 6.2.0.9.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.2.1.
Version 4.3.2
- Supports Pangle Android adapter version 6.2.0.6.0.
- Supports Pangle iOS adapter version 6.2.0.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.2.0.
Version 4.3.1
- Supports Pangle Android adapter version 6.2.0.5.0.
- Supports Pangle iOS adapter version 6.2.0.7.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.2.0.
Version 4.3.0
- Supports Pangle Android adapter version 6.2.0.4.0.
- Supports Pangle iOS adapter version 6.2.0.5.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.2.0.
Version 4.2.1
- Supports Pangle Android adapter version 6.1.0.7.0.
- Supports Pangle iOS adapter version 6.1.0.6.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.2.0.
Version 4.2.0
- Renamed
DummyClient
toPlaceholderClient
. - Supports Pangle Android adapter version 6.1.0.6.0.
- Supports Pangle iOS adapter version 6.1.0.5.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.2.0.
Version 4.1.0
- Supports Pangle Android adapter version 6.0.0.8.0.
- Supports Pangle iOS adapter version 6.1.0.5.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.1.1.
Version 4.0.1
- Supports Pangle Android adapter version 6.0.0.5.0.
- Supports Pangle iOS adapter version 6.0.0.6.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.1.0.
Version 4.0.0
- Supports Pangle Android adapter version 6.0.0.5.0.
- Supports Pangle iOS adapter version 6.0.0.5.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.1.0.
Version 3.0.0
- Supports Pangle Android adapter version 6.0.0.3.0.
- Supports Pangle iOS adapter version 5.9.0.9.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.1.0.
Version 2.8.1
- Supports Pangle Android adapter version 5.9.0.6.0.
- Supports Pangle iOS adapter version 5.9.0.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.1.0.
Version 2.8.0
- Supports Pangle Android adapter version 5.9.0.4.0.
- Supports Pangle iOS adapter version 5.9.0.7.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.1.0.
Version 2.7.0
- Supports Pangle Android adapter version 5.9.0.2.0.
- Supports Pangle iOS adapter version 5.8.0.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.1.0.
Version 2.6.0
- Supports Pangle Android adapter version 5.8.0.9.0.
- Supports Pangle iOS adapter version 5.8.0.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 9.0.0.
Version 2.5.0
- Supports Pangle Android adapter version 5.7.0.1.0.
- Supports Pangle iOS adapter version 5.7.0.7.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 8.6.0.
Version 2.4.0
- Supports Pangle Android adapter version 5.5.0.9.0.
- Supports Pangle iOS adapter version 5.5.0.9.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 8.6.0.
Version 2.3.0
- Supports Pangle Android adapter version 5.3.0.6.0.
- Supports Pangle iOS adapter version 5.3.1.2.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 8.4.1.
Version 2.2.0
- Supports Pangle Android adapter version 5.2.0.6.0.
- Supports Pangle iOS adapter version 5.2.0.9.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 8.3.0.
Version 2.1.0
- Supports Pangle Android adapter version 5.1.0.9.0.
- Supports Pangle iOS adapter version 5.1.1.0.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 8.1.0.
Version 2.0.0
- Moved adapter content to
GoogleMobileAds/Mediation/Pangle/
. - Refactored adapter namespace to use
GoogleMobileAds.Mediation.Pangle
. - Supports Pangle Android adapter version 5.0.0.7.0.
- Supports Pangle iOS adapter version 5.0.0.6.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.4.1.
Version 1.5.1
- Supports Pangle Android adapter version 4.9.0.7.0.
- Supports Pangle iOS adapter version 4.9.0.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.4.0.
Version 1.5.0
- Supports Pangle Android adapter version 4.9.0.6.0.
- Supports Pangle iOS adapter version 4.9.0.7.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.3.1.
Version 1.4.0
- Supports Pangle Android adapter version 4.8.1.0.0.
- Supports Pangle iOS adapter version 4.8.1.0.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.3.1.
Version 1.3.1
- Supports Pangle Android adapter version 4.7.0.6.0.
- Supports Pangle iOS adapter version 4.7.0.6.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.2.0.
Version 1.3.0
- Renamed the following methods in the
Pangle
class:SetGDPR()
->SetGDPRConsent()
SetCCPA()
->SetDoNotSell()
- Supports Pangle Android adapter version 4.7.0.5.0.
- Supports Pangle iOS adapter version 4.7.0.5.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.2.0.
Version 1.2.0
- Supports Pangle Android adapter version 4.5.0.6.1.
- Supports Pangle iOS adapter version 4.5.2.8.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.1.0.
Version 1.1.0
- Supports Pangle Android adapter version 4.5.0.3.0.
- Supports Pangle iOS adapter version 4.5.1.3.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.0.2.
Version 1.0.0
- Initial release!
- Supports Pangle Android adapter version 4.3.0.8.0.
- Supports Pangle iOS adapter version 4.3.0.5.0.
- Built and tested with the Google Mobile Ads Unity Plugin version 7.0.0.