إنشاء إجراءات إحالة ناجحة

يقدّم هذا الدليل قائمة بأنواع إجراءات الإحالات الناجحة المختلفة التي يمكنك إنشاؤها باستخدام Google Ads API، ومعلومات عن كيفية ربطها بواجهة "إعلانات Google" على الويب، بالإضافة إلى مثال رمز برمجي تفصيلي يوضّح كيفية إنشاء إجراءات إحالات ناجحة جديدة.

لقياس الإحالات الناجحة، عليك إعداد ConversionAction من أجل type إجراء الإحالة الناجحة الذي تريد تتبُّعه. على سبيل المثال، تتطلب عملية الشراء على الإنترنت ومكالمة هاتفية إجراءات تحويل مختلفة.

إنّ أفضل طريقة لإعداد إجراءات إحالات ناجحة جديدة في واجهة برمجة التطبيقات هي استخدام مثال رمز إضافة إجراء الإحالة الناجحة أدناه. يتولّى النموذج معالجة جميع مهام المصادقة في الخلفية نيابةً عنك، ويرشدك إلى خطوات إنشاء ConversionAction.

تتطلّب معظم إجراءات الإحالات الناجحة أيضًا خطوات إضافية من جانبك لتتبُّعها. على سبيل المثال، لتتبُّع الإحالات الناجحة على موقعك الإلكتروني، يجب إضافة مقتطف رمز يُعرف باسم علامة إلى صفحة الإحالات الناجحة على موقعك الإلكتروني. للاطّلاع على متطلبات إجراءات الإحالات الناجحة الأخرى، اطّلِع على مقالة "مركز المساعدة".

الإحالات الناجحة من الموقع الإلكتروني

تتيح لك الإحالات الناجحة للموقع الإلكتروني تتبُّع إجراءات الموقع الإلكتروني، مثل المبيعات على الإنترنت والنقرات على الروابط ومشاهدات الصفحات وعمليات الاشتراك.

لتتبُّع الإحالات الناجحة على موقعك الإلكتروني، عليك إنشاء ConversionAction مع ضبط ConversionActionType على WEBPAGE، وإضافة مقتطف رمز يُعرف باسم علامة إلى صفحة الإحالات الناجحة على موقعك الإلكتروني.

يضم ConversionAction عدة أنواع من الإحالات الناجحة للمواقع الإلكترونية، والتي يتم تمييزها ضمن واجهة برمجة التطبيقات من خلال الحقل type في كل TagSnippet مدرَج في حقل tag_snippets في ConversionAction.

توفِّر TagSnippet رمز التتبّع الذي يجب تضمينه في موقعك الإلكتروني لتتبّع إجراءات إحالاتك الناجحة. تتطلّب الإحالات الناجحة للموقع الإلكتروني والنقرة على رقم الهاتف إضافة event_snippet، التي يجب وضعها على صفحات الويب التي تشير إلى إجراء إحالة ناجحة، مثل صفحة تأكيد الدفع أو صفحة إرسال نموذج العميل المحتمل، وglobal_site_tag، التي يجب تثبيتها على كل صفحة من موقعك الإلكتروني. يمكنك استرداد هاتَين السمتَين باستخدام ConversionActionService. انتقِل إلى مركز المساعدة للحصول على مزيد من المعلومات حول كيفية وضع علامات على صفحاتك.

يعرض الجدول التالي معلَمات واجهة برمجة التطبيقات المكافئة لاستخدامها لكل مصدر في واجهة "إعلانات Google" على الويب:

نوع رمز التتبّع مصدر "إعلانات Google"
WEBPAGE الموقع الإلكتروني والموقع الإلكتروني ("إحصاءات Google" (GA4))
WEBPAGE_ONCLICK الموقع الإلكتروني والموقع الإلكتروني ("إحصاءات Google" (GA4))
CLICK_TO_CALL نقرات رقم الهاتف
--- الموقع الإلكتروني ("إحصاءات Google" (UA))

الإحالات الناجحة للتطبيق

