Müşteriyi kapsül yayınlama yönlendirmesine hazırlama

Bu kılavuzda, kapsül yayınlama API'si ve manifest düzenleyicinizle HLS veya DASH canlı yayını yüklemek için istemci uygulaması geliştirme konusu ele alınmaktadır.

Ön koşullar

Devam etmeden önce aşağıdakilere sahip olmanız gerekir:

Akış isteğinde bulunma

Kullanıcınız bir yayın seçtiğinde aşağıdakileri yapın:

  1. Canlı yayın hizmeti yöntemine POST isteği gönderin. Ayrıntılar için Yöntem: stream başlıklı makaleyi inceleyin.

  2. Reklam hedefleme parametrelerini application/x-www-form-urlencoded veya application/json biçimlerinde iletin. Bu istek, Google DAI ile bir akış oturumu kaydeder.

    Aşağıdaki örnekte bir akış isteği gönderiliyor:

    Form kodlaması

    const url = `https://dai.google.com/ssai/pods/api/v1/` +
          `network/NETWORK_CODE/custom_asset/CUSTOM_ASSET_KEY/stream`;
    
    const params = new URLSearchParams({
            cust_params: 'section=sports&page=golf,tennis'
    }).toString();
    
    const response = await fetch(url, {
            method: 'POST',
            headers: {
              'Content-Type': 'application/x-www-form-urlencoded'
            },
            body: params
    });
    
    console.log(await response.json());
    

    JSON kodlama

    const url = `https://dai.google.com/ssai/pods/api/v1/` +
          `network/NETWORK_CODE/custom_asset/CUSTOM_ASSET_KEY/stream`;
    
    const response = await fetch(url, {
            method: 'POST',
            headers: {
              'Content-Type': 'application/json'
            },
            body: JSON.stringify({
              cust_params: {
                section: 'sports',
                page: 'golf,tennis'
              }
            })
    });
    
    console.log(await response.json());
    

    İşlem başarılı olursa aşağıdakine benzer bir çıkış görürsünüz:

    {
    "stream_id": "8d2b2292-6356-4c0e-94be-cece01d2df2e:DLS",
    "media_verification_url": "https://dai.google.com/view/.../event/c14aZDWtQg-ZwQaEGl6bYA/media/",
    "metadata_url": "https://dai.google.com/linear/pods/hls/.../metadata",
    "session_update_url": "https://dai.google.com/linear/.../session",
    "polling_frequency": 10
    }
    
  3. JSON yanıtında akış oturumu kimliğini bulun ve sonraki adımlar için diğer verileri saklayın.

Anket reklamı meta verileri

Reklam meta verilerini yoklamak için aşağıdakileri yapın:

  1. Yayın kaydı yanıtından metadata_url değerini okuyun.

  2. Uç noktaya bir GET isteği gönderin. Ayrıntılar için Yöntem: meta verileri başlıklı makaleyi inceleyin.

    Aşağıdaki örnekte reklam meta verileri getirilmektedir:

    const response = await fetch(metadata_url);
    console.log(await response.json());
    

    Başarılı olursa mevcut ve yaklaşan reklam araları için PodMetadata yanıtını alırsınız:

    {
      "tags":{
        "google_5555555555":{
          "ad":"0000229834_ad1",
          "ad_break_id":"0000229834",
          "type":"firstquartile"
        },
        "google_1234567890123456789":{
          "ad":"0000229834_ad1",
          "ad_break_id":"0000229834",
          "type":"progress"
        },
        ...
      },
      "ads":{
        "0000229834_ad1":{
          "ad_break_id":"0000229834",
          "position":1,
          "duration":15,
          "clickthrough_url":"https://.../",
          ...
        },
              ...
      },
      "ad_breaks":{
        "0000229834":{
          "type":"mid",
          "duration":15,
          "ads":1
        },
        ...
      }
    }
    
  3. tags nesnesini sonraki adımlar için kaydedin.

  4. polling_frequency değerini kullanarak düzenli aralıklarla tüm ardışık reklam araları için meta veri isteğinde bulunmak üzere bir zamanlayıcı ayarlayın.

Akışı video oynatıcınıza yükleyin

Kayıt yanıtından oturum kimliğini aldıktan sonra kimliği manifest işleyicinize iletin veya akışı bir video oynatıcıya yüklemek için bir manifest URL'si oluşturun.

Oturum kimliğini iletmek için manifest işleyici belgelerinize bakın. Manifest düzenleyici geliştiriyorsanız Canlı yayın için manifest düzenleyici başlıklı makaleyi inceleyin.

