[SDK-361] Preventing push notification from killing exisitng activity#994
Open
franco-zalamena-iterable wants to merge 1 commit intomasterfrom
Open
[SDK-361] Preventing push notification from killing exisitng activity#994franco-zalamena-iterable wants to merge 1 commit intomasterfrom
franco-zalamena-iterable wants to merge 1 commit intomasterfrom
Conversation
Member
|
This PR is giving good confidence. |
Ayyanchira
approved these changes
Feb 23, 2026
Member
Ayyanchira
left a comment
There was a problem hiding this comment.
This change looks promising. Will have to monitor after release for customer feedback if any.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
🔹 Jira Ticket(s) if any
✏️ Description
Problem
Tapping an Iterable push while the app is already running destroys the entire existing activity task, forcing a full cold start. In React Native apps this is highly visible - the JS bridge re-initializes and startup logic re-runs. In native apps the same destruction happens silently.
Two compounding issues in
IterableTrampolineActivity:taskAffinity- defaults to the app's package name, so it shares the app's taskFLAG_ACTIVITY_CLEAR_TASKon the notification PendingIntent - with a shared affinity, this wipes the app's entire activity stack before the trampoline launchesIterableTrampolineActivitywas introduced in MOB-3754 / SDK 3.4.1 for Android 12 trampoline restrictions. ThetaskAffinityisolation was never added, andFLAG_ACTIVITY_CLEAR_TASKwas carried over from the pre-Android-12 path where it was applied to a different intent.Fix
android:taskAffinity=""toIterableTrampolineActivity- isolates it into its own task, standard practice for transparent routing activitiesFLAG_ACTIVITY_CLEAR_TASKfrom the trampolinePendingIntentinIterableNotificationHelperandIterableNotificationBuilder- not necessaryReferences