Video yükleme

YouTubeVideoUploadService Google Ads API aracılığıyla videoları doğrudan YouTube'a yüklemenize olanak tanır. Bu videolar daha sonra Maksimum Performans kampanyaları veya Talep Yaratma kampanyaları gibi çeşitli reklam türlerinde öğe olarak kullanılabilir.

Bu hizmet, YouTube yükleme sürecini yöneterek videoların hesabınızla doğru şekilde ilişkilendirilmesini sağlar ve video reklam oluşturma iş akışını kolaylaştırır.

Temel kavramlar

Başlamadan önce, video yüklemelerinin nasıl yönetildiğini ve geçebilecekleri farklı durumları anlamanız önemlidir.

Kanal sahipliği

Bir video yüklediğinizde, YouTubeVideoUpload kaynağındaki channel_id alanını kullanarak hedef YouTube kanalını belirtebilirsiniz:

  • Reklamverene ait (marka) kanal: Reklamverene ait bir YouTube kanalının channel_id bilgisini sağlayın. Marka kanalına yükleme yapmak, videonun gizliliği ve görünürlüğü üzerinde daha fazla kontrol sağlar.
  • Google tarafından yönetilen kanal: channel_id atlanırsa video, Google Ads hesabıyla ilişkili ve Google tarafından yönetilen bir YouTube kanalına yüklenir.

Yükleme durumları

Yüklenen bir YouTube videosunun yaşam döngüsü state alanı tarafından izlenir. YouTubeVideoUploadState enum, aşağıdaki durumları tanımlar:

Eyalet Açıklama
PENDING Video yükleniyor.
UPLOADED Video başarıyla yüklendi ve YouTube tarafından işleniyor.
PROCESSED Video başarıyla işlendi ve kullanıma hazır.
FAILED Yükleme veya işleme başarısız oldu ve tamamlanamıyor.
REJECTED Video, doğrulama veya politika nedenleriyle reddedildi.
UNAVAILABLE Video durumu kullanılamıyor. Video, YouTube'dan kaldırılmış olabilir.

Gizlilik ayarları

video_privacy alanı, yüklenen videoyu kimlerin görebileceğini kontrol eder. The YouTubeVideoPrivacy enum supports:

  • PUBLIC: Video, YouTube'daki herkes tarafından izlenebilir. (Yalnızca marka kanalları için izin verilir.)
  • UNLISTED: Video aranabilir değildir ancak bağlantıya sahip herkes tarafından görüntülenebilir. Bu, Google tarafından yönetilen kanallar için varsayılan ve tek seçenektir.

Video yükleme

Video yüklemek için CreateYouTubeVideoUpload yöntemine çok parçalı bir istek göndermeniz gerekir. İstek, hem yüklemeyle ilgili meta verileri hem de video dosyasını içerir.

1. Yükleme işlemini başlatma

Aşağıdakileri belirterek CreateYouTubeVideoUploadRequest oluşturun:

  • customer_id: Google Ads müşteri kimliğiniz.
  • you_tube_video_upload: video_title, video_description ve isteğe bağlı olarak channel_id ve video_privacy özelliklerini içeren bir YouTubeVideoUpload nesnesi.

İstemci kitaplığı kullanıyorsanız video dosyanızı ileterek CreateYouTubeVideoUpload yöntemini çağırın. Video yükleme işlemi dahili olarak gerçekleştirilir.

Java

This example is not yet available in Java; you can take a look at the other languages.
    

C#

This example is not yet available in C#; you can take a look at the other languages.
    

PHP

This example is not yet available in PHP; you can take a look at the other languages.
    

Python

yt_service: YouTubeVideoUploadServiceClient = client.get_service(
    "YouTubeVideoUploadService"
)

create_upload_request: CreateYouTubeVideoUploadRequest = (
    youtube_video_upload_service.CreateYouTubeVideoUploadRequest()
)
create_upload_request.customer_id = customer_id
create_upload_request.you_tube_video_upload.video_title = "Test Video"
create_upload_request.you_tube_video_upload.video_description = (
    "Test Video Description"
)
create_upload_request.you_tube_video_upload.video_privacy = (
    client.enums.YouTubeVideoPrivacyEnum.UNLISTED
)

