Hello! This is the public repository of the unified mParticle Apple SDK built for the iOS and tvOS platforms.
At mParticle our mission is straightforward: make it really easy for apps and app services to connect and take ownership of your 1st party data. Like most app owners, you end up implementing and maintaining numerous SDKs ranging from analytics, attribution, push notification, remarketing, monetization, etc. However, embedding multiple 3rd party libraries creates a number of unintended consequences and hidden costs.
The mParticle platform addresses all these problems. We support an ever growing number of integrations with services and SDKs, including developer tools, analytics, attribution, messaging, advertising, and more. mParticle has been designed to be the central hub connecting all these services – check our site, or hit us at support@mparticle.com to learn more.
This document will help you:
- Obtain the mParticle SDK via CocoaPods or via Carthage
- Extend the mParticle SDK with Kits
- Initialize the mParticle SDK
The mParticle SDK is composed of the core library and a series of kit libraries that depend on the core. With each integration with a partner we strive to implement as many features as possible in the server-to-server layer, however some times a deeper integration to work side-by-side with a 3rd party SDK comes with greater benefits to our clients. We use the term Kit to describe such integrations.
The core SDK takes care of initializing the kits depending on what you've configured in your app's dashboard, so you just have to decide which kits you may use prior to submission to the App Store. You can easily include all of the kits, none of the kits, or individual kits – the choice is yours.
The mParticle-Apple-SDK is available via CocoaPods or via Carthage. Follow the instructions below based on your preference.
To integrate the SDK using CocoaPods, specify it in your Podfile:
# Uncomment the line below if you're using Swift or would like to use dynamic frameworks (recommended but not required)
# use_frameworks!
target '<Your Target>' do
pod 'mParticle-Apple-SDK', '~> 7'
end
Configuring your Podfile
with the statement above will include only the Core mParticle SDK.
If your app targets iOS and tvOS in the same Xcode project, you need to configure the
Podfile
differently in order to use the SDK with multiple platforms. You can find an example of multi-platform configuration here.
If you'd like to add any kits, you can do so as follows:
# Uncomment the line below if you're using Swift or would like to use dynamic frameworks (recommended but not required)
# use_frameworks!
target '<Your Target>' do
pod 'mParticle-Appboy', '~> 7'
pod 'mParticle-BranchMetrics', '~> 7'
pod 'mParticle-Localytics', '~> 7'
end
In the cases above, the Appboy, Branch Metrics, and Localytics kits would be integrated together with the core SDK.
mParticle's iOS SDK and its embedded kits are dynamic libraries, meaning their code is loaded into an app's address space only as needed, as opposed to a 'static' library, which is always included in full in the app's executable file. Some mParticle embedded kits rely on static libraries maintained by our partners. A static framework, wrapped in a dynamic library is incompatible with CocoaPods' use frameworks!
option. Affected kits are: Appboy, AppsFlyer, comScore, Kahuna, Kochava and Localytics.
Attempting to use these kits with use_frameworks!
will result in the following error message:
[!] The '<your Target>' target has transitive dependencies that include static binaries: (<path to framework>)
If you need to reference these kits' methods from user-level code, you must incorporate them manually. To do this:
- Add the partner SDK (for example,
Appboy-iOS-SDK
orAppsFlyer-SDK
) directly to your Podfile. - Remove the embedded kit pod(
mParticle-<partner name>
) from the Podfile, download the source code from Github and manually drag its.m
and.h
files directly into your project.
For iOS only, you can also choose to install the crash reporter by including it as a separate pod:
pod 'mParticle-CrashReporter', '~> 1.3'
You can read detailed instructions for including the Crash Reporter at its repository: mParticle-CrashReporter
Note you can't use the crash reporter at the same time as the Apteligent kit.
To integrate the SDK using Carthage, specify it in your Cartfile:
github "mparticle/mparticle-apple-sdk" ~> 7.0
If you'd like to add any kits, you can do so as follows:
github "mparticle-integrations/mparticle-apple-integration-branchmetrics" ~> 7.0
In this case, only the Branch Metrics kit would be integrated; all other kits would be left out.
Kit | CocoaPods | Carthage |
---|---|---|
Adjust | ✓ | ✓ |
Appboy | ✓ | ✓ |
Adobe | ✓ | ✓ |
AppsFlyer | ✓ | ✓ |
Apptentive | ✓ | ✓ |
Apptimize | ✓ | |
Apteligent | ✓ | |
Branch Metrics | ✓ | ✓ |
Button | ✓ | ✓ |
comScore | ✓ | |
Flurry | ✓ | |
Instabot | ✓ | |
Iterable | ✓ | ✓ |
Kahuna | ✓ | |
Kochava | ✓ | |
Leanplum | ✓ | ✓ |
Localytics | ✓ | |
Primer | ✓ | ✓ |
Radar | ✓ | |
Reveal Mobile | ✓ | |
Singular | ✓ | |
Skyhook | ✓ | |
Tune | ✓ | ✓ |
Urban Airship | ✓ | |
Wootric | ✓ |
The mParticle SDK is initialized by calling the startWithOptions
method within the application:didFinishLaunchingWithOptions:
delegate call. Preferably the location of the initialization method call should be one of the last statements in the application:didFinishLaunchingWithOptions:
. The startWithOptions
method requires an options argument containing your key and secret and an initial Identity request.
Note that it is imperative for the SDK to be initialized in the
application:didFinishLaunchingWithOptions:
method. Other parts of the SDK rely on theUIApplicationDidBecomeActiveNotification
notification to function properly. Failing to start the SDK as indicated will impair it. Also, please do not use GCD'sdispatch_async
to start the SDK.
import mParticle_Apple_SDK
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
let mParticleOptions = MParticleOptions(key: "<<<App Key Here>>>", secret: "<<<App Secret Here>>>")
//Please see the Identity page for more information on building this object
let request = MPIdentityApiRequest()
request.email = "email@example.com"
mParticleOptions.identifyRequest = request
mParticleOptions.onIdentifyComplete = { (apiResult, error) in
NSLog("Identify complete. userId = %@ error = %@", apiResult?.user.userId.stringValue ?? "Null User ID", error?.localizedDescription ?? "No Error Available")
}
//Start the SDK
MParticle.sharedInstance().start(with: mParticleOptions)
return true
}
For apps supporting iOS 8 and above, Apple recommends using the import syntax for modules or semantic import. However, if you prefer the traditional CocoaPods and static libraries delivery mechanism, that is fully supported as well.
If you are using mParticle as a framework, your import statement will be as follows:
@import mParticle_Apple_SDK; // Apple recommended syntax, but requires "Enable Modules (C and Objective-C)" in pbxproj
#import <mParticle_Apple_SDK/mParticle.h> // Works when modules are not enabled
Otherwise, for CocoaPods without use_frameworks!
, you can use either of these statements:
#import <mParticle-Apple-SDK/mParticle.h>
#import "mParticle.h"
Next, you'll need to start the SDK:
- (BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
MParticleOptions *mParticleOptions = [MParticleOptions optionsWithKey:@"REPLACE ME"
secret:@"REPLACE ME"];
//Please see the Identity page for more information on building this object
MPIdentityApiRequest *request = [MPIdentityApiRequest requestWithEmptyUser];
request.email = @"email@example.com";
mParticleOptions.identifyRequest = request;
mParticleOptions.onIdentifyComplete = ^(MPIdentityApiResult * _Nullable apiResult, NSError * _Nullable error) {
NSLog(@"Identify complete. userId = %@ error = %@", apiResult.user.userId, error);
};
[[MParticle sharedInstance] startWithOptions:mParticleOptions];
return YES;
}
Please see Identity for more information on supplying an MPIdentityApiRequest
object during SDK initialization.
A sample project is provided with the mParticle Apple SDK. It is a multi-platform video streaming app for both iOS and tvOS.
Clone the repository to your local machine
git clone https://github.com/mParticle/mparticle-apple-sdk.git
In order to run either the iOS or tvOS examples, first install the mParticle Apple SDK via CocoaPods.
- Change to the
Examples/CocoaPodsExample
directory - Run
pod install
- Open Example.xcworkspace in Xcode, select either the iOS_Example or tvOS_Example scheme, build and run.
Just by initializing the SDK you'll be set up to track user installs, engagement, and much more. Check out our doc site to learn how to add specific event tracking to your app.
Questions? Have an issue? Consult the Troubleshooting page or contact our Customer Success team at support@mparticle.com.
The mParticle-Apple-SDK is available under the Apache License, Version 2.0. See the LICENSE file for more info.