We are pleased to announce the release of our SDK! Banner and interstitial ad formats are currently supported, with more coming. Be sure to check-in frequently for the latest releases and announcements.
Version | Release Date | Description |
---|---|---|
0.6.9 | June 29th, 2020 | • GMA SDK 7.61.0 compatibility. • Removed usage of UIWebView (deprecated). |
0.6.8 | May 4th, 2020 | • Increase max adunit limit from 10 to 50. |
0.6.7 | April 13th, 2020 | • Banner autoload feature. |
0.6.6 | February 6th, 2020 | • GMA SDK 7.55.0 compatibility. • Build optimization level increase. • Decrease network timeout(s). |
0.6.4 | January 22nd, 2020 | • GMA SDK 7.53.1 compatibility. |
0.6.3 | January 9th, 2020 | • Dashboard compatibility release. |
0.6.2 | November 15th, 2019 | • Facebook Audience Network mediation support. |
0.6.0 | October 23th, 2019 | • Firebase analytics compatibility fix. • Minimum iOS deployment target 9.0. • GMA SDK 7.50.0 compatibility. |
0.5.2 | October 15th, 2019 | • Null check for ad refresh rate. |
0.5.0 | September 23th, 2019 | • Swift 5.1 module stability. • GMA SDK 7.50.0 compatibility. |
0.4.7 | September 10th, 2019 | • MoPub mediation support. |
0.4.6 | August 26th, 2019 | • Analytics remote switch. |
0.4.5 | June 24th, 2019 | • Queuing for analytics delivery (protobuf messages). |
0.4.4 | June 12th, 2019 | • Registration retry policy. |
0.4.3 | May 29th, 2019 | • Public setter for root view controller on banner view. |
0.4.2 | May 21th, 2019 | • Fixed ad event function name constants. |
0.4.1 | May 20th, 2019 | • Fixed fill rate issue for banner ads. |
0.4.0 | May 16th, 2019 | • GMA SDK 7.41.0 compatibility. • Runtime adjustable refresh rates. • Nullability updates. |
0.3.2 | May 14th, 2019 | • Prebid Mobile SDK is now an internal dependency, see updated Podfile. |
0.3.1 | February 13th, 2019 | • Bundle id override, for testing only. |
0.3.0 | January 7th, 2019 | • Dynamic iTunes Id. • Ad size lock down. |
0.2.0 | November 20th, 2018 | • Analytics support. • GMA SDK runtime updates. • Pause and resume API for banner auto-refresh. • Event name convenience constants. |
0.1.1 | August 13th, 2018 | • Fix to registration fallback url. |
0.1.0 | August 6th, 2018 | • Interstitial support. • Registration status delegate. • Removed unnecessary dependency to core framework. |
0.0.1 | June 21st, 2018 | • Initial release. |
Latest |
---|
[ 0.6.7 ] • Banner autoload feature. This can be enabled or disabled via the API. |
Warning: This step is required as of Google Mobile Ads SDK version 7.42.0. Failure to add add this Info.plist entry results in a crash with the message: "The Google Mobile Ads SDK was initialized incorrectly."
Info.plist:
<key>GADIsAdManagerApp</key>
<true/>
Previous |
---|
[ 0.6.0 ] • Usage of the forked GMA SDK is no longer needed, however version pinning is still required. See compatibility matrix below. |
[ 0.5.0 ] • Xcode 11+ upgrade required. • Update your Info.plist to enable GADIsAdManagerApp key. |
[ 0.4.7 ] • MoPub mediation support. |
[ 0.4.3 ] • Deprecated existing createBanner API. |
[ 0.4.0 ] • Nullability API updates. • Podfile updates. |
[ 0.2.0 ] • Pause and resume for banner auto-refresh. • Banner convenience constants to detect event handler callback parameter. • Interstitial convenience constants to detect interstitial event handler callback parameter. |
[ 0.1.0 ] • Change to ad provider createBanner method. Added registration delegate parameter. Support for interstitial ad format. |
Starting with SDK version 0.6.0, it is no longer required to use the forked version of GMA SDK. Please refer to below matrix to determine which version of GMA SDK is compatible to our Freestar SDK. Whenever possible, it is always recommended to be on the latest version(s).
FSAdSDK Version | GMA SDK Version | unForked? | Podfile |
---|---|---|---|
~> 0.6.9 | 7.61.0 | ☑️ | pod 'Google-Mobile-Ads-SDK', '7.61.0' |
~> 0.6.6 | 7.55.0 | ☑️ | pod 'Google-Mobile-Ads-SDK', '7.55.0' |
~> 0.6.4 | 7.53.1 | ☑️ | pod 'Google-Mobile-Ads-SDK', '7.53.1' |
~> 0.6.3 | 7.50.0 | ☑️ | pod 'Google-Mobile-Ads-SDK', '7.50.0' |
~> 0.5 | 7.50.0 | ❌ | pod 'Google-Mobile-Ads-SDK', :git => 'https://github.com/freestarcapital/GMA-iOS-SDK.git', :tag => '7.50.0' |
~> 0.4 | 7.41.0 | ❌ | pod 'Google-Mobile-Ads-SDK', :git => 'https://github.com/freestarcapital/GMA-iOS-SDK.git', :tag => '7.41.0' |
<= 0.3.2 | 7.24.1 | ☑️ | pod 'Google-Mobile-Ads-SDK', '~> 7.24.1' |
- Mac running macOS 10.13.2 or later
- XCode 9
- Cocoapods
- Device
- iOS 9.0+
Here are the basic steps required to download and link the SDK to your project. Although there are many approaches to this, we highly recommend you to use the Cocoapods method.
The Freestar Ad SDK is available through Cocoapods, which is the de facto dependency manager for iOS projects. Here are the steps required to download and incorporate the SDK into your project. It is highly recommended to use Cocoapods, as that is the fastest way to get up and running with our SDK.
1.
Update your Podfile, here is an example:
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '9.0'
use_frameworks!
target "YourAppTarget" do
pod 'FSAdSDK/Banner'
pod 'Google-Mobile-Ads-SDK', '7.61.0'
end
2.
Run "pod install" or "pod update".
3.
That's it as far as linking the SDK !! To continue, skip down to the code integration section of this document and follow those steps to complete the integration process.
Please contact us for details.
To be able to show ads from all demand sources, it is important to follow these steps for proper integration of the SDK into your app.
To see a working example, there is a sample banner app project included in this repository. See the banner sample.
1.
Register your app with Freestar in AppDelegate.didFinishLaunchingWithOptions():
import UIKit
import FSAdSDK
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
...
// Freestar app registration
FSRegistration.register() // ensure your bundle identifier
return true
}
2.
Create your banner ad object(s), preferably in ViewController.viewDidLoad().
import UIKit
import FSAdSDK
import GoogleMobileAds
class ViewController: UIViewController {
let adUnitID = "/your_dfp_adunit_ID/placement_id" // DFP Ad Unit ID
let adIdentifier = "your_freestar_ad_identifier" // Freestar Ad Identifier
var bannerView: (UIView & FSBanner)? // banner
override func viewDidLoad() {
super.viewDidLoad()
bannerView = FSAdProvider.createBanner(withIdentifier: adIdentifier,
size: kGADAdSizeBanner,
adUnitId: adUnitID,
registrationDelegate: self,
eventHandler:nil)
bannerView?.rootViewController = self
let request: DFPRequest? = DFPRequest()
bannerView?.load(request)
addToView(bannerView) // for layout, see banner sample
}
...
}
3.
Optional, to receive the registration status, implement FSRegistrationDelegate. If so, please remember to pass self into the ad provider convenience constructor as the registrationDelegate parameter.
class ViewController: UIViewController, FSRegistrationDelegate {
...
func didRegister(forIdentifier identifier: String) {
print("didRegister: \(identifier)")
}
func didFailToRegister(forIdentifier identifier: String) {
print("didFailToRegister: \(identifier)")
}
}
1.
Optional, to pause or resume banner auto-refresh, call resumeRefresh() or pauseRefresh(). During moments when the banner is still in the window but is behind other views, it is recommended to pause auto-refresh. Also be sure to resume refresh when appropriate.
override func viewWillDisappear(_ animated: Bool) {
bannerView!.pauseRefresh()
}
override func viewWillAppear(_ animated: Bool) {
bannerView!.resumeRefresh()
}
To see a working example, there is a sample interstitial app project included in this repository. See the interstitial sample.
1.
Register your app with Freestar in AppDelegate.didFinishLaunchingWithOptions():
import UIKit
import FSAdSDK
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
...
// Freestar app registration
FSRegistration.register() // ensure your bundle identifier
return true
}
2.
Create your interstitial ad object(s), preferably in ViewController.viewDidLoad().
import UIKit
import FSAdSDK
import GoogleMobileAds
class ViewController: UIViewController {
let adUnitID = "/your_dfp_adunit_ID/placement_id" // DFP Ad Unit ID
let adIdentifier = "your_freestar_ad_identifier" // Freestar Ad Identifier
var interstitial: FSInterstitial? // interstitial
override func viewDidLoad() {
super.viewDidLoad()
interstitial = FSAdProvider.createInterstitial(withIdentifier: adIdentifier, adUnitId: adUnitID, registrationDelegate: nil, eventHandler: nil)
let request: DFPRequest? = DFPRequest()
interstitial?.load(request)
}
...
}
3.
When ready, present your interstitial. Please ensure you are calling this on main thread.
class ViewController: UIViewController {
func someMethod() {
...
self.presentInterstitial() // main thread
}
func presentInterstitial() {
if (interstitial!.isReady) {
interstitial?.present(fromRootViewController: self)
}
}
...
}
4.
Optional, to receive the registration status, implement FSRegistrationDelegate. If so, please remember to pass self into the ad provider convenience constructor as the registrationDelegate parameter.
class ViewController: UIViewController, FSRegistrationDelegate {
...
func didRegister(forIdentifier identifier: String) {
print("didRegister: \(identifier)")
}
func didFailToRegister(forIdentifier identifier: String) {
print("didFailToRegister: \(identifier)")
}
}
Often times it is necessary to receive ad event callbacks, such as when an ad is received or when an ad has failed to load. These callbacks are handled through the eventHandler method parameter (refer to the reference guide relating to FSAdProvider.createBanner or FSAdProvider.createInterstitial).
Warning: It is up to the discretion of the developer on how to handle these events, the below snippets are just generalized examples. Do not implement this in your code without modification.
eventHandler: { [weak self] (methodName: String!, params: [ String : Any]) in...
There are two parameters that are passed into the eventHandler closure expression, one is the methodName (string type) and the other is the parameter info (key value type). Below are some common ad events and examples of how each of these events can be handled.
In order to react to the receiving of an ad, the eventHandler must check for a matching methodName parameter. In this case the methodName parameter is adViewDidReceiveAd:. Here is an example which adds the banner view to it's parent view when an ad is received:
bannerView = FSAdProvider.createBanner(withIdentifier: adIdentifier,
size: kGADAdSizeMediumRectangle,
adUnitId: adUnitID,
rootViewController: self,
registrationDelegate: nil,
eventHandler: { [weak self] (methodName: String!, params: [ String : Any]) in
// create a reference to the banner
let banner: UIView? = params["bannerView"] as? UIView
if (methodName == DFPEventNameBanner.adViewDidReceiveAd.rawValue) {
// convenience method to add the banner to self.view
self?.addToView(banner)
}
})
Below is a chart that lists and describes all the ad events related to banner.
Ad Event | Constant | Parameter Key(s) | Description |
---|---|---|---|
-adViewDidReceiveAd: | DFPEventNameBannerAdViewDidReceiveAd | bannerView | Ad request successfully received an ad. |
-adView:didFailToReceiveAdWithError: | DFPEventNameBannerAdViewDidFailToReceiveAd | bannerView, error | Ad request failure, or no ad available. |
-adViewWillPresentScreen: | DFPEventNameBannerAdViewWillPresentFullScreen | bannerView | A full screen view will be presented in response to the user tapping on an ad. |
-adViewWillDismissScreen: | DFPEventNameBannerAdViewWillDismissScreen | bannerView | The full screen view will be dismissed. |
-adViewDidDismissScreen: | DFPEventNameBannerAdViewDidDismissScreen | bannerView | The full screen view has been dismissed. |
-adViewWillLeaveApplication: | DFPEventNameBannerAdViewWillLeaveApplication | bannerView | The user click will open another app, backgrounding the current application |
Ad Event (methodName) | Constant | Parameter Key(s) | Description |
---|---|---|---|
-interstitialDidReceiveAd: | DFPEventNameInterstitialDidReceiveAd | interstitial | Interstitial ad request succeeded. |
-interstitial:didFailToReceiveAdWithError: | DFPEventNameInterstitialDidFailToReceiveAdWithError | interstitial, error | Interstitial ad request completed without an interstitial to show. |
-interstitialWillPresentScreen: | DFPEventNameInterstitialWillPresentScreen | interstitial | Interstitial will animate onto the screen. |
-interstitialDidFailToPresentScreen: | DFPEventNameInterstitialDidFailToPresentScreen | interstitial | Interstitial failed to present. |
-interstitialWillDismissScreen: | DFPEventNameInterstitialWillDismissScreen | interstitial | Interstitial is to be animated off the screen. |
-interstitialDidDismissScreen: | DFPEventNameInterstitialDidDismissScreen | interstitial | Interstitial has animated off the screen. |
-interstitialWillLeaveApplication: | DFPEventNameInterstitialWillLeaveApplication | interstitial | Application will background or terminate because the user clicked on an ad that will launch another application. |
To be able to support targeting for our various demand partners, it is important to use the Prebid Mobile API. By using this API, the developer is assured that targeting will be set on all Prebid related ad objects.
By default, the iOS Prebid Mobile SDK does not automatically send location information. In order for Prebid Mobile to use location information for targeting, the app developer must explicitly pass the location information to the Prebid Mobile API.
Note: Developers should ensure adequate consent is obtained before sharing location information. Developers can control whether location is collected and sent by the SDK.
In this snippet, we create a location manager property, create a setupLocationManager() method and implement the CLLocationManagerDelegate delegate:
import UIKit
import CoreLocation
import PrebidMobileFS
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate, CLLocationManagerDelegate {
var locationManager: CLLocationManager = CLLocationManager()
...
func setupLocationManager() {
// guard to ensure minimum iOS level
guard #available(iOS 8, *) else {
return
}
locationManager.delegate = self
locationManager.distanceFilter = kCLDistanceFilterNone
locationManager.desiredAccuracy = kCLLocationAccuracyKilometer
locationManager.requestWhenInUseAuthorization()
locationManager.startUpdatingLocation()
}
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
PBTargetingParams.sharedInstance().location = locations.last
}
}
import UIKit
import PrebidMobileFS
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {\
PBTargetingParams.sharedInstance().age = 24;
PBTargetingParams.sharedInstance().gender = PBTargetingParamsGender.female;
}
}
Currently, demand partners use iTunes Track Id to identify iOS apps. Normally, iTunes Id is set automatically (0.3.0+), however this provides a way to override the iTunes Id.
import UIKit
import PrebidMobileFS
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
PBTargetingParams.sharedInstance().itunesID = "123456789"
}
}
To avoid getting AdX blacklisted, it is required to pass an extra targeting parameter if there is NSFW content in the app due to GAM's (Google Ad Manager) content restriction guidelines.
let request = DFPRequest()
request.customTargeting = ["campaign" : "NSFW"]
Prebid Mobile supports the IAB GDPR recommendations. For a general overview of Prebid Mobile support for GDPR, see Prebid Mobile Guide to European Ad Inventory and Providing Notice, Transparency and Choice
Enable or disable the ability to provide consent. By default, GDPR is set to false.
PBTargetingParams.sharedInstance().subjectToGDPR = true
Note: If GDPR subject is set to true, setting the consent string is required.
PBTargetingParams.sharedInstance().gdprConsentString = "sample_consent_string"
Prebid mobile also checks if the values are present in the NSUserDefaults keys specified by the IAB. If the values are also set in these objects they will be passed in the OpenRTB request object.
Custom keywords are used to attach arbitrary key/value pairs to the ad call. Use key/value pairs to add users to segments, as shown here:
PBTargetingParams.sharedInstance().setUserKeywords("foo", withValues: ["bat"])
PBTargetingParams.sharedInstance().setUserKeywords("foo", withValues: ["bee"])
PBTargetingParams.sharedInstance().setUserKeywords("foo", withValues: ["bar"])
If a value is set for an existing keyword, the value for the key is replaced with the new value. In the preceding example, the key foo will have a value of bar, the most recent value associated with that key.
You can set a key to have an array of values with the following API:
PBTargetingParams.sharedInstance().setUserKeywords("foo", withValues: ["bat", "bee", "bar"])
The preceding commands will result in the following request JSON body construct:
user = {
keywords = "foo=bat,foo=bee,foo=bar";
};
Prebid analytics is disabled by default. However, if granular reporting is required, please enable analytics using PBAnalyticsManager in your AppDelegate. Here is an example showing how to enable analytics:
import FSAdSDK
...
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
FSAdSDK.setAnalyticsEnabled(true)
}
To enable support for 3rd party ad networks, follow the Cocoapods integration guideline(s) below. Each mediation partner will require an entry to be added to your Podfile. The mediation adapter module(s) below have been compatibility tested with our SDK. No additional code integration is required.
Note: Alternatively, custom mediation adapters can be added to your project but caution will need to be exercised to ensure proper impression tracking and ad slot sizing.
To enable MoPub demand (via mediation) in your project, add this entry to your Podfile:
target "YourAppTarget" do
pod 'FSAdSDK/Mediation/MoPub'
...
end
Full Podfile example with MoPub:
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '9.0'
use_frameworks!
target "YourAppTarget" do
pod 'FSAdSDK/Mediation/MoPub'
pod 'FSAdSDK/Banner'
pod 'Google-Mobile-Ads-SDK', '7.61.0'
end
To enable Facebook Audience Network demand (via mediation) in your project, add this entry to your Podfile:
target "YourAppTarget" do
pod 'FSAdSDK/Mediation/Facebook'
...
end
Full Podfile example with Facebook:
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '9.0'
use_frameworks!
target "YourAppTarget" do
pod 'FSAdSDK/Mediation/Facebook'
pod 'FSAdSDK/Banner'
pod 'Google-Mobile-Ads-SDK', '7.61.0'
end
The API reference guide for the SDK is available in this repository in HTML format. See reference guide.
Special modes can be enabled to help with diagnosing issues related to SDK integration. See below instructions.
For display ad formats, such as banner, it is expected that display ads will be shown after ad loading has completed. But, if for any reason, an ad cannot be displayed as a result of a bug in the integration, the SDK will not throw any errors or exceptions indicating an impression was lost. Under these circumstances, it might be useful to have the SDK throw an exception to halt execution of the app to make the app developer aware that they are, potentially, losing out on said impression. Halting the execution of an app due to error conditions is called fail safe mode. Fail safe mode is disabled by default. To enable fail safe mode in debug builds, follow the instructions below:
Update your application Info.plist with the following:
- Create a dictionary entry at root called freestar
- Add a sub-entry under freestar called failsafeModeEnabled and set that to true (YES).
Info.plist -> freestar (dictionary) -> failsafeModeEnabled (bool) = YES
If you have any questions, don’t hesitate to email us.
Thank you.