video_upload_resource_name: str
with open(video_file_path, "rb") as stream:
    response: CreateYouTubeVideoUploadResponse = (
        yt_service.create_you_tube_video_upload(
            stream=stream,
            request=create_upload_request,
            retry=None,
        )
    )
    print(f"Created YouTube video upload: {response.resource_name}")
      

Ruby

This example is not yet available in Ruby; you can take a look at the other languages.
    

Perl

This example is not yet available in Perl; you can take a look at the other languages.
    

curl

# 
# Use the --i curl parameter to capture response headers in the $RESPONSE
# variable.
FILE_SIZE=$(wc -c < "${VIDEO_FILE_NAME}" | tr -d '\r')
RESPONSE=$(curl -i -f -v -s --request POST \
"https://googleads.googleapis.com/resumable/upload/v${API_VERSION}/customers/${CUSTOMER_ID}:youTubeVideoUploads:create" \
--header "Content-Type: application/json" \
--header "developer-token: ${DEVELOPER_TOKEN}" \
--header "login-customer-id: ${MANAGER_CUSTOMER_ID}" \
--header "Authorization: Bearer ${OAUTH2_ACCESS_TOKEN}" \
--header "X-Goog-Upload-Protocol: resumable" \
--header "X-Goog-Upload-Command: start" \
--header "X-Goog-Upload-Header-Content-Length: ${FILE_SIZE}" \
--data @- <<EOF
{
  "customer_id": "${CUSTOMER_ID}",
  "you_tube_video_upload": {
    "video_title": "${VIDEO_TITLE}",
    "video_description": "${VIDEO_DESCRIPTION}",
    "video_privacy": "UNLISTED"
  }
}
EOF
)

# Extract the value of the "x-goog-upload-url" header from the HTTP response.
UPLOAD_URL=$(echo "${RESPONSE}" \
  | grep -i '^x-goog-upload-url' \
  | awk '{print $2}' \
  | tr -d '\r')
CHUNK_SIZE=$(echo "${RESPONSE}" \
  | grep -i '^x-goog-upload-chunk-granularity' \
  | awk '{print $2}' \
  | tr -d '\r')
      

REST kullanıyorsanız aşağıdaki bölümde video yükleme işleminin nasıl yönetileceği açıklanmaktadır.

2. Videoyu yükleyin.

CreateYouTubeVideoUpload yöntemine bir REST isteği gönderdiğinizde, yanıtta x-goog-upload-url HTTP yanıt üst bilgisinde video baytlarını yüklemek için kullanılacak URL'nin yanı sıra parçalı yüklemeler için her parçanın beklenen boyutu gibi diğer meta veriler de yer alır.

Yükleyeceğiniz videonun boyutunu, süreci başlatırken x-goog-upload-header-content-length HTTP istek üstbilgisiyle de belirtebilirsiniz.

Video yükleme protokolünde kullanılan HTTP üstbilgilerinin tam açıklaması için aşağıdaki kod örneğine bakın:

# Take the first ${CHUNK_SIZE} bytes of the video file and upload them.
head -c ${CHUNK_SIZE} ${VIDEO_FILE_NAME} | curl -i -v -X PUT "${UPLOAD_URL}" \
--header "Authorization: Bearer ${OAUTH2_ACCESS_TOKEN}" \
--header "X-Goog-Upload-Offset: 0" \
--header "X-Goog-Upload-Command: upload" \
--header "Content-Length: ${CHUNK_SIZE}" \
--data-binary @-

# Query the status of the upload.
QUERY_RESPONSE=$(curl -i -s -X POST "${UPLOAD_URL}" \
--header "Authorization: Bearer ${OAUTH2_ACCESS_TOKEN}" \
--header "X-Goog-Upload-Command: query")

# Extract the value of the "x-goog-upload-size-received" header from the HTTP
# response.
UPLOADED_BYTES=$(echo "${QUERY_RESPONSE}" \
  | grep -i '^x-goog-upload-size-received' \
  | awk '{print $2}' \
  | tr -d '\r')

