البدء

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

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

من المهم التأكّد من أنّ لديك إذنًا بمشاركة بيانات الإحالات الناجحة مع Google. يمكنك تنفيذ هذه الخطوة باتّباع إحدى الطريقتين التاليتين:

  1. ضبط إعدادات الموافقة التلقائية على مستوى الحساب. في واجهة مستخدِم "إعلانات Google"، انقر على الأدوات - > إدارة بيانات إعلانات Google -> إعدادات الموافقة -> إعدادات الموافقة التلقائية.
  2. ضبط حقل ClickConversion.consent في كل إحالة ناجحة مستورَدة.

إعداد موقعك الإلكتروني لتتبُّع الإحالات الناجحة

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

تفعيل ميزة "تتبُّع الإحالات الناجحة" في حساب الإحالات الناجحة على "إعلانات Google"

استرداد معلومات عن إعداد ميزة "تتبُّع الإحالات الناجحة"

يمكنك التحقّق من إعداد ميزة "تتبُّع الإحالات الناجحة" في حسابك والتأكّد من تفعيلها من خلال طلب Customer من مورد ConversionTrackingSetting. أرسِل طلب البحث التالي باستخدام GoogleAdsService.SearchStream:

SELECT
  customer.conversion_tracking_setting.google_ads_conversion_customer,
  customer.conversion_tracking_setting.conversion_tracking_status,
  customer.conversion_tracking_setting.conversion_tracking_id,
  customer.conversion_tracking_setting.cross_account_conversion_tracking_id
FROM customer

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

يشير الحقل conversion_tracking_status إلى ما إذا كانت ميزة "تتبُّع الإحالات الناجحة" مفعّلة وما إذا كان الحساب يستخدم ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات".

إنشاء إجراء إحالة ناجحة ضمن عميل الإحالات الناجحة على "إعلانات Google"

إذا كانت قيمة conversion_tracking_status هي NOT_CONVERSION_TRACKED، فهذا يعني أنّ ميزة "تتبُّع الإحالات الناجحة" غير مفعّلة للحساب. فعِّل ميزة "تتبُّع الإحالات الناجحة" من خلال إنشاء إجراء واحد على الأقل ConversionAction في حساب الإحالات الناجحة على "إعلانات Google"، كما في المثال التالي. بدلاً من ذلك، يمكنك إنشاء إجراء إحالة ناجحة في واجهة المستخدِم باتّباع التعليمات الواردة في مركز المساعدة لنوع الإحالة الناجحة الذي تريد تفعيله.

يُرجى العِلم بأنّه يتم تفعيل ميزة "الإحالات الناجحة المحسّنة" تلقائيًا عند إرسالها من خلال Google Ads API، ولكن يمكن إيقافها من خلال واجهة مستخدِم "إعلانات Google".

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

جافا

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.V24.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: GoogleAdsClient, customer_id: str) -> None:
    conversion_action_service: ConversionActionServiceClient = (
        client.get_service("ConversionActionService")
    )

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

    # Create conversion action.
    conversion_action: ConversionAction = 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: ConversionAction.ValueSettings = (
        conversion_action.value_settings
    )
    value_settings.default_value = 15.0
    value_settings.always_use_default_value = True

    # Add the conversion action.
    conversion_action_response: MutateConversionActionsResponse = (
        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::V24::Resources::ConversionAction->new({
      name                          => $conversion_action_name,
      category                      => DEFAULT,
      type                          => WEBPAGE,
      status                        => ENABLED,
      viewThroughLookbackWindowDays => 15,
      valueSettings                 =>
        Google::Ads::GoogleAds::V24::Resources::ValueSettings->new({
          defaultValue          => 23.41,
          alwaysUseDefaultValue => "true"
        })});

  # Create a conversion action operation.
  my $conversion_action_operation =
    Google::Ads::GoogleAds::V24::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;
}
      

curl

تأكَّد من ضبط conversion_action_type على قيمة ConversionActionType الصحيحة. لمزيد من الإرشادات حول إنشاء إجراءات إحالات ناجحة في Google Ads API، يُرجى الاطّلاع على إنشاء إجراءات إحالات ناجحة.

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

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

SELECT
  conversion_action.resource_name,
  conversion_action.name,
  conversion_action.status
FROM conversion_action
WHERE conversion_action.type = 'INSERT_CONVERSION_ACTION_TYPE'

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

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

تفعيل ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات" في Google Ads API

يمكنك استخدام Google Ads API لتفعيل ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات" عند إنشاء حسابات عملاء أو تعديلها.

