Here’s how to integrate the Prebid SDK with Google AdMob.
These are the required components:
Here’s how the ad bidding-auction-rendering process works in this integration scenario.
Steps 1-2 Prebid SDK makes a bid request. Prebid Server runs an auction and returns the winning bid.
Step 3 GMA SDK makes an ad request. AdMob returns the mediation chain with respective ad sources.
Step 4 For each Prebid ad source, the GMA SDK sequentially instantiates a Prebid adapter function.
Step 5 The adapter function verifies the targeting keywords of the winning bid and the server properties of the given ad source. If they match the adapter will render the winning bid. Otherwise, it will immediately fail with a “no ad” error and the next ad source will instantiate the same adapter but for another set of server params.
Assuming your app is already integrated with the GMA SDK, the technical implementation of Prebid mobile into your app will involve these major steps:
The Ad Operations team will need to create a Mediation Group in AdMob.
This information may be useful when comparing data across various reporting systems:
Scenario | Tracked? |
---|---|
Fires Prebid win event | yes |
Fires Prebid imp event | no |
Fires OpenRTB burl | no (1) |
Fires OpenRTB nurl | no (1) |
Fires OpenMeasurement events | yes |
Notes:
Prebid SDK is integrated into AdMob setup thru custom adapters. To integrate Prebid Adapters into your app, add the following line to your Podfile:
pod 'PrebidMobileAdMobAdapters'
Warning: The GADMobileAds.sharedInstance().start()
should be called in the adapters bundle, otherwise, GMA SDK won’t load the ads with error: adView:didFailToReceiveAdWithError: SDK tried to perform a networking task before being initialized.
To avoid the error add the following line to your app right after initialization of GMA SDK:
AdMobUtils.initializeGAD()
Integration example:
// 1. Create GADRequest and GADBannerView
gadRequest = GADRequest()
gadBanner = GADBannerView(adSize: size)
gadBanner.delegate = self
gadBanner.rootViewController = self
gadBanner.adUnitID = adUnitId
// 2. Create an AdMobMediationBannerUtils
mediationDelegate = AdMobMediationBannerUtils(gadRequest: gadRequest,
bannerView: gadBanner)
// 3. Create the MediationBannerAdUnit
prebidAdMobMediaitonAdUnit = MediationBannerAdUnit(configID: configID,
size: CGSize(width: 320, height: 50),
mediationDelegate: mediationDelegate)
// 4. Make a bid request
prebidAdMobMediaitonAdUnit.fetchDemand { [weak self] result in
// 5. Make an ad request to AdMob
self?.gadBanner.load(self?.gadRequest)
}
This step is the same as for the original AdMob integration. You don’t have to make any modifications here.
The AdMobMediationBannerUtils
is a helper class, which performs certain utilty work for the MediationBannerAdUnit
, such as passing the targeting keywords to the adapters and checking the visibility of the ad view.
The MediationBannerAdUnit
is part of Prebid mediation API. This class is responsible for making a bid request and providing the winning bid and targeting keywords to mediating SDKs.
The fetchDemand
method makes a bid request to a Prebid server and returns a result in a completion handler.
Make a regular AdMob’s ad request. Everything else will be handled by Prebid adapters.
Integration example:
// 1. Create GADRequest
gadRequest = GADRequest()
// 2. Create AdMobMediationInterstitialUtils
mediationDelegate = AdMobMediationInterstitialUtils(gadRequest: self.gadRequest)
// 3. Create MediationInterstitialAdUnit
admobAdUnit = MediationInterstitialAdUnit(configId: configID,
mediationDelegate: mediationDelegate!)
// 4. Make a bid request
admobAdUnit?.fetchDemand(completion: { [weak self]result in
// 5. Make an ad request to AdMob
GADInterstitialAd.load(withAdUnitID: adUnitID, request: self?.gadRequest) { [weak self] ad, error in
guard let self = self else { return }
if let error = error {
PBMLog.error(error.localizedDescription)
return
}
// 6. Present the interstitial ad
self.interstitial = ad
self.interstitial?.fullScreenContentDelegate = self
self.interstitial?.present(fromRootViewController: self)
}
})
The default ad format for interstitial is .banner. In order to make a multiformat bid request
, set the respective values into the adFormats
property.
// Make bid request for video ad
adUnit?.adFormats = [.video]
// Make bid request for both video amd banner ads
adUnit?.adFormats = [.video, .banner]
// Make bid request for banner ad (default behaviour)
adUnit?.adFormats = [.banner]
This step is the same as for the original AdMob integration. You don’t have to make any modifications here.
The AdMobMediationInterstitialUtils
is a helper class, which performs certain utilty work for the MediationInterstitialAdUnit
, such as passing the targeting keywords to adapters and checking the visibility of the ad view.
The MediationInterstitialAdUnit
is part of the Prebid mediation API. This class is responsible for making a bid request and providing a winning bid to the mediating SDKs.
The fetchDemand
method makes a bid request to a Prebid server and provides a result in a completion handler.
Make a regular AdMob’s ad request. Everything else will be handled by GMA SDK and prebid adapters.
Once you receive the ad it will be ready for display. Follow the AdMob instructions for displaying an ad.
Integration example:
// 1. Create GADRequest
let request = GADRequest()
// 2. Create AdMobMediationInterstitialUtils
let mediationDelegate = AdMobMediationRewardedUtils(gadRequest: request)
// 3. Create MediationInterstitialAdUnit
admobRewardedAdUnit = MediationRewardedAdUnit(configId: "12f58bc2-b664-4672-8d19-638bcc96fd5c", mediationDelegate: mediationDelegate)
// 4. Make a bid request
admobRewardedAdUnit.fetchDemand { [weak self] result in
guard let self = self else { return }
// 5. Make an ad request to AdMob
GADRewardedAd.load(withAdUnitID: self.admobPrebidAdUnitId, request: request) { [weak self] ad, error in
guard let self = self else { return }
if let error = error {
PBMLog.error(error.localizedDescription)
return
}
// 6. Present the interstitial ad
self.gadRewardedAd = ad
self.gadRewardedAd?.fullScreenContentDelegate = self
DispatchQueue.main.asyncAfter(deadline: .now() + .seconds(3)) {
self.gadRewardedAd?.present(fromRootViewController: self, userDidEarnRewardHandler: {
print("Reward user")
})
}
}
}
The process of displaying the rewarded ad is the same as for displaying an Interstitial Ad.
To be notified when a user earns a reward follow the AdMob intructions.
This step is the same as for the original AdMob integration. You don’t have to make any modifications here.
The AdMobMediationRewardedUtils
is a helper class, which performs certain utilty work for the MediationRewardedAdUnit
, like passing the targeting keywords to the adapters.
The MediationRewardedAdUnit
is part of the Prebid mediation API. This class is responsible for making a bid request and providing a winning bid and targeting keywords to the adapters.
The fetchDemand
method makes a bid request to the a Prebid server and provides a result in a completion handler.
Make a regular AdMob’s ad request. Everything else will be handled by GMA SDK and prebid adapters.
Once the rewarded ad is received you can display it. Follow the AdMob instructions for displaying an ad.
Warning: If you use Native Ads you must integrate AdMob Adapters via the source files instead of cocoapods integration or standalone framework.
In order to integrate AdMob adapters just add the adapters’ source files to your app project.
Integration example:
// 1. Create GAD Request
gadRequest = GADRequest()
// 2. Create AdMobMediationNativeUtils
mediationDelegate = AdMobMediationNativeUtils(gadRequest: gadRequest)
// 3. Create and configure MediationNativeAdUnit
nativeAdUnit = MediationNativeAdUnit(configId: prebidConfigId,
mediationDelegate: mediationDelegate!)
nativeAdUnit.setContextType(ContextType.Social)
nativeAdUnit.setPlacementType(PlacementType.FeedContent)
nativeAdUnit.setContextSubType(ContextSubType.Social)
// 4. Set up assets for bid request
nativeAdUnit.addNativeAssets(nativeAssets)
// 5. Set up event tracker for bid request
nativeAdUnit.addEventTracker(eventTrackers)
// 6. Make a bid request
nativeAdUnit.fetchDemand { [weak self] result in
guard let self = self else { return }
// 7. Load AdMob Native ad
self.adLoader = GADAdLoader(adUnitID: self.adMobAdUnitId!,
rootViewController: self.rootController,
adTypes: [ .native ],
options: nil)
self.adLoader?.delegate = self
self.adLoader?.load(self.gadRequest)
}
Prepare the GADRequest
object before you make a bid request. It will be needed for the Prebid mediation utils.
The AdMobMediationNativeUtils
is a helper class, which performs certain utilty work for MediationNativeAdUnit
, like passing the targeting keywords to adapters and checking the visibility of the ad view.
The MediationNativeAdUnit
is part of the Prebid mediation API. This class is responsible for making a bid request and providing a winning bid and targeting keywords to the adapters. For better targetting you should provide additional properties like conteaxtType
and placemantType
.
The bid request for native ads should have the description of any expected assets. The full spec for the native template can be found in the Native Ad Specification from IAB.
Example of creating the assets array:
let image = NativeAssetImage(minimumWidth: 200, minimumHeight: 50, required: true)
image.type = ImageAsset.Main
let icon = NativeAssetImage(minimumWidth: 20, minimumHeight: 20, required: true)
icon.type = ImageAsset.Icon
let title = NativeAssetTitle(length: 90, required: true)
let body = NativeAssetData(type: DataAsset.description, required: true)
let cta = NativeAssetData(type: DataAsset.ctatext, required: true)
let sponsored = NativeAssetData(type: DataAsset.sponsored, required: true)
return [icon, title, image, body, cta, sponsored]
The bid request for mative ads may have a description of expected event trackers. The full spec for the Native template can be found in the Native Ad Specification from IAB.
The example of creating the event trackers array:
let eventTrackers = [
NativeEventTracker(event: EventType.Impression,
methods: [EventTracking.Image,EventTracking.js])
]
The fetchDemand
method makes a bid request to Prebid server and provides a result in a completion handler.
Now just load a native ad from AdMob according to the AdMob instructions.
The adPosition
property allows developers to specify the position of the ad within the publisher’s content. This property maps to the pos
field in the OpenRTB specification under the imp[].banner
or imp[].video
objects, depending on the ad format. The possible values for this field could be found in the respective specification.
You can set adPosition
by using the following property:
adUnit.adPosition = .footer