echo "Uploaded ${UPLOADED_BYTES} bytes."

REMAINING_BYTES=$((FILE_SIZE - UPLOADED_BYTES))
echo "${REMAINING_BYTES} bytes remaining to upload."

FINALIZE_RESPONSE=$(tail -c ${REMAINING_BYTES} ${VIDEO_FILE_NAME} | curl -v -X PUT "${UPLOAD_URL}" \
--header "Authorization: Bearer ${OAUTH2_ACCESS_TOKEN}" \
--header "X-Goog-Upload-Offset: ${UPLOADED_BYTES}" \
--header "X-Goog-Upload-Command: upload, finalize" \
--data-binary @-)
UPLOADED_VIDEO_RESOURCE_NAME=$(echo $FINALIZE_RESPONSE | jq -r '.resourceName')
      

3. Video yükleme durumunu alma

Video yüklemeyi başlattıktan sonra, GAQL ile you_tube_video_upload kaynağını sorgulayarak videonun durumunu alabilirsiniz:

Java

This example is not yet available in Java; you can take a look at the other languages.
    

C#

This example is not yet available in C#; you can take a look at the other languages.
    

PHP

This example is not yet available in PHP; you can take a look at the other languages.
    

Python

# Retrieve the metadata of the newly uploaded video.
query: str = f"""
    SELECT
      you_tube_video_upload.resource_name,
      you_tube_video_upload.video_id,
      you_tube_video_upload.state
    FROM you_tube_video_upload
    WHERE you_tube_video_upload.resource_name = '{video_upload_resource_name}'"""

ga_service: GoogleAdsServiceClient = client.get_service("GoogleAdsService")
stream: Iterator[SearchGoogleAdsStreamResponse] = ga_service.search_stream(
    customer_id=customer_id, query=query
)

for row in itertools.chain.from_iterable(batch.results for batch in stream):
    video = row.you_tube_video_upload
    print(
        f"Video with ID {row.you_tube_video_upload.video_id} was found in state {row.you_tube_video_upload.state}."
    )
      

Ruby

This example is not yet available in Ruby; you can take a look at the other languages.
    

Perl

This example is not yet available in Perl; you can take a look at the other languages.
    

curl

curl -i -v -X POST \
"https://qa-prod-googleads.sandbox.googleapis.com/v${API_VERSION}/customers/${CUSTOMER_ID}/googleAds:search" \
--header "Content-Type: application/json" \
  --header "Developer-Token: ${DEVELOPER_TOKEN}" \
  --header "login-customer-id: ${MANAGER_CUSTOMER_ID}" \
  --header "Authorization: Bearer ${OAUTH2_ACCESS_TOKEN}" \
  --data @- <<EOF
{
  "query": "SELECT you_tube_video_upload.resource_name, you_tube_video_upload.video_id, you_tube_video_upload.state FROM you_tube_video_upload WHERE you_tube_video_upload.resource_name = '$UPLOADED_VIDEO_RESOURCE_NAME'"
}
EOF
      

Yüklemeleri yönet

Video yükleme işlemi tamamlandıktan sonra videoyu video öğesi olarak kullanabilirsiniz.

Yüklenen videoyu kullanma

Bir video PROCESSED durumuna ulaştıktan sonra YouTube video kimliğini YouTubeVideoUpload kaynağının video_id alanında bulabilirsiniz.

video_id kullanarak VideoAsset oluşturun veya video kimliğine referans vererek doğrudan YouTube videolarını destekleyen reklam türlerine bağlayın.

Meta veriyi güncelle

Bu API aracılığıyla yüklenen bir videonun meta verilerini UpdateYouTubeVideoUpload yöntemini kullanarak güncelleyebilirsiniz. Yalnızca video_title, video_description ve video_privacy alanları güncellenebilir.

Yüklemeleri kaldırma

Google Ads API ile yüklenen videoları silmeniz gerekiyorsa RemoveYouTubeVideoUpload yöntemini kullanın. Bu işlem, videoyu hem Google Ads öğe kitaplığından hem de YouTube'dan kaldırır.