From b2018d804607fbfd6ad9946342a2cdabccb95dfa Mon Sep 17 00:00:00 2001 From: Dori Frost Date: Thu, 19 Sep 2024 16:01:49 +0300 Subject: [PATCH 1/2] Adrevenue - new article replacing the adrevenue connector --- docs/API.md | 23 +++--- docs/ad-revenue-unity.md | 153 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 164 insertions(+), 12 deletions(-) create mode 100644 docs/ad-revenue-unity.md diff --git a/docs/API.md b/docs/API.md index 3f2307e..10c2da7 100755 --- a/docs/API.md +++ b/docs/API.md @@ -22,9 +22,9 @@ The list of available methods for this plugin is described below. - [setResolveDeepLinkURLs](#setresolvedeeplinkurls) - [setOneLinkCustomDomain](#setonelinkcustomdomain) - [setCurrencyCode](#setcurrencycode) - - [setDeepLinkTimeout](#setDeepLinkTimeout) - - [enableTCFDataCollection](#enableTCFDataCollection) - - [setConsentData](#setConsentData) + - [setDeepLinkTimeout](#setdeeplinktimeout) + - [enableTCFDataCollection](#enabletcfdatacollection) + - [setConsentData](#setconsentdata) - [recordLocation](#recordlocation) - [anonymizeUser](#anonymizeuser) - [getAppsFlyerId](#getappsflyerid) @@ -34,7 +34,7 @@ The list of available methods for this plugin is described below. - [setPhoneNumber](#setphonenumber) - [getConversionData](#getconversiondata) - [attributeAndOpenStore](#attributeandopenstore) - - [logAdRevenue](#logAdRevenue) + - [logAdRevenue](#logadrevenue) - [recordCrossPromoteImpression](#recordcrosspromoteimpression) - [generateUserInviteLink](#generateuserinvitelink) - [setSharingFilterForAllPartners *Deprecated*](#setsharingfilterforallpartners-deprecated) @@ -56,8 +56,8 @@ The list of available methods for this plugin is described below. - [isPreInstalledApp](#ispreinstalledapp) - [handlePushNotifications](#handlepushnotifications) - [getAttributionId](#getattributionid) - - [validateAndSendInAppPurchase (legacy)](#validateandsendinapppurchase) - - [validateAndSendInAppPurchase (beta)](#validateAndSendInAppPurchase-beta) + - [validateAndSendInAppPurchase-beta](#validateandsendinapppurchase-beta) + - [validateAndSendInAppPurchase](#validateandsendinapppurchase) - [setCollectOaid](#setcollectoaid) - [setDisableAdvertisingIdentifiers](#setdisableadvertisingidentifiers) - [setDisableNetworkData](#setdisablenetworkdata) @@ -68,8 +68,8 @@ The list of available methods for this plugin is described below. - [setDisableCollectIAd](#setdisablecollectiad) - [setUseReceiptValidationSandbox](#setusereceiptvalidationsandbox) - [setUseUninstallSandbox](#setuseuninstallsandbox) - - [validateAndSendInAppPurchase (legacy)](#validateandsendinapppurchase-1) - - [validateAndSendInAppPurchase (beta)](#validateAndSendInAppPurchase-beta-iOS) + - [validateAndSendInAppPurchase-beta-iOS](#validateandsendinapppurchase-beta-ios) + - [validateAndSendInAppPurchase](#validateandsendinapppurchase-1) - [registerUninstall](#registeruninstall) - [handleOpenUrl](#handleopenurl) - [waitForATTUserAuthorizationWithTimeoutInterval](#waitforattuserauthorizationwithtimeoutinterval) @@ -87,10 +87,9 @@ The list of available methods for this plugin is described below. - [onOpenStoreLinkGenerated](#onopenstorelinkgenerated) - [IAppsFlyerValidateReceipt](#iappsflyervalidatereceipt) - [didFinishValidateReceipt](#didfinishvalidatereceipt) - - [didFinishValidateReceiptWithError](#didfinishvalidatereceiptwitherror) -- [IAppsFlyerValidateAndLog](#IAppsFlyerValidateAndLog) - - [onValidateAndLogComplete](#onValidateAndLogComplete) - - [onValidateAndLogFailure](#onValidateAndLogFailure) +- [IAppsFlyerValidateAndLog](#iappsflyervalidateandlog) + - [onValidateAndLogComplete](#onvalidateandlogcomplete) + - [onValidateAndLogFailure](#onvalidateandlogfailure) - [Events](#events) - [onRequestResponse](#onrequestresponse) - [onInAppResponse](#oninappresponse) diff --git a/docs/ad-revenue-unity.md b/docs/ad-revenue-unity.md new file mode 100644 index 0000000..939283b --- /dev/null +++ b/docs/ad-revenue-unity.md @@ -0,0 +1,153 @@ +--- +title: "Ad revenue" +slug: "ad-revenue-unity" +category: 5f9705393c689a065c409b23 +parentDoc: 6370c9e2441a4504d6bca3bd +excerpt: "Impression-level ad revenue reporting by SDK" +hidden: false +order: 12 +--- +The app sends impression revenue data to the SDK which then sends it to AppsFlyer. The revenue data is collected and processed in AppsFlyer, and the revenue is attributed to the original UA source. To learn more about ad revenue see [here](https://support.appsflyer.com/hc/en-us/articles/217490046#connect-to-ad-revenue-integrated-partners). + +There are two ways for the SDK to generate an ad revenue event, depending on your SDK version. Use the correct method for your SDK version: +- [For SDK 6.15.0 and above](#log-ad-revenue-for-sdk-6150-and-above). Uses the ad revenue SDK API. +- [For SDK 6.14.2 and below](#legacy-log-ad-revenue-for-sdk-6142-and-below). Uses the ad revenue SDK connector. + +## Log ad revenue (for SDK 6.15.0 and above) + +When an impression with revenue occurs, invoke the [`logAdRevenue`](doc:api#logadrevenue) method with the revenue details of the impression. + +**To implement the method:** + +1. Create an instance of `AFAdRevenueData` with the revenue details of the impression to be logged. Version 6.15.0 of the SDK removes the need for using a connector for sending Ad Revenue data to AppsFlyer. +2. If you want to add additional details to the ad revenue event, populate a map with key-value pairs. +3. Invoke the  `logAdRevenue` method with the following arguments: + - The `AFAdRevenueData` object you created in step 1. + - The `Map` instance with the additional details you created in step 2. + +### Code Example + +```c# +Dictionary additionalParams = new Dictionary(); +additionalParams.Add("value1", "5"); +additionalParams.Add(AdRevenueScheme.COUNTRY, "USA"); +additionalParams.Add(AFAdRevenueEvent.AD_UNIT, "89b8c0159a50ebd1"); +additionalParams.Add(AFAdRevenueEvent.AD_TYPE, "Banner"); +additionalParams.Add(AFAdRevenueEvent.PLACEMENT, "place"); +var logRevenue = new AFAdRevenueData("monetizationNetworkEx", MediationNetwork.GoogleAdMob, "USD", 0.99); +AppsFlyer.logAdRevenue(logRevenue, parameters); +``` + +> 📘 Note +> The AdMob iLTV SDK reports impression revenue in micro-units. To display the correct ad revenue amount in USD in AppsFlyer, divide the amount extracted from the iLTV event handler by 1 million before sending it to AppsFlyer. + +## [LEGACY] Log ad revenue (for SDK 6.14.2 and below) +For SDK v6.14.2 and below - the AdRevenue Connector should be used along side the AppsFlyer SDK to send Ad Revenue data to AppsFlyer. + +### Using Unity Package + +1. Clone or download [the Ad revenue connector](https://github.com/AppsFlyerSDK/appsflyer-unity-adrevenue-generic-connector/tree/main) repository. +2. Import the Adrevenue Unity package into your Unity project (To learn how to import to Unity refer to the [Unity documentation](https://docs.unity3d.com/Manual/AssetPackages.html)). + 1. In Unity, go to **Assets** > **Import Package** > **Custom Package** + 2. From the repository root select the `appsflyer-unity-adrevenue-plugin-x.x.x.unitypackage` file. + +### Using Unity Package Manager + +1. Add the dependency in your `manifest.json` file: + +``` + "appsflyer-unity-adrevenue-generic-connector": "https://github.com/AppsFlyerSDK/appsflyer-unity-adrevenue-generic-connector.git#upm" +``` + +2. If you haven't already done so, download the [External Dependency Manager for Unity](https://github.com/googlesamples/unity-jar-resolver) to be able to resolve our Android / iOS dependencies. + +**Note:** To choose a specific version and not the latest, you can replace the `upm` with the specific version tag, `v6.9.4-upm` for example. + +### Initialize the connector + +Make sure to initialize the AppsFlyer SDK before initializing the connector. + +```java +using AppsFlyerSDK; + +public class AppsFlyerObjectScript : MonoBehaviour +{ + void Start() + { + AppsFlyerAdRevenue.start(); + /* AppsFlyerAdRevenue.setIsDebug(true); */ + } +} + +``` + +### Ad revenue connector API + +#### `start` + +`public static void start()` + +Start sending AdRevenue data to AppsFlyer. + +_Example:_ + +```java +using AppsFlyerSDK; + void Start() + { + AppsFlyerAdRevenue.start(); + } +``` + +#### `setIsDebug` + + `public static void setIsDebug(bool isDebug)` + +Set to true to view debug logs. (development only!) + +| parameter | type | description | +| --------- | ---- | ------------------------------- | +| isDebug | bool | set to true in development only | + +_Example:_ + +```java + AppsFlyerAdRevenue.setIsDebug(true); +``` + +**Note:** This API will only set the debug logs for iOS. For Android the debug logs are controlled by the native SDK. +To turn on the debug logs on Android call `AppsFlyer.setIsDebug(true);` + +#### `logAdRevenue` + +`public static void logAdRevenue(string monetizationNetwork, AppsFlyerAdRevenueMediationNetworkType mediationNetwork, double eventRevenue, string revenueCurrency, Dictionary additionalParameters)` + +Send ad revenue data from the impression payload to AppsFlyer regardless of the mediation network you use. + +| parameter | type | description | +| -------------------- | -------------------------------------- | -------------------------------- | +| monetizationNetwork | string | monetization network | +| mediationNetwork | AppsFlyerAdRevenueMediationNetworkType | Enum for mediaton network type | +| eventRevenue | string | event revenue | +| revenueCurrency | string | revenue currency | +| additionalParameters | Dictionary\ | Any custom additional parameters | +| | | | + +_Example:_ + +```java +Dictionary additionalParams = new Dictionary(); +additionalParams.Add(AFAdRevenueEvent.COUNTRY, "US"); +additionalParams.Add(AFAdRevenueEvent.AD_UNIT, "89b8c0159a50ebd1"); +additionalParams.Add(AFAdRevenueEvent.AD_TYPE, "Banner"); +additionalParams.Add(AFAdRevenueEvent.PLACEMENT, "place"); + +additionalParams.Add("custom", "foo"); +additionalParams.Add("custom_2", "bar"); +additionalParams.Add("af_quantity", "1"); +AppsFlyerAdRevenue.logAdRevenue("facebook", + AppsFlyerAdRevenueMediationNetworkType.AppsFlyerAdRevenueMediationNetworkTypeGoogleAdMob, + 0.026, + "USD", + additionalParams); +``` \ No newline at end of file From c080f5caebeff0e819725bd55a792d6e9341ef7c Mon Sep 17 00:00:00 2001 From: Dori Frost Date: Thu, 19 Sep 2024 19:05:44 +0300 Subject: [PATCH 2/2] AdRevenue - fixes after review --- docs/ad-revenue-unity.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/docs/ad-revenue-unity.md b/docs/ad-revenue-unity.md index 939283b..0b8355e 100644 --- a/docs/ad-revenue-unity.md +++ b/docs/ad-revenue-unity.md @@ -29,13 +29,12 @@ When an impression with revenue occurs, invoke the [`logAdRevenue`](doc:api#loga ```c# Dictionary additionalParams = new Dictionary(); -additionalParams.Add("value1", "5"); additionalParams.Add(AdRevenueScheme.COUNTRY, "USA"); additionalParams.Add(AFAdRevenueEvent.AD_UNIT, "89b8c0159a50ebd1"); additionalParams.Add(AFAdRevenueEvent.AD_TYPE, "Banner"); additionalParams.Add(AFAdRevenueEvent.PLACEMENT, "place"); var logRevenue = new AFAdRevenueData("monetizationNetworkEx", MediationNetwork.GoogleAdMob, "USD", 0.99); -AppsFlyer.logAdRevenue(logRevenue, parameters); +AppsFlyer.logAdRevenue(logRevenue, additionalParams); ``` > 📘 Note @@ -130,7 +129,7 @@ Send ad revenue data from the impression payload to AppsFlyer regardless of the | mediationNetwork | AppsFlyerAdRevenueMediationNetworkType | Enum for mediaton network type | | eventRevenue | string | event revenue | | revenueCurrency | string | revenue currency | -| additionalParameters | Dictionary\ | Any custom additional parameters | +| additionalParameters | Dictionary | Any custom additional parameters | | | | | _Example:_