تتيح لك الإحالات الناجحة للتطبيق تتبُّع عمليات تثبيت تطبيق الأجهزة الجوّالة أو عمليات الشراء في التطبيق من متجر Google Play.

يعرض الجدول التالي معلَمات واجهة برمجة التطبيقات ConversionActionType المكافئة التي يجب استخدامها لكل مصدر في واجهة "إعلانات Google" على الويب:

نوع إجراء الإحالة الناجحة مصدر "إعلانات Google"
GOOGLE_PLAY_DOWNLOAD Google Play > عمليات التثبيت
GOOGLE_PLAY_IN_APP_PURCHASE Google Play > عمليات الشراء داخل التطبيق

إذا كنت تريد تتبُّع إجراءات أخرى للتطبيقات المتوافقة مع الأجهزة الجوّالة باستخدام مواقع "إحصاءات Google 4" أو إحصاءات التطبيقات التابعة لجهات خارجية. اطّلِع على أنواع إجراءات الإحالات الناجحة الإضافية.

الإحالات الناجحة للمكالمات الهاتفية

تتيح لك ميزة تتبُّع الإحالات الناجحة للمكالمات الهاتفية تتبُّع المكالمات من الإعلانات، والمكالمات الواردة إلى رقم معيّن على موقعك الإلكتروني، والنقرات على الأرقام في المواقع الإلكترونية للأجهزة الجوّالة.

يعرض الجدول التالي معلَمات واجهة برمجة التطبيقات ConversionActionType المكافئة التي يجب استخدامها لكل مصدر في واجهة "إعلانات Google" على الويب:

نوع إجراء الإحالة الناجحة مصدر "إعلانات Google"
AD_CALL المكالمات من الإعلانات التي تستخدم إضافات المكالمات أو الإعلانات للاتصال فقط
WEBSITE_CALL المكالمات الواردة إلى رقم هاتف مُدرَج في موقعك الإلكتروني
CLICK_TO_CALL النقرات التي يتم إجراؤها على رقم في موقعك الإلكتروني المتوافق مع الأجهزة الجوّالة

يختلف النوع CLICK_TO_CALL عن النوع AD_CALL لأنّه لا يتتبّع المكالمات الهاتفية الفعلية. بدلاً من ذلك، لا تتبّع CLICK_TO_CALL سوى النقرات على رقم هاتف من جهاز جوّال. يكون هذا الإجراء مفيدًا عندما يتعذّر عليك استخدام رقم توجيه المكالمات من Google لتتبُّع المكالمات الهاتفية.

AD_CALL

يظهر إجراء الإحالة الناجحة AD_CALL على أنّه إحالة ناجحة من نوع المكالمات من الإعلانات في واجهة "إعلانات Google" الإلكترونية. بعد إنشاء إجراء الإحالة الناجحة "AD_CALL"، حدِّد اسم المورد التابع له في الحقل call_conversion_action عند إنشاء CallAsset. تتيح لك مواد عرض المكالمات عرض رقم هاتف مباشرةً في إعلاناتك.

يتم تسجيل المكالمة على أنّها إحالة ناجحة إذا استمرت لفترة أطول من مدة محدّدة. المدة التلقائية هي 60 ثانية.

WEBSITE_CALL

يظهر إجراء الإحالة الناجحة WEBSITE_CALL على أنّه إحالة ناجحة بالمكالمات من موقع إلكتروني في واجهة "إعلانات Google" على الويب.

على عكس AD_CALL، تتطلّب أداة التتبُّع هذه إضافة event_snippet وglobal_site_tag إلى موقعك الإلكتروني لاسترداد رقم توجيه المكالمات الديناميكي من Google لتتبُّع المكالمات على الأرقام المدرَجة على موقعك الإلكتروني. بالإضافة إلى ذلك، عليك إعداد مادة عرض مكالمة وربطها على مستوى العميل أو الحملة أو المجموعة الإعلانية.

استيراد الإحالات الناجحة خارج إطار الإنترنت

