Apptics is a library that enables your app to send in-app usage reports and data securly to our servers. You can track Sessions, Screens, and we also offer Crash Reporting. With minimal initialization of the framework, you get these features without doing any other configuration.
The minimum support is for iOS 9.0, macOS 10.9, tvOS 9.0 and watchOS 3.0. Supported Swift version - 4.0. Supported devices - iPhone, iPod, iPad, Mac, Apple watch and Apple tv. min Xcode version 9.0
- All you need to do is create a project in the Apptics console using this link link
- Use Swift Package Manager to integrate Apptics in your project.
-
Add a package by selecting File → Add Packages… in Xcode’s menu bar.
-
Enter the package URL of Apptics-SP repository.
https://github.com/zoho/Apptics-SP
-
Next, set the Dependency Rule to be Up to Next Major Version.
-
Then, select Add Package.
-
Choose the package of Apptics that you want installed.
-
pod 'Apptics-SDK/Scripts'
-
Click on the project, then on the main target, then on the “Build Phases” tab.
-
Click the + at the top left to create a new build phase; choose “New Run Script Phase”.
-
Triple-click on “Run Script” to select it, and type “Apptics pre build”.
-
Drag the new phase as close to the top of the list as possible. I’d prefer to put it at the very top, but Xcode reserves the topmost position for “Target Dependencies.”
-
Click the triangle next to your build phase title to expand the phase. Make sure Shell is set to /bin/sh and “Run script only when installing” is not checked.
-
Click into the black script box and paste in the following script.
#Pre build script will register the app version, upload dSYM file to the server and add apptics specific information to the main info.plist which will be used by the SDK. sh "./Pods/Apptics-SDK/scripts/run" --upload-symbols-for-configurations="Release, Appstore"
Usage:
run --upload-symbols-for-configurations="Release, Appstore" --config-file-path="YOUR_PATH/apptics-config.plist" --app-group-identifier="group.com.company.application [Optional]"
Parameters:
--upload-symbols-for-configurations
String - Provide the configurations separated by comma for which the dSYM files should be uploaded.--config-file-path
String - Provide the path of apptics-config.plist file if to any sub directory instead of root.--app-group-identifier
String - App group identifier to support app extensions.
- Please visit Apptics Github repo and follow the steps.
-
Create a new application or select an existing application from the quickstart page to download the
apptics-config.plist
. Move theapptics-config.plist
to the root of your Xcode project and add it to the necessary targets. -
In your
Appdelegate
class make sure you call the initialize method in app launch.Apptics.initialize(withVerbose: true)
-
For AppExtensions call
Apptics.startExtensionSession("APP_GROUP_IDENTIFIER")
on start andApptics.stopExtensionSession()
at the end.
Note : The analytic data of App-Extensions will be sent by the main application based on the network availability.
To get proper symbolicated crashes, make sure your build settings have the following when you ship your app.
- Debug information format - Dwarf with dSYM file
A session is a single period of user interaction with your app. For example, when a user opens the app for the first time and the app goes to the background, that is considered a session.
Sessions are automatically tracked in Apptics, once you have integrated our SDK and called the initialization method.
Events help you track all the user actions within your app. For example, sign up, purchase made, feedback given, and so on. Events analytics and the associated data help you understand your users.
Event types
Zoho Apptics provides two types of event analytics; Defined events and Custom events.
Defined events: These are the default events that are available for your use once you have integrated our SDK.
Custom events: These are the events that you want to capture using our SDK.
Objective C
[APEvent trackEvent:<#(nonnull NSString *)#> andGroupName:<#(nonnull NSString *)#>]
Swift
APEvent.trackEvent(<#T##eventName: String##String#>, withGroupName: <#T##String#>)
Make sure that the event name and group name follow the below norms, or else the event won't be logged within the SDK.
- should not be more than 100 characters.
- should start with an alphabet.
- should not contain any space or special characters apart from underscore (_).
- cannot start with 'ap_' or 'AP_'. These are reserved for the defined events.
An example of a valid event name: 'helloworld', 'Hello_world', 'helloWorld'
An example of an invalid event name: '_helloworld', '1hello', `Hello World`, 'ap_helloworld`
For more details, please visit our SDK guide for In-App-Events
Screens are content that your users view in your app. Using Zoho Apptics' screen tracking, you can measure the screen views and associate the screen data with events. This helps you to understand user engagement and behavior.
- Make sure that you have integrated Apptics with your app. Refer to the integration guide for detailed steps.
- Once the integration is done, you can track the screens either manually or automatically.
-
You can track the screens manually and also provide custom screen names using Apptics.
-
Use the below method to view the controller class that you want to track.
To track the entry of the view, call the method viewDidAppear.
Objective C[APScreentracker trackViewEnter:<#(nonnull NSString *)#>];
Swift
APScreentracker.trackViewEnter(<#T##screenName: String##String#>)
To track the exit of the view, call the method viewWillDisappear.
Objective C[APScreentracker trackViewExit:<#(nonnull NSString *)#>];
Swift
APScreentracker.trackViewExit(<#T##screenName: String##String#>)
NOTE: Make sure that the screen name follows the below norms, or else the event won't be logged within the SDK.
- screen name is mandatory and cannot be nil or empty.
- screen name should not be more than 250 characters.
- should start with an alphabet.
- only numbers, spaces, dots, and underscore are allowed after the first letter.
- cannot start with 'ap_' or 'AP_'. These are reserved for the defined events.
Crashes are automatically tracked and symbolicated by Apptics. To get proper symbolicated reports please make sure to configure your build settings correctly.
The crashes will not be captured if the debugger is attached at the launch, please follow the below steps.
- Run your app from Xcode and install it on your simulator or device.
- Quit the app using the stop button.
- Launch the app from the home screen and try to crash the app by invoking our ready-made method
Apptics.crash()
. - Run the app again in order to push the crash to the server and get symbolicated.
Check the web console, you should find the crash listed in the console.
Apptics includes a script to upload your project's dSYM automatically. The script is executed through the run-script in your project build phases during the onboarding process. There are some cases where dSYM upload fails because of network interruptions or improper configuration of the run script. Missing dSYMs can be uploaded by following the below steps.
While archiving your project, build dSYMs are placed inside the xarchive directory. To view, open the Xcode organizer window, ctrl+click, or right-click on the list to go to the directory in Finder. ctrl+click to view its content, Inside the content, you will find a directory called "dSYMs" which will contain dSYMs files. Also, that is the location where dSYMs are placed when you hit "download dSYM" in the Xcode organizer.
On the "Manage dSYM page" (Left menu -> Quality -> dSYM), upload the dSYMs.zip that you have downloaded from the iTunes connect for bitcode enabled or the one you find in xarchive directory.
You can use our protocols to customize the Analytics Settings, App updates and Feedback screens. Just create a swift/Obj class in the name of ThemeManager and extend those protocols to implement the required methods link.
Get callbacks for all the events at a single point by extending APCustomHandler
. It deals with user consent , crash consent, feedback, and ratings & reviews.
A separate module that does "Shake to Feedback", Please check if it suits your needs here.
Now you can prompt users to update to the latest version of your app from the App Store.
Please check our guide before you start here.
Engage with your users and learn about their experience. Promote them to rate your app after they have fulfilled the configured criteria.
Check how to configure automatic ratings here.
For more information about how Apptics works, checkout the below links.
For any assistance, contact Apptics at [email protected]