Unreal SDK

    Maven metadata URL

    Attention

    This is a guide for the installation and setup of Unreal SDK v4. For previous versions, refer to the Unreal SDK (Previous) guide.

    Install the Airbridge SDK and implement the necessary settings by following the steps below.

    Install SDK

    The Airbridge Unreal SDK supports the Unreal Engine v.4.23 and later.

    The Airbridge Unreal SDK can be installed using the method below. After installation, you can confirm whether the SDK has been properly installed through the Unreal SDK Test.

    1. Download the latest version of the Airbridge Unreal SDK.

    2. Create the Plugins folder in the root directory of your Unreal Engine project.

    3. Locate the Airbridge Unreal SDK within the Plugins folder like in the following structure.

    123456
    <YOUR_UE_PROJECT>
      ├── Plugins
              └── AirbridgeUnrealSDK
                  ├── Resources
                  ├── Source
                  └── AirbridgeUnrealSDK.uplugin

    4. Navigate to [Settings]>[Plugins] in the Unreal Engine toolbar and enable the Airbridge Unreal SDK.

    5. Add AirbridgeUnreal to the PublicDependencyModuleNames array within the app's Build.cs file (<YOUR_UE_PROJECT>.Build.cs).

    123456789
    public class <YOUR_UE_PROJECT> : ModuleRules
    {
        public <YOUR_UE_PROJECT>(ReadOnlyTargetRules Target) : base(Target)
        {
            ...
            PublicDependencyModuleNames.AddRange(new string[] { ... , "AirbridgeUnreal" });   // ADD DEPENDENCY 
            ...
        }
    }

    Install Restricted SDK

    Note

    Install only one version of the SDK, either the general SDK or the restricted SDK.

    Depending on policies and environments, restrictions on collecting device IDs like GAID and IDFA may be required. When installing the Restricted SDK version, the device IDs are not collected.

    Install the Restricted SDK using the method below.

    1. Download the latest version of the Airbridge Unreal SDK.

    2. Create a Plugins folder in the root directory of your Unreal Engine project.

    3. Locate the Airbridge Unreal SDK within the Plugins folder like in the following structure.

    123456
    <YOUR_UE_PROJECT>
      ├── Plugins
              └── AirbridgeUnrealSDK
                  ├── Resources
                  ├── Source
                  └── AirbridgeUnrealSDK.uplugin

    4. Navigate to [Settings]>[Plugins] in the Unreal Engine toolbar and enable the Airbridge Unreal SDK.

    5. Add AirbridgeUnreal to the PublicDependencyModuleNames array within the app's Build.cs file (<YOUR_UE_PROJECT>.Build.cs).

    123456789
    public class <YOUR_UE_PROJECT> : ModuleRules
    {
        public <YOUR_UE_PROJECT>(ReadOnlyTargetRules Target) : base(Target)
        {
            ...
            PublicDependencyModuleNames.AddRange(new string[] { ... , "AirbridgeUnreal" });   // ADD DEPENDENCY 
            ...
        }
    }

    Initialize SDK

    Enter the correct App Name and App Token values in the SDK Settings window. The App Name and App Token can be found on the [Settings]>[Tokens] page in the Airbridge dashboard.

    Configure SDK settings

    1. Open the Project Settings window in the Unreal Engine.

    2. Under the [Plugins] section, click Airbridge Unreal SDK to open the SDK settings window. You may fill in the fields or click on the checkboxes that are necessary for your service.

    3. After filling in the required fields, click the Set as Default button.

    See below for a guide to the settings.

    Value

    Reference

    App Name

    Initialize SDK

    Enable app launch with Airbridge deep links

    App Token

    Initialize SDK

    Log Level

    SDK Log Setting

    iOS URI Scheme

    Enable app launch with Airbridge deep links

    Android URI Scheme

    Enable app launch with Airbridge deep links

    Custom Domain

    Set up custom domain

    Session Timeout Seconds

    Configure in-app event sessions

    User Info Hash Enabled

    Hash user information

    Track Airbridge Link Only

    Track Airbridge deep links only

    Auto Start Tracking Enabled

    SDK Opt-In

    SDK Opt-Out

    Facebook Deferred App Link Enabled

    Set Up Meta Deferred App Links

    iOS Tracking Authorize Timeout Seconds

    Configure ATT Prompt

    SDK Signature Secret ID

    SDK Signature

    SDK Signature Secret

    SDK Signature

    Track In Session Life Cycle Event Enabled

    Collect in-session lifecycle events

    Clear Event Buffer On Initialize Enabled

    Clear unsent in-app events

    SDK Enabled

    Initialize the Airbridge SDK in Deactivation Mode

    Event Buffer Count Limit

    Configure in-app event storage

    Event Buffer Size Limit In Gibibyte

    Configure in-app event storage

    Event Transmit Interval Seconds

    Configure in-app event transmission frequency

    Meta Install Referrer (Facebook App ID)

    Meta Install Referrer collection settings

    Is Handle Airbridge Deeplink Only

    Receive Airbridge Deep Link only

    Calculate SKAdNetwork By Server Enabled

    Calculating SKAdNetwork Conversion Value on the Server

    Configure ATT Prompt

    Note

    The functions necessary to ensure compliance with privacy policies should be reviewed with legal counsel.

    In the iOS environment, the IDFA can only be collected when users consent to data tracking through the App Tracking Transparency (ATT) prompt.

    Event collection should be delayed until the user allows tracking. If the install event is collected before the user allows tracking through the ATT prompt, the install event data will lack an identifier, making performance measurement difficult. We recommend setting a sufficient delay time for event collection to collect identifiers.

    1. Prepare the text you will use in the ATT prompt.

    2. Provide the ATT prompt following this guide provided by Apple.

    3. If the install event is not collected, the Airbridge React Native SDK delays collecting install events for 30 seconds until the user allows tracking each time the app is launched. If the user exits the app before deciding whether to allow tracking, the SDK will not collect the install event and will try again at the next app launch.

    In the SDK settings, configure the iOS Tracking Authorize Timeout Seconds to set a sufficient delay time for collecting install events. The default value is 30 seconds, and it can be set to up to 3600 seconds (1 hour).

    Attention

    Set a sufficient delay time to collect the app install event. If the SDK collects install events before users can allow tracking on the ATT prompt, the IDFA won't be collected along with the install events.

    Opt-in setup

    Attention

    Optional settings. Configure only if necessary.

    The opt-in policy requires user consent before using user data.

    After setting the Auto Start Tracking Enabled in the SDK settings to false, call the StartTracking function at the time when you can collect events. The SDK will start collecting events when the startTracking function is called.

    1
    FAirbridge::StartTracking();

    Opt-out setup

    Attention

    Optional settings. Configure only if necessary.

    The opt-out policy allows the use of user information until the user explicitly declines.

    After setting the Auto Start Tracking Enabled in the SDK settings to true, call the StopTracking function at the time when you can no longer collect events. The SDK will stop collecting events when the stopTracking function is called.

    1
    FAirbridge::StopTracking();

    SDK Signature

    Attention

    Optional settings. Configure only if necessary.

    With the SDK Signature, you can prevent SDK spoofing and use verified events to measure ad performance.

    The SDK Signature credentials, which are the Secret ID and the Secret, are required for the SDK Signature setup. They can be found on the [Management]>[Fraud Validation Rules]>[SDK Signature] page in the Airbridge dashboard. For more details on how to find the SDK Signature credentials, refer to this Airbridge guide.

    Once you have the credentials, go to the SDK settings and enter the Secret ID as sdkSignatureID and the Secret as sdkSignatureSecret.

    Deep Linking

    Deep linking allows you to redirect users from ads to specific locations within your app. The data collected from the tracking link enables you to monitor the performance of the deep link in Airbridge.

    When a user clicks on the Airbridge tracking link, the scheme deep link embedded in the tracking link is converted into an Airbridge Deep Link, which can be either an HTTP deep link or a scheme deep link. This Airbridge Deep Link redirects the user to the desired app location. Then, the Airbridge SDK converts the Airbridge Deep Link back to the original scheme deep link embedded in the tracking link and passes it to the app.

    • Example scheme deep link embedded in the tracking link: YOUR_SCHEME://product/12345

    • Examples of Airbridge Deep Links

      • HTTP deep link format 1: https://YOUR_APP_NAME.airbridge.io/~~~

      • HTTP deep link format 2: https://YOUR_APP_NAME.abr.ge/~~~

      • Scheme deep link format: YOUR_SCHEME://product/12345?airbridge_referrer=~~~

    When the app is installed on the device and the tracking link is clicked, the app opens through the Airbridge Deep Link. The Airbridge SDK converts the Airbridge Deep Link into the scheme deep embedded in the tracking link and passes it to the app.

    When the app is not installed on the device and the tracking link is clicked, the Airbridge SDK saves the Airbridge Deep Link. After the user is redirected to the app store or website and the app is installed and launched, the Airbridge SDK converts the saved Airbridge Deep Link into the scheme deep link embedded in the tracking link and passes it to the app.

    Set up deep linking

    For the deep linking setup, the following information is required.

    • Deep link information submitted in the Airbridge dashboard

    • In-app location address for user redirection

    First, submit the deep link information to the Airbridge dashboard.

    For the deep linking setup, the following information must be entered into the Airbridge dashboard.

    iOS

    • iOS URI scheme: The Airbridge Deep Link is converted to a scheme deep link using the iOS URI scheme.

    • iOS App ID: The universal link domain of the Airbridge Deep Link is set using the iOS App ID.

    Android

    • Android URI scheme: The Airbridge deep link is converted to a scheme deep link using the Android URI scheme. This information is necessary for the App Link and URI scheme.

    • Package name: This is the Android app identifier necessary for the App Link and URI scheme.

    • Android sha256_cert_fingerprints: This is used for setting the App Link domain. This information is necessary for the App Link.

    Attention

    To properly redirect users as intended, submit different information for the production app and the development app.

    Follow the steps below to submit the necessary information to the Airbridge dashboard.

    iOS

    1. Navigate to [Tracking Link]>[Deep Links] in the Airbridge dashboard.

    2. Enter the iOS URI scheme in the iOS URI Scheme field. Include ://. For example, if the iOS URI scheme is demo, enter demo://.

    3. In the Apple Developer Dashboard, navigate to [Identifier] of the app you want to set up the deep link. Find the App ID Prefix and Bundle ID.

    4. The iOS App ID is in the format of App ID Prefix+ . + Bundle ID. Enter the iOS App ID into the iOS App ID field. For example, if the App ID Prefix is prefix and the Bundle ID is example, the iOS App ID is prefix.example.

    Android

    1. Navigate to [Tracking Link]>[Deep Links] in the Airbridge dashboard.

    2. Enter the Android URI scheme into the Android URI Scheme field. Include ://. For example, if the URI scheme is demo, enter demo://.

    3. Enter the package name in the Package name field.

    4. You need to find the sha256_cert_fingerprints. Run the following command from the keystore file you are deploying.

    1
    keytool -list -v -keystore YOUR_KEYSTORE.keystore

    Find the SHA256 value in the results. The SHA256 value is the sha256_cert_fingerprints.

    1234
    Certificate fingerprints:
        MD5:  4C:65:04:52:F0:3F:F8:65:08:D3:71:86:FC:EF:C3:49
        SHA1: C8:BF:B7:B8:94:EA:5D:9D:38:59:FE:99:63:ED:47:B2:D9:5A:4E:CC
        SHA256: B5:EF:4D:F9:DC:95:E6:9B:F3:9A:5E:E9:D6:E0:D8:F6:7B:AB:79:C8:78:67:34:D9:A7:01:AB:6A:86:01:0E:99

    5. Enter the SHA256 value into the sha256_cert_fingerprints field.

    After entering the deep link information into the Airbridge dashboard, an additional setup is required to enable the following.

    • App launch with Airbridge Deep Links

    • Airbridge Deep Link event collection

    • User redirection with Airbridge Deep Links

    For detailed instructions, refer to the information below.

    Perform the following setup to enable app launch with Airbridge Deep Links after the user clicks on a tracking link.

    iOS

    Unreal setup

    1. Navigate to SDK settings in Unity.

    2. Enter the iOS URI scheme that you entered on the [Tracking Link]>[Deep Links] page in the Airbridge dashboard into the iOS URI Scheme field.

    Xcode setup

    1. Navigate to [YOUR_PROJECT]>[Signing & Capabilities] in Xcode.

    2. Click + Capability to add Associated Domains.

    3. Add applinks:YOUR_APP_NAME.airbridge.io and applinks:YOUR_APP_NAME.abr.ge to Associated Domains. YOUR_APP_NAME is the Airbridge App Name.

    Android

    Unreal setup

    1. Navigate to SDK settings in Unity.

    2. Enter the Android URI scheme that you entered on the [Tracking Link]>[Deep Links] page in the Airbridge dashboard into the Android URI Scheme field. The App Name value in the SDK settings will be used to set up the App Links automatically.

    • When the Airbridge Deep Link is executed, it is converted into a scheme deep link and passed to the onDeeplinkReceived callback. And if a deep link that is not an Airbridge Deep Link is executed, it is passed to the callback without being converted.

    • Use the received deep link to redirect the user to the intended destination.

    1. Navigate to Content Browser > Add/Import > New C++ Class... and specify the parent class as Game Mode Base to create a Game Mode Base class.

    2. Proceed with the deep link callback setup through the following method in the source code of the created Game Mode Base class.

    ExampleGameModeBase.cpp
    1234567891011121314
    ...
    #include "AirbridgeUnreal.h"
    
    void AExampleGameModeBase::BeginPlay()
    {
        ...
        
        FAirbridge::SetOnDeeplinkReceived([](const FString& Url)
        {
            // show proper content using url
        });
    
        ...
    }

    3. In the Unreal Editor Project Settings window, navigate to Project > Maps & Modes > Default Modes and set the Default GameMode field value as the game mode after the deep link callback setup is completed.

    Set up deferred deep linking

    When a user clicks on a tracking link with deferred deep linking capabilities and the app is not installed on the device, the Airbridge SDK collects the deep link as follows.

    After initialization, the Airbridge SDK attempts to collect a deep link when all of the following conditions are met. When the app is closed before collection, the Airbridge SDK considers it as if there has not been an Airbridge Deep Link.

    • The FAirbridge::StartTracking function is called with the opt-in settings in place. Or, opt-in has not been set.

    • The user's response to the ATT prompt has been determined. Or, the event collection delay time configured regarding the ATT prompt has expired.

    Deferred deep links are automatically passed to onDeeplinkReceived callback, so no additional settings are required.

    Set up custom domain

    Attention

    Optional settings. Configure only if necessary.

    1. Enter the custom domain address into the Airbridge dashboard by referring to this article

    2. In the SDK Settings, enter the custom domain address in the Custom Domain.

      Attention

      The custom domain address you add to the SDK should be the same as the custom domain address entered into the Airbridge dashboard.

    In-app events

    The Airbridge SDK collects user actions from the app as per settings and sends them as in-app events.

    Send in-app events

    Setting up a Hybrid App

    You can set up the Unreal SDK to handle Airbridge-related work occurring on in-app websites in hybrid apps without changing the website code.

    The Airbridge.TrackEvent function must be called to send events. Refer to the information below about the required Airbridge.TrackEvent function components and their types.

    12345
    static void TrackEvent(
    	const FString& Category,
    	const UAirbridgeMap* SemanticAttributes = nullptr,
    	const UAirbridgeMap* CustomAttributes = nullptr
    );

    Name

    Required

    Type

    Description

    category

    Required

    String

    Name of the event

    semanticAttributes

    Optional

    UAirbridgeMap

    Semantic attributes of events

    customAttributes

    Optional

    UAirbridgeMap

    Custom attributes of events

    Refer to the component definition and available strings below.

    The Standard Event Categories provided by the Airbridge SDK can be found in the AirbridgeCategory. You can also enter the Event Categories from the list of Standard Events.

    Custom events can be sent by entering the event name set in the event taxonomy.

    Refer to the example below.

    123456
    // track standard event (provided by sdk)
    FAirbridge::TrackEvent(AirbridgeCategory::ORDER_COMPLETED);
    // track standard event (not provided by sdk)
    FAirbridge::TrackEvent("airbridge.ecommerce.order.canceled");
    // track custom event
    FAirbridge::TrackEvent("eventViewed");

    Attention

    The Airbridge SDK v4 attributes differ from the previous version. The previous version's attributes do not include action, label, and value.

    Additional information about the event can be collected using attributes.

    • Action, Label: Collect information that can be used as GroupBys in the Airbridge reports

    • Value: Collect information that can be used for sales analysis. Airbridge can perform calculations using the collected data.

    • Semantic Attribute: Collect predefined attributes by Airbridge.

    • Custom Attributes: Collect attributes defined by Airbridge users.

    In the FAirbridge::TrackEvent function, you can enter Action, Label, Value, and Semantic Attributes using the semanticAttributes parameter and Custom Attributes using the customAttributes parameter.

    The semantic attributes predefined by Airbridge can be found in the user guide below.

    Please refer to the example below.

    123456789101112131415161718192021
    UAirbridgeList* Products = UAirbridgeList::CreateObject();
    UAirbridgeMap* PlasticHammer = UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::PRODUCT_ID, 12345);
    Products->Add(PlasticHammer);
    
    UAirbridgeMap *SemanticAttributes = UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::ACTION, "Tool")
        ->Set(AirbridgeAttribute::LABEL, "Hammer")
        ->Set(AirbridgeAttribute::VALUE, 10)
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS, Products)
        ->Set("totalQuantity", 1);
    
    UAirbridgeMap *CustomAttributes = UAirbridgeMap::CreateObject()
        ->Set("promotion", "FirstPurchasePromotion")
    
    FAirbridge::TrackEvent(
        "airbridge.ecommerce.order.canceled",
        SemanticAttributes,
        CustomAttributes
    );

    Attention

    Semantic attributes and custom attributes only allow JSON as a data type.

    • JSON types: String, Number, Boolean, Object<String, JSON>, Array<JSON>

    • Types that cannot be used in semantic attributes and custom attributes: Struct, Class, etc.

    The standard event categories and semantic attributes provided by the SDK are as follows.

    Key

    Data

    SIGN_UP

    airbridge.user.signup

    SIGN_IN

    airbridge.user.signin

    SIGN_OUT

    airbridge.user.signout

    HOME_VIEWED

    airbridge.ecommerce.home.viewed

    PRODUCT_LIST_VIEWED

    airbridge.ecommerce.productList.viewed

    SEARCH_RESULTS_VIEWED

    airbridge.ecommerce.searchResults.viewed

    PRODUCT_VIEWED

    airbridge.ecommerce.product.viewed

    ADD_PAYMENT_INFO

    airbridge.addPaymentInfo

    ADD_TO_WISHLIST

    airbridge.addToWishlist

    ADDED_TO_CART

    airbridge.ecommerce.product.addedToCart

    INITIATE_CHECKOUT

    airbridge.initiateCheckout

    ORDER_COMPLETED

    airbridge.ecommerce.order.completed

    ORDER_CANCELED

    airbridge.ecommerce.order.canceled

    START_TRIAL

    airbridge.startTrial

    SUBSCRIBE

    airbridge.subscribe

    UNSUBSCRIBE

    airbridge.unsubscribe

    AD_IMPRESSION

    airbridge.adImpression

    AD_CLICK

    airbridge.adClick

    COMPLETE_TUTORIAL

    airbridge.completeTutorial

    ACHIEVE_LEVEL

    airbridge.achieveLevel

    UNLOCK_ACHIEVEMENT

    airbridge.unlockAchievement

    RATE

    airbridge.rate

    SHARE

    airbridge.share

    SCHEDULE

    airbridge.schedule

    SPEND_CREDITS

    airbridge.spendCredits

    Key

    Data

    Data type

    ACTION

    action

    string

    LABEL

    label

    string

    VALUE

    value

    float

    CURRENCY

    currency

    string

    PRODUCTS

    products

    array

    PRODUCT_ID

    productID

    string

    PRODUCT_NAME

    name

    string

    PRODUCT_PRICE

    price

    float

    PRODUCT_QUANTITY

    quantity

    int

    PRODUCT_CURRENCY

    currency

    string

    PRODUCT_POSITION

    position

    int

    PRODUCT_CATEGORY_ID

    categoryID

    string

    PRODUCT_CATEGORY_NAME

    categoryName

    string

    PRODUCT_BRAND_ID

    brandID

    string

    PRODUCT_BRAND_NAME

    brandName

    string

    PERIOD

    period

    string

    IS_RENEWAL

    isRenewal

    boolean

    RENEWAL_COUNT

    renewalCount

    int

    PRODUCT_LIST_ID

    productListID

    string

    CART_ID

    cartID

    string

    TRANSACTION_ID

    transactionID

    string

    TRANSACTION_TYPE

    transactionType

    string

    TRANSACTION_PAIRED_EVENT_CATEGORY

    transactionPairedEventCategory

    string

    TRANSACTION_PAIRED_EVENT_TIMESTAMP

    transactionPairedEventTimestamp

    int

    TOTAL_QUANTITY

    totalQuantity

    int

    QUERY

    query

    string

    IN_APP_PURCHASED

    inAppPurchased

    boolean

    CONTRIBUTION_MARGIN

    contributionMargin

    float

    LIST_ID

    listID

    string

    RATE_ID

    rateID

    string

    RATE

    rate

    float

    MAX_RATE

    maxRate

    float

    ACHIEVEMENT_ID

    achievementID

    string

    SHARED_CHANNEL

    sharedChannel

    string

    DATE_TIME

    datetime

    string

    DESCRIPTION

    description

    string

    IS_REVENUE

    isRevenue

    boolean

    PLACE

    place

    string

    SCHEDULE_ID

    scheduleID

    string

    TYPE

    type

    string

    LEVEL

    level

    string

    SCORE

    score

    float

    AD_PARTNERS

    adPartners

    array

    IS_FIRST_PER_USER

    isFirstPerUser

    boolean

    Refer to the example codes for each type of data below.

    1234567891011
    FAirbridge::TrackEvent(
        "event",
        UAirbridgeMap::CreateObject()
            ->Set(AirbridgeAttribute::VALUE, 10),
        UAirbridgeMap::CreateObject()
            ->Set("string", "string")
            ->Set("number", 1000)
            ->Set("boolean", true)
            ->Set("object", UAirbridgeMap::CreateObject()->Set("key", "value"))
            ->Set("array", UAirbridgeList::CreateObject()->Add("value"))
    );

    Additional in-app event settings

    Attention

    The default settings will apply if no additional settings are configured. Proceed after reviewing whether additional settings are necessary.

    Configure additional settings for sending in-app events if necessary.

    The Airbridge SDK includes session information when sending event data.

    When the app moves to the background or the process is terminated, the background entry time is recorded. When the app returns to the foreground or the process is restarted, the re-entry time is recorded. If the time difference between the last background entry and re-entry exceeds the session timeout, the previous session ends and a new session begins.

    The default session timeout is 300 seconds (5 minutes). In the SDK settings, you can configure Session Timeout Seconds up to 604,800 seconds (7 days).

    Attention

    The Airbridge SDK collects Open events and Foreground events that initiate a new session. However, those events are not collected during a session. To collect them while the session is being maintained, additional settings are required.

    The default transmission interval is set to 0 seconds. In the SDK settings, you can adjust Event Transmit Interval Seconds to modify it to a maximum of 86,400 seconds (1 day).

    The following table shows the default and maximum values for the number of events and storage size.

    Number of Events

    Storage Size

    Default Value

    INT_MAX

    1024 GiB

    Maximum Value Allowed

    INT_MAX

    1024 GiB

    In the SDK settings, If you want to limit the number of events the SDK stores, use the Buffer Count Limit, and to limit the storage size of the SDK, use the Event Buffer Size Limit In Gibibyte.

    When the event deletion option is activated, all in-app events that are not transmitted during the Airbridge SDK's initialization process are deleted. By default, the event deletion option is inactive.

    In the SDK settings, set Clear Event Buffer On Initialize Enabled to true to activate the event deletion option.

    The Airbridge SDK supports functions to include device identifiers in all events for transmission.

    Function

    Description

    FAirbridge::SetDeviceAlias

    Adds additional device identifiers. Up to 10 identifiers can be entered.

    - Key: Maximum 128 characters. It must satisfy the regular expression ^[a-zA-Z_][a-zA-Z0-9_]*$.

    - Value: Maximum 128 characters.

    FAirbridge::RemoveDeviceAlias

    Deletes only specified device identifiers.

    FAirbridge::ClearDeviceAlias

    Deletes all device identifiers.

    Refer to the example below.

    123
    FAirbridge::SetDeviceAlias("string", "string");
    FAirbridge::RemoveDeviceAlias("string");
    FAirbridge::ClearDeviceAlias();

    Example Codes

    Airbridge collects in-app events that are classified as Standard Events and Custom Events. Standard Events are events predefined by Airbridge. Refer to the example codes below.

    Sign Up

    1234567
    FAirbridge::SetUserID("string");
    FAirbridge::SetUserAlias("string", "string");
    FAirbridge::SetUserEmail("string");
    FAirbridge::SetUserPhone("string");
    FAirbridge::SetUserAttribute("string", "string");
    	
    FAirbridge::TrackEvent(AirbridgeCategory::SIGN_UP);

    Sign In

    1234567
    FAirbridge::SetUserID("string");
    FAirbridge::SetUserAlias("string", "string");
    FAirbridge::SetUserEmail("string");
    FAirbridge::SetUserPhone("string");
    FAirbridge::SetUserAttribute("string", "string");
    	
    FAirbridge::TrackEvent(AirbridgeConstant::AirbridgeCategory::SIGN_IN);

    Sign Out

    123
    FAirbridge::TrackEvent(AirbridgeCategory::SIGN_OUT);
    	
    FAirbridge::ClearUser();

    Home viewed

    1
    FAirbridge::TrackEvent(AirbridgeCategory::HOME_VIEWED);

    Product list viewed

    12345678910111213141516171819202122232425
    FAirbridge::TrackEvent(
        AirbridgeCategory::PRODUCT_LIST_VIEWED,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::LIST_ID, "84e6e236-38c4-48db-9b49-16e4cc064386")
        ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "d6ab2fbe-decc-4362-b719-d257a131e91e")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticFork")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 1)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Search result viewed

    12345678910111213141516171819202122232425
    FAirbridge::TrackEvent(
        AirbridgeCategory::SEARCH_RESULTS_VIEWED,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::QUERY, "Plastic")
        ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "d6ab2fbe-decc-4362-b719-d257a131e91e")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticFork")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 1)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Product viewed

    12345678910111213141516
    FAirbridge::TrackEvent(
        AirbridgeCategory::PRODUCT_VIEWED,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Add payment info

    12345
    FAirbridge::TrackEvent(
        AirbridgeCategory::ADD_PAYMENT_INFO,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::TYPE, "CreditCard")
    );

    Add to wishlist

    1234567891011121314151617
    FAirbridge::TrackEvent(
        AirbridgeCategory::ADD_TO_WISHLIST,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::LIST_ID, "189a2f8b-83ee-4074-8158-726be54e57d4")
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Add to cart

    1234567891011121314151617
    FAirbridge::TrackEvent(
    	AirbridgeCategory::ADDED_TO_CART,
    	UAirbridgeMap::CreateObject()
    	->Set(:AirbridgeAttribute::CART_ID, "421eaeb7-6e80-4694-933e-f2e1a55e9cbd")
    	->Set(AirbridgeAttribute::CURRENCY, "USD")
    	->Set(AirbridgeAttribute::PRODUCTS,
    		UAirbridgeList::CreateObject()
    		->Add(
    			UAirbridgeMap::CreateObject()
    			->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
    			->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
    			->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
    			->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
    			->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
    		)
    	)
    );

    Initiate checkout

    12345678910111213141516171819202122232425
    FAirbridge::TrackEvent(
        AirbridgeCategory::INITIATE_CHECKOUT,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::TRANSACTION_ID, "0a7ee1ec-33da-4ffb-b775-89e80e75978a")
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "d6ab2fbe-decc-4362-b719-d257a131e91e")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticFork")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 1)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Order completed

    123456789101112131415161718192021222324252627
    FAirbridge::TrackEvent(
        AirbridgeCategory::ORDER_COMPLETED,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::VALUE, 11)
        ->Set(AirbridgeAttribute::TRANSACTION_ID, "8065ef16-162b-4a82-b683-e51aefdda7d5")
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::IN_APP_PURCHASED, true)
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "d6ab2fbe-decc-4362-b719-d257a131e91e")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticFork")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 1)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Order canceled

    123456789101112131415161718192021222324252627
    FAirbridge::TrackEvent(
        AirbridgeCategory::ORDER_CANCELED,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::VALUE, 11)
        ->Set(AirbridgeAttribute::TRANSACTION_ID, "8065ef16-162b-4a82-b683-e51aefdda7d5")
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::IN_APP_PURCHASED, true)
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "d6ab2fbe-decc-4362-b719-d257a131e91e")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticFork")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 1)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Start trial

    1234567891011121314151617
    FAirbridge::TrackEvent(
        AirbridgeCategory::START_TRIAL,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::TRANSACTION_ID, "ef1e5271-0370-407c-b1e9-669a8df1dc2c")
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PERIOD, "P1M")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "306a57cb-f653-4220-a208-8405d8e4d506")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "MusicStreamingMembership")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 15)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Subscribe

    12345678910111213141516171819
    FAirbridge::TrackEvent(
        AirbridgeCategory::SUBSCRIBE,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::VALUE, 15)
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::TRANSACTION_ID, "cbe718c7-e44e-4707-b5cd-4a6a29f29649")
        ->Set(AirbridgeAttribute::PERIOD, "P1M")
        ->Set(AirbridgeAttribute::IS_RENEWAL, true)
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "306a57cb-f653-4220-a208-8405d8e4d506")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "MusicStreamingMembership")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 15)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Unsubscribe

    123456789101112131415161718
    FAirbridge::TrackEvent(
        AirbridgeCategory::UNSUBSCRIBE,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::VALUE, 15)
        ->Set(AirbridgeAttribute::CURRENCY, "USD")
        ->Set(AirbridgeAttribute::TRANSACTION_ID, "cbe718c7-e44e-4707-b5cd-4a6a29f29649")
        ->Set(AirbridgeAttribute::IS_RENEWAL, true)
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "306a57cb-f653-4220-a208-8405d8e4d506")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "MusicStreamingMembership")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 15)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Add impression

    123456789101112131415161718192021222324252627
    FAirbridge::TrackEvent(
        AirbridgeCategory::AD_IMPRESSION,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::VALUE, 0.01)
        ->Set(AirbridgeAttribute::AD_PARTNERS, 
            UAirbridgeMap::CreateObject()
            ->Set("mopub",
                UAirbridgeMap::CreateObject()
                ->Set("app_version", "5.18.0")
                ->Set("adunit_id", "12345")
                ->Set("adunit_name", "12345")
                ->Set("adunit_format", "Banner")
                ->Set("id", "12345")
                ->Set("currency", "USD")
                ->Set("publisher_revenue", 12345.123)
                ->Set("adgroup_id", "12345")
                ->Set("adgroup_name", "12345")
                ->Set("adgroup_type", "12345")
                ->Set("adgroup_priority", "12345")
                ->Set("country", "kr")
                ->Set("precision", "publisher_defined")
                ->Set("network_name", "12345")
                ->Set("network_placement_id", "12345")
                ->Set("demand_partner_data", "12345")
            )
        )
    );

    Ad click

    123456789101112131415161718192021222324252627
    FAirbridge::TrackEvent(
        AirbridgeCategory::AD_CLICK,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::VALUE, 0.01)
        ->Set(AirbridgeAttribute::AD_PARTNERS, 
            UAirbridgeMap::CreateObject()
            ->Set("mopub",
                UAirbridgeMap::CreateObject()
                ->Set("app_version", "5.18.0")
                ->Set("adunit_id", "12345")
                ->Set("adunit_name", "12345")
                ->Set("adunit_format", "Banner")
                ->Set("id", "12345")
                ->Set("currency", "USD")
                ->Set("publisher_revenue", 12345.123)
                ->Set("adgroup_id", "12345")
                ->Set("adgroup_name", "12345")
                ->Set("adgroup_type", "12345")
                ->Set("adgroup_priority", "12345")
                ->Set("country", "kr")
                ->Set("precision", "publisher_defined")
                ->Set("network_name", "12345")
                ->Set("network_placement_id", "12345")
                ->Set("demand_partner_data", "12345")
            )
        )
    );

    Complete tutorial

    12345
    FAirbridge::TrackEvent(
        AirbridgeCategory::COMPLETE_TUTORIAL,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::DESCRIPTION, "Finish Initial Tutorial")
    );

    Achieve level

    12345
    FAirbridge::TrackEvent(
        AirbridgeCategory::ACHIEVE_LEVEL,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::LEVEL, 13)
    );

    Unlock achievement

    1234567
    FAirbridge::TrackEvent(
        AirbridgeCategory::UNLOCK_ACHIEVEMENT,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::ACHIEVEMENT_ID, "36a0f0bb-b153-4be1-a3e0-3cb5b2b076c1")
        ->Set(AirbridgeAttribute::DESCRIPTION, "Get Score Over 50")
        ->Set(AirbridgeAttribute::SCORE, 80)
    );

    Rate

    12345678910111213141516171819
    FAirbridge::TrackEvent(
        AirbridgeCategory::RATE,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::RATE_ID, "531c64b3-4704-4780-a306-89014ec18daf")
        ->Set(AirbridgeAttribute::RATE, 4.5)
        ->Set(AirbridgeAttribute::MAX_RATE, 5)
        ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Share

    123456
    FAirbridge::TrackEvent(
        AirbridgeCategory::SHARE,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::DESCRIPTION, "Share Promotion")
        ->Set(AirbridgeAttribute::SHARED_CHANNEL, "CopyLink")
    );

    Schedule

    123456789101112131415
    FAirbridge::TrackEvent(
        AirbridgeCategory::SCHEDULE,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::SCHEDULE_ID, "75712915-2cd9-4e42-a85e-8d42f356f4c6")
        ->Set(AirbridgeAttribute::DATE_TIME, "2024-01-01T00:00:00+00:00")
        ->Set(AirbridgeAttribute::PLACE, "ConferenceRoom")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "abb3e65d-17bc-4b28-89e3-5e356c0ea697")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "ConferenceRoom")
            )
        )
    );

    Spend credits

    1234567891011121314151617
    FAirbridge::TrackEvent(
        AirbridgeCategory::SPEND_CREDITS,
        UAirbridgeMap::CreateObject()
        ->Set(AirbridgeAttribute::TRANSACTION_ID, "22eb193d-be11-4fe4-95da-c91a196faf1c")
        ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
        ->Set(AirbridgeAttribute::PRODUCTS,
            UAirbridgeList::CreateObject()
            ->Add(
                UAirbridgeMap::CreateObject()
                ->Set(AirbridgeAttribute::PRODUCT_ID, "0117b32a-5a6c-4d4c-b64c-7858e07dba78")
                ->Set(AirbridgeAttribute::PRODUCT_NAME, "PlasticHammer")
                ->Set(AirbridgeAttribute::PRODUCT_PRICE, 10)
                ->Set(AirbridgeAttribute::PRODUCT_QUANTITY, 1)
                ->Set(AirbridgeAttribute::PRODUCT_CURRENCY, "USD")
            )
        )
    );

    Custom Events are events defined by Airbridge users to track user actions that are unique to their services. Refer to the example code below.

    1234567891011
    FAirbridge::TrackEvent(
        "event",
        UAirbridgeMap::CreateObject()
            ->Set(AirbridgeAttribute::VALUE, 10),
        UAirbridgeMap::CreateObject()
            ->Set("string", "string")
            ->Set("number", 1000)
            ->Set("boolean", true)
            ->Set("object", UAirbridgeMap::CreateObject()->Set("key", "value"))
            ->Set("array", UAirbridgeList::CreateObject()->Add("value"))
    );

    User Data

    Airbridge sends user data along with events. User data allows for a more accurate ad performance measurement.

    Set User ID

    User IDs refer to the user identifier used in a service. User IDs should be unique IDs that can identify unique users across websites and apps.

    #{"width":"140px"}

    Function

    #{"width":"240px"}

    Description

    FAirbridge::SetUserID

    Inputs the user ID.

    FAirbridge::ClearUserID

    Deletes the user ID.

    FAirbridge::SetUserAlias

    Adds additional user identifiers. Up to 10 items can be added.

    - key: Up to 128 characters. Must follow the regular expression ^[a-zA-Z_][a-zA-Z0-9_]*$.

    - value: Up to 1024 characters.

    FAirbridge::RemoveUserAlias

    Deletes only specified identifiers.

    FAirbridge::ClearUserAlias

    Deletes all additional user identifiers.

    Refer to the example below.

    1234567
    // ID
    FAirbridge::SetUserID("testID");
    
    // Alias
    FAirbridge::SetUserAlias("ADD_YOUR_KEY", "ADD_YOUR_VALUE");
    FAirbridge::RemoveUserAlias("DELETE_THIS_KEY");
    FAirbridge::ClearUserAlias();

    Send additional user information

    Attention

    Sensitive user information may be included. Send after a thorough review with a legal advisor.

    Refer to the functions below to send additional user information.

    #{"width":"140px"}

    Function

    #{"width":"240px"}

    Description

    FAirbridge::SetUserEmail

    Inputs user's email. The data is hashed using SHA256.

    FAirbridge::ClearUserEmail

    Deletes the user email.

    FAirbridge::SetUserPhone

    Inputs user's phone number. The data is hashed using SHA256.

    FAirbridge::ClearUserPhone

    Deletes the user's phone number.

    FAirbridge::SetUserAttribute

    Adds additional user attributes. Up to 100 items can be added.

    - key: Up to 128 characters. Must satisfy the regular expression: ^[a-zA-Z_][a-zA-Z0-9_]*$.

    - value: Only supports string, number, and Boolean types. Up to 1024 characters.

    FAirbridge::RemoveUserAttribute

    Deletes only specified attributes from the additional attributes.

    FAirbridge::ClearUserAttributes

    Deletes all additional user attributes.

    Refer to the example below.

    1234567891011121314
    // Automatically hashed on client side using SHA256
    // Can turn off hashing feature with special flag
    FAirbridge::SetUserEmail("testID@ab180.co");
    FAirbridge::SetUserPhone("821012341234");
    
    // Attributes
    FAirbridge::SetUserAttribute("ADD_YOUR_KEY", 1);
    FAirbridge::SetUserAttribute("ADD_YOUR_KEY", 1L);
    FAirbridge::SetUserAttribute("ADD_YOUR_KEY", 1f);
    FAirbridge::SetUserAttribute("ADD_YOUR_KEY", 1.0);
    FAirbridge::SetUserAttribute("ADD_YOUR_KEY", "1");
    FAirbridge::SetUserAttribute("ADD_YOUR_KEY", true);
    FAirbridge::RemoveUserAttribute("DELETE_THIS_KEY");
    FAirbridge::ClearUserAttributes();

    Hash user information

    When User Info Hash Enabled is set to false in the SDK settings, user emails and phone numbers are passed without being hashed. The default setting is true.

    Reset User Information

    You can initialize user information with the FAirbridge::ClearUser function.

    Attention

    Optional settings. Configure only if necessary.

    Include User Information in Install/Open Events

    The SDK automatically sends install and open events immediately after the app launches. Therefore, if you call user information functions right after the app launches, the user information may not be included in the install/open events depending on the event transmission timing.

    To ensure user information is included in install/open events, control the timing of event transmission through Opt-In setup.

    Implement in the following order:

    1. Set the Auto Start Tracking Enabled option to false when Configure SDK settings.

    2. Call user information functions to set user information.

    3. Call the startTracking() function to start event collection.

    Additional SDK Settings

    Follow the instructions below for additional setup.

    Attention

    Optional settings. Configure only if necessary.

    Calculating SKAdNetwork Conversion Value on the Server

    By default, the ConversionValue in SKAdNetwork is calculated using the values from the SDK. If you want to measure events collected server-side through SKAN instead of the SDK, set the calculateSKAdNetworkByServerEnabled option to true.

    Attention

    If you are currently using conversion values calculated by the SDK via SKAdNetwork, please exercise caution when making changes. Altering the conversion value calculation method may cause inconsistencies between existing and new data.

    SDK settings by build settings

    Note

    Airbridge Unreal SDK 4.5.0 or later is required.

    You can apply different SDK settings per build setting.

    Activate the Use Development Airbridge Settings or Use Production Airbridge Settings option, depending on your build setting to configure the SDK accordingly.

    If the Use Development Airbridge Settings or Use Production Airbridge Settings option is inactive, the SDK settings are set to the Default settings.

    • When the Use Development Airbridge Settings is activated and your app is on development Debug, Development, or Test setting, the SDK settings are set to the Development settings.

    • When the Use Production Airbridge Settings is activated and your app is on production Shipping setting, the SDK settings are set to the Production settings.

    Integrate Google's ICM attribution data

    Attention

    React Native SDK v.4.4.0 or later is required.

    Integrated Conversion Measurement (ICM) is Google’s privacy-driven solution for filling in conversion tracking gaps caused by stricter tracking limitations. Google provides the ICM attribution data, which is the non-deterministic attribution data provided by Google's privacy-preserving conversion modeling.

    To integrate the ICM attribution data, the Google's On-Device Conversion Measurement (ODM) SDK must be installed. For detailed information, refer to this article. or contact Google.

    Airbridge Unreal SDK v.4.3.0 or later is required.

    Tracking links are links that are embedded to ads for data collection. When users click on the ad, the tracking link is used to pass the touchpoint data to Airbridge, allowing for ad attribution.

    Also, users who click on the ad with a tracking link can be redirected to a specific destination.

    Use the CreateTrackingLink function to create tracking links. Refer to the code examples and the parameter details below.

    c++
    123456
    void FAirbridge::CreateTrackingLink(
        const FString& Channel,
        const UAirbridgeMap* Option,
        const AirbridgeTrackingLinkParamFunction& OnSuccess,
        const AirbridgeStringParamFunction& OnFailure
    )

    Name

    Required or Optional

    Type

    Description

    Channel

    필수

    FString

    The ad channel the tracking link is used

    Option

    필수

    UAirbridgeMap*

    Options for creating tracking links

    OnSuccess

    필수

    TFunction<void(const FAirbridgeTrackingLink&)>

    Success callback

    OnFailure

    선택

    TFunction<void(const FString&)>

    Fail callback

    Use the Option parameter in the CreateTrackingLink function to configure tracking link options.

    Key

    Type

    Description

    AirbridgeTrackingLinkOption::CAMPAIGN

    String

    The campaign credited with the winning touchpoint or conversion.

    AirbridgeTrackingLinkOption::AD_GROUP

    String

    The ad group credited with the winning touchpoint or conversion.

    AirbridgeTrackingLinkOption::AD_CREATIVE

    String

    The ad creative credited with the winning touchpoint or conversion.

    AirbridgeTrackingLinkOption::CONTENT

    String

    The content credited with the winning touchpoint or conversion.

    AirbridgeTrackingLinkOption::TERM

    String

    The search term credited with the winning touchpoint or conversion.

    AirbridgeTrackingLinkOption::SUB_ID

    String

    The sub publisher that generated the touchpoint.
    Sub media values are usually provided by predefined "integrated" channels.

    AirbridgeTrackingLinkOption::SUB_ID_1

    String

    The 1st level sub-sub publisher that generated the touchpoint.
    Sub media values are usually provided by predefined "integrated" channels.

    AirbridgeTrackingLinkOption::SUB_ID_2

    String

    The 2nd level sub-sub publisher that generated the touchpoint.
    Sub media values are usually provided by predefined "integrated" channels.

    AirbridgeTrackingLinkOption::SUB_ID_3

    String

    The 3rd level sub-sub publisher that generated the touchpoint.
    Sub media values are usually provided by predefined "integrated" channels.

    AirbridgeTrackingLinkOption::DEEPLINK_URL

    (Custom Scheme URL String)

    Deeplink URL

    AirbridgeTrackingLinkOption::DEEPLINK_STOPOVER

    Boolean

    Deeplink 의 스탑오버 기능 활성화 여부
    true : 활성화
    false : 비활성화

    AirbridgeTrackingLinkOption::FALLBACK_IOS

    ("store" | Web URL String)

    ios fallback when app is not installed

    AirbridgeTrackingLinkOption::FALLBACK_ANDROID

    ("store" | Web URL String)

    android fallback when app is not installed

    AirbridgeTrackingLinkOption::FALLBACK_DESKTOP

    (Web URL String)

    desktop fallback when app is not installed

    AirbridgeTrackingLinkOption::FALLBACK_IOS_STORE_PPID

    String

    he ppid for the Custom Product Page in the Apple App Store.

    Enable the custom product page to be shown when landing in the App Store.

    AirbridgeTrackingLinkOption::FALLBACK_ANDROID_STORE_LISTING

    String

    The Custom Store Listing listing value for the Google Play Store.

    Enables the display of your custom store listing when landing on the Google Play Store.

    AirbridgeTrackingLinkOption::OGTAG_TITLE

    String

    og:title for tracking link

    AirbridgeTrackingLinkOption::OGTAG_DESCRIPTION

    String

    og:description for tracking link

    AirbridgeTrackingLinkOption::OGTAG_IMAGE_URL

    (Web URL String)

    og:image for tracking link

    AirbridgeTrackingLinkOption::OGTAG_WEBSITE_CRAWL

    ("desktop")

    A customization of link-preview.. Airbridge crawl og-tag from response of FALLBACK_DESKTOP.
    The values set for title, description, and imageUrl are ignored.

    AirbridgeTrackingLinkOption::CUSTOM_SHORT_ID

    String

    Configure the short ID of tracking links depending on your campaign or contents.
    If not passed, a random short ID will be generate, and can not be changed once generated.

    AirbridgeTrackingLinkOption::IS_REENGAGEMENT

    ("off" | "on_true" | "on_false")

    Configure the Re-engagement parameter. The Re-engagement parameter has three options.
    off: OFF is the default setting. The touchpoint can be attributed to both install events and post-install events (in-app events).
    on_true: ON-TRUE is used for re-engagement campaigns for installed users. The touchpoint generated by the tracking link is attributed only to the deeplink open and the following in-app events, not to the install event.
    on_false: ON-FALSE is used for user acquisition campaigns targeting uninstalled users. The touchpoint generated by the tracking link is attributed only to the install event and the following in-app events, not to the 'deeplink open' event.

    Use the OnSuccess callback in the CreateTrackingLink function to pass the FAirbridgeTrackingLink.

    c++
    12345
    struct FAirbridgeTrackingLink
    {
        FString ShortURL;
        FString QrcodeURL;
    };

    Name

    Type

    Description

    ShortURL

    FString

    The short URL of the tracking link

    QrcodeURL

    FString

    The QR code URL of the tracking link

    Refer to the example codes below.

    c++
    1234567891011121314151617
    FAirbridge::CreateTrackingLink(
        TEXT("test_channel"),
        UAirbridgeMap::CreateObject()
            ->Set(AirbridgeTrackingLinkOption::CAMPAIGN, TEXT("test_campaign"))
            ->Set(AirbridgeTrackingLinkOption::DEEPLINK_URL, TEXT("YOUR_SCHEME://..."))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_IOS, TEXT("store"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_ANDROID, TEXT("store"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_DESKTOP, TEXT("https://example.com/")),
        [](const FAirbridgeTrackingLink& TrackingLink)
        {
    
        },
        [](const FString& Error)
        {
            
        }
    );

    c++
    1234567891011121314151617
    FAirbridge::CreateTrackingLink(
        TEXT("test_channel"),
        UAirbridgeMap::CreateObject()
            ->Set(AirbridgeTrackingLinkOption::CAMPAIGN, TEXT("test_campaign"))
            ->Set(AirbridgeTrackingLinkOption::DEEPLINK_URL, TEXT("sample://home"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_IOS, TEXT("https://example.com/"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_ANDROID, TEXT("https://example.com/"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_DESKTOP, TEXT("https://example.com/")),
        [](const FAirbridgeTrackingLink& TrackingLink)
        {
    
        },
        [](const FString& Error)
        {
            
        }
    );

    c++
    12345678910111213141516
    FAirbridge::CreateTrackingLink(
        TEXT("test_channel"),
        UAirbridgeMap::CreateObject()
            ->Set(AirbridgeTrackingLinkOption::CAMPAIGN, TEXT("test_campaign"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_IOS, TEXT("store"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_ANDROID, TEXT("store"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_DESKTOP, TEXT("https://example.com/")),
        [](const FAirbridgeTrackingLink& TrackingLink)
        {
    
        },
        [](const FString& Error)
        {
            
        }
    );

    c++
    12345678910111213141516
    FAirbridge::CreateTrackingLink(
        TEXT("test_channel"),
        UAirbridgeMap::CreateObject()
            ->Set(AirbridgeTrackingLinkOption::CAMPAIGN, TEXT("test_campaign"))
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_IOS, TEXT("https://example.com/")),
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_ANDROID, TEXT("https://example.com/")),
            ->Set(AirbridgeTrackingLinkOption::FALLBACK_DESKTOP, TEXT("https://example.com/")),
        [](const FAirbridgeTrackingLink& TrackingLink)
        {
    
        },
        [](const FString& Error)
        {
            
        }
    );

    The deep links passed through the AFAirbridge::SetOnDeeplinkReceived method of the Airbridge Unreal SDK include not only Airbridge Deep Links but also deep links from other solutions.

    ExampleGameModeBase.cpp
    1234567891011121314
    ...
    #include "AirbridgeUnreal.h"
    
    void AExampleGameModeBase::BeginPlay()
    {
        ...
        
        FAirbridge::SetOnDeeplinkReceived([](const FString& Url)
        {
            // show proper content using url
        });
    
        ...
    }

    By setting Is Handle Airbridge Deeplink Only to true in the SDK settings, only Airbridge Deep Links will be passed to the onDeeplinkReceived callback. In this way, you can handle the deep links from other solutions separately from the Airbridge Deep Links.

    Depending on how the link is opened, it may be difficult to properly utilize the app's tracking link in-app.

    The FAirbridge::Click function or FAirbridge::Impression function allows you to utilize tracking links normally, bypassing the external browser.

    When a user clicks on the tracking link in the app, call the FAirbridge::Click function. Depending on the tracking link settings, the scheme deep link is passed, or the user is redirected to the app store or website.

    123456789101112
    FAirbridge::Click(
        "https://abr.ge/~~~",
        []()
        {
            // when url is tracking link and succeed
        },
        [](const FString& Error)
        {
            // when url is tracking link and failed
            // example: url is another app's tracking link, internet is not connected
        }
    );

    When a user is impressed to the tracking link, call the FAirbridge::Impression function. Calling this function collects Impression event data.

    123456789101112
    FAirbridge::Impression(
        "https://abr.ge/~~~",
        []()
        {
            // when url is tracking link and succeed
        },
        [](const FString& Error)
        {
            // when url is tracking link and failed
            // example: url is another app's tracking link, internet is not connected
        }
    );

    Attention

    When you set up the Airbridge SDK to use tracking links within apps, every time a tracking link is used within the app, Deeplink Pageviews are aggregated as Target Events. The deep link performance may be affected when Deeplink Pageviews occur frequently right after Deeplink Opens.

    The attribution window for Deeplink Pageviews is set to 3 days by default. If you want to change the attribution window for Deeplink Pageviews, contact your Airbridge CSM. If you don't have a designated CSM, contact the Airbridge Help Center.

    Get attribution results

    Attention

    It takes some time for the Airbridge SDK to collect attribution results. We do not recommend using attribution results for functionalities requiring real-time processing.

    You can receive attribution results for installation events through the FAirbridge::SetOnAttributionReceivedfunction.

    123456
    static void OnReceived(TMap<FString, FString> Attribution) {  }
    
    void SomeFunction() 
    { 
        FAirbridge::SetOnAttributionReceived(OnReceived);
    }

    The value is delivered as follows, depending on the existence of attribution results.

    If the attribution result exists, a dictionary including the values below will be passed to the callback. All keys provide the attribution data. For example, attributedChannel contains information about the ad channel to which the ad performance is attributed.

    The attribution results are passed to the callback within 1 minute after SDK initialization. If the app is closed before the attribution result is passed, the previous attribution results will be passed to the callback within 1 minute the next time the app is launched. Depending on network conditions and other factors, there may be a delay of up to 5 minutes.

    Key

    Type

    Description

    attributedChannel

    String

    Channel

    attributedCampaign

    String

    Campaign

    attributedAdGroup

    String

    Ad Group

    attributedAdCreative

    String

    Ad Creative

    attributedContent

    String

    Content

    attributedTerm

    String

    Keyword

    attributedSubPublisher

    String

    Sub Publisher

    attributedSubSubPublisher1

    String

    Sub Sub Publisher 1

    attributedSubSubPublisher2

    String

    Sub Sub Publisher 2

    attributedSubSubPublisher3

    String

    Sub Sub Publisher 3

    If there is no attribution result, the following dictionary will be sent to the callback. For this data to be passed, the app must be launched again at least 3 hours after the SDK initialization.

    123
    {
        "attributedChannel": "unattributed"
    }

    Attention

    Apply the code below using a custom iOS AppDelegate.

    After the push notification is clicked, you need to pass the deep link information in the payload to the Airbridge SDK to collect the deep link event. Set up the FAirbridge::trackDeeplink function.

    iOS

    Add the code below to your custom AppDelegate.

    123456789101112131415161718192021222324252627282930
    #import <Foundation/Foundation.h>
    #import <UIKit/UIKit.h>
    #import <Airbridge/Airbridge.h>
    #import <UserNotifications/UserNotifications.h>
    
    @interface SomeAppDelegate : NSObject <UIApplicationDelegate, UNUserNotificationCenterDelegate>
    
    @end
    
    @implementation SomeAppDelegate
    
    - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
        UIApplicationState state = UIApplication.sharedApplication.applicationState;
        if (state == UIApplicationStateInactive) {
            NSURL *url = // 푸시 알림 페이로드의 딥링크
            
            Airbridge.trackDeeplink(url)
        }
    }
    
    - (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)(void))completionHandler {
        UIApplicationState state = UIApplication.sharedApplication.applicationState;
        if ((state == UIApplicationStateInactive || state == UIApplicationStateBackground)
            && [response.actionIdentifier isEqualToString:UNNotificationDefaultActionIdentifier]) {
            NSURL *url = // 푸시 알림 페이로드의 딥링크
            
            Airbridge.trackDeeplink(url)
        }
    }
    
    12345678910
    #if PLATFORM_IOS
    #include "SomeAppDelegate.h"
    #endif 
    
    void SomeCpp::SomeCpp
    {
    #if PLATFORM_IOS
        [SomeAppDelegate load];
    #endif
    }

    The Airbridge SDK collects deep link events when the app is opened through a deep link, even if the deep link is not an Airbridge Deep Link. Configure Track Airbridge Link Only in the SDK settings to true to collect deep link events only if the app is opened through an Airbridge Deep Link and prevent unnecessary event collection.

    Collect in-session lifecycle events

    The Airbridge SDK collects Open and Foreground events that initiate a new session. These events are not collected during an ongoing session.

    By configuring the Track In Session Life Cycle Event Enabled in the SDK settings to true, the Open and Foreground events can be collected during ongoing sessions.

    All collected Foreground events are recorded as Open events.

    Compliance with Google DMA

    To comply with the Digital Markets Act (DMA), the user consent data must be sent to Airbridge. For more information about the DMA and whether it applies to your service, refer to the Airbridge user guide.

    Attention

    Advertisers must collect user consent data from all existing and new users in the EEA at least once starting March 6, 2024.

    If you are collecting user consent data using a consent management platform that complies with the Transparency and Consent Framework v2.2 protocol, refer to the following method to pass the user consent data to the Airbridge SDK.

    Note

    Airbridge Unreal SDK v.4.4.0 or later is required.

    1. In the SDK settings, set Collect TCF Data Enabled to true and Auto Start Tracking Enabled to false.

    2. After the user consent data is stored in the consent management platform, call the StartTracking function.

    1
    FAirbridge::StartTracking();

    For all other cases, refer to the following method.

    Note

    Airbridge cannot provide guidance on storing the user consent data and implementing the prompts. For assistance, consult legal professionals.

    1. Check the location of the users who launched the app. If their location is within the EEA, check whether the user consent data has been previously collected. If not, user consent data collection is not required.

    2. Configure the Auto Start Tracking Enabledin the SDK settings to false.

    3. If no user consent data has been collected previously, you may collect the data using a prompt or other means. The user consent data fields that need to be collected are adPersonalization, adUserData.

    After initializing the Airbridge SDK, send the user consent data and the user location data (eea) to the Airbridge SDK using the FAirbridge::SetDeviceAlias function.

    Unreal - Set Device Alias
    123456
    // Based on actual region
    FAirbridge::SetDeviceAlias("eea", "0" /* or "1" */);
    
    // Based on actual user consent
    FAirbridge::SetDeviceAlias("adPersonalization", "0" /* or "1" */);
    FAirbridge::SetDeviceAlias("adUserData", "0" /* or "1" */);

    Refer to the table below for the user consent data and the user location data that need to be sent to the Airbridge SDK. Note that the Airbridge field names listed in the table below must be used to successfully send data.

    #{"width":"80px"}

    에어브릿지 필드 이름

    #{"width":"80px"}

    구글 필드 이름

    #{"width":"160px"}

    설명

    eea

    <string>

    eea

    디지털 시장법 준수 지역 여부.

    - 0: 디지털 시장법 준수와 관계 없는 지역. EEA 지역에 해당하지 않음.

    - 1: 디지털 시장법 준수 지역. EEA 지역에 해당함.

    adPersonalization

    <string>

    ad_personalization

    개인 맞춤형 광고 제공을 위한 정보 수집에 대한 동의 여부.

    - 0: 유저가 정보 수집에 동의하지 않음.

    - 1: 유저가 정보 수집에 동의함.

    adUserData

    <string>

    ad_user_data

    유저 데이터를 구글에 전송하는 것에 대한 동의 여부.

    - 0: 유저가 전송에 동의하지 않음.

    - 1: 유저가 전송에 동의함.

    4. After the user consent data and the user location data are sent to the Airbridge SDK, call the StartTracking function.

    1
    FAirbridge::StartTracking();

    Follow the steps below to use deferred deep linking in Meta ads. The Airbridge SDK collects the Meta deferred app links before the Airbridge deferred deep links. If there are no Meta deferred app links, the Airbridge deferred deep links are collected.

    Note that Meta does not support Meta deferred app links for SKAdNetwork campaigns.

    1. Install the Facebook SDK. Refer to the Meta Ads Guide (iOS).

    2. Configure the Facebook Deferred App Link Enabled in the SDK settings to true.

    Initialize the Airbridge SDK with all functions disabled

    Attention

    If the SDK is not enabled immediately after the SDK initialization, the Install, Open, and Deeplink Openbvevents may not be collected.

    Upon initialization, all functions of the SDK are enabled by default. By configuring SDK Enabled in the SDK settings to false, the SDK can be initialized with all functions disabled.

    You can also check the activation status of the Airbridge SDK and enable or disable all functions, as in the following example.

    123
    FAirbridge::IsSDKEnabled();
    FAirbridge::EnableSDK();
    FAirbridge::DisableSDK();

    Set up Meta Install Referrer collection

    To collect the Meta Install Referrer, enter the Meta App ID as the key value for Meta Install Referrer (Facebook App ID) in the SDK settings.

    Note that the decryption key must be submitted to the Airbridge dashboard to read the decrypted Meta Install Referrer. Refer to this user guide to learn how to enter the decryption key.

    Set up uninstall tracking

    Airbridge sends a silent push every day between 3:00 PM and 4:00 PM (UTC) to users who performed an app event at least once in the last 6 months to check if the app has been deleted. You can check the uninstall event in the Airbridge reports and raw data export files.

    Refer to the article below for the detailed setup instructions.

    Integrate with third-party solutions

    An additional SDK setup is required to integrate with some third-party solutions. It is recommended that you complete this setup before collecting data with the Airbridge SDK.

    Refer to the articles listed below for integrating with third-party solutions.

    SDK logs

    The logs provided by the Airbridge SDK are categorized into Debug, Info, Warning, Error, and Fault levels. The Debug level is the least critical log, while the Fault level is the most critical log.

    By default, the Airbridge SDK provides logs at Warning, Error, and Fault levels. By entering a specific log level as the Log Level value in the SDK settings, the logs from that specified level up to the Fault level will be available.

    Was this helpful?

    Any questions or suggestions?