يعرض الجدول التالي معلَمات واجهة برمجة التطبيقات ConversionActionType المكافئة التي يمكن استخدامها لكل مصدر في واجهة "إعلانات Google" على الويب، بالإضافة إلى رابط يؤدي إلى المستندات المتعلّقة بكل نوع إجراء إحالة ناجحة محدّد:

نوع إجراء الإحالة الناجحة مصدر "إعلانات Google" دليل إعداد واجهة برمجة التطبيقات
UPLOAD_CLICKS تتبُّع الإحالات الناجحة من خلال النقرات والإحالات الناجحة المحسَّنة للعملاء المحتملين دليل تحميل النقرات
دليل الإحالات الناجحة المحسّنة للعملاء المحتملين
UPLOAD_CALLS تتبع الإحالات الناجحة من المكالمات دليل إعداد واجهة برمجة التطبيقات
STORE_SALES تتبُّع الإحالات الناجحة والمبيعات في المتاجر دليل إعداد واجهة برمجة التطبيقات

الإحالات الناجحة المحسّنة للويب

تتيح لك ميزة الإحالات الناجحة المحسّنة للمواقع الإلكترونية إرسال بيانات إحالات ناجحة الطرف الأول لإجراءات إحالة ناجحة عددها WEBPAGE خلال 24 ساعة من حدث الإحالة الناجحة بدلاً من إرسالها في الوقت نفسه. ويتيح ذلك تحديد بيانات الطرف الأول من مجموعة متنوعة من المصادر، مثل قاعدة بيانات العملاء أو نظام إدارة علاقات العملاء (CRM).

أنواع إجراءات الإحالات الناجحة الإضافية

توفِّر Google Ads API أنواعًا إضافية من إجراءات الإحالات الناجحة في التقارير، ولكنها قد تحدّ أو تحظر إنشاء هذه الإجراءات أو تعديلها.

إحالات SKAdNetwork الناجحة

إذا كنت تدير حملات تطبيقات iOS ونفّذت SKAdNetwork، يمكنك الوصول إلى بيانات SkyAdNetwork المقدَّمة إلى Google على مستوى Customer وCampaign باستخدام المراجع التالية:

حقل التقرير الوصف
metrics.sk_ad_network_conversions عدد الإحالات الناجحة التي أبلغت عنها Apple. لا يمكن تقسيم هذا المقياس إلا حسب أي مجموعة من segments.sk_ad_network_conversion_value والشرائح المرتبطة بالتاريخ.
segments.sk_ad_network_conversion_value

قيمة الإحالة الناجحة التي أبلغت عنها Apple. لا يمكن تطبيق هذه الشريحة على أي مقياس غير metrics.sk_ad_network_conversions، ويمكن دمجها فقط مع الشرائح المرتبطة بالتاريخ.

يتم عرض القيمة 0 إذا أبلغت Apple عن القيمة 0 وعدم توفّر قيمة في أي مكان آخر. تحقَّق من توفّر الحقل للتمييز بين الحالتين.

يمكنك أيضًا حفظ عملية ربط قيمة الإحالة الناجحة في SKAdNetwork لعملاء مرتبطين محدّدين باستخدام تطبيقات iOS من خلال CustomerSkAdNetworkConversionValueSchema.

نموذج رمز بايثون

#!/usr/bin/env python
# Copyright 2019 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import argparse
import sys

from google.ads.googleads.client import GoogleAdsClient
from google.ads.googleads.errors import GoogleAdsException

def main(client, customer_id):
    """Adds a keyword plan, campaign, ad group, etc. to the customer account.

    Also handles errors from the API and prints them.

    Args:
        client: An initialized instance of GoogleAdsClient
        customer_id: A str of the customer_id to use in requests.
    """

    res = update_skan_cv_schema(
        client, customer_id, "my_app_id", "account_link_id"
    )
    print(res)

