Enable Google DAI playback (iOS)
Enable ad playback with the Google Dynamic Ad Insertion ad client in an iOS app.
After adding the Google IMA Dynamic Ad Insertion (DAI) SDK to your app and acquiring the required items listed in the Requirements section, you can enable Google DAI ad playback in your iOS app.
Requirements
- JWP iOS SDK 4.0.0+
- All the JWP iOS SDK requirements
- Google DAI dependency
- All Google account information listed in the following table
Property | Description |
---|---|
apiKey NSString | Stream request API key |
assetKeyΒ NSString | Stream asset key, used for live streams You can find this ID in your Google Ad Manager portal. Ask your Google representative for assistance locating this ID. |
cmsID NSString | Content management system ID of the video, used for video on demand You can find this ID in your Google Ad Manager portal. Ask your Google representative for assistance locating this ID. |
videoID NSString | Identifier of the DAI video to be displayed, used for video on demand You can find this ID in your Google Ad Manager portal. Ask your Google representative for assistance locating this ID. |
Specify ad content for a single playlist item
Use the following steps to set up dynamic ad insertion for a single playlist item.
For the following reasons, be sure that the video URL (
videoURL
in our code examples) used to set up the player is consistent with the media content registered with DAI for yourvideoID
orassetKey
:β’ If the DAI request fails, the video URL will play as a fallback.
β’ Analytics will be attributed to the correct media item.
- Define your Google account information.
β’ If you are displaying a video on demand, definecmsID
andvideoID
.
β’ If you are displaying a live stream, defineassetKey
. - Instantiate a
JWAdvertisingConfig
object using JWImaDaiAdvertisingConfigBuilder() and theJWGoogleDAIStream
object.
β’ If you are displaying a video on demand, usevodStreamInfo(videoID:cmsID:)
.
β’ If you are displaying a live stream, useliveStreamInfo(assetKey:)
. - If your content is protected, set the
apiKey
property with your Google DAI API key. - Assign the
adConfig
to yourJWPlayerConfiguration
.
In the code examples below, we have added a DAI configuration for a video-on-demand playlist item.
Video On Demand
import JWPlayerKit
class ViewController: JWPlayerViewController {
override func viewDidLoad() {
super.viewDidLoad()
do {
// Create the DAI advertising configuration
let stream = JWGoogleDAIStreamBuilder().apiKey(<#API Key#>)
.vodStreamInfo(videoID: <#Video ID#>, cmsID: <#CMS ID#>)
.build()
let adConfig = JWImaDaiAdvertisingConfigBuilder()
.googleDAIStream(stream)
.build()
// Create the content to be played.
let item = try JWPlayerItemBuilder()
.file(URL(string:<#Fallback Video URL#>)!)
.build()
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
let config = try JWPlayerConfigurationBuilder()
.playlist([item])
.autostart(true)
.advertising(adConfig)
.build()
// Set the config.
player.configurePlayer(with: config)
}
catch {
// Handle Error
}
}
}
#import <JWPlayerKit/JWPlayerKit-Swift.h>
#import <JWPlayerKit/JWPlayerObjCViewController.h>
@interface ViewController : JWPlayerObjCViewController
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// For brevity, we are not checking for errors.
// To check for errors, supply an NSError object to buildAndReturn.
// Create the Google DAI Advertising configuration
JWGoogleDAIStream *stream = [[[JWGoogleDAIStreamBuilder new]
vodStreamInfoWithVideoID:<#Video ID#> cmsID:<#CMS ID#>]
buildAndReturnError:nil];
JWAdvertisingConfig *adConfig = [[[JWImaDaiAdvertisingConfigBuilder new]
googleDAIStream:stream]
buildAndReturnError:nil];
// Create the content to be played.
JWPlayerItem *item = [[[JWPlayerItemBuilder new]
file:<#Video URL#>]
buildAndReturnError:nil];
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
JWPlayerConfiguration *config = [[[[[JWPlayerConfigurationBuilder new]
playlist:@[item]]
autostart:YES]
advertising:adConfig]
buildAndReturnError:nil];
// Set the config
[self.player configurePlayerWith:config];
}
@end
Live Stream
import JWPlayerKit
class ViewController: JWPlayerViewController {
override func viewDidLoad() {
super.viewDidLoad()
do {
// Create the DAI advertising configuration
let stream = JWGoogleDAIStreamBuilder().apiKey(<#API Key#>)
.liveStreamInfo(assetKey: <#Asset Key#>)
.build()
let adConfig = JWImaDaiAdvertisingConfigBuilder()
.googleDAIStream(stream)
.build()
// Create the content to be played.
let item = try JWPlayerItemBuilder()
.file(URL(string:<#Fallback Video URL#>)!)
.build()
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
let config = try JWPlayerConfigurationBuilder()
.playlist([item])
.autostart(true)
.advertising(adConfig)
.build()
// Set the config.
player.configurePlayer(with: config)
}
catch {
// Handle Error
}
}
}
#import <JWPlayerKit/JWPlayerKit-Swift.h>
#import <JWPlayerKit/JWPlayerObjCViewController.h>
@interface ViewController : JWPlayerObjCViewController
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// For brevity, we are not checking for errors.
// To check for errors, supply an NSError object to buildAndReturn.
// Create the Google DAI Advertising configuration
JWGoogleDAIStream *stream = [[[JWGoogleDAIStreamBuilder new]
liveStreamInfoWithAssetKey:<#Asset Key#>]
buildAndReturnError:nil];
JWAdvertisingConfig *adConfig = [[[JWImaDaiAdvertisingConfigBuilder new]
googleDAIStream:stream]
buildAndReturnError:nil];
// Create the content to be played.
JWPlayerItem *item = [[[JWPlayerItemBuilder new]
file:<#Video URL#>]
buildAndReturnError:nil];
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
JWPlayerConfiguration *config = [[[[[JWPlayerConfigurationBuilder new]
playlist:@[item]]
autostart:YES]
advertising:adConfig]
buildAndReturnError:nil];
// Set the config
[self.player configurePlayerWith:config];
}
@end
Specify ad content for multiple playlist items
Use the following steps to associate new DAI ad content with another playlist item. You should follow the steps in the previous section first.
- Define your Google account information for each stream.
β’ If you are displaying a video on demand, definecmsID
andvideoID
.
β’ If you are displaying a live stream, defineassetKey
. - Instantiate a
JWGoogleDAIStream
for eachJWPlayerItem
in your playlist. In our code example, we name thisdaiConfig
. This will serve as a default stream if the others cannot be loaded.
β’ If you are displaying a video on demand, usevodStreamInfo(videoID:cmsID:)
.
β’ If you are displaying a live stream, useliveStreamInfo(assetKey:)
.
β’ If your content is protected, set theapiKey
property with your Google DAI API key. - Instantiate a
JWAdvertisingConfig
object using theJWImaDaiAdvertisingConfigBuilder()
and theJWGoogleDAIStream
object. This will serve as a default stream if the others cannot be loaded.
β’ If you are displaying a video on demand, usevodStreamInfo(videoID:cmsID)
.
β’ If you are displaying a live stream, useliveStreamInfo(assetKey:)
. - Assign the
adConfig
to yourJWPlayerConfiguration
.
Video On Demand
#import <JWPlayerKit/JWPlayerKit-Swift.h>
#import <JWPlayerKit/JWPlayerObjCViewController.h>
@interface ViewController : JWPlayerObjCViewController
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// For brevity, we are not checking for errors.
// To check for errors, supply an NSError object to buildAndReturn.
// Create the DAI streams for use in the JWPlayerItems
JWGoogleDAIStream *stream0 = [[[JWGoogleDAIStreamBuilder new]
vodStreamInfoWithVideoID:<#Video ID#> cmsID:<#CMS ID#>]
buildAndReturnError:nil];
JWGoogleDAIStream *stream1 = [[[JWGoogleDAIStreamBuilder new]
vodStreamInfoWithVideoID:<#Video ID#> cmsID:<#CMS ID#>]
buildAndReturnError:nil];
// Create the default Google DAI Advertising configuration
JWGoogleDAIStream *defaultStream = [[[JWGoogleDAIStreamBuilder new]
vodStreamInfoWithVideoID:<#Video ID#> cmsID:<#CMS ID#>]
buildAndReturnError:nil];
JWAdvertisingConfig *adConfig = [[[JWImaDaiAdvertisingConfigBuilder new]
googleDAIStream:defaultStream]
buildAndReturnError:nil];
// Create the content to be played.
JWPlayerItem *item0 = [[[[JWPlayerItemBuilder new]
file:<#Video URL#>]
googleDAIStream: stream0]
buildAndReturnError:nil];
JWPlayerItem *item1 = [[[[JWPlayerItemBuilder new]
file:<#Video URL#>]
googleDAIStream: stream0]
buildAndReturnError:nil];
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
JWPlayerConfiguration *config = [[[[[JWPlayerConfigurationBuilder new]
playlist:@[item0, item1]]
autostart:YES]
advertising:adConfig]
buildAndReturnError:nil];
// Set the config
[self.player configurePlayerWith:config];
}
@end
import JWPlayerKit
class ViewController: JWPlayerViewController {
override func viewDidLoad() {
super.viewDidLoad()
do {
// Create the DAI streams
let stream0 = JWGoogleDAIStreamBuilder()
.apiKey(<#API Key#>)
.vodStreamInfo(videoID: <#Video ID#>, cmsID: <#CMS ID#>)
.build()
let stream1 = JWGoogleDAIStreamBuilder()
.apiKey(<#API Key#>)
.vodStreamInfo(videoID: <#Video ID#>, cmsID: <#CMS ID#>)
.build()
let defaultStream = JWGoogleDAIStreamBuilder()
.apiKey(<#API Key#>)
.vodStreamInfo(videoID: <#Video ID#>, cmsID: <#CMS ID#>)
.build()
let adConfig = JWImaDaiAdvertisingConfigBuilder()
.googleDAIStream(defaultStream)
.build()
// Create the content to be played.
let item0 = try JWPlayerItemBuilder()
.file(URL(string:<#Fallback Video URL#>)!)
.googleDAIStream(stream0)
.build()
let item1 = try JWPlayerItemBuilder()
.file(URL(string:<#Fallback Video URL#>)!)
.googleDAIStream(stream1)
.build()
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
let config = try JWPlayerConfigurationBuilder()
.playlist([item0, item1])
.autostart(true)
.advertising(adConfig)
.build()
// Set the config.
player.configurePlayer(with: config)
}
catch {
// Handle Error
}
}
}
Live Stream
#import <JWPlayerKit/JWPlayerKit-Swift.h>
#import <JWPlayerKit/JWPlayerObjCViewController.h>
@interface ViewController : JWPlayerObjCViewController
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// For brevity, we are not checking for errors.
// To check for errors, supply an NSError object to buildAndReturn.
// Create the DAI streams for use in the JWPlayerItems
JWGoogleDAIStream *stream0 = [[[JWGoogleDAIStreamBuilder new]
liveStreamInfoWithAssetKey:<#Asset Key#>]
buildAndReturnError:nil];
JWGoogleDAIStream *stream1 = [[[JWGoogleDAIStreamBuilder new]
liveStreamInfoWithAssetKey:<#Asset Key#>]
buildAndReturnError:nil];
// Create the default Google DAI Advertising configuration
JWGoogleDAIStream *defaultStream = [[[JWGoogleDAIStreamBuilder new]
liveStreamInfoWithAssetKey:<#Asset Key#>]
buildAndReturnError:nil];
JWAdvertisingConfig *adConfig = [[[JWImaDaiAdvertisingConfigBuilder new]
googleDAIStream:defaultStream]
buildAndReturnError:nil];
// Create the content to be played.
JWPlayerItem *item0 = [[[[JWPlayerItemBuilder new]
file:<#Video URL#>]
googleDAIStream: stream0]
buildAndReturnError:nil];
JWPlayerItem *item1 = [[[[JWPlayerItemBuilder new]
file:<#Video URL#>]
googleDAIStream: stream0]
buildAndReturnError:nil];
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
JWPlayerConfiguration *config = [[[[[JWPlayerConfigurationBuilder new]
playlist:@[item0, item1]]
autostart:YES]
advertising:adConfig]
buildAndReturnError:nil];
// Set the config
[self.player configurePlayerWith:config];
}
@end
import JWPlayerKit
class ViewController: JWPlayerViewController {
override func viewDidLoad() {
super.viewDidLoad()
do {
// Create the DAI streams
let stream0 = JWGoogleDAIStreamBuilder()
.apiKey(<#API Key#>)
.liveStreamInfo(assetKey: <#Asset Key#>)
.build()
let stream1 = JWGoogleDAIStreamBuilder()
.apiKey(<#API Key#>)
.liveStreamInfo(assetKey: <#Asset Key#>)
.build()
let defaultStream = JWGoogleDAIStreamBuilder()
.apiKey(<#API Key#>)
.liveStreamInfo(assetKey: <#Asset Key#>)
.build()
let adConfig = JWImaDaiAdvertisingConfigBuilder()
.googleDAIStream(defaultStream)
.build()
// Create the content to be played.
let item0 = try JWPlayerItemBuilder()
.file(URL(string:<#Fallback Video URL#>)!)
.googleDAIStream(stream0)
.build()
let item1 = try JWPlayerItemBuilder()
.file(URL(string:<#Fallback Video URL#>)!)
.googleDAIStream(stream1)
.build()
// Create a config, and give it the item as a playlist.
// Set it to begin automatically.
let config = try JWPlayerConfigurationBuilder()
.playlist([item0, item1])
.autostart(true)
.advertising(adConfig)
.build()
// Set the config.
player.configurePlayer(with: config)
}
catch {
// Handle Error
}
}
}
FAQ
Which iOS SDK features are not supported with Google DAI?
The following iOS SDK features are not supported with Google DAI:
- Side-loaded captions
- Chromecast and Airplay
- Use of seek API during ad playback
- Use of playbackRate API
- Stream request Auth token
Updated 11 months ago