- New: Adds a
SEGCrypto
API that can be used to configure the at rest encryption strategy for the client.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
// Set a custom crypto implementation. An AES-256 implementation is provided out of the box.
configuration.crypto = [SEGAES256Crypto initWithPassword:"YOUR_PRIVATE_PASSWORD"];
// Set any other custom configuration options.
...
// Initialize the SDK with the configuration.
[SEGAnalytics setupWithConfiguration:configuration]
- New: Add the ability for the SDK to natively report attribution information via Segment integrations enabled for your project, without needing to bundle their SDKs. Attribution information is sent as a track call as documented in the mobile lifecycle spec.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
// Enable attribution tracking.
configuration.trackAttributionData = @YES;
// Set any other custom configuration options.
...
// Initialize the SDK with the configuration.
[SEGAnalytics setupWithConfiguration:configuration]
- New: Add the ability for the SDK to disable bluetooth collection. Going forwards, bluetooth information will not be collected by default. This is because iOS 10 requires explicit documentation on why the CoreBluetooth APIs are accessed. If you enable this flag, your app's Info.plist must contain an
NSBluetoothPeripheralUsageDescription
key with a string value explaining to the user how the app uses this data. On this note, you should do the same forNSLocationAlwaysUsageDescription
if you haveshouldUseLocationServices
set to@YES
. If you are linking against iOS 10, you'll want to update to this version to prevent your app submission from being rejected (or provideNSBluetoothPeripheralUsageDescription
and/orNSLocationAlwaysUsageDescription
descriptions in your app's Info.plist).
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
// Enable bluetooth collection.
configuration.shouldUseBluetooth = @YES;
// Set any other custom configuration options.
...
// Initialize the SDK with the configuration.
[SEGAnalytics setupWithConfiguration:configuration]
- New: Adds a
SEGRequestFactory
API that can be used to configure the HTTP requests made by Segment.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
// Set a custom request factory which allows you to modify the way the library creates an HTTP request.
// In this case, we're transforming the URL to point to our own custom non-Segment host.
configuration.requestFactory = ^(NSURL *url) {
NSURLComponents \*components = [NSURLComponents componentsWithURL:url resolvingAgainstBaseURL:NO];
// Replace YOUR_PROXY_HOST with the address of your proxy, e.g. aba64da6.ngrok.io.
components.host = @"YOUR_PROXY_HOST";
NSURL \*transformedURL = components.URL;
return [NSMutableURLRequest requestWithURL:transformedURL];
};
// Set any other custom configuration options.
...
// Initialize the SDK with the configuration.
[SEGAnalytics setupWithConfiguration:configuration]
- New: Add method to retrieve anonymous ID.
[[SEGAnalytics sharedAnalytics] getAnonymousId];
-
Improvement: Store
context
object with every event. This makes it more accurate collecting the context at the time the event was observed, rather than uploaded. -
Improvement: Automatic screen tracking improvements, specifically in the case when the root view is a
UINavigationController
. -
Improvement: Don't send
Segment.io: false
in integration dictionary. -
Improvement: Friendly assert messages.
-
Fix: Namespace GZIP extension to avoid conflicts.
-
Fix: Fix assertion in
identify
method. -
Fix: Static analyzer warnings for reachability implementation.
-
Fix: Handle case where screen name is empty.
- New: Add Carthage support.
- Fix: Flush timer behaviour. Previously it was not being invoked periodically as expected.
- New: Automatically track campaign data.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
configuration.trackPushNotifications = YES;
[SEGAnalytics setupWithConfiguration:configuration];
- New: Automatically track deep links. Please note that you'll still need to call the
continueUserActivity
andopenURL
methods on the analytics client.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
configuration.trackDeepLinks = YES;
[SEGAnalytics setupWithConfiguration:configuration];
- Improvement: Limit queue size to 1000. This will prevent crashes/memory issues from the queue being too large.
- Fix: Replace Foundation import with UIKit import.
- Improvement: Exclude cache files from backup.
- New: Add tvOS support.
- New: Update context object with referrer information.
- Improvement: Handle case when root view is a navigation controller.
- Improvement: More user friendly assert messages.
- New: Add method to retrieve anonymousID.
- New: Carthage support.
- Fix: Case when ViewController title is an empty string.
- Improvement: Fixes the following static analyzer warnings.
SEGReachability.m:115:9: Potential leak of an object stored into 'ref'
SEGReachability.m:131:9: Potential leak of an object stored into 'ref'
- Fix: Correctly skip sending events for disabled events in the tracking plan.
- Fix: Handle case when ViewController is named simply "ViewController".
- Fix: Handle case when ViewController is named simply "ViewController".
- Fix: Namespace NSData GZIP extension methods to avoid conflicts.
- Fix: Build and version were reversed in automatic application lifecycle tracking.
- Instrument automatic in app purchase tracking. Enable this during initialization.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
configuration.trackInAppPurchases = YES;
[SEGAnalytics setupWithConfiguration:configuration];
- Improvement: gzip http request body.
- Fix: Implement workaround for CTTelephonyNetworkInfo bug.
- Fix potential duplication of events in queue when there are events queued in NSUserDefaults and on disk.
- Analytics-iOS Core SDK now includes support for iOS 7.0+ (Previously 8.0+). Bundled integrations may have different OS version requirements, please check the specific integration you use for details.
- Store event queue and traits to disk instead of NSUserDefaults. We will check for queue/traits in NSUserDefaults and copy to disk if they exist.
- Instrument automatic screen view tracking. Enable this during initialization.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
configuration.recordScreenViews = YES;
[SEGAnalytics setupWithConfiguration:configuration];
- Instrument automatic application lifecycle event tracking. Enable this during initialization.
SEGAnalyticsConfiguration *configuration = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
configuration.trackApplicationLifecycleEvents = YES;
[SEGAnalytics setupWithConfiguration:configuration];
- Make
SEGAnalyticsIntegrationDidStart
public (use this to be notified when an integration is initialized). - Fixed crashes due to NSNotificationCenter observers not being removed.
- Make
initWithConfiguration
public.
- Fix crash with forwarding notification info to integrations.
- Fix crash with using NSUserDefaults.
- Fix issue with location updates.
- Forward notification info to integrations.
- Use NSUserDefaults for persistence where possible.
- Fix how we detect whether the device is offline or not.
- Correctly send
context.library.version
.
- Deliver application lifecycle and push events synchronously to integrations when possible.
- Add ability to set a custom anonymous ID.
- Fix bug with overriding
userId
in alias calls (this bug would manifest when trying to alias anonymous users).
- v3 Release. This release restructures bundled integrations, which requires a few additional steps.
Add the integration dependencies.
pod `Segment`
pod `Segment-Bugsnag`
pod `Segment-Branch`
...
Register them in your configuration when you initialize the SDK.
SEGAnalyticsConfiguration *config = [SEGAnalyticsConfiguration configurationWithWriteKey:@"YOUR_WRITE_KEY"];
// Add any of your bundled integrations.
config use:[SEGGoogleAnalyticsIntegrationFactory instance];
config use:[BNCBranchIntegrationFactory instance];
...
[SEGAnalytics setupWithConfiguration:config];
- Adds API to track notification lifecycle.
- Fixes bug where traits in identify and group were ignored.
- Fixes
pod lib lint
warnings.