def update_skan_cv_schema(client, customer_id, app_id, account_link_id):
    skan_service = client.get_service(
        "CustomerSkAdNetworkConversionValueSchemaService"
    )

    req = client.get_type(
        "MutateCustomerSkAdNetworkConversionValueSchemaRequest"
    )
    operation = client.get_type(
        "CustomerSkAdNetworkConversionValueSchemaOperation"
    )
    schema_instance = client.get_type(
        "CustomerSkAdNetworkConversionValueSchema"
    )

    new_schema = operation.update
    new_schema.resource_name = (
        skan_service.customer_sk_ad_network_conversion_value_schema_path(
            "customer_id", "account_link_id"
        )
    )
    new_schema.schema.app_id = app_id
    new_schema.schema.measurement_window_hours = 48

    skan_cv_mapping = (
        schema_instance.SkAdNetworkConversionValueSchema.FineGrainedConversionValueMappings()
    )
    skan_cv_mapping.fine_grained_conversion_value = 0  # 0 - 63
    skan_cv_mapping.conversion_value_mapping.min_time_post_install_hours = 0
    skan_cv_mapping.conversion_value_mapping.max_time_post_install_hours = 48

    skan_cv_event = schema_instance.SkAdNetworkConversionValueSchema.Event()
    skan_cv_event.mapped_event_name = "TEST"
    skan_cv_event.event_revenue_value = 10

    skan_cv_mapping.conversion_value_mapping.mapped_events.append(skan_cv_event)
    new_schema.schema.fine_grained_conversion_value_mappings.append(
        skan_cv_mapping
    )

    req.operation = operation
    req.customer_id = customer_id

    res = skan_service.mutate_customer_sk_ad_network_conversion_value_schema(
        req
    )
    return res

if __name__ == "__main__":
    # GoogleAdsClient will read the google-ads.yaml configuration file in the
    # home directory if none is specified.
    googleads_client = GoogleAdsClient.load_from_storage(
        version="v16"
    )

    parser = argparse.ArgumentParser(
        description="Creates a keyword plan for specified customer."
    )
    # The following argument(s) should be provided to run the example.
    parser.add_argument(
        "-c",
        "--customer_id",
        type=str,
        required=True,
        help="The Google Ads customer ID.",
    )
    args = parser.parse_args()

    try:
        main(googleads_client, args.customer_id)
    except GoogleAdsException as ex:
        print(
            f'Request with ID "{ex.request_id}" failed with status '
            f'"{ex.error.code().name}" and includes the following errors:'
        )
        for error in ex.failure.errors:
            print(f'\tError with message "{error.message}".')
            if error.location:
                for field_path_element in error.location.field_path_elements:
                    print(f"\t\tOn field: {field_path_element.field_name}")
        sys.exit(1)
  

إحصاءات Google

تتضمّن الإحالات الناجحة من موقع مرتبط على "إحصاءات Google" إحدى قيم type التالية:

  • الإحالة الناجحة للموقع على "إحصاءات Google 4":

    • GOOGLE_ANALYTICS_4_CUSTOM
    • GOOGLE_ANALYTICS_4_PURCHASE

    يمكنك أيضًا استرداد رقم تعريف موقع "إحصاءات Google 4" واسم الموقع واسم الحدث من الحقل google_analytics_4_settings.

  • الإحالة الناجحة إلى موقع Universal Analytics:

    • UNIVERSAL_ANALYTICS_GOAL
    • UNIVERSAL_ANALYTICS_TRANSACTION

يمكنك إجراء التغييرات التالية على إحالة ناجحة لموقع على "إحصاءات Google 4":

ستؤدي أيّ محاولة لتعديل سمات أخرى لإحالة ناجحة تم استيرادها من "إحصاءات Google 4" أو أي سمات لإحالة ناجحة تم استيرادها في Universal Analytics إلى ظهور الخطأ MUTATE_NOT_ALLOWED. لا يمكنك إجراء هذه التغييرات إلا باستخدام واجهة مستخدم "إعلانات Google".

Firebase وإحصاءات التطبيقات التابعة لجهات خارجية

