From fecb45dd0e615261fa9b533bb9469f3d7b0f4a6e Mon Sep 17 00:00:00 2001 From: jinliu9508 Date: Tue, 10 Dec 2024 12:23:01 -0500 Subject: [PATCH] fix ANR caused by operationRepo.enqueue while loading is not finished --- .../onesignal/common/modeling/ModelStore.kt | 49 ++++++++++--------- 1 file changed, 25 insertions(+), 24 deletions(-) diff --git a/OneSignalSDK/onesignal/core/src/main/java/com/onesignal/common/modeling/ModelStore.kt b/OneSignalSDK/onesignal/core/src/main/java/com/onesignal/common/modeling/ModelStore.kt index f7c41a410b..8651db5295 100644 --- a/OneSignalSDK/onesignal/core/src/main/java/com/onesignal/common/modeling/ModelStore.kt +++ b/OneSignalSDK/onesignal/core/src/main/java/com/onesignal/common/modeling/ModelStore.kt @@ -169,33 +169,34 @@ abstract class ModelStore( val str = _prefs.getString(PreferenceStores.ONESIGNAL, PreferenceOneSignalKeys.MODEL_STORE_PREFIX + name, "[]") val jsonArray = JSONArray(str) - synchronized(models) { - val shouldRePersist = models.isNotEmpty() - for (index in jsonArray.length() - 1 downTo 0) { - val newModel = create(jsonArray.getJSONObject(index)) ?: continue - - /* - * NOTE: Migration fix for bug introduced in 5.1.12 - * The following check is intended for the operation model store. - * When the call to this method moved out of the operation model store's initializer, - * duplicate operations could be cached. - * See https://github.com/OneSignal/OneSignal-Android-SDK/pull/2099 - */ - val hasExisting = models.any { it.id == newModel.id } - if (hasExisting) { - Logging.debug("ModelStore<$name>: load - operation.id: ${newModel.id} already exists in the store.") - continue - } - models.add(0, newModel) - // listen for changes to this model - newModel.subscribe(this) + val shouldRePersist = models.isNotEmpty() + for (index in jsonArray.length() - 1 downTo 0) { + val newModel = create(jsonArray.getJSONObject(index)) ?: continue + + /* + * NOTE: Migration fix for bug introduced in 5.1.12 + * The following check is intended for the operation model store. + * When the call to this method moved out of the operation model store's initializer, + * duplicate operations could be cached. + * See https://github.com/OneSignal/OneSignal-Android-SDK/pull/2099 + */ + val hasExisting = models.any { it.id == newModel.id } + if (hasExisting) { + Logging.debug("ModelStore<$name>: load - operation.id: ${newModel.id} already exists in the store.") + continue } - hasLoadedFromCache = true - // optimization only: to avoid unnecessary writes - if (shouldRePersist) { - persist() + + synchronized(models) { + models.add(0, newModel) } + // listen for changes to this model + newModel.subscribe(this) + } + hasLoadedFromCache = true + // optimization only: to avoid unnecessary writes + if (shouldRePersist) { + persist() } }