Aşağıdaki örnekte bir manifest URL'si oluşturulmaktadır:

https://<your_manifest_manipulator_url>/manifest.m3u8?DAI_stream_ID=SESSION_ID&network_code=NETWORK_CODE&DAI_custom_asset_key=CUSTOM_ASSET_KEY"

Oynatıcınız hazır olduğunda çalmaya başlayın.

Reklam etkinliklerini dinleme

Zamanlanmış meta veriler için yayınınızın kapsayıcı biçimini kontrol edin:

  • Transport Stream (TS) kapsayıcılarına sahip HLS akışları, zamanlanmış meta verileri taşımak için zamanlanmış ID3 etiketlerini kullanır. Ayrıntılar için HTTP Canlı Yayın (HLS) ile Ortak Medya Uygulama Biçimi Hakkında başlıklı makaleyi inceleyin.

  • DASH akışları, manifestteki etkinlikleri belirtmek için EventStream öğelerini kullanır.

  • DASH akışlarında, segmentler ID3 etiketleri de dahil olmak üzere yük verileri için InbandEventStream öğeleri kullanır.emsg Ayrıntılar için InbandEventStream'e bakın.

  • DASH ve HLS dahil olmak üzere CMAF akışlarında, ID3 etiketleri içeren emsg kutuları kullanılır.

Akışınızdan ID3 etiketlerini almak için video oynatıcınızın kılavuzuna bakın. Ayrıntılar için Zamanlanmış meta verileri işleme rehberi başlıklı makaleyi inceleyin.

ID3 etiketlerinden reklam etkinliği kimliğini almak için aşağıdakileri yapın:

  1. Etkinlikleri scheme_id_uri ile urn:google:dai:2018 veya https://aomedia.org/emsg/ID3'ye göre filtreleyin.
  2. Bayt dizisini message_data alanından çıkarın.

    Aşağıdaki örnekte, emsg verileri JSON'a dönüştürülüyor:

    {
      "scheme_id_uri": "https://developer.apple.com/streaming/emsg-id3",
      "presentation_time": 27554,
      "timescale": 1000,
      "message_data": "ID3TXXXgoogle_1234567890123456789",
      ...
    }
    
  3. ID3 etiketlerini TXXXgoogle_{ad_event_ID} biçiminde filtreleyin:

    TXXXgoogle_1234567890123456789
    

Reklam etkinliği verilerini göster

TagSegment nesnesini bulmak için aşağıdakileri yapın:

  1. Poll ad metadata işlevinden reklam meta verileri tags nesnesini alın. tags nesnesi, TagSegment nesnelerinden oluşan bir dizidir.

  2. TagSegment türünde bir progress nesnesi bulmak için tam reklam etkinliği kimliğini kullanın.

  3. Diğer türlerdeki bir TagSegment nesnesini bulmak için reklam etkinliği kimliğinin ilk 17 karakterini kullanın.

  4. TagSegment değerini aldıktan sonra, reklam meta verileri ad_breaks nesnesinde AdBreak nesnesini bulmak için anahtar olarak ad_break_id özelliğini kullanın.

    Aşağıdaki örnekte bir AdBreak nesnesi bulunuyor:

    {
      "type":"mid",
      "duration":15,
      "ads":1
    }
    
  5. Reklam arasındaki reklam konumu hakkında bilgi göstermek için TagSegment ve AdBreak verilerini kullanın. Örneğin, Ad 1 of 3.

Medya doğrulama ping'leri gönderme

progress türü hariç her reklam etkinliği için medya doğrulama ping'i gönderin. Google DAI, progress etkinliklerini siler ve bu etkinliklerin sık sık gönderilmesi uygulamanızın performansını etkileyebilir.

Bir reklam etkinliğinin tam medya doğrulama URL'sini oluşturmak için aşağıdakileri yapın:

  1. Yayın yanıtından, tam reklam etkinliği kimliğini media_verification_url değerine ekleyin.

  2. Tam URL ile bir GET isteği gönderin:

    // media_verification_url: "https://dai.google.com/view/.../event/c14aZDWtQg-ZwQaEGl6bYA/media/"
    const completeUrl = `${media_verification_url}google_5555555555123456789`;
    
    const response = await fetch(completeUrl);
    

    Başarılı olursa 202 kod durumu yanıtını alırsınız. Aksi takdirde 404 hata kodu alırsınız.

Tüm reklam etkinliklerinin geçmiş günlüğünü incelemek için Akış Etkinliği İzleyicisi'ni (SAM) kullanabilirsiniz. Ayrıntılar için Canlı yayını izleme ve sorunlarını giderme başlıklı makaleyi inceleyin.