From 6b1270bb842e449f43de698013e801535a0c8f49 Mon Sep 17 00:00:00 2001 From: echo Date: Tue, 26 Mar 2024 18:03:25 -0700 Subject: [PATCH] SDK-2309 cache link data when initialization is deferred for plugins --- Sources/BranchSDK/Branch.m | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/Sources/BranchSDK/Branch.m b/Sources/BranchSDK/Branch.m index 984fbb40d..ed23381f4 100644 --- a/Sources/BranchSDK/Branch.m +++ b/Sources/BranchSDK/Branch.m @@ -155,6 +155,7 @@ @interface Branch() { // This is enabled by setting deferInitForPluginRuntime to true in branch.json @property (nonatomic, assign, readwrite) BOOL deferInitForPluginRuntime; @property (nonatomic, copy, nullable) void (^cachedInitBlock)(void); +@property (nonatomic, copy, readwrite) NSString *cachedURLString; @end @@ -1922,11 +1923,21 @@ - (void)initSafetyCheck { - (void)initUserSessionAndCallCallback:(BOOL)callCallback sceneIdentifier:(NSString *)sceneIdentifier urlString:(NSString *)urlString { - // ignore lifecycle calls while waiting for a plugin runtime. @synchronized (self) { if (self.deferInitForPluginRuntime) { - [[BranchLogger shared] logDebug:@"Branch init is deferred, ignoring init call."]; + if (urlString) { + [[BranchLogger shared] logDebug:@"Branch init is deferred, caching link"]; + self.cachedURLString = urlString; + } else { + [[BranchLogger shared] logDebug:@"Branch init is deferred, ignoring lifecycle call without a link"]; + } return; + } else { + if (!urlString && self.cachedURLString) { + urlString = self.cachedURLString; + self.cachedURLString = nil; + [[BranchLogger shared] logDebug:[NSString stringWithFormat:@"Using cached link: %@", urlString]]; + } } }