AI-generated Key Takeaways
- 
          IMAAdsRequest is a data class that describes the ad request. 
- 
          You can specify the ad to load either by providing an ad tag URL or a VAST, VMAP, or ad rules response. 
- 
          An ad display container is required for rendering the ad UI. 
- 
          The request includes properties to indicate if the ad will autoplay, play muted, or if the content uses continuous playback, although changing these settings does not impact ad playback. 
- 
          Optional parameters for AdX requests include content duration, keywords, and title, and you can also specify secure signals and content URL. 
- 
          You can set a timeout for VAST ad loading and specify a prefetch time for live stream ad requests. 
- 
          Several initialization methods are provided for creating an IMAAdsRequest instance, depending on whether you use an ad tag URL or a canned response, and if Picture-in-Picture support is needed. 
IMAAdsRequest
@interface IMAAdsRequest : NSObjectData class describing the ad request.
- 
                  
                  Specifies the full URL to use for ads loading from an ad server. Required for any adsRequest. For details on constructing the ad tag url, see Create a main ad video tag manually.DeclarationSwift var adTagUrl: String? { get }Objective-C @property (nonatomic, copy, readonly, nullable) NSString *adTagUrl;
- 
                  
                  Specifies a VAST, VMAP, or ad rules response to be used instead of making a request through an ad tag URL. This can be useful for debugging and other situations in which an ad response is already available. DeclarationSwift var adsResponse: String? { get }Objective-C @property (nonatomic, copy, readonly, nullable) NSString *adsResponse;
- 
                  
                  The ad display container. DeclarationSwift var adDisplayContainer: IMAAdDisplayContainer { get }Objective-C @property (nonatomic, readonly) IMAAdDisplayContainer *_Nonnull adDisplayContainer;
- 
                  
                  The user context. DeclarationSwift var userContext: Any? { get }Objective-C @property (nonatomic, readonly, nullable) id userContext;
- 
                  
                  Specifies whether the player intends to start the content and ad in response to a user action or whether they will be automatically played. Changing this setting will have no impact on ad playback. DeclarationSwift var adWillAutoPlay: Bool { get set }Objective-C @property (nonatomic) BOOL adWillAutoPlay;
- 
                  
                  Specifies whether the player intends to start the content and ad with no volume. Changing this setting will have no impact on ad playback. DeclarationSwift var adWillPlayMuted: Bool { get set }Objective-C @property (nonatomic) BOOL adWillPlayMuted;
- 
                  
                  Specifies whether the player intends to continuously play the content videos one after another similar to TV broadcast. Not calling this function leaves the setting as unknown. Note: Changing this setting will have no impact on ad playback. DeclarationSwift var continuousPlayback: Bool { get set }Objective-C @property (nonatomic) BOOL continuousPlayback;
- 
                  
                  Specifies the duration of the content in seconds to be shown. Used in AdX requests. This parameter is optional. DeclarationSwift var contentDuration: Float { get set }Objective-C @property (nonatomic) float contentDuration;
- 
                  
                  Specifies the keywords used to describe the content to be shown. Used in AdX requests. This parameter is optional. DeclarationSwift var contentKeywords: [String]? { get set }Objective-C @property (nonatomic, copy, nullable) NSArray<NSString *> *contentKeywords;
- 
                  
                  Specifies the title of the content to be shown. Used in AdX requests. This parameter is optional. DeclarationSwift var contentTitle: String? { get set }Objective-C @property (nonatomic, copy, nullable) NSString *contentTitle;
- 
                  
                  Specifies the Secure Signal with custom data for this ads request. Secure Signal with custom data is an encrypted blob containing signals collected by the publisher and previously agreed upon by the publisher and bidder. The Secure Signal with custom data can be cleared out by passing null to this function. DeclarationSwift var secureSignals: IMASecureSignals? { get set }Objective-C @property (nonatomic, strong, nullable) IMASecureSignals *secureSignals;
- 
                  
                  Specifies the universal link to the content’s screen. If provided, this parameter is passed to the OM SDK. See Apple documentation for more information. DeclarationSwift var contentURL: URL? { get set }Objective-C @property (nonatomic, copy, nullable) NSURL *contentURL;
- 
                  
                  Specifies the VAST load timeout in milliseconds for the initial request and any subsequent wrappers. This parameter is optional and will override the default timeout. DeclarationSwift var vastLoadTimeout: Float { get set }Objective-C @property (nonatomic) float vastLoadTimeout;
- 
                  
                  Specifies the maximum amount of time to wait in seconds, after calling requestAds, before requesting the ad tag URL. This can be used to stagger requests during a live-stream event, in order to mitigate spikes in the number of requests. DeclarationSwift var liveStreamPrefetchSeconds: Float { get set }Objective-C @property (nonatomic) float liveStreamPrefetchSeconds;