لاستيراد الإحالات الناجحة من إحصاءات التطبيقات التابعة لجهات خارجية أو Firebase، يمكنك تغيير status ConversionAction من HIDDEN إلى ENABLED باستخدام طريقة mutate ConversionActionService. لا يمكن تعديل app_id لإجراءات الإحالات الناجحة هذه.

  • FIREBASE_ANDROID_FIRST_OPEN
  • FIREBASE_ANDROID_IN_APP_PURCHASE
  • FIREBASE_ANDROID_CUSTOM
  • FIREBASE_IOS_FIRST_OPEN
  • FIREBASE_IOS_IN_APP_PURCHASE
  • FIREBASE_IOS_CUSTOM
  • THIRD_PARTY_APP_ANALYTICS_ANDROID_FIRST_OPEN
  • THIRD_PARTY_APP_ANALYTICS_ANDROID_IN_APP_PURCHASE
  • THIRD_PARTY_APP_ANALYTICS_ANDROID_CUSTOM
  • THIRD_PARTY_APP_ANALYTICS_IOS_FIRST_OPEN
  • THIRD_PARTY_APP_ANALYTICS_IOS_IN_APP_PURCHASE
  • THIRD_PARTY_APP_ANALYTICS_IOS_CUSTOM

عملية بيع في المتجر

مع أنّه لا يمكنك إنشاء إجراءات إحالات ناجحة STORE_SALES أو STORE_SALES_DIRECT_UPLOAD باستخدام Google Ads API، تتيح واجهة برمجة التطبيقات إمكانية تحميل معاملات المبيعات في المتاجر.

  • STORE_SALES
  • STORE_SALES_DIRECT_UPLOAD

خيارات متنوعة

إنّ أنواع إجراءات الإحالات الناجحة التالية للقراءة فقط في Google Ads API ويتم تقديمها لأغراض إعداد التقارير.

  • ANDROID_APP_PRE_REGISTRATION
  • ANDROID_INSTALLS_ALL_OTHER_APPS
  • FLOODLIGHT_ACTION
  • FLOODLIGHT_TRANSACTION
  • GOOGLE_HOSTED
  • LEAD_FORM_SUBMIT
  • SALESFORCE
  • SEARCH_ADS_360
  • SMART_CAMPAIGN_AD_CLICKS_TO_CALL
  • SMART_CAMPAIGN_MAP_CLICKS_TO_CALL
  • SMART_CAMPAIGN_MAP_DIRECTIONS
  • SMART_CAMPAIGN_TRACKED_CALLS
  • STORE_VISITS
  • WEBPAGE_CODELESS

غير معروف

إذا كان حسابك على "إعلانات Google" يتضمّن أنواعًا أخرى من إجراءات الإحالات الناجحة، قد تجد أنّ طلبات البحث والتقارير تعرض إجراءات إحالات ناجحة حيث تكون قيمة ConversionAction.type UNKNOWN. لا تتيح واجهة برمجة التطبيقات إدارة إجراءات الإحالات الناجحة هذه، ولكنها تعرض هذه الإجراءات في تقارير بهدف تقديم نتائج كاملة لمقاييس الإحالات الناجحة الرئيسية مثل metrics.conversions وmetrics.conversions_value.

مثال الرمز البرمجي

يرشدك مثال الرمز التالي خلال عملية إنشاء إجراء إحالة ناجحة جديد. وعلى وجه التحديد، يتم إنشاء إجراء إحالة ناجحة مع ضبط type على UPLOAD_CLICKS. هذا هو مسار واجهة المستخدم في "إعلانات Google" نفسه عند إنشاء إجراء إحالة ناجحة جديد باستخدام استيراد > الاستيراد اليدوي باستخدام واجهة برمجة التطبيقات أو عمليات التحميل > تتبُّع الإحالات الناجحة من النقرات. ويتم أيضًا ضبط category على DEFAULT.

تنطبق الإعدادات التلقائية التالية:

Java

