Начать

Предварительные условия

  • Xcode 13 или выше.

В этом руководстве описывается, как вызвать PAL SDK для получения nonce и отслеживания событий воспроизведения. Чтобы увидеть пример приложения, использующего PAL для генерации nonce, загрузите пример iOS с GitHub .

Добавьте PAL SDK в свой проект

Установите PAL SDK с помощью диспетчера пакетов Swift.

SDK библиотеки программного доступа поддерживает Swift Package Manager, начиная с версии 2.5.3. Выполните следующие действия, чтобы импортировать пакет Swift.

  1. В Xcode установите пакет PAL SDK Swift, выбрав «Файл» > «Добавить пакеты...» .

  2. В появившемся окне найдите репозиторий GitHub PAL SDK Swift Package:

    https://github.com/googleads/swift-package-manager-google-programmatic-access-library-ios
    
  3. Выберите версию пакета PAL SDK Swift, которую вы хотите использовать. Для новых проектов мы рекомендуем использовать Up to Next Major Version .

Когда вы закончите, Xcode разрешит зависимости вашего пакета и загрузит их в фоновом режиме. Более подробную информацию о том, как добавить зависимости пакета, можно найти в статье Apple .

Загрузите и установите PAL SDK вручную.

Если вы не хотите использовать Swift Package Manager, вы можете загрузить PAL SDK и вручную добавить его в свой проект.

  1. Загрузите и распакуйте PAL SDK для iOS.
  2. Следуйте Руководству разработчика Apple , чтобы включить эту платформу в свой проект.

Создать одноразовый номер

«Nonce» — это одна зашифрованная строка, созданная PAL с использованием PALNonceLoader . PAL SDK требует, чтобы каждый новый поток сопровождался вновь созданным одноразовым номером. Однако одноразовые номера можно повторно использовать для нескольких запросов объявлений в одном потоке.

Все приведенные ниже фрагменты кода являются модификациями ViewController.m в примере приложения PAL для iOS .

Чтобы запросить одноразовый номер, начните с импорта библиотеки PAL:

@import ProgrammaticAccessLibrary;

У вас по-прежнему есть контроль над коррелятором потока, или &scor , который необходимо сбрасывать один раз для каждого нового потока. Все запросы объявлений одного и того же потока должны использовать одно и то же значение PALNonceLoader и коррелятора потока, чтобы функции ограничения частоты показов и конкурентного исключения работали правильно.

Затем создайте экземпляр PALNonceLoader и добавьте заглушки для двух методов делегата:

@interface ViewController () <PALNonceLoaderDelegate>
// The nonce loader to use for nonce requests.
@property(nonatomic) PALNonceLoader *nonceLoader;
// The view in which a video would play. In this sample, it is mocked for
// simplification.
@property(nonatomic, weak) IBOutlet UIView *videoView;
@end
...
- (void) viewDidLoad {
  [super viewDidLoad];
  // The default value for 'allowStorage' and 'directedForChildOrUnknownAge' is
  // 'NO', but should be updated once the appropriate consent has been gathered.
  // Publishers should either integrate with a CMP or use a different method to
  // handle storage consent.
  PALSettings *settings = [[PALSettings alloc] init];
  settings.allowStorage = YES;
  settings.directedForChildOrUnknownAge = NO;

  self.nonceLoader = [[PALNonceLoader alloc] initWithSettings:settings];
  self.nonceLoader.delegate = self;
}

#pragma mark - PALNonceLoaderDelegate methods

- (void)nonceLoader:(PALNonceLoader *)nonceLoader
            withRequest:(PALNonceRequest *)request
    didLoadNonceManager:(PALNonceManager *)nonceManager {
}

- (void)nonceLoader:(PALNonceLoader *)nonceLoader
         withRequest:(PALNonceRequest *)request
    didFailWithError:(NSError *)error {
}

Затем инициируйте запрос nonce, заполните его свойства и используйте его для инициализации менеджера nonce:

@interface ViewController () <PALNonceLoaderDelegate>
// The nonce loader to use for nonce requests.
@property(nonatomic) PALNonceLoader *nonceLoader;
// The nonce manager result from the last successful nonce request.
@property(nonatomic) PALNonceManager *nonceManager;
// The view in which a video would play. In this sample, it is mocked for
// simplification.
@property(nonatomic, weak) IBOutlet UIView *videoView;
@end
...
- (void)viewDidLoad {
  ...
  self.nonceLoader.delegate = self;
  [self requestNonceManager];
}
...
#pragma mark - UI Callback methods

/**
 * Requests a new nonce manager with a request containing arbitrary test values
 * like a user might supply. Displays the nonce or error on success. This
 * should be called once per stream.
 */
