Skip to content

Latest commit

 

History

History
870 lines (637 loc) · 43.7 KB

CHANGELOG.md

File metadata and controls

870 lines (637 loc) · 43.7 KB

Change Log

All notable changes to this project will be documented in this file. This project adheres to Semantic Versioning.

[3.5.10]

Added

  • Added mobileFrameworkInfo configuration option to IterableConfig to identify the mobile framework (Flutter, React Native, or Native) being used with the SDK.
  • Support for push notifications with text input. Pending intent is now mutable when buttons are of text input type.

[3.5.9]

Fixed

  • Fixed notification tracking bug that prevents SDK from receiving push notifications when system notification settings are turned off.

[3.5.8]

Fixed

  • Fixed logic issue where notifications were being disabled even when auto push registration was turned off

[3.5.7]

Added

  • Support for JSON-only in-app messages, JSON-only messages are now handled by the onNewInApp handler and consumed after retrieval
  • Enhanced notification state tracking to align with system notification permissions changes

[3.5.6]

Fixed

  • Fixed Crash while initializing IterableSDK on some devices (Unsupported IV Length).

[3.5.5]

Added

    • Added IterableDecryptionFailureHandler interface to handle decryption failures of PII information.

Removed

  • Removed encryptionEnforced parameter from IterableConfig as data is now always encoded for security

Changed

  • Migrated from EncryptedSharedPreferences to regular SharedPreferences to prevent ANRs while EncryptedSharedPreferences was created on the main thread. We are now using our own encryption library to encrypt PII information before storing it in SharedPreferences.

[3.5.4]

Fixed

  • In-Apps are now robust with animation, resolving flickering and animation issues observed on Pixel 6 Pro with API 35.
  • Fixed an issue where AuthManager was not reset correctly when logging out a user.
  • Fixed ConcurrentModificationException leading to crashes during application launches.
  • Addressed a text truncation issue in Embedded Message templates for applications targeting Android 14 and Android 15.
  • Improved InboxActivity compatibility with edge-to-edge layouts, ensuring seamless handling of notches and display cutouts.

[3.5.3]

Fixed

  • Fixed an issue where the SDK would crash if the IterableInAppMessage object was null when consuming an in-app message.

Changed

  • SDK now provides more insight into JWT refresh failures, so you can take appropriate action in your application code. With this update, when a JWT refresh fails (for any of various reasons), the SDK calls onAuthFailure on the IterableAuthHandler instance you can provide to the SDK at initialization. For more information, see the documentation for Iterable's Android SDK.
  • The IterableAuthHandler's onTokenRegistrationFailed(Throwable object) has been replaced with onAuthFailure(Throwable object) which will be called when JWT token refresh fails.

[3.5.2]

Added

  • Introducing a new method setAuthRetryPolicy in IterableConfig to set the retry policy for JWT token refresh.
  • You can now use method - pauseAuthRetries(boolean pauseRetry) to pause or resume the JWT token refresh retries.
  • trackPurchase method now accepts attributionInfo parameter to track purchase with attribution information.

Fixed

  • Embedded manager listeners are active only if feature is enabled

[3.5.1]

Fixed

  • Embedded manager syncs messages as soon as user logs in
  • Fixed a bug to prevent app crashes due to malformed authTokens
  • Fixes a bug where push notifications opens would lead to app crashes
  • Fixes a bug where crashes would occur due to SDK not being initialized

Changed

  • Updates Glide library in embedded message OOTB views to version 4.16.0

[3.5.0]

Added

  • introduces support for embedded messaging: an eligibility–based, personalized messages sent from Iterable to your mobile and web apps, which can display them inline, using native interface components.
  • To display embedded messages, you can use customizable, out-of-the-box components provided by the SDK (cards, notifications, banners), or you can build fully custom components of your own design.
  • To learn more, read Embedded Messages with Iterable's iOS SDK.

Changed

  • IterableConfig is updated with an enableEmbeddedMessaging flag that needs to be set to true to allow use of embedded messaging functionality

Added

  • when JWT is invalid, IterableAuthManager is updated to fetch and store a new JWT token locally
  • IterableRequestTask now has a retry mechanism that fetches a new JWT token and retries the request if JWT is invalid
  • retries are capped at a max of 5

Fixed

  • SDK now handles null scenarios preventing crashes when IterableEncryptedSharedPreference creation fails.
  • Updated crypto library to version 1.1.0-alpha06. 1.1.0-alpha05 solves a race condition during creation process.