private void runExample(GoogleAdsClient googleAdsClient, long customerId) {

  // Creates a ConversionAction.
  ConversionAction conversionAction =
      ConversionAction.newBuilder()
          // Note that conversion action names must be unique. If a conversion action already
          // exists with the specified conversion_action_name the create operation will fail with
          // a ConversionActionError.DUPLICATE_NAME error.
          .setName("Earth to Mars Cruises Conversion #" + getPrintableDateTime())
          .setCategory(ConversionActionCategory.DEFAULT)
          .setType(ConversionActionType.WEBPAGE)
          .setStatus(ConversionActionStatus.ENABLED)
          .setViewThroughLookbackWindowDays(15L)
          .setValueSettings(
              ValueSettings.newBuilder()
                  .setDefaultValue(23.41)
                  .setAlwaysUseDefaultValue(true)
                  .build())
          .build();

  // Creates the operation.
  ConversionActionOperation operation =
      ConversionActionOperation.newBuilder().setCreate(conversionAction).build();

  try (ConversionActionServiceClient conversionActionServiceClient =
      googleAdsClient.getLatestVersion().createConversionActionServiceClient()) {
    MutateConversionActionsResponse response =
        conversionActionServiceClient.mutateConversionActions(
            Long.toString(customerId), Collections.singletonList(operation));
    System.out.printf("Added %d conversion actions:%n", response.getResultsCount());
    for (MutateConversionActionResult result : response.getResultsList()) {
      System.out.printf(
          "New conversion action added with resource name: '%s'%n", result.getResourceName());
    }
  }
}
      

C#

public void Run(GoogleAdsClient client, long customerId)
{
    // Get the ConversionActionService.
    ConversionActionServiceClient conversionActionService =
        client.GetService(Services.V16.ConversionActionService);

    // Note that conversion action names must be unique.
    // If a conversion action already exists with the specified name the create operation
    // will fail with a ConversionAction.DUPLICATE_NAME error.
    string ConversionActionName = "Earth to Mars Cruises Conversion #"
        + ExampleUtilities.GetRandomString();

    // Add a conversion action.
    ConversionAction conversionAction = new ConversionAction()
    {
        Name = ConversionActionName,
        Category = ConversionActionCategory.Default,
        Type = ConversionActionType.Webpage,
        Status = ConversionActionStatus.Enabled,
        ViewThroughLookbackWindowDays = 15,
        ValueSettings = new ConversionAction.Types.ValueSettings()
        {
            DefaultValue = 23.41,
            AlwaysUseDefaultValue = true
        }
    };

    // Create the operation.
    ConversionActionOperation operation = new ConversionActionOperation()
    {
        Create = conversionAction
    };

    try
    {
        // Create the conversion action.
        MutateConversionActionsResponse response =
            conversionActionService.MutateConversionActions(customerId.ToString(),
                    new ConversionActionOperation[] { operation });

        // Display the results.
        foreach (MutateConversionActionResult newConversionAction in response.Results)
        {
            Console.WriteLine($"New conversion action with resource name = " +
                $"'{newConversionAction.ResourceName}' was added.");
        }
    }
    catch (GoogleAdsException e)
    {
        Console.WriteLine("Failure:");
        Console.WriteLine($"Message: {e.Message}");
        Console.WriteLine($"Failure: {e.Failure}");
        Console.WriteLine($"Request ID: {e.RequestId}");
        throw;
    }
}
      

PHP

public static function runExample(GoogleAdsClient $googleAdsClient, int $customerId)
{
    // Creates a conversion action.
    $conversionAction = new ConversionAction([
        // Note that conversion action names must be unique.
        // If a conversion action already exists with the specified conversion_action_name
        // the create operation will fail with a ConversionActionError.DUPLICATE_NAME error.
        'name' => 'Earth to Mars Cruises Conversion #' . Helper::getPrintableDatetime(),
        'category' => ConversionActionCategory::PBDEFAULT,
        'type' => ConversionActionType::WEBPAGE,
        'status' => ConversionActionStatus::ENABLED,
        'view_through_lookback_window_days' => 15,
        'value_settings' => new ValueSettings([
            'default_value' => 23.41,
            'always_use_default_value' => true
        ])
    ]);

    // Creates a conversion action operation.
    $conversionActionOperation = new ConversionActionOperation();
    $conversionActionOperation->setCreate($conversionAction);

    // Issues a mutate request to add the conversion action.
    $conversionActionServiceClient = $googleAdsClient->getConversionActionServiceClient();
    $response = $conversionActionServiceClient->mutateConversionActions(
        MutateConversionActionsRequest::build($customerId, [$conversionActionOperation])
    );

    printf("Added %d conversion actions:%s", $response->getResults()->count(), PHP_EOL);

    foreach ($response->getResults() as $addedConversionAction) {
        /** @var ConversionAction $addedConversionAction */
        printf(
            "New conversion action added with resource name: '%s'%s",
            $addedConversionAction->getResourceName(),
            PHP_EOL
        );
    }
}
      