- 
                  
                  Initializes an ads request instance with the given canned ads response and ad display container with Picture-in-Picture support. Serial ad requests may reuse the same IMAAdDisplayContainer by first calling [IMAAdsManager destroy] on its current adsManager. Concurrent requests must use different ad containers. DeclarationSwift convenience init(adsResponse: String, adDisplayContainer: IMAAdDisplayContainer, avPlayerVideoDisplay: IMAAVPlayerVideoDisplay, pictureInPictureProxy: IMAPictureInPictureProxy, userContext: Any?)Objective-C - (nonnull instancetype) initWithAdsResponse:(nonnull NSString *)adsResponse adDisplayContainer:(nonnull IMAAdDisplayContainer *)adDisplayContainer avPlayerVideoDisplay: (nonnull IMAAVPlayerVideoDisplay *)avPlayerVideoDisplay pictureInPictureProxy: (nonnull IMAPictureInPictureProxy *)pictureInPictureProxy userContext:(nullable id)userContext;ParametersadsResponsethe canned ads response adDisplayContainerthe IMAAdDisplayContainer for rendering the ad UI avPlayerVideoDisplaythe IMAAVPlayerVideoDisplay for rendering ads pictureInPictureProxythe IMAPictureInPictureProxy for tracking PIP events userContextthe user context for tracking requests (optional) Return Valuethe IMAAdsRequest instance 
- 
                  
                  Initializes an ads request instance with the given canned ads response and ad display container. Serial ad requests may reuse the same IMAAdDisplayContainer by first calling [IMAAdsManager destroy] on its current adsManager. Concurrent requests must use different ad containers. Does not support Picture-in-Picture. DeclarationSwift init(adsResponse: String, adDisplayContainer: IMAAdDisplayContainer, contentPlayhead: (any NSObjectProtocol & IMAContentPlayhead)?, userContext: Any?)Objective-C - (nonnull instancetype) initWithAdsResponse:(nonnull NSString *)adsResponse adDisplayContainer:(nonnull IMAAdDisplayContainer *)adDisplayContainer contentPlayhead:(nullable NSObject<IMAContentPlayhead> *)contentPlayhead userContext:(nullable id)userContext;ParametersadsResponsethe canned ads response adDisplayContainerthe IMAAdDisplayContainer for rendering the ad UI contentPlayheadthe IMAContentPlayhead for the content player (optional) userContextthe user context for tracking requests (optional) Return Valuethe IMAAdsRequest instance 
- 
                  
                  Initializes an ads request instance with the given ad tag URL and ad display container with Picture-in-Picture support. Serial ad requests may reuse the same IMAAdDisplayContainer by first calling [IMAAdsManager destroy] on its current adsManager. Concurrent requests must use different ad containers. DeclarationSwift convenience init(adTagUrl: String, adDisplayContainer: IMAAdDisplayContainer, avPlayerVideoDisplay: IMAAVPlayerVideoDisplay, pictureInPictureProxy: IMAPictureInPictureProxy, userContext: Any?)Objective-C - (nonnull instancetype)initWithAdTagUrl:(nonnull NSString *)adTagUrl adDisplayContainer: (nonnull IMAAdDisplayContainer *)adDisplayContainer avPlayerVideoDisplay: (nonnull IMAAVPlayerVideoDisplay *)avPlayerVideoDisplay pictureInPictureProxy: (nonnull IMAPictureInPictureProxy *)pictureInPictureProxy userContext:(nullable id)userContext;ParametersadTagUrlthe ad tag URL adDisplayContainerthe IMAAdDisplayContainer for rendering the ad UI avPlayerVideoDisplaythe IMAAVPlayerVideoDisplay for rendering ads pictureInPictureProxythe IMAPictureInPictureProxy for tracking PIP events userContextthe user context for tracking requests (optional) Return Valuethe IMAAdsRequest instance 
- 
                  
                  Initializes an ads request instance with the given ad tag URL and ad display container. Serial ad requests may reuse the same IMAAdDisplayContainer by first calling [IMAAdsManager destroy] on its current adsManager. Concurrent requests must use different ad containers. Does not support Picture-in-Picture. DeclarationSwift init(adTagUrl: String, adDisplayContainer: IMAAdDisplayContainer, contentPlayhead: (any NSObjectProtocol & IMAContentPlayhead)?, userContext: Any?)Objective-C - (nonnull instancetype) initWithAdTagUrl:(nonnull NSString *)adTagUrl adDisplayContainer:(nonnull IMAAdDisplayContainer *)adDisplayContainer contentPlayhead:(nullable NSObject<IMAContentPlayhead> *)contentPlayhead userContext:(nullable id)userContext;ParametersadTagUrlthe ad tag URL adDisplayContainerthe IMAAdDisplayContainer for rendering the ad UI contentPlayheadthe IMAContentPlayhead for the content player (optional) userContextthe user context for tracking requests (optional) Return Valuethe IMAAdsRequest instance