في مورد Customer، اضبط حقل conversion_tracking_setting.google_ads_conversion_customer على اسم مورد الحساب الإداري الذي يجب أن يدير إجراءات الإحالات الناجحة نيابةً عن حساب العميل.

يجب أن يتم إرسال الطلبات التي تعدِّل عميل الإحالات الناجحة لحساب عميل من قِبل الحساب الإداري الذي سيصبح عميل الإحالات الناجحة الجديد للعميل. يمكنك تنفيذ ذلك من خلال ضبط login-customer-id على رقم تعريف الحساب الإداري.

عند تفعيل ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات" أو تبديل مدير تتبُّع الإحالات الناجحة لحساب عميل حالي، تنطبق التحذيرات نفسها كما لو كنت ستجري هذا التغيير في واجهة المستخدِم. على وجه التحديد:

  • سيتبنّى حساب العميل قواعد قيمة الإحالة الناجحة التلقائية وأهداف مراحل نشاط العملاء التلقائية لمدير تتبُّع الإحالات الناجحة الجديد.
  • سيتم تبديل الحملات التي تستهدِف إجراء إحالة ناجحة محدّدًا إلى استخدام أهداف الإحالات الناجحة التلقائية لحساب مدير الإحالات الناجحة. وإذا تمت مواصلة استهداف إجراء إحالة ناجحة محدّد، قد يؤدي ذلك إلى سلوك غير متّسق، لأنّ الحساب الإداري قد لا تكون له الأهداف نفسها التي يستخدِمها حساب العميل. تأكَّد من تحسين حملاتك لتحقيق الأهداف الصحيحة.
  • إذا كان أحد الحسابات ينتمي إلى أكثر من حساب إداري، يمكنه فقط استخدام إجراءات الإحالات الناجحة من حساب إداري واحد. إذا لم يتم تحديد حساب لتتبُّع الإحالات الناجحة، سيستخدم الحساب نفسه كحساب لتتبُّع الإحالات الناجحة تلقائيًا.

استيراد الإحالات الناجحة في جميع الحسابات

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

لتحميل إحالة ناجحة بنجاح، يجب أن يتمكّن حساب التحميل من الوصول إلى إجراء الإحالة الناجحة. في التسلسل الهرمي لميزة "تتبُّع الإحالات الناجحة في جميع الحسابات"، يمكن لحساب التحميل الوصول إلى الإجراء إذا كان حسابًا رئيسيًا (إداريًا) أو حسابًا فرعيًا لمالك إجراء الإحالة الناجحة في شجرة الحساب.

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

بنية التفويض

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

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

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

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

إذا كنت تستخدم ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات "، تعرض ConversionActionService إجراءات الإحالات الناجحة التالية:

  • جميع إجراءات الإحالات الناجحة التي يحدّدها الحساب الإداري الذي يستخدمه الحساب لتتبُّع الإحالات الناجحة في جميع الحسابات
  • جميع إجراءات الإحالات الناجحة التي سجّل العميل إحصاءات عنها، بما في ذلك الإجراءات التي يحدّدها النظام والإجراءات التي يملكها المدير حتى إذا ألغى المدير ربط الحساب لاحقًا
  • جميع الإجراءات التي حدّدها العميل في حسابه الخاص
  • الإحالات الناجحة في "إحصاءات Google" التي تم إنشاؤها في مواقع "إحصاءات Google" المرتبطة. ويشمل ذلك إجراءات الإحالات الناجحة في "إحصاءات Google" التي لم يتم استيرادها إلى "إعلانات Google"، والتي تكون حالتها HIDDEN.

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

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

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

جافا

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.V24.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: GoogleAdsClient, customer_id: str) -> None:
    conversion_action_service: ConversionActionServiceClient = (
        client.get_service("ConversionActionService")
    )

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

    # Create conversion action.
    conversion_action: ConversionAction = 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: ConversionAction.ValueSettings = (
        conversion_action.value_settings
    )
    value_settings.default_value = 15.0
    value_settings.always_use_default_value = True

    # Add the conversion action.
    conversion_action_response: MutateConversionActionsResponse = (
        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::V24::Resources::ConversionAction->new({
      name                          => $conversion_action_name,
      category                      => DEFAULT,
      type                          => WEBPAGE,
      status                        => ENABLED,
      viewThroughLookbackWindowDays => 15,
      valueSettings                 =>
        Google::Ads::GoogleAds::V24::Resources::ValueSettings->new({
          defaultValue          => 23.41,
          alwaysUseDefaultValue => "true"
        })});

  # Create a conversion action operation.
  my $conversion_action_operation =
    Google::Ads::GoogleAds::V24::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;
}
      

curl

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

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

تتيح "إعلانات 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.