Skip to content

Latest commit

 

History

History
210 lines (147 loc) · 6.63 KB

File metadata and controls

210 lines (147 loc) · 6.63 KB

Huawei Analytics Kit and Crash Service Solar2d Plugin

This plugin was created based on Huawei Analytics and Crash Service. Please Analytics, Crash Service for detailed information.

In order to use this plugin, you must first create an account from developer.huawei.com. And after logging in with your account, you must create a project in the huawei console in order to use HMS kits.

Project Setup

To use the plugin please add following to build.settings

{
    plugins = {
        ["plugin.huaweiAnalyticsKit"] = {
            publisherId = "com.solar2d",
        },
    },
}

And then you have to create keystore for your app. And you must generate sha-256 bit fingerprint from this keystore using the command here. You have to define this fingerprint to your project on the huawei console.

And you must add the keystore you created while building your project. Also you need to give the package-name of the project you created on Huawei Console. And you need to put agconnect-services.json file into main.lua directory.

After all the configuration processes, you must define the plugin in main.lua.

local huaweiAnalytics = require "plugin.huaweiAnalyticsKit"

local function listener(event)
    print(event)
end

huaweiAnalytics.init(listener) -- sets listener and inits plugin

We should call all methods through huaweiAnalytics object.

Methods in the Plugin

Analytics Kit

HiAnalyticsInstance

setAnalyticsEnabled

Sets whether to enable event tracking. If event tracking is disabled, no data is recorded or analyzed.

huaweiAnalytics.HiAnalyticsInstance("setAnalyticsEnabled", {enabled=true})

setUserId

Sets a user ID. When this method is called, a new session will be generated if the old value of id is not empty and is different from the new value. If you do not want to use id to identify a user (for example, when a user signs out), you must set id to null when calling setUserId.

huaweiAnalytics.HiAnalyticsInstance("setUserId", {id=""})

setUserProfile

Sets user attributes. The values of user attributes remain unchanged throughout the app lifecycle and during each session. A maximum of 25 user attributes are supported. If the name of an attribute set later is the same as that of an existing attribute, the value of the existing attribute is updated.

huaweiAnalytics.HiAnalyticsInstance("setUserProfile", {name="", value=""})

setPushToken

Sets the push token. After obtaining a push token through Push Kit, call this method to save the push token so that you can use the audience defined by Analytics Kit to create HCM notification tasks.

huaweiAnalytics.HiAnalyticsInstance("setPushToken", {token=""})

setMinActivitySessions

Sets the minimum interval for starting a new session. A new session will be generated when an app is switched back to the foreground after it runs in the background for the specified minimum interval. By default, the minimum interval is 30,000 milliseconds (that is, 30 seconds).

huaweiAnalytics.HiAnalyticsInstance("setAnalyticsEnabled", {milliseconds=123})

setSessionDuration

Sets the session timeout interval. A new session will be generated when an app is running in the foreground but the interval between two adjacent events exceeds the specified timeout interval. By default, the timeout interval is 1,800,000 milliseconds (that is, 30 minutes).

huaweiAnalytics.HiAnalyticsInstance("setSessionDuration", {milliseconds=123})

onEvent

Records an event.

huaweiAnalytics.HiAnalyticsInstance("onEvent", {key=value, key=value})

clearCachedData

Clears all collected data cached locally, including cached data that failed to be sent.

huaweiAnalytics.HiAnalyticsInstance("clearCachedData")

getAAID

Obtains the AAID from AppGallery Connect.

huaweiAnalytics.HiAnalyticsInstance("getAAID")

getUserProfiles

Obtains the automatically collected or custom user attributes.

huaweiAnalytics.HiAnalyticsInstance("getUserProfiles", {preDefined=true})

pageStart

Defines a page entry event. This method applies only to non-activity pages because automatic collection is supported for activity pages. If it is called for an activity page, statistics on page entry and exit events will be inaccurate. After this method is called, the pageEnd method must be called.

huaweiAnalytics.HiAnalyticsInstance("pageStart", {pageName="", pageClassOverride=""})

pageEnd

Defines a page exit event. This method applies only to non-activity pages because automatic collection is supported for activity pages. If it is called for an activity page, statistics on page entry and exit events will be inaccurate. Before this method is called, the pageStart method must be called.

huaweiAnalytics.HiAnalyticsInstance("pageEnd", {pageName=""})

setRestrictionEnabled

Sets whether to disable data analysis. The default value is false, which indicates that data analysis is enabled.

huaweiAnalytics.HiAnalyticsInstance("setRestrictionEnabled", {isEnabled=true})

isRestrictionEnabled

Checks whether data analysis is disabled.

huaweiAnalytics.HiAnalyticsInstance("isRestrictionEnabled")

HiAnalyticsTools

enableLog

Enables the log function.

huaweiAnalytics.HiAnalyticsTools("enableLog")

Enables the debug log function and sets the minimum log level. Log levels:

  • Log.DEBUG(3)
  • Log.INFO(4)
  • Log.WARN(5)
  • Log.ERROR(6)
huaweiAnalytics.HiAnalyticsTools("enableLog", {level=3})

Crash Service

enableCrashCollection

Enables or disables Crash. This service is enabled by default, indicating that the Crash service collects and reports crash information. If you do not need this service, you can disable it.

huaweiAnalytics.CrashService("enableCrashCollection", {enabled=true})

testIt

Creates a crash for testing. This method is used only for you to test the crash implementation. Do not use this method in officially released apps.

huaweiAnalytics.CrashService("testIt")

setUserId

Sets a custom user ID.

huaweiAnalytics.CrashService("setUserId", {userId=""})

setCustomKey

Sets a custom key-value pair.

huaweiAnalytics.CrashService("setCustomKey", {key="", value=""})

log

Records a custom log.

huaweiAnalytics.CrashService("log", {message="", level=""})

References

Analytics Kit Check Crash Service Check

License

MIT