Added

This release allows you to use projects hosted on Iterable's EU data center. If your project is hosted on Iterable's European data center (EUDC), configure the SDK to use Iterable's EU-based API endpoints:

Java

IterableConfig config = new IterableConfig.Builder()
  // ... other configuration options ...
  .setDataRegion(IterableDataRegion.EU)
  .build();
IterableApi.initialize(context, "<YOUR_API_KEY>", config);

Kotlin

val configBuilder = IterableConfig.Builder()
   // ... other configuration options ...
  .setDataRegion(IterableDataRegion.EU)
  .build();
IterableApi.initialize(context, "<YOUR_API_KEY>", config);

Fixed

  • Addressed React Native SDK push notification deep linking issues where the app would restart instead of resuming the last activity upon being backgrounded.
  • Resolves an additional push notification problem wherein the customActionHandler and urlHandler were not being invoked in specific scenarios, as documented in issue #470. (Credit to @tnortman-jabra for the report and the fix)

Added

  • IterableInAppManager.setRead now accepts IterableHelper.FailureHandler failureHandler

Fixed

  • Fixes an issue where IterableInAppManager.removeMessage caused build failure in React Native SDK pointing to legacy method calls.
  • Fixes an issue where custom action handlers were not invoked when tapping on push notification when the app is in background.

Added

  • IterableInAppManager.setRead now accepts IterableHelper.SuccessHandler successHandler.
  • IterableApi.inAppConsume now accepts IterableHelper.SuccessHandler successHandler and IterableHelper.FailureHandler failureHandler.

Added

  • setEmail and setUserId now accepts IterableHelper.SuccessHandler successHandler and IterableHelper.FailureHandler failureHandler.

Changed

  • OTT devices (FireTV) will now register as OTT device instead of Android under user's devices.

Added

  • Custom push notification sounds! To play a custom sound for a push notification, add a sound file to your app's res/raw folder and specify that same filename when setting up a template in Iterable.

    Some important notes about custom sounds and notification channels:

    • Android API level 26 introduced notification channels. Every notification must be assigned to a channel.
    • Each custom sound you add to an Iterable template creates a new Android notification channel. The notification channel's name matches the filename of the sound (without its extension).
    • To ensure sensible notification channel names for end users, give friendly names to your sound files. For example, a custom sound file with name Paid.mp3 creates a notification channel called Paid. The end user can see this notification channel name in their device's notification channel settings.
    • Be sure to place the corresponding sound file in your app's res/raw directory.
  • To help you access a user's email address, userId, and authToken, the SDK now provides convenience methods: getEmail(), getUserId(), and getAuthToken().

Changed

  • Updated the Security library and improved EncryptedSharedPreferences handling.

    To work around a known Android issue that can cause crashes when creating EncryptedSharedPreferences, we've upgraded androidx.security.crypto from version 1.0.0 to 1.1.0-alpha04. When EncryptedSharedPreferences cannot be created, the SDK now uses SharedPreferences (unencrypted).

    If your app requires encryption, you can prevent this fallback to SharedPreferences by setting the encryptionEnforced configuration flag to true. However, if you enable this flag and EncryptedSharedPreferences cannot be created, an exception will be thrown.

  • Improved JWT token management. This change addresses an issue where null values could prevent the refresh of a JWT token.

Fixed

  • Fixed an issue which could prevent in-app messages from respecting the Position value selected when setting up the template (top / center / bottom / full).

  • Fixed crashes that sometimes happened during in-app message animations.

This release includes support for encrypting some data at rest, and an option to store in-app messages in memory.

Encrypted data

In Android apps with minSdkVersion 23 or higher (Android 6.0) Iterable's Android SDK now encrypts the following fields when storing them at rest:

  • email — The user's email address.
  • userId — The user's ID.
  • authToken — The JWT used to authenticate the user with Iterable's API.