Python

def main(client, customer_id):
    conversion_action_service = client.get_service("ConversionActionService")

    # Create the operation.
    conversion_action_operation = client.get_type("ConversionActionOperation")

    # Create conversion action.
    conversion_action = conversion_action_operation.create

    # Note that conversion action names must be unique. If a conversion action
    # already exists with the specified conversion_action_name, the create
    # operation will fail with a ConversionActionError.DUPLICATE_NAME error.
    conversion_action.name = f"Earth to Mars Cruises Conversion {uuid.uuid4()}"
    conversion_action.type_ = (
        client.enums.ConversionActionTypeEnum.UPLOAD_CLICKS
    )
    conversion_action.category = (
        client.enums.ConversionActionCategoryEnum.DEFAULT
    )
    conversion_action.status = client.enums.ConversionActionStatusEnum.ENABLED
    conversion_action.view_through_lookback_window_days = 15

    # Create a value settings object.
    value_settings = conversion_action.value_settings
    value_settings.default_value = 15.0
    value_settings.always_use_default_value = True

    # Add the conversion action.
    conversion_action_response = (
        conversion_action_service.mutate_conversion_actions(
            customer_id=customer_id,
            operations=[conversion_action_operation],
        )
    )

    print(
        "Created conversion action "
        f'"{conversion_action_response.results[0].resource_name}".'
    )
      

Ruby

def add_conversion_action(customer_id)
  # GoogleAdsClient will read a config file from
  # ENV['HOME']/google_ads_config.rb when called without parameters
  client = Google::Ads::GoogleAds::GoogleAdsClient.new


  # Add a conversion action.
  conversion_action = client.resource.conversion_action do |ca|
    ca.name = "Earth to Mars Cruises Conversion #{(Time.new.to_f * 100).to_i}"
    ca.type = :UPLOAD_CLICKS
    ca.category = :DEFAULT
    ca.status = :ENABLED
    ca.view_through_lookback_window_days = 15

    # Create a value settings object.
    ca.value_settings = client.resource.value_settings do |vs|
      vs.default_value = 15
      vs.always_use_default_value = true
    end
  end

  # Create the operation.
  conversion_action_operation = client.operation.create_resource.conversion_action(conversion_action)

  # Add the ad group ad.
  response = client.service.conversion_action.mutate_conversion_actions(
    customer_id: customer_id,
    operations: [conversion_action_operation],
  )

  puts "New conversion action with resource name = #{response.results.first.resource_name}."
end
      

Perl

sub add_conversion_action {
  my ($api_client, $customer_id) = @_;

  # Note that conversion action names must be unique.
  # If a conversion action already exists with the specified conversion_action_name,
  # the create operation fails with error ConversionActionError.DUPLICATE_NAME.
  my $conversion_action_name = "Earth to Mars Cruises Conversion #" . uniqid();

  # Create a conversion action.
  my $conversion_action =
    Google::Ads::GoogleAds::V16::Resources::ConversionAction->new({
      name                          => $conversion_action_name,
      category                      => DEFAULT,
      type                          => WEBPAGE,
      status                        => ENABLED,
      viewThroughLookbackWindowDays => 15,
      valueSettings                 =>
        Google::Ads::GoogleAds::V16::Resources::ValueSettings->new({
          defaultValue          => 23.41,
          alwaysUseDefaultValue => "true"
        })});

  # Create a conversion action operation.
  my $conversion_action_operation =
    Google::Ads::GoogleAds::V16::Services::ConversionActionService::ConversionActionOperation
    ->new({create => $conversion_action});

  # Add the conversion action.
  my $conversion_actions_response =
    $api_client->ConversionActionService()->mutate({
      customerId => $customer_id,
      operations => [$conversion_action_operation]});

  printf "New conversion action added with resource name: '%s'.\n",
    $conversion_actions_response->{results}[0]{resourceName};

  return 1;
}
      