- (void)requestNonceManager {
  PALNonceRequest *request = [[PALNonceRequest alloc] init];
  request.continuousPlayback = PALFlagOff;
  request.descriptionURL = [NSURL URLWithString:@"https://example.com/desc?key=val"];
  request.iconsSupported = YES;
  request.playerType = @"AwesomePlayer";
  request.playerVersion = @"4.2.1";
  request.PPID = @"123987456";
  request.sessionID = @"Sample SID";
  // Sample API framework integer. See reference docs for more details.
  NSInteger SampleAPIFramework = 501;
  request.supportedApiFrameworks = [NSMutableSet setWithArray:@[ SampleAPIFramework ]];
  request.videoPlayerHeight = 480;
  request.videoPlayerWidth = 640;
  request.willAdAutoPlay = PALFlagOn;
  request.willAdPlayMuted = PALFlagOff;
  request.OMIDPartnerName = @"SamplePartner";
  request.OMIDPartnerVersion = @"6.2.1";

  if (self.nonceManager) {
    // Detach the old nonce manager's gesture recognizer before destroying it.
    [self.videoView removeGestureRecognizer:self.nonceManager.gestureRecognizer];
    self.nonceManager = nil;
  }
  [self.nonceLoader loadNonceManagerWithRequest:request];
}

Наконец, заполните делегаты загрузчика nonce для регистрации сгенерированных nonce:

#pragma mark - PALNonceLoaderDelegate methods

- (void)nonceLoader:(PALNonceLoader *)nonceLoader
            withRequest:(PALNonceRequest *)request
    didLoadNonceManager:(PALNonceManager *)nonceManager {
  NSLog(@"Programmatic access nonce: %@", nonceManager.nonce);
  // Capture the created nonce manager and attach its gesture recognizer to the video view.
  self.nonceManager = nonceManager;
  [self.videoView addGestureRecognizer:self.nonceManager.gestureRecognizer];
}

- (void)nonceLoader:(PALNonceLoader *)nonceLoader
         withRequest:(PALNonceRequest *)request
    didFailWithError:(NSError *)error {
  NSLog(@"Error generating programmatic access nonce: %@", error);
}

При выполнении прямого вызова VAST (DVC) установите свой nonce в качестве значения параметра givn . Nonce безопасен для URL — вам не нужно его URL-кодировать.

Наконец, вам необходимо добавить в SDK методы для обработки отправки информации о сеансе воспроизведения контента и кликов. См. следующий пример реализации методов sendPlaybackStart , sendPlaybackEnd и sendAdClick :

...
// Reports the start of playback for the current content session.
- (void)sendPlaybackStart {
  [self.nonceManager sendPlaybackStart];
}

// Reports the end of playback for the current content session.
- (void)sendPlaybackEnd {
  [self.nonceManager sendPlaybackEnd];
}

// Reports an ad click for the current nonce manager, if not nil.
- (void)sendAdClick {
  [self.nonceManager sendAdClick];
}

В вашей реализации sendPlaybackStart должен вызываться при «запуске видеоплеера», когда воспроизведение инициируется в первый раз, в ответ либо на действие, инициированное пользователем (воспроизведение по щелчку), либо на действие, инициированное приложением (автовоспроизведение), sendPlaybackEnd должен быть вызывается, когда воспроизведение заканчивается, а sendAdClick должен вызываться каждый раз, когда зритель нажимает на рекламу.

(Необязательно) Отправляйте сигналы Google Ad Manager через сторонние рекламные серверы.

Настройте запрос стороннего рекламного сервера к Менеджеру рекламы. После выполнения следующих шагов параметр nonce будет распространяться из PAL SDK через ваши промежуточные серверы, а затем в Google Ad Manager. Это обеспечивает лучшую монетизацию через Google Ad Manager.

Настройте свой сторонний рекламный сервер так, чтобы он включал nonce в запрос сервера к Менеджеру рекламы. Вот пример рекламного тега, настроенного на стороннем рекламном сервере:

https://pubads.serverside.net/gampad/ads?givn=%%custom_key_for_google_nonce%%&...

Дополнительную информацию см. в руководстве по внедрению на стороне сервера Google Ad Manager .

Менеджер рекламы ищет givn= чтобы определить значение nonce. Сторонний сервер объявлений должен поддерживать какой-либо собственный макрос, например %%custom_key_for_google_nonce%% , и заменять его параметром запроса nonce, который вы указали на предыдущем шаге. Дополнительную информацию о том, как это сделать, можно найти в документации стороннего рекламного сервера.