(Note that Iterable's Android SDK does not store the last push payload at rest—before or after this update.)

For more information about this encryption in Android, examine the source code for Iterable's Android SDK: IterableKeychain.

Storing in-app messages in memory

This release also allows you to have your Android apps (regardless of minSdkVersion) store in-app messages in memory, rather than in an unencrypted local file. However, an unencrypted local file is still the default option.

To store in-app messages in memory, set the setUseInMemoryStorageForInApps(true) SDK configuration option (defaults to false):

Java

IterableConfig.Builder configBuilder = new IterableConfig.Builder()
   // ... other configuration options ...
  .setUseInMemoryStorageForInApps(true);
IterableApi.initialize(context, "<YOUR_API_KEY>", config);

Kotlin

val configBuilder = IterableConfig.Builder()
   // ... other configuration options ...
  .setUseInMemoryStorageForInApps(true);
IterableApi.initialize(context, "<YOUR_API_KEY>", configBuilder.build());

When users upgrade to a version of your Android app that uses this version of the SDK (or higher), and you've set this configuration option to true, the local file used for in-app message storage (if it already exists) is deleted However, no data is lost.

Android upgrade instructions

If your app targets API level 23 or higher, this is a standard SDK upgrade, with no special instructions.

If your app targets an API level less than 23, you'll need to make the following changes to your project (which allow your app to build, even though it won't encrypt data):

  1. In AndroidManifest.xml, add <uses-sdk tools:overrideLibrary="androidx.security" />
  2. In your app's app/build.gradle:
    • Add multiDexEnabled true to the default object, under android.
    • Add implementation androidx.multidex:multidex:2.0.1 to the dependencies.

Added

  • Added new methods for setEmail, setUserId and updateEmail which accepts authToken, providing more ways to pass authToken to SDK
  • Added two interface methods - onTokenRegistrationSuccessful and onTokenRegistrationFailed. Override these methods to see if authToken was successfully received by the SDK.

Changed

  • setAuthToken method is now public allowing additional way to provide authToken to SDK.

Removed

  • Removed collection of advertising ID.

Fixed

  • Fixed an issue where disableDevice would get called with no device token.

Added

  • This release makes offline events processing available to all Iterable customers who'd like to use it — just ask your customer success manager to enable it for your account. Offline events processing saves a local copy of events triggered in your app while the device is offline (up to 1000 events). When a connection is re-established and your app is in the foreground, the events will be sent to Iterable. For more information, read Offline events processing.

Fixed

  • Fixed an issue where configurations would not be loaded. config in IterableApi is now accessed through sharedInstance.

Fixed

  • Fixed in-apps disappearing due to the functionality of loading HTML changing in Android SDK version 29+.

Fixed

  • Fixed in-app layouts always showing up in the top format.

Added

  • Notification Badging/Dots can be explicitly enabled or disabled in AndroidManifest by setting iterable_notification_badging value to true or false. Read More.

Fixed

  • Fixed device registration failure users in JWT enabled projects.
  • Fixed an issue where app would hide from app switcher when external links are deep linked from push notification.

Fixed

  • Fixed a regression with pending intents losing immutability that was causing issues on Android 12. (Thanks to @scaires)

Fixed

  • Notification Trampoline restriction is now handled by the SDK allowing push notification to work seamlessly on Android 12+.

Fixed

  • Prevented in-app messages from executing JavaScript code included in their HTML templates.
  • Prevented web views from accessing local files.

Changed

  • Changed two static methods on the IterableApi class, handleAppLink and getAndTrackDeepLink, to instance methods. To call these methods, grab an instance of the IterableApi class by calling IterableApi.getInstance(). For example, IterableApi.getInstance().handleAppLink(...).

    WARNING This is a breaking change. You'll need to update your code.