يمكن العثور على هذا المثال أيضًا في مجلد "تجديد النشاط التسويقي" في مكتبة العملاء وفي مجموعة أمثلة الرموز: مثال على رمز إجراء الإحالة الناجحة.

شروط التحقق من صحة القيمة

تتيح "إعلانات Google" وGoogle Ads API مجموعة متنوعة من إجراءات الإحالات الناجحة، لذا تختلف بعض قواعد التحقّق استنادًا إلى type الإجراء.

إلى حد كبير، يقع الخطأ الأكثر شيوعًا عند إنشاء إجراء إحالة ناجحة هو DUPLICATE_NAME. تأكّد من استخدام اسم فريد لكلّ إجراء إحالة ناجحة.

في ما يلي بعض النصائح لإعداد حقول ConversionAction:

جميع حقول التعداد
تؤدي محاولة ضبط أي حقل تعداد على UNKNOWN إلى ظهور الخطأ RequestError.INVALID_ENUM_VALUE.
app_id
السمة app_id غير قابلة للتغيير. ولا يمكن ضبطها إلا عند إنشاء إحالة ناجحة جديدة للتطبيق.
attribution_model_settings
يؤدي ضبط هذا الإجراء على خيار متوقّف نهائيًا إلى حدوث خطأ CANNOT_SET_RULE_BASED_ATTRIBUTION_MODELS. تتيح "إعلانات Google" استخدام GOOGLE_ADS_LAST_CLICK وGOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVEN فقط.
click_through_lookback_window_days

ويؤدي ضبط هذه السمة على قيمة خارج النطاق المسموح به إلى ظهور خطأ RangeError.TOO_LOW أو RangeError.TOO_HIGH.

يجب أن تكون هذه السمة ضمن النطاق [1,60] لإجراء إحالة ناجحة من النوع AD_CALL أو WEBSITE_CALL. بالنسبة إلى معظم إجراءات الإحالات الناجحة الأخرى، النطاق المسموح به هو [1,30].

include_in_conversions_metric

تعذَّر ضبط هذه القيمة في عملية create أو update مع ظهور خطأ FieldError.IMMUTABLE_FIELD. بدلاً من ذلك، اضبط primary_for_goal على النحو الموضّح في دليل أهداف الإحالات الناجحة.

phone_call_duration_seconds

تؤدي محاولة ضبط هذه السمة على إجراء إحالة ناجحة ليس للطلبات إلى ظهور خطأ FieldError.VALUE_MUST_BE_UNSET.

type

تُعدّ السمة type غير قابلة للتغيير، ولا يمكن ضبطها إلا عند إنشاء إحالة ناجحة جديدة.

يؤدي تعديل إجراء إحالة ناجحة بقيمة type يساوي UNKNOWN إلى خطأ MutateError.MUTATE_NOT_ALLOWED.

value_settings

value_settings لإجراء الإحالة الناجحة WEBSITE_CALL أو AD_CALL يجب ضبط always_use_default_value على true. إنّ تحديد قيمة false عند إنشاء هذه القيمة أو تعديلها يؤدي إلى خطأ INVALID_VALUE.

view_through_lookback_window_days

ويؤدي ضبط هذه السمة على قيمة خارج النطاق المسموح به إلى ظهور خطأ RangeError.TOO_LOW أو RangeError.TOO_HIGH. بالنسبة إلى معظم إجراءات الإحالات الناجحة، يكون النطاق المسموح به هو [1,30].

لا يمكن ضبط هذه السمة على إجراءَي إحالة ناجحة AD_CALL أو WEBSITE_CALL. يؤدي تحديد قيمة إلى حدوث خطأ VALUE_MUST_BE_UNSET.