Releases: Iterable/iterable-android-sdk
3.4.16
Fixed
- SDK now handles
null
scenarios preventing crashes whenIterableEncryptedSharedPreference
creation fails. - Updated crypto library to version 1.1.0-alpha06.
1.1.0-alpha05 solves a race condition during creation process. - Fixes #631 and #616
3.4.15
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)
3.4.14
Added
IterableInAppManager.setRead
now acceptsIterableHelper.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.
3.4.13
Added
IterableInAppManager.setRead
now acceptsIterableHelper.SuccessHandler successHandler
.IterableApi.inAppConsume
now acceptsIterableHelper.SuccessHandler successHandler
andIterableHelper.FailureHandler failureHandler
.
3.4.12
Added
setEmail
andsetUserId
now acceptsIterableHelper.SuccessHandler successHandler
andIterableHelper.FailureHandler failureHandler
.
Changed
- OTT devices (FireTV) will now register as
OTT
device instead ofAndroid
under user's devices.
3.5.0-alpha2
3.5.0-alpha1
3.4.11
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 calledPaid
. 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
, andauthToken
, the SDK now provides convenience methods:getEmail()
,getUserId()
, andgetAuthToken()
.
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 upgradedandroidx.security.crypto
from version1.0.0
to1.1.0-alpha04
. WhenEncryptedSharedPreferences
cannot be created, the SDK now usesSharedPreferences
(unencrypted).If your app requires encryption, you can prevent this fallback to
SharedPreferences
by setting theencryptionEnforced
configuration flag totrue
. However, if you enable this flag andEncryptedSharedPreferences
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.
3.4.10
Warning
Some users have reported crashes in apps built with version 3.4.10 of
Iterable's Android SDK. We're investigating the issue. In the meantime, please
test thoroughly. If you see crashes, revert to version 3.4.9.
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):
- In
AndroidManifest.xml
, add<uses-sdk tools:overrideLibrary="androidx.security" />
- In your app's
app/build.gradle
:- Add
multiDexEnabled true
to thedefault
object, underandroid
. - Add
implementation androidx.multidex:multidex:2.0.1
to thedependencies
.
- Add
3.4.9
Added
- Added new methods for
setEmail
,setUserId
andupdateEmail
which acceptsauthToken
, providing more ways to passauthToken
to SDK - Added two interface methods -
onTokenRegistrationSuccessful
andonTokenRegistrationFailed
. Override these methods to see if authToken was successfully received by the SDK.
Changed
setAuthToken
method is now public allowing additional way to provideauthToken
to SDK.