Added

  • Added the allowedProtocols field to the IterableConfig class.

    Use this array to declare the specific URL protocols that the SDK can expect to see on incoming links (and that it should therefore handle). Doing this will prevent the SDK from opening links that use unexpected URL protocols.

    For example, this code allows the SDK to handle http and custom links:

    Java

    IterableConfig.Builder configBuilder = new IterableConfig.Builder()
      .setAllowedProtocols(new String[]{"http", "custom"});
    IterableApi.initialize(context, "<YOUR_API_KEY>", config);

    Kotlin

    val configBuilder = IterableConfig.Builder()
      .setAllowedProtocols(arrayOf("http","custom"))
    IterableApi.initialize(context, "<YOUR_API_KEY>", configBuilder.build());

    Iterable's Android SDK handles https, action, itbl, and iterable links, regardless of the contents of this array. However, you must explicitly declare any other types of URL protocols you'd like the SDK to handle (otherwise, the SDK won't open them in the web browser or as deep links).

Changed

  • Auth keys and API keys will no more be logged in Android Logcat for security reasons.

Fixed

  • Crash on closing system dialog is now addressed for Android 12+.

Fixed

  • Fixed an issue where push notifications retained data from previously sent notifications.

Fixed

  • When syncing in-app queues, new messages that already have read set to true will not spawn an InAppDelivery event.

Fixed

  • Added android:exported attribute to activities as required in Android 12.
  • Pending intents now specify its mutability as required in Android 12. (Thanks to @sidcpatel!)

Added

  • Push notifications will now have timestamps on devices with SDK 17 and above.

Added

  • updateCart has been added to the SDK
  • dataFields have been added as a field to CommerceItem

Fixed

  • Devices with Android 11 should now be able to open browser when performing open url actions instead of landing on the app.

Added

  • Added a new static method - setContext to IterableAPI. Use this method in your ReactNative project to pass context to IterableSDK from Application - onCreate method.

Added

  • The following properties have been added to the CommerceItem class:

    • sku - The item's SKU
    • description - A description of the item
    • url - A URL associated with the item
    • imageUrl - A URL that points to an image of the item
    • categories - Categories associated with the item

    Set these values on CommerceItem objects passed to the IterableApi.trackPurchase method.

Changed

  • To resolve a breaking change introduced in Firebase Cloud Messaging version 22.0.0, version 3.3.1 of Iterable's Android SDK bumps the minimum required version of its Firebase Android dependency to 20.3.0.

    If upgrading to version 3.3.1 causes your app to crash on launch, or your build to fail, add the following lines to your app's build.gradle file:

    android {
        ...
        compileOptions {
            sourceCompatibility JavaVersion.VERSION_1_8
            targetCompatibility JavaVersion.VERSION_1_8
        }
        ...
    }
  • Updated minimum version for firebase-messaging to 20.3.0 to use FirebaseMessaging.getToken() instead of deprecated FirebaseInstanceId.getToken().

  • Notifications will now show timestamp.

Added

  • Offline events processing - This feature saves a local copy of events triggered in your app while the device is offline (up to 1000 events). When a connection is re-established and your app is in the foreground, the events will be sent to Iterable. This feature is off by default, and we're rolling it out on a customer-by-customer basis. After you start using this version of the SDK, we'll send you a message before we enable the feature on your account (unfortunately, we can't give you an exact timeline for when this will happen). If you have any questions, talk to your Iterable customer success manager.

Removed

  • Removed legacyGCMSenderId from IterableConfig.
  • Removed deprecated functions spawnInAppNotification and redirected getInAppMessages to be called from IterableInAppManager.

Changed

  • Updated minimum version for firebase-messaging to 19.0.0.
  • Added dependency on Kotlin standard library.

Fixed

  • Non-silent inbox messages will now properly account for the read state.

Added

  • In-app message prioritization - Ordering the display of in-app messages based on a priority you select in Iterable when creating in-app campaigns

Added

  • Support for the display of a custom message (title and body) in an empty mobile inbox. For more details, see Customizing Mobile Inbox on Android

  • Support for syncing in-app message read state across multiple devices:

    • When the SDK fetches in-app messages from Iterable, it examines each message's read field to determine if it has already been read.
    • The SDK's default implementation no longer automatically displays in-app messages that have already been seen on another device (even if those messages were not configured to go directly to the inbox).

    If you'd like to try out these beta features, talk with your Iterable customer success manager.

Added

  • Support for the display of a custom message (title and body) in an empty mobile inbox. For more details, see Customizing Mobile Inbox on Android
  • Support for syncing in-app message read state across multiple devices:
    • When the SDK fetches in-app messages from Iterable, it examines each message's read field to determine if it has already been read.
    • The SDK's default implementation no longer automatically displays in-app messages that have already been seen on another device (even if those messages were not configured to go directly to the inbox).

Changed

  • Changed the timeout for GET calls (/inApp/getMessages in particular) from 3 to 10 seconds.

Fixed

  • Fixed a crash that would sometimes happen when dismissing an in-app message while the app is in background.

Added

  • This beta SDK release includes support for two new Iterable features (both of which are in beta):

    • Offline events processing - Capturing engagement events when a device is offline and sending them to Iterable when a network connection is reestablished
    • In-app message prioritization - Ordering the display of in-app messages based on a priority you select in Iterable when creating in-app campaigns

    If you'd like to try out these beta features, talk with your Iterable customer success manager.

Fixed

  • Fixed Firebase check to work without a Firebase database URL in google-services.json that may not be present in some recently created Firebase projects.

Added

  • Added support for delayed initialization of the SDK. While we still recommend calling IterableApi.initialize in Application#onCreate, apps initializing the Iterable SDK later should now work properly with push actions and background push notifications without issues.

Fixed

  • Fixed IllegalStateException crash in IterableInAppFragmentHTMLNotification by adding safety checks before dismissing the in-app dialog.
  • Fixed a crash in the in-app dialog that could occur in some cases when the device is rotated while the in-app dialog is beginning to load.
  • Fixed a crash in IterablePushActionReceiver when extras are null. This was only happening in automated analysis tools and not in production, but was nevertheless showing up in crash reports.

Added

  • Added support for in-app animations. Select the checkbox to use preset animations when creating a template to see this feature in action.
  • Added support to set custom color and transparency for in-app background.

Fixed

  • Fixed an issue where closing an in-app could crash the app if the message gets deleted from another logged in device while it is being displayed.

Changed

  • The method getExpiresAt in IterableInAppMessage is now public.

Added

  • Added authentication support.

Added

  • Added a new method - setAutoDisplayPaused to InAppManager. This method pauses the display of in-app messages and can be used to prevent interruptions in certain areas of your app.

Changed

  • Changed messageId argument to be non-null in trackPushOpen.

Fixed

  • Fixed an issue where the in-app message queue wasn't being refreshed on app launch.
  • Removed warning messages from logs when using string resources for notification channel name.

Changed

  • app_name was removed from published strings and replaced with plain string values in test manifests.
  • disableToken now disables all devices with the current device token when email and userId are not set.

Fixed

  • Fixed an issue where in-app click events were not being registered after displaying an in-app message.
  • Fixed NullPointerExceptions in IterableInAppFragmentHTMLNotification that could occur in some cases when the activity is destroyed and recreated.
  • Fixed an issue where in-app messages were not getting cleared upon logout.

Added

  • Added support for new parameters - mergeNestedObject in updateUser method.
  • Added public methods - setDeviceAttribute and removeDeviceAttribute to support additional device attributes.

Fixed

  • Method tracing now logs only in VERBOSE log level.

Added

  • IterableInAppMessage now stores the campaignId it belongs to. (Thanks to @nkotula!)

Changed

  • The SDK now uses DialogFragment to show in-app messages. In-app messages are more stable than before and resilient to device configuration changes like device rotation.

Fixed

  • Fixed an ArrayIndexOutOfBoundsException in IterableRequest which is thrown from inside HttpUrlConnection/OkHttp module in certain Android firmwares

Added

  • Added support for new parameters - subscribedMessageTypeIDs, campaignId, templateId in updateSubscriptions method.

Added

  • Mobile Inbox

    Changes since beta:

    • Added support for various ways to customize the default interface for a mobile inbox
    • Added a sample project that demonstrates how to customize the default interface for a mobile inbox
    • Added tracking for inbox sessions (when the inbox is visible in the app) and inbox message impressions (when a individual message's item is visible in the mobile inbox message list)

Removed

  • Removed all old initialization methods starting with sharedInstanceWithApiKey
  • Removed sendPush methods (these API methods can't be called from mobile apps)
  • Removed all deprecated methods with extra parameters for push registration:
    • void registerDeviceToken(String token) is the only one available now for token registration
    • void disablePush() is the only one available for disabling the current push token
    • Platform is always FCM, and push integration name is taken from IterableConfig

Changed

  • The SDK now depends on AndroidX libraries. Migrate your app to use AndroidX before using version 3.2.0 or higher of the SDK.
  • When pushIntegrationName is not set on IterableConfig, the SDK now defaults it to the app's package name. If you've set up your push integration with the new Mobile Apps UI, you don't have to specify pushIntegrationName in the SDK anymore.

Added

  • Added a new static method to IterableFirebaseMessagingService: isGhostPush. Use this method to determine whether a Firebase message is an Iterable ghost push or silent push message.

Fixed

  • Fixed the height of full-screen in-app messages to make sure they're not clipped by the Android navigation bar.
  • The SDK doesn't log an error message anymore when a custom notification channel name is not set.

Changed

  • Automatic push registration is now only done if the app is running in foreground

Added

  • Push notifications now also display image thumbnails when collapsed

Changed

  • Connection timeout for GET requests is now 3 seconds, to match other request timeouts
  • Api-Key header is now also used for GET requests

Fixed

  • Fixed possible exceptions when an in-app message is not on the screen when it's being resized

Fixed

  • Fixed a NullPointerException that could occur in some cases when trying to get Advertising ID

Changed

  • Removed FirebaseInstanceIDService dependency to support newer versions of firebase-messaging library. This bumps the minimum required version of firebase-messaging to 17.4.0.

Fixed

  • Fixed deserialization of in-app messages stored with beta versions of the SDK

Added

  • SDK platform and version is now sent with every API request via headers

Changed

  • Api-Key header name is now used for the API key instead of api_key, for consistency with HTTP header naming conventions

Fixed

  • Fixed an issue that could cause the SDK not to persist in-app message properties (processed/consumed)
  • Fixed a NullPointerException that could occur in IterableActivityMonitor if it was initialized after application start

Added

BREAKING CHANGES

The in-app messaging implementation has been significantly improved:

  • The SDK now maintains a local queue and keep it in sync with the server-side queue automatically
  • Iterable servers now notify apps via silent push messages whenever the in-app message queue is updated
  • In-app messages are shown by default whenever they arrive

Check the In-app messages documentation for more details.

Please refer to the Migration guide if you've been using in-app messages in your app and updating a newer version of the SDK.

Changed

  • BREAKING CHANGE: Added IterableContext argument to IterableCustomActionHandler

    The new method signature is:

    boolean handleIterableCustomAction(IterableAction action, IterableActionContext actionContext)

    actionContext can be used to determine where the call is calling from - push message, in-app message, or a deep link.

  • The SDK now sets notificationsEnabled flag on the device to indicate whether notifications are enabled for the app

  • Changes to in-app links:

    • action:// URL scheme is now reserved for app-specific custom actions. When a user clicks on a link with href = action://myCustomAction, the SDK calls IterableCustomActionHandler.handleIterableCustomAction with action type set to myCustomAction.
    • iterable:// URL scheme is now reserved for actions handled by the SDK (i.e. future versions of the SDK may define iterable://delete as an action to delete the in-app message)
    • itbl:// links will keep working as custom actions (similar to action:// URLs) for backwards compatibility, but itbl:// namespace is deprecated in favor of action://.
    • Migration: if you've been using itbl:// links in the past, please update your templates with action:// instead
  • Connect timeout for deeplink resolution is now 3 seconds

Removed

  • spawnInAppNotification has been removed. Please refer to the in-app migration guide (above)

Fixed

  • Fixed the URL parameter in inAppClick event

Changed

  • The SDK now passes preferUserId flag to create a user by userId if it does not exist when using userId to identify the user
  • Incresed the deep link timeout to 3 seconds

Fixed

  • Fixed InAppClick event parameter to properly track the URL that was clicked
  • Fixed a NullPointerException when an in-app message was being shown while the app was in background

Added

  • Added an option to specify notification channel name via manifest metadata (iterable_notification_channel_name)
  • Added support for color resource references in iterable_notification_color manifest metadata parameter

Changed

  • updateEmail can now be used if the user is identified with userId
  • Connection timeout is now 3 seconds

Fixed

  • Fixed a NullPointerException when the app has a plain-text label in AndroidManifest.xml instead of a string resource reference

Added

  • Added updateEmail method with success & failure callbacks

Added

  • Added public methods to IterableFirebaseMessagingService and IterableFirebaseInstanceIDService that can be called from a custom FirebaseMessagingService subclass

Added

  • Added a new field to IterableConfig - logLevel - to specify the log level for Iterable SDK log messages

Changed

  • The SDK now uses preferUserId flag to create a user by userId instead of the deprecated createUserForUserId API

Fixed

  • The SDK now catches any RuntimeExceptions that may sometimes happen when calling getAdvertisingIdInfo
  • registerDeviceToken and disableToken now use the email/userId that was set at the time of the call, to handle login/logout correctly

Added

  • Added support for user registration with userId. The SDK will now create a new user for userId if it does not exist before registering the device on the user's profile.

Added

  • Added new device fields (Iterable SDK version, app version, app package name) to registerDeviceToken call
  • Deferred Deep Linking support

Fixed

  • Fixed a NullPointerException when an in-app was resized after being dismissed

Added

  • The SDK now registers the token when a new email/userId is set and disables the old device if email/userId was previously set and then changed. This can be disabled by setting autoPushRegistration to false in IterableConfig.

Fixed

  • Fixed a NullPointerException when SDK isn't initialized in Application#onCreate and the app is opened from a push notification

Released on 2018-08-10

Fixed

  • The new email is now persisted when updateEmail is called
  • SDK now ensures that only one in-app message can be shown at a time

Released on 2018-07-30

Added

  • Full FCM support
  • Added support for push action buttons
  • Added a new SDK initialization method that takes IterableConfig object with configuration options
  • User ID/email is now decoupled from SDK initialization. It can be changed by calling setEmail or setUserId on the IterableApi instance.
  • The SDK now stores attribution data within 24 hours of opening the app from a push notififcation or from an App Link in an email
  • Added two handlers: IterableUrlHandler and IterableCustomActionHandler that can be used to customize URL and custom action handling for push notifications
  • Added getPayloadData() method to retrieve the entire notification payload for the notification that opened the app (thanks @steelbrain)

Removed

  • Removed GCM support

Changed

  • Old initialization methods (sharedInstanceWithApiKey) are now deprecated
  • Old registerForPush and registerDeviceToken methods are now deprecated

Migration Notes

  1. If you're using GCM, update your Android app to Firebase Cloud Messaging
  2. Replace IterableAPI.sharedInstanceWithApiKey(...) with the following:
IterableConfig config = new IterableConfig.Builder()
        .setPushIntegrationName("myPushIntegration")
        .setUrlHandler(this)        // If you want to handle URLs coming from push notifications
        .build();
IterableApi.initialize(context, "YOUR API KEY", config);
  1. Call registerForPush() to retrieve the push token and register the device.
  2. User email/userId is now persisted, so you'll only need to call setEmail or setUserId when the user logs in or logs out.
  3. The SDK now tracks push opens automatically, as long as the SDK is initialized in Application's onCreate. See README for instructions. Once it is set up, remove all direct calls to trackPushOpen.

Released on 2018-03-31

Changed

  • Updated requests to not send when there is an exception while constructing the JSON request body.

Fixed

  • Fixed the reference to internal fields in NotificationCompat.Builder for buildVersion 27.

Released on 2018-03-07

Fixed

  • Fixed the load sequence for retrieving a notification image.

Released on 2018-01-22

Added

  • Added non-empty data body for notification rendering.
  • Added default channel id support.

Released on 2017-11-30

Fixed

  • Fixed error in IterablePushRegistration when getDeviceToken returns an empty PushRegistrationObject.

Released on 2017-11-20

Added

  • Added the updateSubscriptions function to create to modify channel, list, and message subscription preferences.

Released on 2017-11-03

Added

  • Added support for html based in-app notifications.

Released on 2017-10-20

Fixed

  • Fixed payload path for image url.

Released on 2017-07-28

Added

  • Added support for android image notifications.

Fixed

  • Fixed load error for empty image url.

Released on 2017-07-19

Fixed

  • Fixed in-app button clicks without an action defined.

Released on 2017-07-19

Added

  • Added the in-app consume logic to automatically remove the notification from list of in-app notifications.

Fixed

  • Fixed the payloadfor trackInAppClick to contain the userId.

Released on 2017-06-09

Added

  • Added full support for newly created Firebase applications
  • Added new functionality for registerForPush which takes in the optional pushServicePlatform
    • IterableConstants.MESSAGING_PLATFORM_GOOGLE (GCM)
    • IterableConstants. MESSAGING_PLATFORM_FIREBASE (FCM)
  • IterableFirebaseInstanceIDService handles firebase token registrations automatically on install.
  • Added in default tracked device values for registerDeviceToken

Changed

  • Changed IterablePushRegistrationGCM to IterablePushRegistration so the registration class is not GCM specific.
  • Changed the disable logic to no longer enable the deviceToken prior to disabling.

Released on 2017-02-23

Fixed

  • fixed uploaded pom file

Released on 2017-02-22

Added

  • Added support for Android deeplink tracking
  • getAndTrackDeeplink tracks a click and returns the destination url.

Released on 2017-01-09

Changed

  • Updated the PendingIntent request code to use the messageId instead of the current timestamp.

Released on 2017-01-09

Fixed

  • fixed overwritten pushnotification metadata on subsequent notifications

Released on 2016-12-28

  • added support for In-App Notifications with different views layouts
    • Full screen
    • Bottom
    • Center
    • Top
  • includes tracking for In-App opens and clicks
  • includes support for GET requests

Released on 2016-10-13

Added

  • Added ability to send data by userId