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

يوفّر هذا الدليل قائمة بالأنواع المختلفة من إجراءات الإحالات الناجحة التي يمكنك إنشاؤها باستخدام 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‏ 4)
WEBPAGE_ONCLICK الموقع الإلكتروني، الموقع الإلكتروني (إحصاءات Google‏ 4)
CLICK_TO_CALL نقرات رقم الهاتف

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

تتيح لك الإحالة الناجحة للتطبيق تتبُّع عمليات تثبيت التطبيقات المتوافقة مع الأجهزة الجوّالة أو عمليات الشراء داخل التطبيق من متجر 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 النقرات التي يتم إجراؤها على رقم في موقعك للجوّال

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 لتتبُّع المكالمات على الأرقام المدرَجة في موقعك الإلكتروني. بالإضافة إلى ذلك، عليك إعداد مادة عرض مكالمة وربطها على مستوى العميل أو الحملة أو المجموعة الإعلانية.

CLICK_TO_CALL

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

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

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

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

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

الإحالات الناجحة المحسّنة

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

يوضّح الجدول التالي مَعلمات واجهة برمجة التطبيقات المماثلة لاستخدامها مع كلّ نوع إحالة ناجحة محسّنة:

نوع إجراء الإحالة الناجحة نوع الإحالة الناجحة المحسّنة دليل إعداد واجهة برمجة التطبيقات
UPLOAD_CLICKS الإحالات الناجحة المحسّنة للعملاء المحتملين
تحسِّن عملية قياس المعاملات التي تتم خارج إطار الإنترنت والتي تنتج عن عميل محتمل أو زائر للموقع الإلكتروني.
دليل إعداد واجهة برمجة التطبيقات
WEBPAGE الإحالات الناجحة المحسّنة للويب
تحسِّن عملية قياس الإحالات الناجحة على الإنترنت.
دليل إعداد واجهة برمجة التطبيقات

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

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

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

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

حقل التقرير الوصف
metrics.sk_ad_network_installs عدد عمليات التثبيت التي أبلغت عنها Apple لا يمكن تقسيم هذا المقياس إلا حسب أيّ مجموعة من شرائح segments.sk_ad_network_conversion_value و ذات الصلة بالتاريخ.
metrics.sk_ad_network_total_conversions إجمالي عدد الإحالات الناجحة، بما في ذلك عمليات التثبيت وأنواع أخرى من الإحالات الناجحة التي أبلغت عنها Apple لا يمكن تقسيم هذا المقياس إلا من خلال الشرائح المرتبطة بـ SKAdNetwork والشرائح المرتبطة بالتاريخ.
segments.sk_ad_network_ad_event_type نوع الحدث الذي حدث لإحالة ناجحة معيّنة.
segments.sk_ad_network_attribution_credit كيفية تحديد نسبة المساهمة في إحالة ناجحة معيّنة
segments.sk_ad_network_fine_conversion_value

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

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

segments.sk_ad_network_coarse_conversion_value القيمة التقريبية لإحالة ناجحة فردية.
segments.sk_ad_network_postback_sequence_index موضع تسجيل الإحالة الناجحة، بالتسلسل، لإحالة ناجحة معيّنة.
segments.sk_ad_network_source_app.sk_ad_network_source_app_id رقم تعريف التطبيق الذي تمّ عرض الإعلان عليه والذي أدّى إلى تثبيت شبكة إعلانات iOS StoreKit
segments.sk_ad_network_source_domain الموقع الإلكتروني الذي تمّ فيه عرض الإعلان الذي أدّى إلى تثبيت شبكة إعلانات iOS StoreKit تعني القيمة الخالية أنّ هذه الشريحة غير قابلة للتطبيق، على سبيل المثال، الحملة غير المخصّصة لأجهزة iOS، أو أنّها لم تكن متوفّرة في أيّ عمليات تسجيل إحالات ناجحة أرسلتها Apple.
segments.sk_ad_network_source_type نوع المصدر الذي تمّ فيه عرض الإعلان الذي أدّى إلى تثبيت شبكة إعلانات iOS StoreKit تعني القيمة الخالية أنّ هذا المقطع لا ينطبق، على سبيل المثال، الحملة غير المخصّصة لنظام التشغيل iOS، أو لم يكن نطاق المصدر أو التطبيق المصدر متوفّرَين في أي عمليات تسجيل إحالات ناجحة أرسلتها Apple.
segments.sk_ad_network_user_type نوع المستخدِم الذي أنشأ إحالة ناجحة معيّنة.
segments.sk_ad_network_redistributed_fine_conversion_value تتضمّن قيم الإحالات الناجحة في هذا المقطع قيمًا فارغة تمت إعادتها توزيعها على قيم الإحالات الناجحة. تمثّل هذه الشريحة مجموع قيم الإحالات الناجحة الجيدة المرصودة التي تعرضها Apple والقيم الفارغة المستندة إلى نموذج من Google.
segments.sk_ad_network_version إصدار iOS Store Kit Ad Network API الذي تم استخدامه

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

نموذج رمز Python

#!/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="v18"
    )

    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.

يمكنك إجراء التغييرات التالية على إحالة ناجحة لموقع على "إحصاءات 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.V18.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::V18::Resources::ConversionAction->new({
      name                          => $conversion_action_name,
      category                      => DEFAULT,
      type                          => WEBPAGE,
      status                        => ENABLED,
      viewThroughLookbackWindowDays => 15,
      valueSettings                 =>
        Google::Ads::GoogleAds::V18::Resources::ValueSettings->new({
          defaultValue          => 23.41,
          alwaysUseDefaultValue => "true"
        })});

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