Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
The newest generation of devtodev SDK
The DevToDev.Messaging
package necessary for notifications is available in the NuGet
package manager.
Package Manager UI
Find the DevToDev.Messaging
package using the package manager search engine and click Install. The latest version of the package is recommended.
Package Manager Console
In progress...
For the correct package functioning, add handlers invoke to the Windows.UI.Xaml.Application
class implementation.
Besides, in the UI editor of the Package.appxmanifest file do the following:
Add Background Tasks to the Declarations tab and mark it as System Event. After that enter DevToDev.Background.ToastNotificationBackgroundTask
to the Entry Point field.
Add Background Tasks to the Declarations tab and mark it as Push Notification. After that enter DevToDev.Background.RawNotificationBackgroundTask
to the Entry Point field.
For the DevToDev.Messaging
package functioning you need to have the main DevToDev.Analytics
package installed. Initialize the SDK before initializing messages. You can read about it in more detail in the SDK initialization section.
After the SDK has been initialized you can move to initializing messages. To do this, call the method:
It is possible to listen to events from the DevToDev.Messaging
package:
1. Push Token - a string that allows to identify the client on a remote server for sending him customized notifications. For listening the unique Push Token ID issue event, it is necessary to be subscribed to the event:
2. To track the errors related to the unique Push Token ID issue, it is necessary to be subscribed to the event:
Where error is a string value containing information about the error.
3. To handle incoming message data, it is necessary to be subscribed to the following event:
Where messageData
belongs to the IDictionary<string, string>
type and contains data sent from the server together with the message.
4. To handle notification activation events, it is necessary to be subscribed to the event:
Where messageAction
is DevToDev.Messaging.DTDMessageAction
class instance:
Call the method to turn notifications off:
11
Unzip the DTDAnalytics.zip archive to the Plugins folder of your project.
For a C++ project type, add the DTDAnalytics
name to the list of dependency module names to the <module_name>.Build.cs file of the module in which you plan to use the plugin.
Example:
A class that implements analytic methods.
Header file:
A class that implements user card methods.
The class header:
SDK tracking status.
Header file:
Values:
Unknown = 0
- leave tracking unchanged
Enable = 1
- tracking enabled
Disable = 2
- tracking disabled
Example:
SDK logging level.
Header file:
Values:
Unknown = 0
- leave logging level unchanged
No = 1
- logging disabled
Error = 2
- logging of errors
Warning = 3
- logging of warnings and errors
Info = 4
- logging of information messages, warnings and errors
Debug = 5
- logging of debugging messages, informational messages, warnings and errors
Example:
Types of resource accumulation.
Header file:
Values:
Earned = 0
- earned resources
Bought = 1
- purchased resources
Example:
Predefined social media.
Header file:
Values:
Facebook = 0
Vkontakte = 1
Twitter = 2
Googleplus = 3
Whatsapp = 4
Viber = 5
Evernote = 6
Googlemail = 7
Linkedin = 8
Pinterest = 9
Reddit = 10
Renren = 11
Tumblr = 12
Qzone = 13
Example:
User gender.
Header file:
Values:
Unknown = 0
Male = 1
Female = 2
Example:
Referral properties.
Header file:
Values:
Source = 0
Medium = 1
Content = 2
Campaign = 3
Term = 4
Example:
An optional parameter of int32 type
Header file:
For your convenience, we implemented the conversion constructor:
Example:
An optional parameter of FString type.
Header file:
For your convenience, we implemented the conversion constructor:
Example:
Configuration of the analytics plugin.
Header file:
Example:
Custom parameters of a custom event.
Header file:
Warning: avoid duplicating keys in parameters of different types, because in native code dictionaries are merged into a single dictionary [string: any].
Example:
Parameters of the progression start event.
Header file:
Example:
Parameters of the progression completion event.
Header file:
Example:
Header file:
Definitions:
The SDK is available as an AAR (recommended) and JAR library. The library is available in the MavenCentral and GitHub repository.
If you use Gradle for building apps specify the following dependencies in the build.gradle
file in the dependencies block.
Use the following way to initialize the library in the first Activity onCreate()
method:
You can find the App ID in the settings of the respective app in devtodev (Settings → SDK → Integration → Credentials).
config
- is a DTDAnalyticsConfiguration
object instance that is used for specifying additional properties during initialization.
DTDAnalyticsConfiguration
Example:
Add the following strings to the proguard-rules.pro
file of your app
The devtodev service allows you to validate transactions to prevent fraud from influencing your statistics. For this, you need to integrate DTDAntiCheat
module.
To validate the transaction you can use the verifyPayment(completionHandler: @escaping (DTDVerifyResponse) -> Void)
method immediately during the transaction processing, e.g.:
We strongly discourage you from using verifyPayment
results for deciding on allowing or denying users to receive their purchases! Employ this method exclusively for preventing fraud transaction data from being sent to devtodev!
DTDVerifyResponse
The DTDVerifyResponse object returned while validating the transaction has two properties:
DTDReceiptStatus
The enum type returned as a result of validation can receive the following values:
We recommend calling the Real Currency Payment method in all cases except when you receive receiptNotValid
or receiptSandbox
as a result of the validation.
To validate the transaction you can use the (void)verifyPaymentCompletion:( void (^ _Nonnull)(DTDVerifyResponse * _Nonnull))completionHandler;
method immediately during the transaction processing, e.g.:
We strongly discourage you from using verifyPayment
results for deciding on allowing or denying users to receive their purchases! Employ this method exclusively for preventing fraud transaction data from being sent to devtodev!
DTDVerifyResponse
The DTDVerifyResponse object returned while validating the transaction has two properties:
DTDReceiptStatus
The enum type returned as a result of validation can receive the following values:
We recommend calling the Real Currency Payment method in all cases except when you receive receiptNotValid
or receiptSandbox
as a result of the validation.
When GooglePlay sends the transaction back to your onActivityResult
, validate it by calling the following method: verifyPayment(receipt: String, signature: String, publicKey: String, completionHandler:(DTDVerifyResponse) -> Unit)
immediately during the transaction processing, e.g.:
We strongly discourage you from using verifyPayment
results for deciding on allowing or denying users to receive their purchases! Employ this method exclusively for preventing fraud transaction data from being sent to devtodev!
DTDVerifyResponse
The DTDVerifyResponse object returned while validating the transaction has two properties:
DTDReceiptStatus
The enum type returned as a result of validation can receive the following values:
We recommend calling the Real Currency Payment method in all cases except when you receive receiptNotValid
as a result of the validation.
devtodev sends a request for transaction verification to the payment platform and then forwards the answer to the app.
To validate the transaction you can use theTask<DTDReceiptStatus> VerifyPayment(string: receipt)
method. As an argument pass the PurchaseResults.ReceiptXml
property. More information about it here.
Example of verification:
We strongly discourage you from using VerifyPayment
results for deciding on allowing or denying users to receive their purchases! Employ this method exclusively for preventing fraud transaction data from being sent to devtodev!
DTDVerifyResponse
The DTDVerifyResponse object returned while validating the transaction has two properties:
DTDReceiptStatus
The enum type returned as a result of validation can receive the following values:
We recommend calling the Real Currency Payment method in all cases except when you receive Invalid
as a result of the validation.
If you use Unity IAP for payment validation, call the following method: void VerifyPayment(string purchasedProduct, string publicKey, Action completionHandler)
Example:
To validate data received from Google play, use void VerifyPayment(string receipt, string signature, string publicKey, Action completionHandler)
when handling the transaction.
Here's how to find your app's public key for licensing (for Google Play platform only, for other platforms the publicKey is not used):
Go to the Google Play Console and sign in. Make sure that you sign in to the account from which the app you are licensing is published (or will be published).
In the app details page, locate the Services & APIs link and click it.
In the Services & APIs page, locate the Licensing & In-App Billing section. Your public key for licensing is given in the Your License Key For This Application field.
If you use Unity IAP for payment validation, call the following method: void VerifyPayment(string purchasedProduct, Action completionHandler)
If you use Unity IAP for payment validation, call the following method: void VerifyPayment(string purchasedProduct, Action completionHandler)
N.B. You can pass a native XML recipe to the purchasedProduct
argument.
We strongly discourage you from using verifyPayment
results for deciding on allowing or denying users to receive their purchases! Employ this method exclusively for preventing fraud transaction data from being sent to devtodev!
DTDVerifyResponse
The DTDVerifyResponse object returned while validating the transaction has two properties:
DTDReceiptStatus
The enum type returned as a result of validation can receive the following values:
We recommend calling the Real Currency Payment method in all cases except when you receive receiptNotValid
or receiptSandbox
as a result of the validation.
CocoaPods is the easiest way to add devtodev into your iOS project.
1. Firstly, install CocoaPods using:
2. In the project directory execute the command:
3. In the created Podfile add the dependency:
4. Finally, run the command in your Xcode project directory:
CocoaPods should download and install the devtodev library, and create a new Xcode workspace. Open this workspace in Xcode.
To connect the module for processing push notifications, you need to:
1. Download the latest devtodev SDK from the repository
2. Add DTDAnalytics.xcframework
to the project (check Do Not Embed)
The DTDMessaging plugin will not work without the DTDAnalytics main analytics plugin.
3.Add DTDMessaging.xcframework to the project (check Do Not Embed)
4. In the Xcode project settings, open the tab, and add: "Push Notifications" and "Background Modes" respectively
5. In the "Background Modes" section, enable "Remote notifications"
6. Add initialization to didFinishLaunchingWithOptions
method:
7. To handle SDK delegate methods, you need to add the implementation of the DTDMessagingDelegate
protocol
The DTDMessaging
module provides support for notifications with attachments. These notifications are available since iOS 10. Attachments support images, animated gifs and videos. To use this function, you will need to create a “Notification Service Extension“, for this create a new target in your application settings:
Open Xcode (File -> New -> Target). Select Notification Service Extension.
The next step is to modify the Notification Extension
class as follows:
Delete all auto-generated code.
Inherit Notification Extension
class from DTDMediaAttachmentExtension
Example:
DTDMessaging
moduleDTDMessagingDelegate
methodsDisplaying push notifications in Foreground state is available since iOS 10.0.
By default, according to Apple Push Notification Guidelines, the display of push notification in the Foreground state is disabled. In order to set the display method, you must:
Assign delegate for UNUserNotificationCenter
Or pass a parameter in the push notification constructor (_fg = 1
). In this case, the display method will be formed from the Notification settings.
Or delegate the system method userNotificationCenter willPresent notification
. In this case, the display properties will be taken from the developer.
An example of a delegated method implementation:
It is an OptionSet
that is used to pass push notification authorization and set up interactions with users.
The user can change the allowed parameters at any time in the notification settings.
Possible values:
DTDNotificationOptionProvisional
- Provisional push notifications appear in the user's Notification Center, but not on the lock screen. This type of push notification does not have to be explicitly allowed by the user. Start submitting them as soon as the user installs and runs your application. However, the user can also opt in/opt out of notifications, but they will need to do it explicitly.
This setting is used to prevent receiving push notification permission requests at the start, which is intrusive and most users refuse to receive them.
It is also important that when using the DTDNotificationOptionProvisional
setting, the user will be able to subscribe to explicit notifications only from the notification center settings.
DTDMediaAttachmentExtension
To handle the application attitude to displaying push notifications, you need to add a Notifications service Extension. And inherit NotificationService
from DTDMediaAttachmentExtension
DTDMessaging automatically swizzles notification tracking and APNS-token usage methods by default. If you want to disable the function, add the flag DTDMessagingSwizzlingEnabled
(boolean) in the app’s Info.plist
file and set it to NO (0). However, if you disable notification swizzling, you will need additional integration for accurate analytics:
For sending APNS-token to DTDMessaging:
For sending information about the application:
Note: If you disable automatic notification swizzling, DTDMessagingDelegate
methods will not be called.
CocoaPods is the easiest way to add devtodev into your iOS project.
1. Firstly, install CocoaPods using:
2. In the project directory execute the command:
3. In the created Podfile add the dependency:
4. Finally, run the command in your Xcode project directory:
CocoaPods should download and install the devtodev library, and create a new Xcode workspace. Open this workspace in Xcode.
In progress...
1. Download the latest version of devtodev SDK from the repository
3. Add frameworks:
AppTrackingTransparency.framework
AdSupport.framework
4. Add initialization todidFinishLaunchingWithOptions
method:
An App ID can be found in the settings of the respective app in devtodev (Settings → SDK → Integration → Credentials).
config
- an object instance of DTDAnalyticsConfiguration
, which is used for specifying additional properties during the initialization.
DTDAnalyticsConfiguration
Example:
Create Bridging-Header. To do this, you need to add any swift file to the project (don’t delete it later) and choose ‘Create Bridging Header’ in the offered dialog box.
Make sure that the ‘Build Settings’ for ‘Defines Module’ value evaluates to ‘YES’.
While importing, use: #import <DTDAnalytics/DTDAnalytics-Swift.h>
For SDK to function properly, it needs to be integrated at the earliest moment of the app launch. It is recommended that you use the following method of main entry point initialization:
1. Download the latest version of devtodev SDK from the repository
2. Add DTDAnalytics.xcframework
to the project (with Do Not Embed specified)
3. Add frameworks:
AppTrackingTransparency.framework
AdSupport.framework
4. Add initialization todidFinishLaunchingWithOptions
method:
An App ID can be found in the settings of the respective app in devtodev (Settings → SDK → Integration → Credentials).
config
- an object instance of DTDAnalyticsConfiguration
, which is used for specifying additional properties during the initialization.
DTDAnalyticsConfiguration
Example:
Create Bridging-Header. To do this, you need to add any swift file to the project (don’t delete it later) and choose ‘Create Bridging Header’ in the offered dialog box.
Make sure that the ‘Build Settings’ for ‘Defines Module’ value evaluates to ‘YES’.
While importing, use: #import <DTDAnalytics/DTDAnalytics-Swift.h>
For SDK to function properly, it needs to be integrated at the earliest moment of the app launch. It is recommended that you use the following method of main entry point initialization:
Find the DevToDev.Analytics.Uwp
package using the package manager search engine and click Install. The latest version of the package is recommended.
Initialize the library using the following code:
You can find the App ID in the settings of the respective app in devtodev (Settings → SDK → Integration → Credentials).
config
- is a DTDAnalyticsConfiguration
object instance that is used for specifying additional properties during initialization.
DTDAnalyticsConfiguration
Example:
Find the DevToDev.Analytics
package using the package manager search engine and click Install. The latest version of the package is recommended.
Initialize the library using the following code:
You can find the App ID in the settings of the respective app in devtodev (Settings → SDK → Integration → Credentials).
config
- is a DTDAnalyticsConfiguration
object instance that is used for specifying additional properties during initialization.
DTDAnalyticsConfiguration
Example:
The SDK can’t control app activity hence this responsibility is passed on to the developer. During the SDK initialization, the activity is triggered automatically, and later the activity status will not change automatically. For tracking app activity, the developer can use the DTDAnalytics.StartActivity
and DTDAnalytics.StopActivity
methods. It is recommended that you use the DTDAnalytics.StopActivity
method to stop the activity when the app goes into the background or being closed. If the window is re-opened from the taskbar it is recommended to renew the activity by using the DTDAnalytics.StartActivity
method.
1
The event allows you to track tutorial completion and identify the stages where you lose new users.
We recommend tracking the starting point (value -1) before beginning the first tutorial stage, then passing the counting number of every completed stage after its completion (integers larger than 0), and at the end, marking the moment of the last tutorial stage completion (value -2).
If your app has an option of skipping the tutorial and the user has used it, then it’s necessary to send a refusal value (value 0) only.
The method takes on the step value with an integer type.
Value | Meaning |
---|---|
The method takes on the step value with an integer type.
Value | Meaning |
---|---|
The method takes on the step value with an integer type.
Value | Meaning |
---|---|
The method takes on the step value with an integer type.
Value | Meaning |
---|---|
The method takes on the step value with an int base type.
The method takes on the step value with an integer type.
The method takes on the step value with an int32 base type.
The event allows you to analyze the distribution of players over different game levels, monitor the in-game currency balance by levels. You can find more information about the right moment to use LevelUp
event here.
The event should be dispatched right after the level-up. The number of the level reached is passed to the level
parameter.
To monitor the average account balance of in-game currency by the end of each level, dispatch in-game currencies (resources) names and their amounts to the method signature:
Attention! The number of tracked in-game currencies or resources (their unique names) should not exceed 30 at all times.
Parameter | Type | Restrictions | Description |
---|---|---|---|
The event should be dispatched right after the level-up. The number of the level reached is passed to the level
parameter.
To monitor the average account balance of in-game currency by the end of each level, dispatch in-game currencies (resources) names and their amounts to the method signature:
Attention! The number of tracked in-game currencies or resources (their unique names) should not exceed 30 at all times.
Parameter | Type | Restrictions | Description |
---|---|---|---|
The event should be dispatched right after the level-up. The number of the level reached is passed to the level
parameter.
To monitor the average account balance of in-game currency by the end of each level, dispatch in-game currencies (resources) names and their amounts to the method signature:
Attention! The number of tracked in-game currencies or resources (their unique names) should not exceed 30 at all times.
Parameter | Type | Restrictions | Description |
---|---|---|---|
The event should be dispatched right after the level-up. The number of the level reached is passed to the level
parameter.
To monitor the average account balance of in-game currency by the end of each level, dispatch in-game currencies (resources) names and their amounts to the method signature:
Attention! The number of tracked in-game currencies or resources (their unique names) should not exceed 30 at all times.
The event should be dispatched right after the level-up. The number of the level reached is passed to the level
parameter.
To monitor the average account balance of in-game currency by the end of each level, dispatch in-game currencies (resources) names and their amounts to the method signature:
Attention! The number of tracked in-game currencies or resources (their unique names) should not exceed 30 at all times.
The event should be dispatched right after the level-up. The number of the level reached is passed to the level
parameter.
You can send and track the following data along with the level values: an average amount of the in-game currency by the end of the level, user spendings on the level, and amounts of purchased or earned in-game currency/resources. Unfortunately, Web SDK doesn’t allow to automatically calculate spending and receiving of the in-game currency/resources while users are passing the level (data accumulation on the Web might be inaccurate as users might utilize multiple browsers and devices, as well as erase local browser data).
Attention! The number of tracked in-game currencies or resources (their unique names) should not exceed 30 at all times.
The event should be dispatched right after the level-up. The number of the level reached is passed to the level
parameter.
To monitor the average account balance of in-game currency by the end of each level, dispatch in-game currencies (resources) names and their amounts to the method signature:
Attention! The number of tracked in-game currencies or resources (their unique names) should not exceed 30 at all times.
To track the average balance of in-game currency disregarding the level up event, pass the list of in-game currency (resource) names and their amount to the method signature:
You need to dispatch the event after every game account balance refill if you want to track the average in-game currency amount acquired or earned by the players for a certain timeframe or during a level playthrough.
acrualType
can receive one of the following values:
acrualType
can receive one of the following values:
accrualType
can receive one of the following values:
AccrualType
can receive one of the following values:
AccrualType
can receive one of the following values:
Example:
Pass this event after every purchase if you want to track in-game currency spends and items’ popularity. You can apply this event to both games and any apps with virtual currency.
In case the item is sold for more than one currency/resource, you need to build a dictionary with all the names and amounts of the currencies/resources.
In case the item is sold for more than one currency/resource, you need to build a dictionary with all the names and amounts of the currencies/resources.
In case the item is sold for more than one currency/resource, you need to build a dictionary with all the names and amounts of the currencies/resources.
In case the item is sold for more than one currency/resource, you need to build a dictionary with all the names and amounts of the currencies/resources.
In case the item is sold for more than one currency/resource, you need to build a dictionary with all the names and amounts of the currencies/resources.
In case the item is sold for more than one currency/resource, you need to build a dictionary with all the names and amounts of the currencies/resources.
In case the item is sold for more than one currency/resource, you need to build a dictionary with all the names (FString) and amounts of the currencies/resources (int32) .
To track payments in a real currency, dispatch this event right after the system validates that the payment went through successfully. The event is fundamental and mandatory for all the app metrics related to monetization.
How to find the transaction ID in GooglePlay transaction?
Find the INAPP_PURCHASE_DATA object In the JSON fields that are returned in the response data for a purchase order. A unique transaction identifier is the value of orderId property in INAPP_PURCHASE_DATA object. If the order is a test purchase made via the In-app Billing Sandbox, orderId property will be empty.
By default (easy to change in the app’s settings) devtodev server invalidates transactions with previously-used identifiers. Besides, the server performs identifier checks by its outer appearance in order to avoid obvious fraud.
If you want to exclude fraud payments from your reports altogether, before creating ‘Real Currency Payment’ event, use devtodev anti-cheat feature.
The described method is available beginning with version 2.1.0!
Tracking of subscriptions is now available for Apple App Store and Google Play only.
Please note that in order to track subscriptions, you need to do the following:
Call the subscriptionPayment
method (described below)
To track your income from subscriptions, you need to call the following method at the moment of the subscription purchase even if the user signed up for a trial subscription: func subscriptionPayment(transaction: SKPaymentTransaction, product: SKProduct).
For example:
Further user actions - renewal, unsubscription, etc. are tracked by using the data received from AppStore in the server-server format. You will need the corresponding setting for it.
Also, if you want to track changes in the status of the subscriptions purchased before devtodev SDK 2.0 integration, you need to transfer your history of previously purchased subscriptions to devtodev.
The SDK monitors the need for historical data to avoid sending out excessive queries to App Store. Use the DTDAnalytics.isRestoreTransactionHistoryRequired
method to check whether or not there is a need in sending out the information about the previously purchased subscriptions to devtodev. The method returns BOOL value.
An example of a purchase history query with verification of the need for it:
Use the DTDAnalytics.subscriptionHistory
method to transfer the list of previously purchased subscriptions received from App Store.
If your project accounts users by user ID (not by device ID) and the device is used by more than one user, you need to filter the transaction history so that it will contain only those transactions that belong to the active user. Otherwise, subscriptions of all device users will be attributed to the user who was the first to launch the app after the integration of subscription tracking.
To recover the purchase history, the user should be logged in with his Apple ID. Be mindful of this before starting the recovering process.
Please note that in order to track subscriptions, you need to do the following:
Call the subscriptionPayment
method (described below)
To track your income from subscriptions, you need to call the following method at the moment of the subscription purchase even if the user signed up for a trial subscription:
(void)subscriptionPaymentWithTransaction:(SKPaymentTransaction * _Nonnull)transaction product:(SKProduct * _Nonnull)product;
For example:
Further user actions - renewal, unsubscription, etc. are tracked by using the data received from AppStore in the server-server format. You will need the corresponding setting for it.
Also, if you want to track changes in the status of the subscriptions purchased before devtodev SDK 2.0 integration, you need to transfer your history of previously purchased subscriptions to devtodev.
The SDK monitors the need for historical data to avoid sending out excessive queries to App Store. Use the (void)isRestoreTransactionHistoryRequiredWithCompletionHandler:( void (^ _Nonnull)(BOOL))completionHandler;
method to check whether or not there is a need in sending out the information about the previously purchased subscriptions to devtodev. The method returns BOOL value.
An example of a purchase history query with verification of the need for it:
Use the (void)subscriptionHistoryWithTransactions:(NSArray<SKPaymentTransaction *> * _Nonnull)transactions;
method to transfer the list of previously purchased subscriptions received from App Store.
If your project accounts users by user ID (not by device ID) and the device is used by more than one user, you need to filter the transaction history so that it will contain only those transactions that belong to the active user. Otherwise, subscriptions of all device users will be attributed to the user who was the first to launch the app after the integration of subscription tracking.
To recover the purchase history, the user should be logged in with his Apple ID. Be mindful of this before starting the recovering process.
Please note that in order to track subscriptions, you need to do the following:
Call the subscriptionPayment
method (described below)
Before sending a request for subscription from your app, during the creation of BillingFlowParams
, to the setObfuscatedAccountId
function of the BillingFlowParams.newBuilder()
object insert obfuscatedAccountId
obtained from DTDAnalytics.getObfuscatedAccountId
.
Attention! The obfuscated identifier is returned asynchronously, outside of the calling thread!
Example:
To track your subscriptions, add this event immediately after the platform confirms that the subscription was approved by the user.
How to find the transaction ID in GooglePlay transaction?
Find the INAPP_PURCHASE_DATA object In the JSON fields that are returned in the response data for a purchase order. A unique transaction identifier is the value of orderId property in INAPP_PURCHASE_DATA object. If the order is a test purchase made via the In-app Billing Sandbox, orderId property will be empty.
Further user actions - renewal, unsubscription, etc. are tracked by using the data received from Google Play in the server-server format. You will need the corresponding setting for it.
The subscriptionHistory
method is used for matching users with subscribers who purchased their subscriptions before the SDK 2.0 integration. Otherwise, it will be impossible to establish the affiliation when it gets renewed or cancelled.
To get a list of active subscriptions call billingClient.queryPurchasesAsync
. After successfully receiving a response from Google Play Services, pass it to DTDAnalytics.subscriptionHistory(purchaseList: List<String>).
purchaseList: List<String> purchaseList
- a string containing list of json objects is passed to the DTDAnalytics.subscriptionHistory
method. For the event to run, the json object must contain the following keys:
orderID
- a unique transaction identifier
productID
- a unique product identifier
The SDK monitors the need for historical data to avoid sending out excessive queries. Use the DTDAnalytics.isRestoreTransactionHistoryRequired
method to check whether or not there is a need in sending out the information about the previously purchased subscriptions to devtodev. The method returns a Boolean value.
Attention! DTDAnalytics.isRestoreTransactionHistoryRequired
is returned asynchronously, outside of the calling thread!
Example:
If your project accounts users by user ID (not by device ID) and the device is used by more than one user, you need to filter the transaction history so that it will contain only those transactions that belong to the active user. Otherwise, subscriptions of all device users will be attributed to the user who was the first to launch the app after the integration of subscription tracking.
Download and import the DTDSubscriptions
package to your app.
For the DTDSubscriptions
module to function you need the DTDAnalytics
and Unity IAP modules.
You also need to create an AppleTangle
file. Open the Unity editor menu and choose Window → Unity IAP → Receipt Validation Obfuscator (pic. 1).
In case you don’t use the IAP receipt validation, clear the input field under “2. Paste the key here:” and click Obfuscate Google Play Licence Key (pic. 2).
Initialize the DTDAnalytics
module (see our instruction manual).
Add DTDSubscriptions.Initialize(IStoreController controller)
to the OnInitialized method.
Restore purchase history in order for the module to function correctly.
If you use Google Play, after successful IAP initialization call the DTDSubscriptions.History()
method.
To avoid excessive restoring of subscription history, use the DTDSubscriptions.IsRestoreTransactionHistoryRequired(Action<bool> resultCallback)
method. If the resultCallback returns true, call the DTDSubscriptions.History()
method.
Example:
If you use AppleStore, first set the DTDSubscriptions.IsRestoring
property to true (this will filter out unwanted transactions). After restoring IAP transactions, call the DTDSubscriptions.History()
method. After that, set the DTDSubscriptions.IsRestoring propert
y to false.
Example:
Add a DTDSubscriptions.Payment(Product product)
call to the ProcessPurchase
method.
Below you can see an example of the entire script:
If you want to track non-basic events, you can create custom events of your own. How you are going to apply them, depends solely on you.
If you want to pass custom parameters, use DTDCustomEventParameters
class instance.
The following data types can be passed using the DTDCustomEventParameters
object:
If you want to pass custom parameters, use DTDCustomEventParameters
class instance.
The following data types can be passed using the DTDCustomEventParameters
object:
If you want to pass custom parameters, use DTDCustomEventParameters
class instance.
The following data types can be passed using the DTDCustomEventParameters
object:
If you want to pass custom parameters, use DTDCustomEventParameters
class instance.
The following data types can be passed using the DTDCustomEventParameters
object:
If you want to pass custom parameters, use DTDCustomEventParameters
class instance.
The following data types can be passed using the DTDCustomEventParameters
object:
If you want to pass custom parameters, use an object with parameters.
The following data types can be passed using parameters object:
If you want to pass custom parameters, use:
The following data types can be passed using the DTDCustomEventParameters object:
devtodev supports no more than 300 custom event names in a single project. Events that exceed the limit of custom event names will be discarded. Try to integrate the tracked actions by type to the event name level, and move the characteristic tags in the parameters.
For example, if you need to track purchasing “Paper” and “Pen” items, then you don’t need to create two events with the names “Paper Purchase” and “Pen Purchase”. Create a “Purchase” event and add an “Item” parameter to it with the appropriate “Paper” or “Pen” value. This way, you can use just one event to track many items.
For a string parameter, you can use no more than 50,000 unique values for the entire history of events. If the number of unique values exceeds the limit, the parameter gets locked by the system and gets discarded from the received data. Therefore, we don’t recommend using highly variable parameters like user IDs or time as string values (moreover, they are automatically added to the event).
We strongly recommend that you do not change the data type passed in the same parameter. If you change the data type in a parameter, it will be duplicated with the same name, which may cause issues while processing reports.
First of all, the progression event is used in games with short (within one game session) areas/game levels, e.g. match 3 games. You can use the event to collect data on how well or how fast users complete levels, how difficult it is for them, how many resources they gained or spent, and other parameters.
There are two methods in working with progression event:
startProgressionEvent
finishProgressionEvent
When a player spawns at a location, the following method is called:
DTDStartProgressionEventParameters
:
Once the player completes the location successfully, the following method is called:
DTDFinishProgressionEventParameters
:
There are two methods in working with progression event:
startProgressionEvent
finishProgressionEvent
When a player spawns at a location, the following method is called:
DTDStartProgressionEventParameters
:
Once the player completes the location successfully, the following method is called:
DTDFinishProgressionEventParameters
:
There are two methods in working with progression event:
startProgressionEvent
finishProgressionEvent
When a player spawns at a location, the following method is called:
DTDStartProgressionEventParameters
:
Once the player completes the location successfully, the following method is called:
DTDFinishProgressionEventParameters
:
There are two methods in working with progression event:
StartProgressionEvent
FinishProgressionEvent
When a player spawns at a location, the following method is called:
DTDStartProgressionEventParameters
:
Once the player completes the location successfully, the following method is called:
DTDFinishProgressionEventParameters
:
There are two methods in working with progression event:
StartProgressionEvent
FinishProgressionEvent
When a player spawns at a location, the following method is called:
DTDStartProgressionEventParameters
:
Once the player completes the location successfully, the following method is called:
DTDFinishProgressionEventParameters
:
There are two methods in working with progression event:
startProgressionEvent
finishProgressionEvent
When a player spawns at a location, the following method is called:
startProgressionEvent
event parameters:
Example:
Once the player completes the location (instead of successfully or not), the following method is called:
startProgressionEvent
event parameters:
Example:
There are two methods in working with progression event:
startProgressionEvent
finishProgressionEvent
When a player spawns at a location, the following method is called (one of them):
Start progression event with parameters:
FDTDStartProgressionEventParams:
Example:
Once the player completes the location (instead of successfully or not), the following method is called (one of them):
Finish progression event with parameters:
FDTDFinishProgressionEventParameters:TMap<FString, int64>
Example:
The user can only be in one area at a time. When moving to another area (including nested ones), the previous location must be completed. Information about events that have not been completed by calling the finishProgressionEvent
method during a game session (the finishProgressionEvent
method call is not integrated, or the user uses the cached app, or the app has crashed) is not included in the statistics.
If you want to use this event to track actions that take more than one game session, you can prepare the required data and call both methods when the action is completed (successfully or unsuccessfully). For example, you can use this event to track the main questline.
This method is used to initialize the user in applications where you have set calculation by user ID specified by the developer, applications that are part of a cross-platform project.
You can also use this method when calculating by device ID (by default) to pass in the user ID used on your servers so that you can easily find the user on devtodev.
We recommend that you pass this parameter in the initialization configuration (userId
property of an instance of theDTDAnalyticsConfiguration
class).
Do not pass an empty string ("") to the setUserID
method as the user ID. Assigning an empty string is a command to assign a default value to the user ID (it is equal to the current device ID). In applications with calculation by user ID, this can lead to unnecessary registrations.
To set a new value as the user ID, use the setUserId
method.
To get the current value of the user ID, use the asynchronous method
getDeviceId(_ completionHandler: @escaping (String) -> Void)
We recommend that you pass this parameter in the initialization configuration (userId
property of an instance of theDTDAnalyticsConfiguration
class).
Do not pass an empty string ("") to the setUserID
method as the user ID. Assigning an empty string is a command to assign a default value to the user ID (it is equal to the current device ID). In applications with calculation by user ID, this can lead to unnecessary registrations.
To set a new value as the user ID, use the setUserId
method.
To get the current value of the user ID, use the asynchronous method
(void)deviceIdHandler:( void (^ _Nonnull)(NSString * _Nonnull))completion-Handler;
We recommend that you pass this parameter in the initialization configuration (userId
property of an instance of theDTDAnalyticsConfiguration
class).
Do not pass an empty string ("") to the setUserID
method as the user ID. Assigning an empty string is a command to assign a default value to the user ID (it is equal to the current device ID). In applications with calculation by user ID, this can lead to unnecessary registrations.
To set a new value as the user ID, use the setUserId
method.
To get the current value of the user ID, use the asynchronous method
getDeviceId(block: (String) -> Unit)
We recommend that you pass this parameter in the initialization configuration (userId
property of an instance of theDTDAnalyticsConfiguration
class).
Do not pass an empty string ("") to the SetUserID
method as the user ID. Assigning an empty string is a command to assign a default value to the user ID (it is equal to the current device ID). In applications with calculation by user ID, this can lead to unnecessary registrations.
To set a new value as the user ID, use the SetUserId
method.
To get the current value of the user ID, use the asynchronous method:
We recommend that you pass this parameter in the initialization configuration (userId
property of an instance of theDTDAnalyticsConfiguration
class).
Do not pass an empty string ("") to the SetUserID
method as the user ID. Assigning an empty string is a command to assign a default value to the user ID (it is equal to the current device ID). In applications with calculation by user ID, this can lead to unnecessary registrations.
To set a new value as the user ID, use the SetUserId
method.
To get the current value of the user ID, use the asynchronous method:
We recommend that you pass this parameter in the initialization configuration (userId
property in config object).
Do not pass an empty string ("") to the setUserID
method as the user ID. Assigning an empty string is a command to assign a default value to the user ID (it is equal to the current device ID). In applications with calculation by user ID, this can lead to unnecessary registrations.
To set a new value as the user ID, use the setUserId
method.
To get the current value of the user ID, use the getUserId
method
We recommend that you pass this parameter in the initialization configuration (UserId
property of an instance of the FDTDAnalyticsConfiguration
class).
Do not pass an empty string ("") to the SetUserID
method as the user ID. Assigning an empty string is a command to assign a default value to the user ID (it is equal to the current device ID). In applications with calculation by user ID, this can lead to unnecessary registrations.
To set a new value as the user ID, use method:
To get the current value of the user ID, use the asynchronous method:
This method is used in very rare cases. It is applicable in the case when the calculation of users in the project is carried out by the user ID specified by the developer. In this case, the application can change this identifier. For example, calculation in the application is carried out by user emails and in the application, it is possible to change this email to another one. At the time of replacement, you need to call this method, specifying the user's previous email and the one with which it was replaced.
Arguments | Type | Description |
---|---|---|
Do not use this method to re-login as a different user! The setUserId method is used for relogging.
This method is used in cross-platform and data synchronized applications. The method is required to update user level data.
To set the current value to the user level, use setCurrentLevel(currentLevel: Int)
method:
We recommend that you use the setCurrentLevel
method immediately after using the setUserID
method or specify the current user level in the initialization configuration (the level property of an instance of the DTDAnalyticsConfiguration
).
Do not use the setCurrentLevel
method when the user reaches a new level. In this case, you must use the levelUp
method.
To get the user-level value stored by the SDK, use getCurrentLevel(completionHandler: @escaping (Int) -> Void)
method
To set the current value to the user level, use (void)currentLevel:(NSInteger)currentLevel;
method:
We recommend that you use the setCurrentLevel
method immediately after using the setUserID
method or specify the current user level in the initialization configuration (the level property of an instance of the DTDAnalyticsConfiguration
).
Do not use the setCurrentLevel
method when the user reaches a new level. In this case, you must use the levelUp
method.
To get the user-level value stored by the SDK, use (void)currentLevelHandler:( void (^ _Nonnull)(NSInteger))completionHandler;
method
To set the current value to the user level, use method:
We recommend that you use the setCurrentLevel
method immediately after using the setUserID
method or specify the current user level in the initialization configuration (the level property of an instance of the DTDAnalyticsConfiguration
).
Do not use the setCurrentLevel
method when the user reaches a new level. In this case, you must use the levelUp
method.
To get the user-level value stored by the SDK, use getCurrentLevel(completionHandler: @escaping (Int) -> Void)
method
To set the current value to the user level, use method:
We recommend that you use the SetCurrentLevel
method immediately after using the SetUserID
method or specify the current user level in the initialization configuration (the level property of an instance of the DTDAnalyticsConfiguration
).
Do not use the SetCurrentLevel
method when the user reaches a new level. In this case, you must use the LevelUp
method.
To get the user-level value stored by the SDK, use GetCurrentLevel
method:
To set the current value to the user level, use method:
We recommend that you use the SetCurrentLevel
method immediately after using the SetUserID
method or specify the current user level in the initialization configuration (the level property of an instance of the DTDAnalyticsConfiguration
).
Do not use the SetCurrentLevel
method when the user reaches a new level. In this case, you must use the LevelUp
method.
To get the user-level value stored by the SDK, use GetCurrentLevel
method:
To set the current value to the user level, use method:
We recommend that you use the setCurrentLevel
method immediately after using the setUserID
method or specify the current user level in the initialization configuration (the level property of an instance of the DTDAnalyticsConfiguration
).
Do not use the setCurrentLevel
method when the user reaches a new level. In this case, you must use the levelUp
method.
To get the user-level value stored by the SDK, use getCurrentLevel
method.
To set the current value to the user level, use method:
We recommend that you use the SetCurrentLevel
method immediately after using the SetUserID
method or specify the current user level in the initialization configuration (the level property of an instance of the EDTDAnalyticsConfiguration
).
Do not use the SetCurrentLevel
method when the user reaches a new level. In this case, you must use the LevelUp
method.
To get the user-level value stored by the SDK, use method:
If you have your own methods for detecting cheaters in the application, you can tag such users. Actions taken by these users will not be counted in statistics.
To get the current value of the 'Cheater' flag, use
getCheater(completionHandler: @escaping (Bool) -> Void
)
To get the current value of the 'Cheater' flag, use(void)getCheaterHandler:( void (^ _Nonnull)(BOOL))completionHandler;
To get the current value of the 'Cheater' flag, use
getCheater(handler: (Boolean) -> Unit)
To get the current value of the 'Cheater' flag, use
To get the current value of the 'Cheater' flag, use
To get the current value of the 'Cheater' flag, use getCheater
method:
To get the current value of the 'cheater' flag, use
Attention! We strongly discourage the storage of personal user data! If you plan to pass this data, be sure to indicate this in the ‘Nutrition label’ when submitting the application to the App Store review.
Attention! We strongly discourage the storage of personal user data! If you plan to pass this data, be sure to indicate this in the ‘Nutrition label’ when submitting the application to the App Store review.
Attention! We strongly discourage the storage of personal user data! If you plan to pass this data, be sure to indicate this in the ‘Nutrition label’ when submitting the application to the App Store review.
Attention! We strongly discourage the storage of personal user data! If you plan to pass this data, be sure to indicate this in the ‘Nutrition label’ when submitting the application to the App Store review.
Example:
Each devtodev project can have up to 30 custom user properties. User custom property values can be a number, a string, or a boolean value.
This is how you can set properties on the current user profile:
It is important to remember that the key for custom user properties has a length limit. If the limit is exceeded (from 1 to 64 characters), the key will be truncated to the maximum allowed length
To get the current value stored in the user profile on the SDK, you need to use the method:
getValue(key: String, _completionHandler: @escaping (Any) -> Void)
When using the getValue
method, note that the Any
return type will need to be cast to the data type you want.
This is how you can set properties on the current user profile:
It is important to remember that the key for custom user properties has a length limit. If the limit is exceeded (from 1 to 64 characters), the key will be truncated to the maximum allowed length
To get the current value stored in the user profile on the SDK, you need to use the method:
(void)getValueWithKey:(NSString * _Nonnull)key :(void (^ _Nonnull)(id _Nullable))completionHandler;
When using the getValue
method, note that the Any
return type will need to be cast to the data type you want.
This is how you can set properties on the current user profile:
It is important to remember that the key for custom user properties has a length limit. If the limit is exceeded (from 1 to 64 characters), the key will be truncated to the maximum allowed length
To get the current value stored in the user profile on the SDK, you need to use the method:
getValue(key: String, handler: (Any?) -> Unit)
When using the getValue
method, note that the Any
return type will need to be cast to the data type you want.
This is how you can set properties on the current user profile:
It is important to remember that the key for custom user properties has a length limit. If the limit is exceeded (from 1 to 64 characters), the key will be truncated to the maximum allowed length
To get the current value stored in the user profile on the SDK, you need to use the method:
When using the Get
method, note that the object
return type will need to be cast to the data type you want.
This is how you can set properties on the current user profile:
It is important to remember that the key for custom user properties has a length limit. If the limit is exceeded (from 1 to 64 characters), the key will be truncated to the maximum allowed length
To get the current value stored in the user profile on the SDK, you need to use the method:
When using the Get
method, note that the object
return type will need to be cast to the data type you want.
This is how you can set properties on the current user profile:
It is important to remember that the key for custom user properties has a length limit. If the limit is exceeded (from 1 to 64 characters), the key will be truncated to the maximum allowed length
To get the current value stored in the user profile on the SDK, you need to use the method:
This is how you can set properties on the current user profile:
It is important to remember that the key for custom user properties has a length limit. If the limit is exceeded (from 1 to 64 characters), the key will be truncated to the maximum allowed length
To get the current value stored in the user profile on the SDK, you need to use methods:
It removes a property or a list of properties and their values from the current user profile.
To remove all properties from the user card, use:
Keep in mind that the cheater mark is not cleared from the user card; you can only uncheck the mark manually using the setCheater
method.
Keep in mind that the cheater mark is not cleared from the user card; you can only uncheck the mark manually using the setCheater
method.
Keep in mind that the cheater mark is not cleared from the user card; you can only uncheck the mark manually using the setCheater
method.
Keep in mind that the cheater mark is not cleared from the user card; you can only uncheck the mark manually using the SetCheater
method.
Keep in mind that the cheater mark is not cleared from the user card; you can only uncheck the mark manually using the SetCheater
method.
Keep in mind that the cheater mark is not cleared from the user card; you can only uncheck the mark manually using the setCheater
method.
Keep in mind that the cheater mark is not cleared from the user card; you can only uncheck the mark manually using the SetCheater
method.
Please do the following to integrate your web application with devtodev:
1. Add the application to the Space using the wizard for adding applications.
2. To integrate SDK, add the following line to the tag of your page:
3. Init the SDK.
In order for SDK for WEB to start working, it is necessary to perform initialization right after the page is loaded and you have a basic user identifier at your disposal.
You can find the App ID in the settings of the respective app in devtodev (Settings → SDK → Integration → Credentials).
config
- is an object that is used for specifying additional properties during initialization.
Config
Example:
The SDK can be found in the devtodev . Download the latest release of the . Unzip the archive and copy the DTDMessaging
folder to the Plugins folder of your project.
If you have a C++ type project, add DTDMessaging
to the list of dependency names in the <module_name>.Build.cs
file of the module in which you plan to use the plugin.
Example:
Add your google-services.json
file to the project's root directory. It will be used to configure notifications during the project-building process.
In the case your Unreal Engine is built from GitHub source code:
Enable notifications in the settings of your project: Edit → Project Settings → iOS → Enable Remote Notifications Support
In the case your Unreal Engine is not built from GitHub source code:
Add the parameter to the engine configuration file (<proj_dir>/Config/DefaultEngine.ini
):
class UDTDMessagingBPLibrary
A class that implements analytic methods.
Header file:
enum class EDTDNotificationActionType : uint8
Notification action type
Header file:
Values:
App = 0
- default value
Url = 1
- external link opening
Share = 2
- share contentc
DeepLink = 2
- an in-app link opening
struct FDTDNotification
Notification data container.
Header file:
struct FDTDNotificationAction
Notification action data container.
Header file:
enum class EDTDIOSNotificationOptions : uint8
iOS only
Push Notification display settings are Bitflags
that are managed by the developer and allow for selecting the method of user notification. It can be altered by the end user.
By default, it has the value: Badge|Sound|Alert
Header file:
Values:
None = 0
- nothing
Badge = 1 << 0
- can display a badge on the app icon
Sound = 1 << 1
- can play a sound
Alert = 1 << 2
- can display an alert
CarPlay = 1 << 3
- can display a push notification on CarPlay
CriticalAlert = 1 << 4
- critical alerts can play a sound even if Do Not Disturb is enabled (critical alerts require a special entitlement issued by Apple). Available from iOS 12 onwards.
AppNotificationSettings = 1 << 5
- this option defines that the system should display a notification settings button in the app. Available from iOS 12.0 onwards.
Provisional = 1 << 6
- an option for sending provisional notifications to the Notification Center without interrupting functioning processes. Available from iOS 12.0 onwards.
Provisional - Provisional push notifications are shown in the User Notification Center but not on the lock screen. This type of push notification doesn’t require an explicit opt-in from the user. You can start sending them as soon as the user installs and launches your app. However, the user can also explicitly enable/disable your notifications.
Use this setting to avoid the permission request on app launch because it is seen as intrusive, and most users opt out of it.
It’s also important that when using the Provisional setting, the user needs to go to Notification Center settings to allow explicit notifications.
Delegates
Header file:
Delegates:
Notification module initialization:
SetAvailability
A method responsible for enabling/disabling push notifications. When the state changes, it sends an event that includes the availability status (true or false). The availability status flag is stored in the SDK.
GetAvailability
Get the current availability
status flag (true or false):
GetToken
Get a current unique device ID used in the notification system:
SetTokenListener
Set a token listener. The listener will be executed when the SDK updates a unique device ID in the notification system.
SetTokenErrorListener
Set a listener for errors in token reception. The listener will be executed when an error occurs while the SDK updates a unique device ID in the notification system.
SetNotificationReceiveListener
Set a listener for notification reception. The listener will be executed when the SDK receives a notification.
SetInvisibleNotificationReceiveListener
Set a listener for invisible notification reception. The listener will be executed when the SDK receives an invisible notification.
SetNotificationActionListener
Set a listener for notification activation. The listener will be executed when the notification gets activated.
IOSSetNotificationOptions
iOS only
Set notification parameters.
An int32 type value is used as an argument of this method. However, this argument should be calculated by using enumerators of EDTDIOSNotificationOptions
and bitwise OR operator.
Android Push Notifications
Push Notifications on Android are sent with the help of the FCM service.
How to create a project in Firebase and integrate Firebase Services into your application, you can find in .
Next, you need to specify the FCM Server key in the push notifications integration settings panel in the application settings section in devtodev service (App → Settings → Push notifications → Push notifications panel)
To get the FCM Server key, go to the Project Settings of your Android project in the Firebase Console and copy the Server key from the Cloud Messaging tab.
1. If you use Gradle for the applications build, add mavenCentral()
into gradle.build file of your application and specify the following relationship in dependencies block:
2. To the app manifest add the following:
3. To add a user icon to your push notification and change its color, add the following strings to the manifest file code:
To add a large user icon to your push notifications, add:
Example:
4. After the DTDAnalytics
initializer, add the DTDMessaging
initializer.
Example:
5. Subscribe a DTDPushListener
to receive information about the DTDMessaging
functioning.
Example:
6. Call the DTDMessaging.startPushService()
method to activate the Messaging module.
DTDMessaging
moduleDTDPushListener
Interface MethodsDTDPushMessage
).DTDActionButton
)This SDK version does not support WebGL. WebGL support will be added in the next releases.
If you have previously used the Unity SDK version 2+, you need to delete the following files and folders in the "Assets" folder of your project:
1.
Attention! When importing to Unity 2020, you may face the following error:
Assembly 'Assets/Plugins/DevToDev/Analytics/Windows/AnalyticsWindowsEditor.dll' will not be loaded due to errors: AnalyticsWindowsEditor references strong named Newtonsoft.Json Assembly references: 13.0.0.0 Found in project: 12.0.0.0. Assembly Version Validation can be disabled in Player Settings "Assembly Version Validation"
The error might occur due to the conflict between our package’s NewtonsoftJson
dependency version and the one used in the VersionControl
package. There are two ways to resolve this issue:
A. If you don’t use the VersionControl
package, remove it from the package list. Choose Window->Package Manager in the Unity window:
In the window that appears, choose Packages: In Project from a drop-down list at the top. After that, select Version Control from the package list and click Remove.
B. If you use Unity’s Version Control, you need to replace the newtonsoft.Json package
. Open the directory of your main project (the one you want to integrate analytics with) MainProject\Library\PackageCache\
and move the com.unity.nuget.newtonsoft-json
folder to the MainProject\Packages\
folder. It should look something like this:
2. Create a script with the following code and attach it to the GameObject
that will survive the entire life cycle of the app.
You can find the AppID in the settings of the respective app in devtodev (Settings → SDK → Integration → Credentials).
config
- an object instance of DTDAnalyticsConfiguration
, which is used for specifying additional properties during the initialization.
DTDAnalyticsConfiguration
Example:
SDK Activity
The SDK can’t control app activity in case you use Windows Standalone therefore this responsibility is shifted to the developer. While initializing the SDK, the activity starts automatically and after that, the activity status will not auto-change. To track app activity, the developer can use the following methods: DTDAnalytics.StartActivity
and DTDAnalytics.StopActivity
. It is recommended to use the DTDAnalytics.StopActivity
method to stop activity when the app goes into the background or gets closed. You can use the DTDAnalytics.StartActivity
method to resume activity when the app gets reopened from the taskbar.
For other platforms, there is no need to manually call the DTDAnalytics.StartActivity
and DTDAnalytics.StopActivity
methods.
To integrate with Xcode, the SDK uses PostProcessBuild
in the DTDPostProcessAnalytics
and DTDPostProcessMessaging
scripts. If you use custom PostProcessBuild
scripts, add them callbackOrder
of less than 98
to avoid conflicts.
If you want to disable tracking of advertising identifiers, you need to open the DTDPostProcesssAnalytics.cs
file and comment out the line 39
.
The event is used for individual tracking of ad revenue on user devices. The method is used if there are CPI data available on the client device (they can be obtained from the ad network SDK).
Do not apply this method if you use ad networks that utilize the server-server protocol for sending ad revenue data (ironSource, AppLovin MAX, and Fyber networks) and you already set up this method of data collection because if you use both data sources, your revenue data may be duplicated.
Parameter | Type | Restrictions | Description |
---|
Parameter | Type | Restrictions | Description |
---|
Parameter | Type | Restrictions | Description |
---|
The event is used to track connections to social media channels.
Use the following constants to specify a social network:
.facebook, .vkontakte , .twitter, .googleplus, .whatsapp, .viber, .evernote, .googlemail, .linkedin, .pinterest, .qzone, .reddit, .renren, .tumblr
Or create an object with the desired social media name.
Use the following constants to specify a social network:
.facebook, .vkontakte , .twitter, .googleplus, .whatsapp, .viber, .evernote, .googlemail, .linkedin, .pinterest, .qzone, .reddit, .renren, .tumblr
Or create an object with the desired social media name.
Use the following constants to specify a social network:
DTDSocialNetwork.facebook, DTDSocialNetwork.vkontakte , DTDSocialNetwork.twitter, DTDSocialNetwork.googleplus, DTDSocialNetwork.whatsapp, DTDSocialNetwork.viber, DTDSocialNetwork.evernote, DTDSocialNetwork.googlemail, DTDSocialNetwork.linkedin, DTDSocialNetwork.pinterest, DTDSocialNetwork.qzone, DTDSocialNetwork.reddit, DTDSocialNetwork.renren, DTDSocialNetwork.tumblr
Or create an object with the desired social media name.
Use the following constants to specify a social network:
DTDSocialNetwork.facebook, DTDSocialNetwork.vkontakte , DTDSocialNetwork.twitter, DTDSocialNetwork.googleplus, DTDSocialNetwork.whatsapp, DTDSocialNetwork.viber, DTDSocialNetwork.evernote, DTDSocialNetwork.googlemail, DTDSocialNetwork.linkedin, DTDSocialNetwork.pinterest, DTDSocialNetwork.qzone, DTDSocialNetwork.reddit, DTDSocialNetwork.renren, DTDSocialNetwork.tumblr
Or create an object with the desired social media name:
Use the following constants to specify a social network:
DTDSocialNetwork.facebook, DTDSocialNetwork.vkontakte , DTDSocialNetwork.twitter, DTDSocialNetwork.googleplus, DTDSocialNetwork.whatsapp, DTDSocialNetwork.viber, DTDSocialNetwork.evernote, DTDSocialNetwork.googlemail, DTDSocialNetwork.linkedin, DTDSocialNetwork.pinterest, DTDSocialNetwork.qzone, DTDSocialNetwork.reddit, DTDSocialNetwork.renren, DTDSocialNetwork.tumblr
Or create an object with the desired social media name:
Or use special method for custom social network:
Track social media posts and analyze their effectiveness and virality. Pass the event after the post has been approved by social media.
If you have referral information, you can pass it using the following method:
To send an event packet before it is full (10 events, by default) or before the end of the period of its formation (2 minutes, by default), you can use immediate dispatch.
We don’t recommend using this method unless absolutely necessary! When the Real payment event is created, the forced dispatch of the packet occurs automatically.
When working with getters you should take into account that the new devtodev SDK is completely asynchronous. The execution result must be processed within the completionHandler
.
All set and get methods need to be called only after the initialization of the SDK.
It is also worth remembering that the SDK will call the callback in background queues, so we recommend that you transfer the processing of return values to the queue you need.
For example:
This method denies/allows tracking of user data and also implements the right to be forgotten in accordance with the requirements of the GDPR.
When this method is called with the 'false' value, the SDK sends a command to the server to delete all personal user data that was collected by devtodev in this application, blocking further user data collection.
The user will remain in the devtodev system only as an impersonal unit in the previously aggregated metrics.
If it is set to ‘true', tracking can be enabled again. In this case, the user will be considered new.
To enable/disable user tracking by the devtodev system. Bool type.
Get device ID. String type.
Get the version of the integrated devtodev SDK. String type.
Retrieving the saved state of the user tracking permission by the devtodev system. See “Setting User Tracking Status”. Bool type.
devtodev ID is the primary numeric identifier for the device/user account in the devtodev database. Using devtodev ID, you are sure to find the user in devtodev.
The identifier will be received from the server some time after the initialization of the SDK.
If you have set counting by users, a separate devtodev id will be issued for each device user.
To obtain the devtodev ID, you need to pass the listener to DTDAnalytics
:
The delegate must implement the func didReceiveDevtodevId(with devtodevId: Int)
The didReceiveDevtodevId
method will be called with every ID change on the server side.
To obtain the devtodev ID, you need to pass the listener to DTDAnalytics
:
The delegate must implement the (void)didReceiveDevtodevIdWith:(NSInteger)devtodevId;
The didReceiveDevtodevId
method will be called with every ID change on the server side.
To obtain the devtodev ID, you need to pass the DTDIdentifiersListener
listener to DTDAnalytics
:
The didReceiveDevtodevId
method will be called with every ID change on the server side.
To obtain the devtodev ID, you need to pass the DTDIdentifiersListener
listener delegate to DTDAnalytics
:
The delegate
method will be called with every ID change on the server side.
To obtain the devtodev ID, you need to pass the DTDIdentifiersListener
listener delegate to DTDAnalytics
:
The delegate
method will be called with every ID change on the server side.
Member | Type | Description |
---|---|---|
Member | Type | Description |
---|---|---|
Member | Type | Description |
---|---|---|
Member | Type | Description |
---|---|---|
Member | Type | Description |
---|---|---|
Member | Type | Description |
---|---|---|
Member | Type | Description |
---|---|---|
Member | Type | Description |
---|---|---|
2. Add DTDAnalytics.xcframework
to the project (with Do Not Embed specified)
Value | Meaning |
---|---|
Value | Meaning |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Value | Meaning |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Restrictions |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Type | Restrictions |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Type | Restrictions |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Type | Restrictions |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Type | Restrictions |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Type | Restrictions |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Type | Restrictions |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Type | Restrictions |
---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Parameter | Type | Restrictions | Description |
---|---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Property | Setter | Getter |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Arguments | Type | Description |
---|---|---|
Member | Type | Description |
---|
Member | Type | Description |
---|
Arguments | Type | Description |
---|
Arguments | Type | Description |
---|
Arguments | Type | Description |
---|
Arguments | Type | Description |
---|
Arguments | Type | Description |
---|
Arguments | Type | Description |
---|
Arguments | Type | Description |
---|
Arguments | Type | Description |
---|
The Messaging module is available as an AAR (recommended) and JAR library. The library is available in the MavenCentral and .
Add the following strings to proguard.txt ():
Your app must request tracking authorization before it can get the advertising identifier. See on how to request it.
Parameter | Type | Restrictions | Description |
---|
Parameter | Type | Restrictions | Description |
---|
Parameter
Type
Description
currentLevel
int
The player level at the moment of devtodev SDK initialization. It is recommended (but optional) to use to improve data precision.
userId
string
A custom user identifier provided by the developer. If you utilize the default calculation by the device ID, this identifier can be used for finding a user in devtodev.
In case your project utilizes the calculation by the user identifier, you must set this parameter because it becomes the main user identifier in devtodev.
trackingAvailability
DTDTrackingStatus (enum)
The property allows or disallows devtodev tracking of the user. By default, it is set to DTDTrackingStatus.enable
. SDK stores the previously assigned value. Pass DTDTrackingStatus.disable
if the user opted out of tracking in line with GDPR.
logLevel
DTDLogLevel (enum)
The level of logging the SDK activity. The DTDLogLevel.no
value is used by default. For troubleshooting during integration it is recommended to set it to DTDLogLevel.debug
, and either switch it off DTDLogLevel.no
or use it only for error handling DTDLogLevel.error
in the release version.
HasValue
bool
Option label
Value
int32
Parameter value
HasValue
bool
Option label
Value
FString
Parameter value
LogLevel
EDTDLogLevel
Logging level
CurrentLevel
FDTDOptionalInt32
Current level
UserId
FDTDOptionalString
User ID
ApplicationVersion
FDTDOptionalString
Application version (Windows)
TrackingAvailability
EDTDTrackingStatus
Tracking settings
StringParameters
TMap<FString, FString>
String parameters
IntParameters
TMap<FString, int64>
Integer parameters
FloatParameters
TMap<FString, float>
Real parameters (floating-point numbers)
BoolParameters
TMap<FString, bool>
Boolean parameters
Difficulty
FDTDOptionalInt32
Difficulty
Source
FDTDOptionalString
Source
SuccessfulCompletion
bool
Successful completion of the progression (‘false’ by default)
Duration
int32
Duration (if 0, duration is calculated automatically)
Spent
TMap<FString, int64>
Resources spent
Earned
TMap<FString, int64>
Resources earned
appKey
FString
You can find it in the settings of the corresponding application in devtodev (Settings → SDK → Integration → Credentials)
appKey
FString
You can find it in the settings of the corresponding application in devtodev (Settings → SDK → Integration → Credentials)
config
FDTDAnalyticsConfiguration
Initialization parameters
Parameter
Type
Description
currentLevel
Integer
The player level at the moment of devtodev SDK initialization. It’s optional but we recommend using it for improving data accuracy.
userId
String
A custom user ID assigned by the developer. In the case of default calculation by device IDs, the identifier can be used for searching users in devtodev. In case the project uses calculation by user IDs, the parameter is mandatory because it becomes the principal calculation ID in devtodev.
trackingAvailability
DTDTrackingStatus (enum)
The property allows or disallows devtodev tracking of the user. By default, it is set to DTDTrackingStatus.enable
. SDK stores the previously assigned value. Pass DTDTrackingStatus.disable
if the user opted out of tracking in line with GDPR.
logLevel
DTDLogLevel (enum)
The level of logging the SDK activity. The DTDLogLevel.no
value is used by default. For troubleshooting during integration it is recommended to set it to DTDLogLevel.debug
, and either switch it off DTDLogLevel.no
or use it only for error handling DTDLogLevel.error
in the release version.
Parameter
Type
Description
currentLevel
Integer
The player level at the moment of devtodev SDK initialization. It’s optional but we recommend using it for improving data accuracy.
userId
String
A custom user ID assigned by the developer. In the case of default calculation by device IDs, the identifier can be used for searching users in devtodev. In case the project uses calculation by user IDs, the parameter is mandatory because it becomes the principal calculation ID in devtodev.
trackingAvailability
DTDTrackingStatus (enum)
The property allows or disallows devtodev tracking of the user. By default, it is set to DTDTrackingStatus.Enable
. SDK stores the previously assigned value. Pass DTDTrackingStatus.Disable
if the user opted out of tracking in line with GDPR.
logLevel
DTDLogLevel (enum)
The level of logging the SDK activity. The DTDLogLevel.No
value is used by default. For troubleshooting during integration, it is recommended to set it to DTDLogLevel.Debug
, and either switch it off DTDLogLevel.No
or use it only for error handling DTDLogLevel.Error
in the release version.
Parameter
Type
Description
currentLevel
Integer
The player level at the moment of devtodev SDK initialization. It’s optional but we recommend using it for improving data accuracy.
userId
String
A custom user ID assigned by the developer. In the case of default calculation by device IDs, the identifier can be used for searching users in devtodev. In case the project uses calculation by user IDs, the parameter is mandatory because it becomes the principal calculation ID in devtodev.
trackingAvailability
DTDTrackingStatus (enum)
The property allows or disallows devtodev tracking of the user. By default, it is set to DTDTrackingStatus.Enabl
e
. SDK stores the previously assigned value. Pass DTDTrackingStatus.Disable
if the user opted out of tracking in line with GDPR.
logLevel
DTDLogLevel (enum)
The level of logging the SDK activity. The DTDLogLevel.No
value is used by default. For troubleshooting during integration, it is recommended to set it to DTDLogLevel.Debug
, and either switch it off DTDLogLevel.No
or use it only for error handling DTDLogLevel.Error
in the release version.
ApplicationVersion
String
The app version during the devtodev SDK initialization. It is recommended that you set the app version before the initialization to make the collection of app version statistics more precise.
Property
Description
receiptStatus
Enum type DTDReceiptStatus
that represents the result of the transaction validation.
verificationResult
Additional information from the validation server.
Value
Description
receiptValid
The payment is valid, the transaction is genuine.
receiptNotValid
The payment is invalid, the transaction may be a duplicate or fraud.
receiptServerError
Server error when validating the payment.
receiptSandbox
Test payment.
receiptInternalError
Internal SDK error.
Property
Description
receiptStatus
Enum type DTDReceiptStatus
that represents the result of the transaction validation.
verificationResult
Additional information from the validation server.
Value
Description
receiptValid
The payment is valid, the transaction is genuine.
receiptNotValid
The payment is invalid, the transaction may be a duplicate or fraud.
receiptServerError
Server error when validating the payment.
receiptSandbox
Test payment.
receiptInternalError
Internal SDK error.
Property
Description
receiptStatus
Enum type DTDReceiptStatus
that represents the result of the transaction validation.
verificationResult
Additional information from the validation server.
Value
Description
receiptValid
The payment is valid, the transaction is genuine.
receiptNotValid
The payment is invalid, the transaction may be a duplicate or fraud.
receiptServerError
Server error when validating the payment.
receiptInternalError
Internal SDK error.
Property
Description
ReceiptStatus
Enum type DTDReceiptStatus
that represents the result of the transaction validation.
VerificationResult
Additional information from the validation server.
Value
Description
Valid = 0L
The payment is valid, the transaction went through successfully
Invalid = 1L
The payment is invalid, the transaction may be a duplicate or fraud
ServerError = 2L
Server error when validating the payment
InternalError = 4L
Internal SDK error
Property
Description
receiptStatus
Enum type DTDReceiptStatus
that represents the result of the transaction validation.
verificationResult
Additional information from the validation server.
Value
Description
receiptValid
The payment is valid, the transaction is genuine.
receiptNotValid
The payment is invalid, the transaction may be a duplicate or fraud.
receiptServerError
Server error when validating the payment.
receiptSandbox
Test payment.
receiptInternalError
Internal SDK error.
Object
Type
Description
startPushService
Method responsible for activating push notifications:
Requests permission from the user to receive Push Notifications
Sends a pushToken and the current state isAllowed
apnsToken
Data?
Getter giving the current pushToken, represented by a Data
apnsTokenString
String?
Getter giving the current pushToken, represented by a String
delegate
DTDMessagingDelegate?
Property for assigning a delegate to handle events from the SDK
pushNotificationsOptions
DTDNotificationOptions
Configuring the display of Push Notifications, is an OptionSet
, is set by the developer to select the method for notifying the user. May be changed by the end user.
By default it has the following value: [.DTDNotificationOptionBadge, .DTDNotificationOptionSound, .DTDNotificationOptionAlert]
Delegate method
Description
didFailToRegisterForRemoteNotifications
(with error:
Error
)
The method is called when an error occurs at the time of receiving a pushToken, represented by the Error
base class.
didOpenRemoteNotification
(with message:
DTDMessage
, and buttonClicked:
DTDActionButton?
)
The method is called when a remote push notification is opened by an end user. A DTDMessage
object and an optional DTDActionButton
object are passed.
didReceiveForegroundNotification
(with message:
DTDMessage
)
The method is called when a remote push notification is received when the application is in the Foreground state. The DTDMessage
object is passed.
didReceiveInvisibleNotification
(with message:
DTDMessage
)
The method is called when an invisible remote push notification is received. The DTDMessage
object is passed.
didRegisterForRemoteNotifications
(with deviceToken:
Data
)
The method is called in case the pushToken
successfully arrives; represented by a Data.
Property
Type
Description
payload
[AnyHashable:Any]
Full information sent using remote push notification.
actionType
DTDActionType
Property returning the enum DTDActionType value. Possible values:
App
- default value
Url
- open an external link
Share
- share content
Deeplink
- open a link inside the application
actionString
String?
Property returning an optional action identifier.
badge
Int
The value that is passed to display a badge on the application icon.
category
String?
Property returning an optional identifier of a push notification category
Property
Type
Description
actionType
DTDActionType
Property returning the enum DTDActionType value. Possible values:
App
- default value
Url
- open an external link
Share
- share content
Deeplink
- open a link inside the application
actionString
String?
Property returning an optional action identifier.
buttonId
String
Property returning the identifier of the pressed button.
text
String
Property returning the text of the pressed button.
Value
Description
DTDNotificationOptionBadge
display a badge on the application icon
DTDNotificationOptionSound
play sound
DTDNotificationOptionAlert
display an alert
DTDNotificationOptionCarPlay
display push notification in CarPlay
DTDNotificationOptionCriticalAlert
play sound for critical notifications regardless of the “Do Not Disturb” setting (Critical alerts require special permission from Apple.) Available since iOS 12.0
DTDNotificationOptionProvidesSettings
an option specifying that the system should display a button for notification settings in the application. Available since iOS 12.0
DTDNotificationOptionProvisional
pre-send notifications to the Action Center without interrupting work. Available since iOS 12.0
DTDNotificationOptionAnnouncement
for Siri to automatically read messages through AirPods. Available since iOS 13.0
0
The user skipped the tutorial
-1
The value defines the beginning of the tutorial
1..int
Counting number of completed tutorial stage
-2
The value defines the completion of the tutorial
0
The user skipped the tutorial
-1
The value defines the beginning of the tutorial
1..int
Counting number of completed tutorial stage
-2
The value defines the completion of the tutorial
step
int32
From 1 to int32.MaxValue - 1
Tutorial step
0
The user skipped the tutorial
-1
The value defines the beginning of the tutorial
1..int32
Counting number of completed tutorial stage
-2
The value defines the completion of the tutorial
0
The user skipped the tutorial
-1
The value defines the beginning of the tutorial
1..int
Counting number of completed tutorial stage
-2
The value defines the completion of the tutorial
0
The user skipped the tutorial
-1
The value defines the beginning of the tutorial
1..int
Counting number of completed tutorial stage
-2
The value defines the completion of the tutorial
0
The user skipped the tutorial
-1
The value defines the beginning of the tutorial
1..int
Counting number of completed tutorial stage
-2
The value defines the completion of the tutorial
0
The user skipped the tutorial
-1
The value defines the beginning of the tutorial
1..int
Counting number of completed tutorial stage
-2
The value defines the completion of the tutorial
level
int
From 1 to Int32.max - 1
Level reached
balances
[String:Int]
String - from 1 to 24 symbols
Int - from Int64.min to int64.max
Resources’ names and number at the time of level up
level
int
From 1 to Int32.max - 1
Level reached
balances
[String:Int]
String - from 1 to 24 symbols
Int - from Int64.min to int64.max
Resources’ names and number at the time of level up
level
int
From 1 to Int.max - 1
Level reached
balances
[String:Long]
String - from 1 to 24 symbols
Long - from Long.min to Long.max
Resources’ names and number at the time of level up
level
int
From 1 to int.MaxValue - 1
Level reached
balances
[string: long]
String - from 1 to 24 symbols
Long - from long.MinValue to long.MaxValue
Resources’ names and number at the time of level up
level
int
From 1 to int32.MaxValue - 1
Level reached
balances
[string: long]
String - from 1 to 24 symbols
Long - from long64.MinValue to long64.MaxValue
Resources’ names and number at the time of level up
level
int
From 1 to int.MaxValue - 1
Level reached
balances
[string: long]
String - from 1 to 24 symbols
Long - from long.MinValue to long.MaxValue
Resources’ names and number at the time of level up
spent
[string: long]
String - from 1 to 24 symbols Long - from 0 to Number.MAX_SAFE_INTEGER
Game currency amount spent during the level. Optional.
earned
[string: long]
String - from 1 to 24 symbols Long - from 0 to Number.MAX_SAFE_INTEGER
Game currency earned during the level. Optional.
bought
[string: long]
String - from 1 to 24 symbols Long - from 0 to Number.MAX_SAFE_INTEGER
Game currency amount bought during the level. Optional.
level
int32
From 1 to int32.MaxValue - 1
Level reached
level
int32
From 1 to int32.MaxValue - 1
Level reached
balance
TMap<FString, int64>
FString - from 1 to 24 symbols
int64 - from int64.MinValue to int64.MaxValue
Resources’ names and number at the time of level up
balance
TMap<FString, int64>
FString - from 1 to 24 symbols
int64 - from int64.MinValue to int64.MaxValue
Resources’ names and number
currencyName
string
from 1 to 24 symbols
In-game currency/resource name
currencyAmount
int
from 1 to Int32.max
Amount of currency in circulation
source
string
from 1 to 23 symbols
The sources of currency/resources. It can be used for breaking down income by its sources. For example, a city builder game may have some: “Rent” for the profit received from rental property, or “Bank” if the player has purchased some currency.
accrualType
DTDAccrualType (enum)
The currency/resource source type. The player can either gain resources during the game (earned
) or purchase them for money (bought
)
currencyName
string
from 1 to 24 symbols
In-game currency/resource name
currencyAmount
int
from 1 to Int32.max
Amount of currency in circulation
source
string
from 1 to 23 symbols
The sources of currency/resources. It can be used for breaking down income by its sources. For example, a city builder game may have some: “Rent” for the profit received from rental property, or “Bank” if the player has purchased some currency.
accrualType
DTDAccrualType (enum)
The currency/resource source type. The player can either gain resources during the game (earned
) or purchase them for money (bought
)
currencyName
string
from 1 to 24 symbols
In-game currency/resource name
currencyAmount
int
from 1 to Int.max
Amount of currency in circulation
source
string
from 1 to 23 symbols
The sources of currency/resources. It can be used for breaking down income by its sources. For example, a city builder game may have some: “Rent” for the profit received from rental property, or “Bank” if the player has purchased some currency.
accrualType
DTDAccrualType (enum)
The currency/resource source type. The player can either gain resources during the game (earned
) or purchase them for money (bought
)
currencyName
string
from 1 to 24 symbols
In-game currency/resource name
currencyAmount
int
from 1 to Int.MaxValue
Amount of currency in circulation
source
string
from 1 to 23 symbols
The sources of currency/resources. It can be used for breaking down income by its sources. For example, a city builder game may have some: “Rent” for the profit received from rental property, or “Bank” if the player has purchased some currency.
accrualType
DTDAccrualType (enum)
The currency/resource source type. The player can either gain resources during the game (earned
) or purchase them for money (bought
)
currencyName
string
from 1 to 24 symbols
In-game currency/resource name
currencyAmount
int
from 1 to Int32.MaxValue
Amount of currency in circulation
source
string
from 1 to 23 symbols
The sources of currency/resources. It can be used for breaking down income by its sources. For example, a city builder game may have some: “Rent” for the profit received from rental property, or “Bank” if the player has purchased some currency.
accrualType
DTDAccrualType (enum)
The currency/resource source type. The player can either gain resources during the game (earned
) or purchase them for money (bought
)
currencyName
string
from 1 to 24 symbols
In-game currency/resource name
currencyAmount
int
from 1 to Int.max
Amount of currency in circulation
source
string
from 1 to 23 symbols
The sources of currency/resources. It can be used for breaking down income by its sources. For example, a city builder game may have some: “Rent” for the profit received from rental property, or “Bank” if the player has purchased some currency.
accrualType
int
The currency/resource source type. The player can either gain resources during the game (0
) or purchase them for money (1
)
currencyName
FString
from 1 to 24 symbols
In-game currency/resource name
currencyAmount
int32
from 1 to Int32.MaxValue
Amount of currency in circulation
source
FString
from 1 to 23 symbols
The sources of currency/resources. It can be used for breaking down income by its sources. For example, a city builder game may have some: “Rent” for the profit received from rental property, or “Bank” if the player has purchased some currency.
accrualType
EDTDAccrualType
The currency/resource source type. The player can either gain resources during the game (earned
) or purchase them for money (bought
)
purchaseId
string
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
string
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int
from 1 to Int32.max
The number of units of goods purchased.
purchaseCurrency
string
from 1 to 24 symbols
The name of a currency used for the purchase.
purchasePrice
int
from 1 to Int32.max
The price of the purchased item in the specified in-game currency.
purchaseId
string
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
string
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int
from 1 to Int32.max
The number of units of goods purchased.
purchaseCurrency
string
from 1 to 24 symbols
The name of a currency used for the purchase.
purchasePrice
int
from 1 to Int32.max
The price of the purchased item in the specified in-game currency.
purchaseId
string
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
string
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int
from 1 to Int.max
The number of units of goods purchased.
purchaseCurrency
string
from 1 to 24 symbols
The name of a currency used for the purchase.
purchasePrice
int
from 1 to Int.max
The price of the purchased item in the specified in-game currency.
purchaseId
string
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
string
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int
from 1 to int.MaxValue
The number of units of goods purchased.
purchaseCurrency
string
from 1 to 24 symbols
The name of a currency used for the purchase.
purchasePrice
int
from 1 to int.MaxValue
The price of the purchased item in the specified in-game currency.
purchaseId
string
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
string
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int
from 1 to Int32.MaxValue
The number of units of goods purchased.
purchaseCurrency
string
from 1 to 24 symbols
The name of a currency used for the purchase.
purchasePrice
int
from 1 to Int32.MaxValue
The price of the purchased item in the specified in-game currency.
purchaseId
string
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
string
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int
from 1 to Number.MAX_SAFE_INTEGER
The number of units of goods purchased.
purchaseCurrency
string
from 1 to 24 symbols
The name of a currency used for the purchase.
purchasePrice
int
from 1 to Number.MAX_SAFE_INTEGER
The price of the purchased item in the specified in-game currency.
purchaseId
FString
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
FString
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int32
from 1 to Int32.MaxValue
The number of units of goods purchased.
purchaseCurrency
FString
from 1 to 24 symbols
The name of a currency used for the purchase.
purchasePrice
int32
from 1 to Int32.MaxValue
The price of the purchased item in the specified in-game currency.
purchaseId
FString
from 1 to 32 symbols
A unique purchase name or ID. Make sure that the names are always in the same language otherwise they will be listed as different items.
purchaseType
FString
from 1 to 96 symbols
The name of a resource group. For example, for “Wood” it can be “Construction materials”.
purchaseAmount
int32
from 1 to int32.MaxValue
The number of units of goods purchased.
resources
TMap<FString, int32>
FString - from 1 to 24 symbols
int32 - from 1 to int32.MaxValue
Map with resources.
orderId
string
from 1 to 65 symbols
A unique transaction ID. Use transactionIdentifier
property value in SKPaymentTransaction
object in a complete transaction receipt.
currencyCode
string
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
double
from Double.min to Double.max
The item price in the transaction currency.
productId
string
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
orderId
string
from 1 to 65 symbols
A unique transaction ID. Use transactionIdentifier
property value in SKPaymentTransaction
object in a complete transaction receipt.
currencyCode
string
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
double
from Double.min to Double.max
The item price in the transaction currency.
productId
string
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
orderId
string
from 1 to 65 symbols
A unique transaction ID.
currencyCode
string
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
double
from Double.min to Double.max
The item price in the transaction currency.
productId
string
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
orderId
string
from 1 to 65 symbols
A unique transaction ID.
currencyCode
string
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
double
from double.MinValue to double.MaxValue
The item price in the transaction currency.
productId
string
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
orderId
string
from 1 to 65 symbols
A unique transaction ID.
currencyCode
string
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
double
from Double.MinValue to Double.MaxValue
The item price in the transaction currency.
productId
string
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
orderId
string
from 1 to 65 symbols
A unique transaction ID.
currencyCode
string
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
double
from Number.MIN_VALUE to Number.MAX_VALUE
The item price in the transaction currency.
productId
string
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
orderId
FString
from 1 to 65 symbols
A unique transaction ID.
currencyCode
FString
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
float
from float.MinValue to float.MaxValue
The item price in the transaction currency.
productId
FString
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
Parameter
Type
Restrictions
Description
orderId
string
from 1 to 65 symbols
A unique transaction identifier.
currencyCode
string
precisely 3 symbols
Transaction currency (ISO 4217 standard) e.g. USD, EUR etc.
price
double
from Double.min to Double.max
The item price in the transaction currency.
productId
string
from 1 to 255 symbols
Item name. We recommend using a bundle or names in the same language.
eventName
string
from 1 to 72 symbols
Custom event name.
parameters
DTDCustomEventParameters
key - from 1 to 32 symbols
value - see below
Custom event parameters.
int
from Int64.min to Int64.max
string
from 1 to 255 symbols
bool
true/false
double
from Double.min to Double.max
eventName
string
from 1 to 72 symbols
Custom event name.
parameters
DTDCustomEventParameters
key - from 1 to 32 symbols
value - see below
Custom event parameters.
int
from Int64.min to Int64.max
string
from 1 to 255 symbols
bool
true/false
double
from Double.min to Double.max
eventName
string
from 1 to 72 symbols
Custom event name.
parameters
DTDCustomEventParameters
key - from 1 to 32 symbols
value - see below
Custom event parameters.
Long
from Long.min to Long.max
String
from 1 to 255 symbols
Boolean
true/false
Double
from Double.min to Double.max
eventName
string
from 1 to 72 symbols
Custom event name.
parameters
DTDCustomEventParameters
key - from 1 to 32 symbols
value - see below
Custom event parameters.
long
from long.MinValue to long.MaxValue
string
from 1 to 255 symbols
bool
true/false
double
from double.MinValue to double.MaxValue
eventName
string
from 1 to 72 symbols
Custom event name.
parameters
DTDCustomEventParameters
key - from 1 to 32 symbols
value - see below
Custom event parameters.
long
from Int64.MinValue to Int64.MaxValue
string
from 1 to 255 symbols
bool
true/false
double
from Double.MinValue to Double.MaxValue
eventName
string
from 1 to 72 symbols
Custom event name.
parameters
object
key - from 1 to 32 symbols
value - see below
Custom event parameters.
long
from Number.MIN_SAFE_INTEGER to Number.MAX_SAFE_INTEGER
string
from 1 to 255 symbols
bool
true/false
double
from Number.MIN_VALUE to Number.MAX_VALUE
eventName
FString
from 1 to 72 symbols
Custom event name.
eventName
FString
from 1 to 72 symbols
Custom event name.
parameters
FDTDCustomEventParams
StringParameters (TMap<FString, FString>)
IntParameters (TMap<FString, int64>)
FloatParameters (TMap<FString, float>)
BoolParameters (TMap<FString, bool>)
key - from 1 to 32 symbols
value - see below
Custom event parameters.
Warning: avoid duplicate keys in all dictionaries. Because dictionaries are combined into a generic dictionary [string: any] in native code.
int64
from int64.MinValue to int64.MaxValue
FString
from 1 to 255 symbols
bool
true/false
float
from float.MinValue to float.MaxValue
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area.
source
string
from 1 to 40 symbols
The name of the previous event used for connecting events together. E.g. a previous area visited by the player.
difficulty
int
from 0 to Int32.max
An optional difficulty value which is set using the value: setDifficulty(difficulty: Int)
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area. It’s important to use the name that was specified at the area’s opening.
successfulCompletion
bool
true/false
The completion event result. ‘True’ if successful, ‘false’ if unsuccessful/lost.
duration
int
from 0 to Int64.max
Time in seconds taken to complete the area. If not specified, it is automatically calculated as the difference between startProgressionEvent
and finishProgressionEvent
method calls.
spent
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Int64.max
Resources consumed during an area completion.
earned
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Int64.max
Resources earned during an area completion.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area.
source
string
from 1 to 40 symbols
The name of the previous event used for connecting events together. E.g. a previous area visited by the player.
difficulty
int
from 0 to Int32.max
An optional difficulty value which is set using the value: setDifficulty(difficulty: Int)
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area. It’s important to use the name that was specified at the area’s opening.
successfulCompletion
bool
true/false
The completion event result. ‘True’ if successful, ‘false’ if unsuccessful/lost.
duration
int
from 0 to Int64.max
Time in seconds taken to complete the area. If not specified, it is automatically calculated as the difference between startProgressionEvent
and finishProgressionEvent
method calls.
spent
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Int64.max
Resources consumed during an area completion.
earned
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Int64.max
Resources earned during an area completion.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area.
source
string
from 1 to 40 symbols
The name of the previous event used for connecting events together. E.g. a previous area visited by the player.
difficulty
int
from 0 to Int32.max
An optional difficulty value which is set using the value: setDifficulty(difficulty: Int)
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area. It’s important to use the name that was specified at the area’s opening.
successfulCompletion
bool
true/false
The completion event result. ‘True’ if successful, ‘false’ if unsuccessful/lost.
duration
int
from 0 to Int64.max
Time in seconds taken to complete the area. If not specified, it is automatically calculated as the difference between startProgressionEvent
and finishProgressionEvent
method calls.
spent
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Int64.max
Resources consumed during an area completion.
earned
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Int64.max
Resources earned during an area completion.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area.
source
string
from 1 to 40 symbols
The name of the previous event used for connecting events together. E.g. a previous area visited by the player.
difficulty
int
from 0 to int.MaxValue
An optional difficulty value.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area. It’s important to use the name that was specified at the area’s opening.
successfulCompletion
bool
true/false
The completion event result. ‘True
’ if successful, ‘false
’ if unsuccessful/lost.
duration
int
from 0 to int.MaxValue
Time in seconds taken to complete the area. If not specified, it is automatically calculated as the difference between StartProgressionEvent
and FinishProgressionEvent
method calls.
spent
[String: Int]
key - from 1 to 24 symbols
value - From 0 to int.MaxValue
Resources consumed during an area completion.
earned
[String: Int]
key - from 1 to 24 symbols
value - From 0 to int.MaxValue
Resources earned during an area completion.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area.
source
string
from 1 to 40 symbols
The name of the previous event used for connecting events together. E.g. a previous area visited by the player.
difficulty
int
from 0 to Int32.MaxValue
An optional difficulty value.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area. It’s important to use the name that was specified at the area’s opening.
successfulCompletion
bool
true/false
The completion event result. ‘True
’ if successful, ‘false
’ if unsuccessful/lost.
duration
int
from 0 to Int64.MaxValue
Time in seconds taken to complete the area. If not specified, it is automatically calculated as the difference between StartProgressionEvent
and FinishProgressionEvent
method calls.
spent
[String: Int]
key - from 1 to 24 symbols
value - From 0 to Int64.MaxValue
Resources consumed during an area completion.
earned
[String: Int]
key - from 1 to 24 symbols
value - From 0 to Int64.MaxValue
Resources earned during an area completion.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area.
parameters
object
see below
Location event parameters.
source
string
from 1 to 40 symbols
The name of the previous event used for connecting events together. E.g. a previous area visited by the player.
difficulty
int
from 0 to Number.MAX_SAFE_INTEGER
An optional difficulty value.
eventName
string
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area. It’s important to use the name that was specified at the area’s opening.
parameters
object
see below
Location event parameters.
successfulCompletion
bool
true/false
The completion event result. ‘True’ if successful, ‘false’ if unsuccessful/lost.
duration
int
from 0 to Number.MAX_SAFE_INTEGER
Time in seconds taken to complete the area. If not specified, it is automatically calculated as the difference between startProgressionEvent
and finishProgressionEvent
method calls.
spent
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Number.MAX_SAFE_INTEGER
Resources consumed during an area completion.
earned
[String: Int]
key - from 1 to 24 symbols
value - from 0 to Number.MAX_SAFE_INTEGER
Resources earned during an area completion.
eventName
FString
from 1 to 72 symbols
Progression event name.
eventName
FString
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area.
params
FDTDStartProgressionEventParams
see below
Start progression event parameters.
source
FString
from 1 to 40 symbols
The name of the previous event used for connecting events together. E.g. a previous area visited by the player.
difficulty
int32
from 0 to int32.MaxValue
An optional difficulty value.
eventName
FString
from 1 to 72 symbols
Progression event name.
eventName
FString
from 1 to 40 symbols
The name of the event. It is usually the number or the name of the area. It’s important to use the name that was specified at the area’s opening.
parameters
FDTDFinishProgressionEventParams
see below
Finish progression event parameters.
successfulCompletion
bool
true/false
The completion event result. ‘True’ if successful, ‘false’ if unsuccessful/lost.
duration
int32
from 0 to int32.MaxValue
Time in seconds taken to complete the area. If not specified, it is automatically calculated as the difference between startProgressionEvent
and finishProgressionEvent
method calls.
spent
TMap<FString, int64>
key - from 1 to 24 symbols
value - from 0 to int64.MaxValue
Resources consumed during an area completion.
earned
TMap<FString, int64>
key - from 1 to 24 symbols
value - from 0 to int64.MaxValue
Resources earned during an area completion.
userId
FString
User ID.
onResult
FAnalyticsDynamicGetterStringDelegate
FDTDGetterStringDelegate
Callback
level
int32
Current level.
onResult
FAnalyticsDynamicGetterIntDelegate
FDTDGetterIntDelegate
Callback
cheater
bool
Cheater flag
onResult
FUserCardDynamicGetterBoolDelegate
FDTDGetterBoolDelegate
Callback
Property
Getter
Setter
Name
setName(name: String)
getName(completionHandler: @escaping (String?) -> Void)
setEmail(email: String)
getEmail(completionHandler: @escaping (String?) -> Void)
Phone
setPhone(phone: String)
getPhone(completionHandler: @escaping (String?) -> Void)
Photo
setPhoto(photo: String)
getPhoto(completionHandler: @escaping (String?) -> Void)
Gender
setGender(gender: DTDGender)
getGender(completionHandler: @escaping (DTDGender) -> Void)
Age
setAge(age: Int)
getAge(completionHandler: @escaping (Int) -> Void
Property
Setter
Getter
Age
[DTDUserCard setAge:(NSInteger)];
[DTDUserCard getAgeHandler:^(NSInteger age) { }]
[DTDUserCard setEmail:(NSString * _Nonnull)];
[DTDUserCard getEmailHandler:^(NSString * email) { }];
Gender
[DTDUserCard setGender:(enum Gender)];
[DTDUserCard getGenderHandler:^(enum Gender gender) { }];
Name
[DTDUserCard setName:(NSString * _Nonnull)];
[DTDUserCard getNameHandler:^(NSString * name) { }];
Phone
[DTDUserCard setPhone:(NSString * _Nonnull)];
[DTDUserCard getPhoneHandler:^(NSString * phone) { }];
Photo
[DTDUserCard setPhoto:(NSString * _Nonnull)];
[DTDUserCard getPhotoHandler:^(NSString * photo) { }];
Property
Getter
Setter
Name
setName(name: String)
getName(handler: (String) -> Unit)
setEmail(email: String)
getEmail(handler: (String) -> Unit)
Phone
setPhone(phone: String)
getPhone(handler: (String) -> Unit)
Photo
setPhoto(photo: String)
getPhoto(handler: (String) -> Unit)
Gender
setGender(gender: DTDGender)
getGender(handler: (DTDGender) -> Void)
Age
setAge(age: Int)
getAge(handler: (String) -> Unit)
Property
Getter
Setter
Name
SetName(name: string)
Task<string> GetName();
SetEmail(email: string)
Task<string> GetEmail()
Phone
SetPhone(phone: string)
Task<string> GetPhone()
Photo
SetPhoto(photo: string)
Task<string> GetPhoto()
Gender
SetGender(gender: DTDGender)
Task<DTDGender> GetGender()
Age
SetAge(age: long)
Task<long> GetAge()
Property
Getter
Setter
Name
SetName(name: string)
GetName(Action<string> onGetName)
SetEmail(email: string)
GetEmail(Action<string> onGetEmail)
Phone
SetPhone(phone: string)
GetPhone(Action<string> onGetPhone)
Photo
SetPhoto(photo: string)
GetPhoto(Action<string> onGetPhoto)
Gender
SetGender(gender: DTDGender)
GetGender(Action<DTDGender> onGetGender)
Age
SetAge(age: long)
GetAge(Action<string> onGetAge)
Property
Getter
Setter
Type
Name
getName()
setName("John Doe")
String
getEmail()
setEmail("email@me.com")
String
Phone
getPhone()
setPhone("+15555555555")
String
Photo
getPhoto()
setPhoto("https://domain.com/photo.jpg")
String
Gender
getGender()
setGender(gender)
Age
getAge()
setAge(age)
Int
Name
SetName(name: FString)
GetName(delegate: FUserCardDynamicGetterStringDelegate)
GetName(delegate: FDTDGetterStringDelegate)
Email
SetEmail(email: FString)
GetEmail(delegate: FUserCardDynamicGetterStringDelegate)
GetEmail(delegate: FDTDGetterStringDelegate)
Phone
SetPhone(phone: FString)
GetPhone(delegate: FUserCardDynamicGetterStringDelegate)
GetPhone(delegate: FDTDGetterStringDelegate)
Photo
SetPhoto(photo: FString)
GetPhoto(delegate: FUserCardDynamicGetterStringDelegate)
GetPhoto(delegate: FDTDGetterStringDelegate)
Gender
SetGender(gender: EDTDGender)
GetGender(delegate: FUserCardDynamicGetterGenderDelegate)
GetGender(delegate: FDTDGetterGenderDelegate)
Age
SetAge(age: int64)
GetAge(delegate: FUserCardDynamicGetterLongDelegate)
GetAge(delegate: FDTDGetterLongDelegate)
key
FString
Parameter key.
value
bool
Parameter value.
key
FString
Parameter key.
value
float
Parameter value.
key
FString
Parameter key.
value
int64
Parameter value.
key
FString
Parameter key.
value
FString
Parameter value.
key
FString
Parameter key.
onResult
FUserCardDynamicGetterOptionalBoolDelegate
FDTDGetterOptionalBoolWithKeyDelegate
Callback.
key
FString
Parameter key.
onResult
FUserCardDynamicGetterOptionalFloatDelegate
FDTDGetterOptionalFloatWithKeyDelegate
Callback.
key
FString
Parameter key.
onResult
FUserCardDynamicGetterOptionalLongDelegate
FDTDGetterOptionalLongWithKeyDelegate
Callback.
key
FString
Parameter key.
onResult
FUserCardDynamicGetterOptionalStringDelegate
FDTDGetterOptionalStringWithKeyDelegate
Callback.
key
FString
Parameter key.
keys
TArray<FString>
Parameter keys.
Parameter
Type
Description
userId
string
Unique user identifier. For example, user’s ID in a social network, or a unique account name used for user identification on your server. If at the time of initialization this identifier is not yet available, specify the identifier later using
the setUserId
method.
currentLevel
integer
The player level at the moment of devtodev SDK initialization. It’s optional but we recommend using it for improving data accuracy.
trackingAvailability
boolean
The property allows or disallows devtodev tracking of the user. By default, it is set to true
. SDK stores the previously assigned value. Pass false if the user opted out of tracking in line with GDPR.
logLevel
string
The level of logging the SDK activity. The "No
" value is used by default. For troubleshooting during integration, it is recommended to set it to "Debug
", and either switch it "No
" or use it only for error handling "Error
" in the release version.
Parameter
Type
Description
currentLevel
int
The player level at the moment of devtodev SDK initialization. It is recommended (but optional) to use to improve data precision.
userId
string
A custom user identifier provided by the developer. If you utilize the default calculation by the device ID, this identifier can be used for finding a user in devtodev.
In case your project utilizes the calculation by the user identifier, you must set this parameter because it becomes the main user identifier in devtodev.
trackingAvailability
DTDTrackingStatus (enum)
The property allows or disallows devtodev tracking of the user. By default, it is set to DTDTrackingStatus.enable
. SDK stores the previously assigned value. Pass DTDTrackingStatus.disable
if the user opted out of tracking in line with GDPR.
logLevel
DTDLogLevel (enum)
The level of logging the SDK activity. The DTDLogLevel.no
value is used by default. For troubleshooting during integration it is recommended to set it to DTDLogLevel.debug
, and either switch it off DTDLogLevel.no
or use it only for error handling DTDLogLevel.error
in the release version.
| EDTDNotificationActionType | Тип действия уведомления |
ActionString | FString | Идентификатор действия уведомления |
Data | TMap<FString, FString> | Данные уведомления |
| EDTDNotificationActionType | Тип действия уведомления |
| FString | Идентификатор действия уведомления |
| FString | Идентификатор нажатой кнопки |
| FString | Текст нажатой кнопки |
| FString | Иконка нажатой кнопки |
| bool | Режим открытия приложения кнопкой |
|
| Callback |
|
| Callback. |
|
| Listener. |
|
| Listener. |
|
| Listener. |
|
| Listener. |
|
| Listener. |
| int32 | Options. |
Object | Description |
| The main object for push notification initialization. |
| The push notification initialization method. |
| The push notification activation method. It passes the |
| A property responsible for the activation/deactivation of push notifications. Functions as a getter (describes the current state) and a setter (sets the current state). When the state transitions, it sends a pt with The |
| A method of passing a user intent to the SDK using PushMessage. |
Written in the manifest file
| Sets a small custom user icon. |
Written in the manifest file
| Sets a color of the small custom user icon. |
Written in the manifest file
| Sets a large custom user icon. |
| Returns a push notification registration token ( |
| Used to pass the push notification to the FirebaseMessagingService if it was implemented by the client but not by the SDK. |
| ( |
DTDPushListener Interface Methods | Description |
| Returns a push notification registration token ( |
onPushServiceRegistrationFailed(String error) | Returns errors during push notification registration. |
| Returns a directory with data for improving your push notifications. |
| Returns |
Property | Type | Description |
| Map<String, String> | Complete information sent with the use of a remote push notification. |
| Int | The notification ID used in the devtodev system. |
| String? | Returns the selected message title or app name if the former is unavailable. |
| String? | The text body. |
| String? | A group of messages. |
| Uri? | Returns the storage path of an audio file. |
| String? | The notification sound name. |
| String? | The notification tag. |
| String? | The notification color. |
| String? | The notification banner if specified. |
| DTDActionType | The property that returns an enum’s DTDActionType value. Possible values:
|
| String? | The property that returns an optional action ID. |
| Int | The icon resource identifier specified by the user (if specified). |
| String? | The large notification icon name. |
| List<DTDActionButton> | The list of action buttons used in the push notification. |
| Boolean | Specifies whether the push notification was sent using the devtodev API. |
Property | Type | Description |
| String? | The property that returns the tapped button ID. |
| String? | The property that returns the optional action ID. |
| DTDActionType | The property that returns an enum’s Possible values:
|
| String? | The property that returns the button’s icon name. |
| Boolean | The button-click app open mode. |
| String? | The property that returns the text of the tapped button. |
Parameter | Type | Description |
| Integer | The player level at the moment of devtodev SDK initialization. It’s optional but we recommend using it for improving data accuracy. |
| String | A custom user ID assigned by the developer. In the case of default calculation by device IDs, the identifier can be used for searching users in devtodev. In case the project uses calculation by user IDs, the parameter is mandatory because it becomes the principal calculation ID in devtodev. |
| DTDTrackingStatus (enum) | The property allows or disallows devtodev tracking of the user. By default, it is set to |
| DTDLogLevel (enum) | The level of logging the SDK activity. The |
| String | The app version during the devtodev SDK initialization. Use the property on the WinStandalone platform only. For all other platforms, data is collected automatically. |
| String | from 1 to 100 symbols | Name of the ad network responsible for the impression |
| Double | from 0,0 to Double.max | Reward for banner display in USD |
| String? | from 1 to 100 symbols, optional | Banner placement |
| String? | from 1 to 100 symbols, optional | Banner name |
| String | from 1 to 100 symbols | Name of the ad network responsible for the impression |
| Double | from 0,0 to Double.max | Reward for banner display in USD |
| String? | from 1 to 100 symbols, optional | Banner placement |
| String? | from 1 to 100 symbols, optional | Banner name |
Parameter | Type | Restrictions | Description |
socialNetwork | FString | from 1 to 100 symbols | The name of the ad network that delivered the impression. |
revenue | float | form 0.0 to float.MaxValue | Reward for displaying a banner in USD. |
placement | FString | from 1 to 100 symbols | Placement of the banner. |
unit | FString | from 1 to 100 symbols | Banner title. |
Argument | Type | Description |
socialNetwork | EDTDSocialNetwork | Predefined social network. |
Argument | Type | Description |
socialNetwork | FString | Custom social network. |
Argument | Type | Description |
socialNetwork | EDTDSocialNetwork | Predefined social network. |
Argument | Type | Description |
socialNetwork | FString | Custom social network. |
Argument | Type | Description |
utmData | TMap<EDTDReferralProperty, FString> | UTM data. |
Argument | Type | Description |
onResult |
| Callback. |
Argument | Type | Description |
onResult |
| Callback. |
Argument | Type | Description |
onResult |
| Callback. |
Argument | Type | Description |
onResult |
| Callback. |
Argument | Type | Description |
listener |
| devtodev ID Listener. |
| String | from 1 to 100 symbols | Name of the ad network responsible for the impression |
| Double | from 0,0 to Double.max | Reward for banner display in USD |
| String? | from 1 to 100 symbols, optional | Banner placement |
| String? | from 1 to 100 symbols, optional | Banner name |
| String | from 1 to 100 symbols | Name of the ad network responsible for the impression |
| Double | from 0,0 to Double.max | Reward for banner display in USD |
| String? | from 1 to 100 symbols, optional | Banner placement |
| String? | from 1 to 100 symbols, optional | Banner name |
| String | from 1 to 100 symbols | Name of the ad network responsible for the impression |
| Double | from 0,0 to Double.max | Reward for banner display in USD |
| String? | from 1 to 100 symbols, optional | Banner placement |
| String? | from 1 to 100 symbols, optional | Banner name |
fromUserId
FString
From user ID
toUserId
FString
To user ID