.class abstract Lcom/ea/nimble/tracking/NimbleTrackingImplBase; .super Lcom/ea/nimble/Component; .source "SourceFile" # interfaces .implements Lcom/ea/nimble/tracking/ITracking; .implements Lcom/ea/nimble/LogSource; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver;, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver;, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$PostTask;, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData; } .end annotation # static fields .field private static final DATA_VERSION_CURRENT:I = 0x3 .field private static final DEFAULT_MAX_QUEUE_LENGTH:I = 0x3 .field protected static final DEFAULT_POST_INTERVAL:D = 1.0 .field protected static final DEFAULT_REPOST_MULTIPLIER:D = 2.0 .field protected static final DEFAULT_RETRY_DELAY:D = 1.0 .field protected static final MAX_POST_RETRY_DELAY:D = 300.0 .field private static final MAX_QUEUED_EVENTS:I = 0x32 .field private static final MAX_QUEUED_SESSIONS:I = 0x32 .field public static final NIMBLE_TRACKING_DEFAULT_POST_ENABLE:Ljava/lang/String; = "NimbleDefaultTrackingPostFlag" .field protected static final NOW_POST_INTERVAL:D = 0.0 .field private static final ORIGIN_LOGIN_STATUS_STRING_AUTO_LOGGING_IN:Ljava/lang/String; = "autoLogin" .field private static final ORIGIN_LOGIN_STATUS_STRING_LIVE_USER:Ljava/lang/String; = "live" .field private static final ORIGIN_NOTIFICATION_LOGIN_STATUS_UPDATE_KEY_STATUS:Ljava/lang/String; = "STATUS" .field private static final PERSISTENCE_CURRENT_SESSION_ID:Ljava/lang/String; = "currentSessionObject" .field private static final PERSISTENCE_ENABLE_FLAG:Ljava/lang/String; = "trackingEnabledFlag" .field private static final PERSISTENCE_EVENT_QUEUE_ID:Ljava/lang/String; = "eventQueue" .field private static final PERSISTENCE_FIRST_SESSION_ID_NUMBER:Ljava/lang/String; = "firstSessionIDNumber" .field private static final PERSISTENCE_LAST_SESSION_ID_NUMBER:Ljava/lang/String; = "lastSessionIDNumber" .field private static final PERSISTENCE_LOGGED_IN_TO_ORIGIN_ID:Ljava/lang/String; = "loggedInToOrigin" .field private static final PERSISTENCE_POST_ENABLE_FLAG:Ljava/lang/String; = "trackingPostEnabledFlag" .field private static final PERSISTENCE_QUEUED_SESSIONS_ID:Ljava/lang/String; = "queuedSessionObjects" .field private static final PERSISTENCE_SAVED_SESSION_ID_NUMBER:Ljava/lang/String; = "savedSession" .field private static final PERSISTENCE_SESSION_DATA_ID:Ljava/lang/String; = "sessionData" .field private static final PERSISTENCE_TOTAL_SESSION_COUNT:Ljava/lang/String; = "totalSessionCount" .field private static final PERSISTENCE_TRACKING_ATTRIBUTES:Ljava/lang/String; = "trackingAttributes" .field private static final PERSISTENCE_VERSION_ID:Ljava/lang/String; = "dataVersion" .field private static final SESSION_FILE_FORMAT:Ljava/lang/String; = "%sSession%d" # instance fields .field protected m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .field protected m_customSessionData:Ljava/util/ArrayList; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/ArrayList<", "Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData;", ">;" } .end annotation .end field .field private m_enable:Z .field private m_firstSessionIDNumber:J .field private m_isFeatureDisabledFromServer:Z .field private m_isPostPending:Z .field protected m_isRequestInProgress:Z .field private m_lastSessionIDNumber:J .field protected m_loggedInToOrigin:Z .field private final m_maxQueueLength:I .field private m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; .field private m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; .field private m_postEnable:Z .field protected m_postInterval:D .field protected m_postRetryDelay:D .field private m_postTimer:Ljava/util/concurrent/ScheduledFuture; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/concurrent/ScheduledFuture<", "*>;" } .end annotation .end field .field private m_receiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver; .field protected m_sessionsToPost:Ljava/util/ArrayList; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/ArrayList<", "Lcom/ea/nimble/tracking/TrackingBaseSessionObject;", ">;" } .end annotation .end field .field protected m_threadManager:Lcom/ea/nimble/tracking/NimbleTrackingThreadManager; .field private m_totalSessions:J .field protected m_trackingAttributes:Ljava/util/HashMap; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/HashMap<", "Ljava/lang/String;", "Ljava/lang/String;", ">;" } .end annotation .end field # direct methods .method public constructor ()V .locals 4 .line 130 invoke-direct {p0}, Lcom/ea/nimble/Component;->()V .line 46 new-instance v0, Ljava/util/ArrayList; invoke-direct {v0}, Ljava/util/ArrayList;->()V iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; const/4 v0, 0x1 iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z const/4 v1, 0x0 iput-boolean v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isFeatureDisabledFromServer:Z .line 133 new-instance v2, Ljava/util/ArrayList; invoke-direct {v2}, Ljava/util/ArrayList;->()V iput-object v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_customSessionData:Ljava/util/ArrayList; const/4 v2, 0x0 iput-object v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_receiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver; iput-object v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; iput-boolean v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_loggedInToOrigin:Z iput-object v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; .line 138 new-instance v2, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; invoke-direct {v2}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->()V iput-object v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; const-wide/high16 v2, 0x3ff0000000000000L # 1.0 iput-wide v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postInterval:D iput-boolean v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isPostPending:Z iput-boolean v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isRequestInProgress:Z const-wide/16 v1, -0x1 iput-wide v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J const-wide/16 v1, 0x0 iput-wide v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J iput-wide v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J .line 145 new-instance v1, Ljava/util/HashMap; invoke-direct {v1}, Ljava/util/HashMap;->()V iput-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_trackingAttributes:Ljava/util/HashMap; iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z const/4 v0, 0x3 iput v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_maxQueueLength:I return-void .end method .method public static synthetic access$000(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;Z)V .locals 0 .line 34 invoke-direct {p0, p1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->postIntervalTimerExpired(Z)V return-void .end method .method public static synthetic access$300(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;)V .locals 0 .line 34 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->updateFeatureDisableState()V return-void .end method .method public static synthetic access$400(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;Landroid/content/Intent;)V .locals 0 .line 34 invoke-direct {p0, p1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->onStartupRequestsFinished(Landroid/content/Intent;)V return-void .end method .method public static synthetic access$500(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;Landroid/content/Intent;)V .locals 0 .line 34 invoke-direct {p0, p1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->onOriginLoginStatusChanged(Landroid/content/Intent;)V return-void .end method .method public static synthetic access$600(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;)V .locals 0 .line 34 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->onNetworkStatusChange()V return-void .end method .method private addCurrentSessionObjectToBackOfQueue()V .locals 4 .line 1223 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J const-wide/16 v2, 0x1 add-long/2addr v0, v2 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J add-long/2addr v0, v2 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 1228 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v0 iget v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_maxQueueLength:I if-lt v0, v1, :cond_0 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; iget-wide v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J .line 1230 invoke-direct {p0, v0, v1, v2}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveSessionToFile(Lcom/ea/nimble/tracking/TrackingBaseSessionObject;J)V goto :goto_0 :cond_0 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; iget-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 1235 invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z .line 1238 :goto_0 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveToPersistence()V return-void .end method .method private configureTrackingOnFirstInstall()V .locals 3 .line 695 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 v0, 0x0 new-array v1, v0, [Ljava/lang/Object; const-string v2, "First Install. Look for App Settings to enable/disable tracking" .line 699 invoke-static {p0, v2, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string v1, "com.ea.nimble.tracking.defaultEnable" .line 701 invoke-static {v1}, Lcom/ea/nimble/NimbleApplicationConfiguration;->getConfigValueAsString(Ljava/lang/String;)Ljava/lang/String; move-result-object v1 .line 703 invoke-static {v1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v2 if-eqz v2, :cond_2 const-string v2, "enable" .line 705 invoke-virtual {v1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result v2 if-eqz v2, :cond_0 const-string v1, "Default App Setting : Enable Tracking" new-array v0, v0, [Ljava/lang/Object; .line 707 invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const/4 v0, 0x1 iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z goto :goto_0 :cond_0 const-string v2, "disable" .line 710 invoke-virtual {v1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result v1 if-eqz v1, :cond_1 const-string v1, "Default App Setting : Disable Tracking" new-array v2, v0, [Ljava/lang/Object; .line 712 invoke-static {p0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z :cond_1 :goto_0 return-void :cond_2 const-string v0, "Nimble" const-string v1, "WARNING! Cannot find valid TrackingEnable from AndroidManifest.xml" .line 723 invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I return-void .end method .method private dropExtraSessions()V .locals 6 .line 1272 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 v0, 0x1 .line 1273 invoke-direct {p0, v0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->dropExtraSessions(Z)Z move-result v0 if-nez v0, :cond_0 const-string v0, "Failed to drop enough sessions. Dropping sessions without checking canDropSession." const/4 v1, 0x0 new-array v2, v1, [Ljava/lang/Object; .line 1275 invoke-static {p0, v0, v2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 1276 invoke-direct {p0, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->dropExtraSessions(Z)Z move-result v0 if-nez v0, :cond_0 .line 1278 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v2, "Still unable to drop enough sessions. Remaining number: " invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-wide v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J iget-wide v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J sub-long/2addr v2, v4 const-wide/16 v4, 0x1 add-long/2addr v2, v4 invoke-virtual {v0, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 new-array v1, v1, [Ljava/lang/Object; invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V :cond_0 return-void .end method .method private dropExtraSessions(Z)Z .locals 14 .line 1304 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J const-wide/16 v2, 0x32 cmp-long v4, v0, v2 const/4 v5, 0x1 if-gez v4, :cond_0 return v5 .line 1311 :cond_0 invoke-static {v0, v1}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v0 const/16 v1, 0x32 invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v1 filled-new-array {v0, v1}, [Ljava/lang/Object; move-result-object v0 const-string v1, "Current number of sessions (%d) has reached maximum (%d). Removing old sessions." .line 1310 invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 1313 new-instance v0, Ljava/util/ArrayList; invoke-direct {v0}, Ljava/util/ArrayList;->()V iget-wide v6, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J :goto_0 iget-wide v8, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J cmp-long v1, v6, v8 const-wide/16 v8, 0x1 if-gtz v1, :cond_8 iget-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J sub-long v10, v6, v10 iget-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 1320 invoke-virtual {v1}, Ljava/util/ArrayList;->size()I move-result v1 int-to-long v12, v1 cmp-long v1, v10, v12 if-gez v1, :cond_1 iget-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; long-to-int v4, v10 .line 1322 invoke-virtual {v1, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; goto :goto_1 .line 1326 :cond_1 invoke-direct {p0, v6, v7}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->loadSessionFromFile(J)Lcom/ea/nimble/tracking/TrackingBaseSessionObject; move-result-object v1 if-nez v1, :cond_2 goto :goto_3 .line 1333 :cond_2 :goto_1 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v4 if-eqz v4, :cond_7 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v4 sub-int/2addr v4, v5 invoke-virtual {v0, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object; move-result-object v4 check-cast v4, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; invoke-virtual {p0, v4, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->isSameSession(Lcom/ea/nimble/tracking/TrackingBaseSessionObject;Lcom/ea/nimble/tracking/TrackingBaseSessionObject;)Z move-result v4 if-eqz v4, :cond_3 goto :goto_2 :cond_3 if-eqz p1, :cond_4 .line 1341 invoke-virtual {p0, v0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->canDropSession(Ljava/util/List;)Z move-result v4 if-eqz v4, :cond_5 :cond_4 sub-long v10, v6, v8 .line 1343 invoke-direct {p0, v0, v10, v11}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->dropSessions(Ljava/util/ArrayList;J)V .line 1345 :cond_5 invoke-virtual {v0}, Ljava/util/ArrayList;->clear()V iget-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J cmp-long v4, v10, v2 if-gez v4, :cond_6 .line 1349 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->fillSessionsToPost()V return v5 .line 1353 :cond_6 invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z goto :goto_3 .line 1336 :cond_7 :goto_2 invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z :goto_3 add-long/2addr v6, v8 goto :goto_0 .line 1357 :cond_8 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v1 if-lez v1, :cond_a if-eqz p1, :cond_9 invoke-virtual {p0, v0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->canDropSession(Ljava/util/List;)Z move-result p1 if-eqz p1, :cond_a :cond_9 sub-long/2addr v6, v8 .line 1359 invoke-direct {p0, v0, v6, v7}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->dropSessions(Ljava/util/ArrayList;J)V .line 1362 :cond_a invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->fillSessionsToPost()V iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J cmp-long p1, v0, v2 if-gez p1, :cond_b goto :goto_4 :cond_b const/4 v5, 0x0 :goto_4 return v5 .end method .method private dropSessions(Ljava/util/ArrayList;J)V .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/ArrayList<", "Lcom/ea/nimble/tracking/TrackingBaseSessionObject;", ">;J)V" } .end annotation .line 1285 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 v0, 0x0 .line 1286 :goto_0 invoke-virtual {p1}, Ljava/util/ArrayList;->size()I move-result v1 if-ge v0, v1, :cond_0 iget-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 1288 invoke-virtual {p1, v0}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object; move-result-object v2 invoke-virtual {v1, v2}, Ljava/util/ArrayList;->remove(Ljava/lang/Object;)Z int-to-long v1, v0 sub-long v1, p2, v1 .line 1290 invoke-direct {p0, v1, v2}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->getFilenameForSessionID(J)Ljava/lang/String; move-result-object v1 sget-object v2, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {v1, v2}, Lcom/ea/nimble/PersistenceService;->removePersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)V add-int/lit8 v0, v0, 0x1 goto :goto_0 .line 1292 :cond_0 invoke-virtual {p1}, Ljava/util/ArrayList;->size()I move-result v0 int-to-long v0, v0 sub-long/2addr p2, v0 const-wide/16 v0, 0x1 add-long/2addr p2, v0 iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J cmp-long p2, p2, v0 if-nez p2, :cond_1 .line 1294 invoke-virtual {p1}, Ljava/util/ArrayList;->size()I move-result p2 int-to-long p2, p2 add-long/2addr v0, p2 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J :cond_1 iget-wide p2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J .line 1296 invoke-virtual {p1}, Ljava/util/ArrayList;->size()I move-result p1 int-to-long v0, p1 sub-long/2addr p2, v0 iput-wide p2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J .line 1297 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveToPersistence()V return-void .end method .method private fillSessionsToPost()V .locals 5 .line 1243 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 1246 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v0 :goto_0 iget v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_maxQueueLength:I if-ge v0, v1, :cond_2 iget-wide v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J int-to-long v3, v0 add-long/2addr v1, v3 iget-wide v3, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J cmp-long v3, v1, v3 if-lez v3, :cond_0 return-void .line 1256 :cond_0 invoke-direct {p0, v1, v2}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->loadSessionFromFile(J)Lcom/ea/nimble/tracking/TrackingBaseSessionObject; move-result-object v3 if-eqz v3, :cond_1 iget-object v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 1260 invoke-virtual {v4, v3}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z .line 1261 invoke-direct {p0, v1, v2}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->getFilenameForSessionID(J)Ljava/lang/String; move-result-object v1 sget-object v2, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {v1, v2}, Lcom/ea/nimble/PersistenceService;->removePersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)V goto :goto_1 :cond_1 iget-wide v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J const-wide/16 v3, 0x1 add-long/2addr v1, v3 iput-wide v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J :goto_1 add-int/lit8 v0, v0, 0x1 goto :goto_0 :cond_2 return-void .end method .method private getFilenameForSessionID(J)Ljava/lang/String; .locals 2 .line 1194 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const-wide/16 v0, 0x0 cmp-long v0, p1, v0 if-gez v0, :cond_0 const/4 p1, 0x0 new-array p1, p1, [Ljava/lang/Object; const-string p2, "Trying to find the filename for an invalid sessionID!" .line 1197 invoke-static {p0, p2, p1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const/4 p1, 0x0 return-object p1 .line 1202 :cond_0 sget-object v0, Ljava/util/Locale;->US:Ljava/util/Locale; invoke-virtual {p0}, Lcom/ea/nimble/Component;->getComponentId()Ljava/lang/String; move-result-object v1 invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object p1 filled-new-array {v1, p1}, [Ljava/lang/Object; move-result-object p1 const-string p2, "%sSession%d" invoke-static {v0, p2, p1}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object p1 return-object p1 .end method .method private killPostTimer()V .locals 2 .line 313 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postTimer:Ljava/util/concurrent/ScheduledFuture; if-eqz v0, :cond_0 const/4 v1, 0x0 .line 316 invoke-interface {v0, v1}, Ljava/util/concurrent/Future;->cancel(Z)Z const/4 v0, 0x0 iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postTimer:Ljava/util/concurrent/ScheduledFuture; :cond_0 return-void .end method .method private loadSessionFromFile(J)Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .locals 2 .line 1171 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 1172 invoke-direct {p0, p1, p2}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->getFilenameForSessionID(J)Ljava/lang/String; move-result-object p1 sget-object p2, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {p1, p2}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object p1 const/4 p2, 0x0 if-eqz p1, :cond_0 const-string v0, "savedSession" .line 1176 invoke-virtual {p1, v0}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object p1 if-eqz p1, :cond_0 .line 1177 invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v0 const-class v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; if-ne v0, v1, :cond_0 .line 1179 check-cast p1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; return-object p1 :cond_0 return-object p2 .end method .method private logEvent(Lcom/ea/nimble/tracking/Tracking$Event;Z)V .locals 2 .line 213 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 214 invoke-virtual {p0, p1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->convertEvent(Lcom/ea/nimble/tracking/Tracking$Event;)Ljava/util/List; move-result-object p1 if-eqz p1, :cond_2 .line 216 invoke-interface {p1}, Ljava/util/List;->isEmpty()Z move-result v0 if-nez v0, :cond_2 .line 218 invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p1 :goto_0 invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z move-result v0 if-eqz v0, :cond_0 invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/util/Map; iget-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 220 iget-object v1, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->events:Ljava/util/List; invoke-interface {v1, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z const-string v1, "Logged event, %s: \n" filled-new-array {v0}, [Ljava/lang/Object; move-result-object v0 .line 221 invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 223 :cond_0 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveToPersistence()V if-nez p2, :cond_2 iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postTimer:Ljava/util/concurrent/ScheduledFuture; if-eqz p1, :cond_1 .line 225 invoke-interface {p1}, Ljava/util/concurrent/Future;->isDone()Z move-result p1 if-eqz p1, :cond_2 iget-boolean p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isRequestInProgress:Z if-nez p1, :cond_2 :cond_1 const/4 p1, 0x0 .line 227 invoke-virtual {p0, p1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->isAbleToPostEvent(Z)Z move-result p1 if-eqz p1, :cond_2 .line 229 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer()V :cond_2 iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 234 iget-object p1, p1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->events:Ljava/util/List; invoke-interface {p1}, Ljava/util/List;->size()I move-result p1 const/16 v0, 0x32 if-lt p1, v0, :cond_3 iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 236 iget-object p1, p1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->events:Ljava/util/List; .line 237 invoke-interface {p1}, Ljava/util/List;->size()I move-result p1 invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p1 invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v0 filled-new-array {p1, v0}, [Ljava/lang/Object; move-result-object p1 const-string v0, "Current number of events (%d) has reached maximum (%d). Posting event queue now." .line 236 invoke-static {p0, v0, p1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_1 :cond_3 if-eqz p2, :cond_4 .line 242 :goto_1 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->killPostTimer()V .line 243 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->packageCurrentSession()V .line 244 invoke-virtual {p0, p2}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->postPendingEvents(Z)V :cond_4 return-void .end method .method private onNetworkStatusChange()V .locals 2 .line 1077 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 1078 invoke-static {}, Lcom/ea/nimble/Network;->getComponent()Lcom/ea/nimble/INetwork; move-result-object v0 invoke-interface {v0}, Lcom/ea/nimble/INetwork;->getStatus()Lcom/ea/nimble/Network$Status; move-result-object v0 sget-object v1, Lcom/ea/nimble/Network$Status;->OK:Lcom/ea/nimble/Network$Status; if-ne v0, v1, :cond_0 const/4 v0, 0x0 new-array v0, v0, [Ljava/lang/Object; const-string v1, "Network status restored, kicking off event post." .line 1080 invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; .line 1083 invoke-static {v0}, Lcom/ea/nimble/Utility;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V const/4 v0, 0x0 iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; const-wide/16 v0, 0x0 .line 1086 invoke-virtual {p0, v0, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer(D)V :cond_0 return-void .end method .method private onOriginLoginStatusChanged(Landroid/content/Intent;)V .locals 2 .line 861 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 862 invoke-virtual {p1}, Landroid/content/Intent;->getExtras()Landroid/os/Bundle; move-result-object v0 const/4 v1, 0x0 if-eqz v0, :cond_2 .line 865 invoke-virtual {p1}, Landroid/content/Intent;->getExtras()Landroid/os/Bundle; move-result-object p1 const-string v0, "STATUS" invoke-virtual {p1, v0}, Landroid/os/BaseBundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 const-string v0, "live" .line 866 invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v0 if-nez v0, :cond_1 const-string v0, "autoLogin" .line 867 invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-eqz p1, :cond_0 goto :goto_0 :cond_0 const-string p1, "Login status update, FALSE" new-array v0, v1, [Ljava/lang/Object; .line 874 invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iput-boolean v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_loggedInToOrigin:Z goto :goto_1 :cond_1 :goto_0 const-string p1, "Login status update, TRUE" new-array v0, v1, [Ljava/lang/Object; .line 869 invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const/4 p1, 0x1 iput-boolean p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_loggedInToOrigin:Z goto :goto_1 :cond_2 const-string p1, "Login status updated event received without extras bundle. Marking NOT logged in to Origin." new-array v0, v1, [Ljava/lang/Object; .line 882 invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iput-boolean v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_loggedInToOrigin:Z :goto_1 return-void .end method .method private onStartupRequestsFinished(Landroid/content/Intent;)V .locals 8 .line 739 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 741 invoke-virtual {p1}, Landroid/content/Intent;->getExtras()Landroid/os/Bundle; move-result-object v0 if-eqz v0, :cond_c .line 743 invoke-virtual {p1}, Landroid/content/Intent;->getExtras()Landroid/os/Bundle; move-result-object p1 const-string v0, "result" invoke-virtual {p1, v0}, Landroid/os/BaseBundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 const-string v0, "1" .line 744 invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-eqz p1, :cond_c .line 747 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object p1 invoke-interface {p1}, Lcom/ea/nimble/ISynergyEnvironment;->getTrackingPostInterval()I move-result p1 if-ltz p1, :cond_1 const/4 v0, -0x1 if-ne p1, v0, :cond_0 goto :goto_0 :cond_0 int-to-double v0, p1 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postInterval:D goto :goto_1 :cond_1 :goto_0 const-wide/high16 v0, 0x3ff0000000000000L # 1.0 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postInterval:D :goto_1 iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; const/4 v0, 0x0 if-eqz p1, :cond_a .line 761 invoke-virtual {p1}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator; move-result-object p1 :cond_2 :goto_2 invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_a invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; if-eqz v1, :cond_2 .line 763 iget-object v2, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; if-eqz v2, :cond_2 const-string v3, "sellId" .line 765 invoke-interface {v2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 .line 766 instance-of v4, v2, Ljava/lang/String; const-string v5, "" const-string v6, "0" if-eqz v4, :cond_4 check-cast v2, Ljava/lang/String; invoke-static {v2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v4 if-eqz v4, :cond_4 .line 767 invoke-virtual {v2, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-nez v2, :cond_4 .line 769 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v2 .line 770 invoke-interface {v2}, Lcom/ea/nimble/ISynergyEnvironment;->getSellId()Ljava/lang/String; move-result-object v2 .line 771 iget-object v4, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; invoke-static {v2}, Lcom/ea/nimble/Utility;->safeString(Ljava/lang/String;)Ljava/lang/String; move-result-object v7 invoke-interface {v4, v3, v7}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; if-eqz v2, :cond_3 .line 772 invoke-virtual {v2, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-nez v3, :cond_3 invoke-virtual {v2, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_4 :cond_3 const-string v2, "Sell Id was still null after synergy update" new-array v3, v0, [Ljava/lang/Object; .line 774 invoke-static {p0, v2, v3}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 777 :cond_4 iget-object v2, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; const-string v3, "hwId" invoke-interface {v2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 .line 778 instance-of v4, v2, Ljava/lang/String; if-eqz v4, :cond_6 check-cast v2, Ljava/lang/String; invoke-static {v2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v2 if-eqz v2, :cond_6 .line 780 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v2 .line 781 invoke-interface {v2}, Lcom/ea/nimble/ISynergyEnvironment;->getEAHardwareId()Ljava/lang/String; move-result-object v2 .line 782 iget-object v4, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; invoke-static {v2}, Lcom/ea/nimble/Utility;->safeString(Ljava/lang/String;)Ljava/lang/String; move-result-object v7 invoke-interface {v4, v3, v7}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; if-eqz v2, :cond_5 .line 783 invoke-virtual {v2, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_6 :cond_5 const-string v2, "Hardware Id was still null after synergy update" new-array v3, v0, [Ljava/lang/Object; .line 785 invoke-static {p0, v2, v3}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 788 :cond_6 iget-object v2, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; const-string v3, "deviceId" invoke-interface {v2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 .line 789 instance-of v4, v2, Ljava/lang/String; if-eqz v4, :cond_8 check-cast v2, Ljava/lang/String; invoke-static {v2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v4 if-eqz v4, :cond_8 .line 790 invoke-virtual {v2, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-nez v2, :cond_8 .line 792 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v2 .line 793 invoke-interface {v2}, Lcom/ea/nimble/ISynergyEnvironment;->getEADeviceId()Ljava/lang/String; move-result-object v2 .line 794 iget-object v4, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; invoke-static {v2}, Lcom/ea/nimble/Utility;->safeString(Ljava/lang/String;)Ljava/lang/String; move-result-object v7 invoke-interface {v4, v3, v7}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; if-eqz v2, :cond_7 .line 795 invoke-virtual {v2, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-nez v3, :cond_7 invoke-virtual {v2, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_8 :cond_7 const-string v2, "Device Id was still null after synergy update" new-array v3, v0, [Ljava/lang/Object; .line 797 invoke-static {p0, v2, v3}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 800 :cond_8 iget-object v2, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; const-string v3, "synergyId" invoke-interface {v2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 .line 801 instance-of v4, v2, Ljava/lang/String; if-eqz v4, :cond_2 check-cast v2, Ljava/lang/String; invoke-static {v2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v4 if-eqz v4, :cond_2 .line 802 invoke-virtual {v2, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-nez v2, :cond_2 .line 804 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v2 .line 805 invoke-interface {v2}, Lcom/ea/nimble/ISynergyEnvironment;->getSynergyId()Ljava/lang/String; move-result-object v2 .line 806 iget-object v1, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; invoke-static {v2}, Lcom/ea/nimble/Utility;->safeString(Ljava/lang/String;)Ljava/lang/String; move-result-object v4 invoke-interface {v1, v3, v4}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; if-eqz v2, :cond_9 .line 807 invoke-virtual {v2, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v1 if-nez v1, :cond_9 invoke-virtual {v2, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v1 if-eqz v1, :cond_2 :cond_9 const-string v1, "Synergy Id was still null after synergy update" new-array v2, v0, [Ljava/lang/Object; .line 809 invoke-static {p0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto/16 :goto_2 :cond_a const-string p1, "Synergy environment update successful. Removing observer and re-attempting event post." new-array v1, v0, [Ljava/lang/Object; .line 816 invoke-static {p0, p1, v1}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_receiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver; if-eqz p1, :cond_b .line 821 invoke-static {p1}, Lcom/ea/nimble/Utility;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V const/4 p1, 0x0 iput-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_receiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver; :cond_b iget-boolean p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isPostPending:Z if-eqz p1, :cond_c iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isPostPending:Z const-wide/16 v0, 0x0 .line 830 invoke-virtual {p0, v0, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer(D)V :cond_c return-void .end method .method private postIntervalTimerExpired(Z)V .locals 0 .line 1092 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V if-eqz p1, :cond_0 .line 1095 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->packageCurrentSession()V :cond_0 const/4 p1, 0x0 .line 1097 invoke-virtual {p0, p1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->postPendingEvents(Z)V return-void .end method .method private saveSessionDataToPersistent()V .locals 3 .line 960 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 961 invoke-virtual {p0}, Lcom/ea/nimble/Component;->getComponentId()Ljava/lang/String; move-result-object v0 sget-object v1, Lcom/ea/nimble/Persistence$Storage;->CACHE:Lcom/ea/nimble/Persistence$Storage; invoke-static {v0, v1}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object v0 const/4 v1, 0x0 new-array v1, v1, [Ljava/lang/Object; const-string v2, "Saving event queue to persistence." .line 964 invoke-static {p0, v2, v1}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string v1, "sessionData" iget-object v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_customSessionData:Ljava/util/ArrayList; .line 965 invoke-virtual {v0, v1, v2}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V .line 970 invoke-virtual {v0}, Lcom/ea/nimble/Persistence;->synchronize()V return-void .end method .method private saveSessionToFile(Lcom/ea/nimble/tracking/TrackingBaseSessionObject;J)V .locals 1 .line 1143 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 1144 invoke-direct {p0, p2, p3}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->getFilenameForSessionID(J)Ljava/lang/String; move-result-object p2 .line 1145 sget-object p3, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {p2, p3}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object p3 .line 1148 invoke-virtual {p3}, Lcom/ea/nimble/Persistence;->getBackUp()Z move-result v0 if-eqz v0, :cond_0 const/4 v0, 0x0 .line 1150 invoke-virtual {p3, v0}, Lcom/ea/nimble/Persistence;->setBackUp(Z)V :cond_0 :try_start_0 const-string v0, "savedSession" .line 1156 invoke-virtual {p3, v0, p1}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V :try_end_0 .catch Ljava/lang/OutOfMemoryError; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 move-exception p1 .line 1160 invoke-virtual {p1}, Ljava/lang/Throwable;->getLocalizedMessage()Ljava/lang/String; move-result-object p1 filled-new-array {p1}, [Ljava/lang/Object; move-result-object p1 const-string v0, "OutOfMemoryError occurred while saving a session object to file. Exception: %s" invoke-static {p0, v0, p1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 1164 :goto_0 invoke-virtual {p3}, Lcom/ea/nimble/Persistence;->synchronize()V .line 1166 sget-object p1, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {p2, p1}, Lcom/ea/nimble/PersistenceService;->cleanReferenceToPersistence(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)V return-void .end method .method private saveToPersistence()V .locals 7 .line 637 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 638 invoke-virtual {p0}, Lcom/ea/nimble/Component;->getComponentId()Ljava/lang/String; move-result-object v0 sget-object v1, Lcom/ea/nimble/Persistence$Storage;->CACHE:Lcom/ea/nimble/Persistence$Storage; invoke-static {v0, v1}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object v0 const/4 v1, 0x0 new-array v2, v1, [Ljava/lang/Object; const-string v3, "Saving event queue to persistence (cache storage)." .line 640 invoke-static {p0, v3, v2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const/4 v2, 0x1 :try_start_0 const-string v3, "dataVersion" const/4 v4, 0x3 .line 647 invoke-static {v4}, Ljava/lang/String;->valueOf(I)Ljava/lang/String; move-result-object v4 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "currentSessionObject" iget-object v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 648 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "sessionData" iget-object v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_customSessionData:Ljava/util/ArrayList; .line 649 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "loggedInToOrigin" iget-boolean v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_loggedInToOrigin:Z .line 650 invoke-static {v4}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v4 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "firstSessionIDNumber" iget-wide v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J .line 651 invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v4 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "lastSessionIDNumber" iget-wide v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J .line 652 invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v4 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "totalSessionCount" iget-wide v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J .line 653 invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v4 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "queuedSessionObjects" iget-object v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 654 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V const-string v3, "trackingAttributes" iget-object v4, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_trackingAttributes:Ljava/util/HashMap; .line 655 invoke-virtual {v0, v3, v4}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V :try_end_0 .catch Ljava/lang/OutOfMemoryError; {:try_start_0 .. :try_end_0} :catch_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 goto :goto_0 :catchall_0 move-exception v0 goto :goto_1 :catch_0 move-exception v3 :try_start_1 const-string v4, "OutOfMemoryError in saving m_sessionsToPost to persistence! MaxQueueLength is %s. Exception: %s" const/4 v5, 0x2 new-array v5, v5, [Ljava/lang/Object; iget v6, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_maxQueueLength:I .line 659 invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v6 aput-object v6, v5, v1 invoke-virtual {v3}, Ljava/lang/Throwable;->getLocalizedMessage()Ljava/lang/String; move-result-object v3 aput-object v3, v5, v2 invoke-static {p0, v4, v5}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 666 :goto_0 invoke-virtual {v0}, Lcom/ea/nimble/Persistence;->synchronize()V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 676 invoke-virtual {p0}, Lcom/ea/nimble/Component;->getComponentId()Ljava/lang/String; move-result-object v0 sget-object v3, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {v0, v3}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object v0 const-string v3, "Saving tracking enable/disable flag to persistence (document storage)." new-array v1, v1, [Ljava/lang/Object; .line 678 invoke-static {p0, v3, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 681 invoke-virtual {v0}, Lcom/ea/nimble/Persistence;->getBackUp()Z move-result v1 if-nez v1, :cond_0 .line 683 invoke-virtual {v0, v2}, Lcom/ea/nimble/Persistence;->setBackUp(Z)V :cond_0 iget-boolean v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z .line 687 invoke-static {v1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v1 const-string v2, "trackingEnabledFlag" invoke-virtual {v0, v2, v1}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V .line 690 invoke-virtual {v0}, Lcom/ea/nimble/Persistence;->synchronize()V return-void .line 670 :goto_1 invoke-virtual {v0}, Ljava/lang/Throwable;->getLocalizedMessage()Ljava/lang/String; move-result-object v0 filled-new-array {v0}, [Ljava/lang/Object; move-result-object v0 const-string v1, "Caught generic throwable while saving to persistence! Discarding attempt to save. Exception: %s" invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V return-void .end method .method private updateFeatureDisableState()V .locals 2 .line 1382 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 1383 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v0 invoke-interface {v0}, Lcom/ea/nimble/ISynergyEnvironment;->isDataAvailable()Z move-result v0 if-eqz v0, :cond_0 .line 1385 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v0 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->getFeatureTag()Ljava/lang/String; move-result-object v1 invoke-interface {v0, v1}, Lcom/ea/nimble/ISynergyEnvironment;->isFeatureDisabled(Ljava/lang/String;)Z move-result v0 iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isFeatureDisabledFromServer:Z if-eqz v0, :cond_0 const/4 v0, 0x0 new-array v0, v0, [Ljava/lang/Object; const-string v1, "*** FEATURE DISABLED FROM SERVER ***" .line 1388 invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V :cond_0 return-void .end method # virtual methods .method public addCustomSessionData(Ljava/lang/String;Ljava/lang/String;)V .locals 1 .line 912 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V .line 913 invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_1 invoke-static {p2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v0 if-nez v0, :cond_0 goto :goto_0 .line 917 :cond_0 new-instance v0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData; invoke-direct {v0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData;->()V iput-object p1, v0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData;->key:Ljava/lang/String; iput-object p2, v0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData;->value:Ljava/lang/String; iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_customSessionData:Ljava/util/ArrayList; .line 920 invoke-virtual {p1, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z .line 922 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveSessionDataToPersistent()V :cond_1 :goto_0 return-void .end method .method public addObserverForSynergyEnvironmentUpdateFinished()V .locals 2 .line 729 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_receiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver; if-nez v0, :cond_0 .line 732 new-instance v0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver; const/4 v1, 0x0 invoke-direct {v0, p0, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver;->(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;Lcom/ea/nimble/tracking/NimbleTrackingImplBase$1;)V iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_receiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$StartupRequestsFinishedReceiver; const-string v1, "nimble.environment.notification.startup_requests_finished" .line 733 invoke-static {v1, v0}, Lcom/ea/nimble/Utility;->registerReceiver(Ljava/lang/String;Landroid/content/BroadcastReceiver;)V :cond_0 return-void .end method .method public canDropSession(Ljava/util/List;)Z .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/List<", "Lcom/ea/nimble/tracking/TrackingBaseSessionObject;", ">;)Z" } .end annotation .line 1374 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 p1, 0x1 return p1 .end method .method public cleanup()V .locals 0 .line 623 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 624 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->killPostTimer()V return-void .end method .method public clearCustomSessionData()V .locals 0 .line 947 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V return-void .end method .method public abstract convertEvent(Lcom/ea/nimble/tracking/Tracking$Event;)Ljava/util/List; .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/ea/nimble/tracking/Tracking$Event;", ")", "Ljava/util/List<", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/String;", ">;>;" } .end annotation .end method .method public getEnable()Z .locals 1 .line 160 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z return v0 .end method .method public abstract getFeatureTag()Ljava/lang/String; .end method .method public getLogSourceTitle()Ljava/lang/String; .locals 1 const-string v0, "TrackingBase" return-object v0 .end method .method public abstract getPersistenceIdentifier()Ljava/lang/String; .end method .method public getPostEnable()Z .locals 1 .line 1071 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z return v0 .end method .method public getSessionId()Ljava/lang/String; .locals 1 .line 953 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V const-string v0, "" return-object v0 .end method .method public isAbleToPostEvent(Z)Z .locals 2 .line 975 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z const/4 v1, 0x0 if-eqz v0, :cond_5 iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isFeatureDisabledFromServer:Z if-nez v0, :cond_5 iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z if-nez v0, :cond_0 goto :goto_0 :cond_0 if-nez p1, :cond_1 .line 990 invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->isMainApplicationActive()Z move-result p1 if-nez p1, :cond_1 const-string p1, "isAbleToPostEvent - return because the app is in background" new-array v0, v1, [Ljava/lang/Object; .line 992 invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V return v1 .line 997 :cond_1 invoke-static {}, Lcom/ea/nimble/Network;->getComponent()Lcom/ea/nimble/INetwork; move-result-object p1 invoke-interface {p1}, Lcom/ea/nimble/INetwork;->getStatus()Lcom/ea/nimble/Network$Status; move-result-object p1 sget-object v0, Lcom/ea/nimble/Network$Status;->OK:Lcom/ea/nimble/Network$Status; if-eq p1, v0, :cond_3 iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; if-nez p1, :cond_2 const-string p1, "Network status not OK for event post. Adding receiver for network status change." new-array v0, v1, [Ljava/lang/Object; .line 1003 invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 1006 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->killPostTimer()V .line 1008 new-instance p1, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$1; invoke-direct {p1, p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$1;->(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;)V iput-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; const-string v0, "nimble.notification.networkStatusChange" .line 1030 invoke-static {v0, p1}, Lcom/ea/nimble/Utility;->registerReceiver(Ljava/lang/String;Landroid/content/BroadcastReceiver;)V :cond_2 return v1 .line 1037 :cond_3 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object p1 invoke-interface {p1}, Lcom/ea/nimble/ISynergyEnvironment;->isDataAvailable()Z move-result p1 const/4 v0, 0x1 if-nez p1, :cond_4 iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isPostPending:Z .line 1040 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->addObserverForSynergyEnvironmentUpdateFinished()V return v1 :cond_4 return v0 :cond_5 :goto_0 return v1 .end method .method public isSameSession(Lcom/ea/nimble/tracking/TrackingBaseSessionObject;Lcom/ea/nimble/tracking/TrackingBaseSessionObject;)Z .locals 0 .line 1368 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 p1, 0x0 return p1 .end method .method public logEvent(Ljava/lang/String;Ljava/util/Map;)V .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/lang/String;", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/String;", ">;)V" } .end annotation .line 251 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z if-eqz v0, :cond_2 iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isFeatureDisabledFromServer:Z if-eqz v0, :cond_0 goto :goto_0 :cond_0 const-string v0, "NIMBLESTANDARD::SESSION_END" .line 261 invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v0 const/4 v1, 0x0 if-eqz v0, :cond_1 .line 263 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v2, "Logging session end event, " invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v2, ". Posting event queue now." invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 new-array v1, v1, [Ljava/lang/Object; invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const/4 v1, 0x1 .line 266 :cond_1 new-instance v0, Lcom/ea/nimble/tracking/Tracking$Event; invoke-direct {v0}, Lcom/ea/nimble/tracking/Tracking$Event;->()V iput-object p1, v0, Lcom/ea/nimble/tracking/Tracking$Event;->type:Ljava/lang/String; iput-object p2, v0, Lcom/ea/nimble/tracking/Tracking$Event;->parameters:Ljava/util/Map; .line 269 new-instance p1, Ljava/util/Date; invoke-direct {p1}, Ljava/util/Date;->()V iput-object p1, v0, Lcom/ea/nimble/tracking/Tracking$Event;->timestamp:Ljava/util/Date; .line 271 invoke-direct {p0, v0, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->logEvent(Lcom/ea/nimble/tracking/Tracking$Event;Z)V :cond_2 :goto_0 return-void .end method .method public abstract packageCurrentSession()V .end method .method public abstract postPendingEvents(Z)V .end method .method public queueCurrentEventsForPost()V .locals 2 .line 1111 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 1112 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v0 invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v0 filled-new-array {v0}, [Ljava/lang/Object; move-result-object v0 const-string v1, "queueCurrentEventsForPost called. Starting queue size: %d" invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; if-nez v0, :cond_0 .line 1117 new-instance v0, Ljava/util/ArrayList; invoke-direct {v0}, Ljava/util/ArrayList;->()V iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; :cond_0 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; const/4 v1, 0x0 if-nez v0, :cond_1 const-string v0, "Unexpected state, currentSessionObject is null." new-array v1, v1, [Ljava/lang/Object; .line 1123 invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 1125 :cond_1 invoke-virtual {v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->countOfEvents()I move-result v0 if-nez v0, :cond_2 const-string v0, "Unexpected state, currentSessionObject events list is null or empty." new-array v1, v1, [Ljava/lang/Object; .line 1127 invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 1131 :cond_2 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->addCurrentSessionObjectToBackOfQueue()V .line 1132 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->dropExtraSessions()V .line 1136 :goto_0 new-instance v0, Ljava/util/HashMap; iget-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; iget-object v1, v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->sessionData:Ljava/util/Map; invoke-direct {v0, v1}, Ljava/util/HashMap;->(Ljava/util/Map;)V .line 1137 new-instance v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; invoke-direct {v1, v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->(Ljava/util/Map;)V iput-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 1138 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveToPersistence()V return-void .end method .method public removeCustomSessionData(Ljava/lang/String;)V .locals 3 .line 928 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V .line 929 invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v0 if-nez v0, :cond_0 return-void :cond_0 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_customSessionData:Ljava/util/ArrayList; .line 933 invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator; move-result-object v0 :cond_1 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_2 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData; .line 935 iget-object v2, v1, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData;->key:Ljava/lang/String; invoke-virtual {v2, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_1 iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_customSessionData:Ljava/util/ArrayList; .line 937 invoke-virtual {p1, v1}, Ljava/util/ArrayList;->remove(Ljava/lang/Object;)Z .line 941 :cond_2 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveSessionDataToPersistent()V return-void .end method .method public removeSessionAndFillQueue(Lcom/ea/nimble/tracking/TrackingBaseSessionObject;)V .locals 4 .line 1209 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 1211 invoke-virtual {v0, p1}, Ljava/util/ArrayList;->remove(Ljava/lang/Object;)Z iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J const-wide/16 v2, 0x1 add-long/2addr v0, v2 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J sub-long/2addr v0, v2 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J .line 1216 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->fillSessionsToPost()V .line 1218 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveToPersistence()V return-void .end method .method public resetPostTimer()V .locals 2 .line 277 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postInterval:D .line 278 invoke-virtual {p0, v0, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer(D)V return-void .end method .method public resetPostTimer(D)V .locals 1 .line 284 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 v0, 0x1 .line 285 invoke-virtual {p0, p1, p2, v0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer(DZ)V return-void .end method .method public resetPostTimer(DZ)V .locals 4 .line 290 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const-wide/16 v0, 0x0 cmpg-double v2, p1, v0 if-gez v2, :cond_0 const/4 v2, 0x0 new-array v2, v2, [Ljava/lang/Object; const-string v3, "resetPostTimer called with an invalid period: period < 0.0. Timer reset with period 0.0 instead" .line 296 invoke-static {p0, v3, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 :cond_0 move-wide v0, p1 .line 300 :goto_0 invoke-static {p1, p2}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double; move-result-object p1 filled-new-array {p1}, [Ljava/lang/Object; move-result-object p1 const-string p2, "Resetting event post timer for %s seconds." invoke-static {p0, p2, p1}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 303 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->killPostTimer()V iget-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_threadManager:Lcom/ea/nimble/tracking/NimbleTrackingThreadManager; .line 305 new-instance p2, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$PostTask; invoke-direct {p2, p0, p3}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$PostTask;->(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;Z)V invoke-virtual {p1, v0, v1, p2}, Lcom/ea/nimble/tracking/NimbleTrackingThreadManager;->createTimer(DLjava/lang/Runnable;)Ljava/util/concurrent/ScheduledFuture; move-result-object p1 iput-object p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postTimer:Ljava/util/concurrent/ScheduledFuture; return-void .end method .method public restore()V .locals 14 .line 332 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 333 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v0 invoke-interface {v0}, Lcom/ea/nimble/ISynergyEnvironment;->isDataAvailable()Z move-result v0 if-eqz v0, :cond_0 .line 335 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->updateFeatureDisableState()V .line 336 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v0 invoke-interface {v0}, Lcom/ea/nimble/ISynergyEnvironment;->getTrackingPostInterval()I move-result v0 int-to-double v0, v0 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postInterval:D goto :goto_0 .line 340 :cond_0 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->addObserverForSynergyEnvironmentUpdateFinished()V .line 345 :goto_0 invoke-virtual {p0}, Lcom/ea/nimble/Component;->getComponentId()Ljava/lang/String; move-result-object v0 sget-object v1, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {v0, v1}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object v0 .line 346 invoke-virtual {p0}, Lcom/ea/nimble/Component;->getComponentId()Ljava/lang/String; move-result-object v1 sget-object v2, Lcom/ea/nimble/Persistence$Storage;->CACHE:Lcom/ea/nimble/Persistence$Storage; invoke-static {v1, v2}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object v1 const-string v2, "trackingEnabledFlag" .line 350 invoke-virtual {v0, v2}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v3 const-class v4, Ljava/lang/Boolean; if-eqz v3, :cond_1 .line 351 invoke-virtual {v3}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v5 if-ne v5, v4, :cond_1 .line 353 check-cast v3, Ljava/lang/Boolean; invoke-virtual {v3}, Ljava/lang/Boolean;->booleanValue()Z move-result v2 iput-boolean v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z goto :goto_1 .line 358 :cond_1 invoke-virtual {v1, v2}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v2 if-eqz v2, :cond_2 .line 359 invoke-virtual {v2}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v3 if-ne v3, v4, :cond_2 .line 361 check-cast v2, Ljava/lang/Boolean; invoke-virtual {v2}, Ljava/lang/Boolean;->booleanValue()Z move-result v2 iput-boolean v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z :cond_2 :goto_1 const-string v2, "trackingPostEnabledFlag" .line 366 invoke-virtual {v0, v2}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v0 const/4 v2, 0x0 if-eqz v0, :cond_3 .line 367 invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v3 if-ne v3, v4, :cond_3 .line 369 check-cast v0, Ljava/lang/Boolean; invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z move-result v0 iput-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z goto :goto_2 :cond_3 const-string v0, "NimbleDefaultTrackingPostFlag" .line 373 invoke-static {v0}, Lcom/ea/nimble/NimbleApplicationConfiguration;->getConfigValueAsString(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 .line 375 invoke-static {v0}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v3 if-eqz v3, :cond_4 const-string v3, "disable" .line 377 invoke-virtual {v0, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_4 iput-boolean v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z :cond_4 :goto_2 const/4 v0, 0x1 new-array v0, v0, [Ljava/lang/Object; iget-boolean v3, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z if-eqz v3, :cond_5 const-string v3, "Enabled" goto :goto_3 :cond_5 const-string v3, "Disabled" :goto_3 aput-object v3, v0, v2 const-string v3, "Tracking Post %s" .line 383 invoke-static {p0, v3, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z const/4 v3, 0x0 const-class v5, Ljava/util/ArrayList; if-eqz v0, :cond_11 iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_isFeatureDisabledFromServer:Z if-nez v0, :cond_11 const-string v0, "currentSessionObject" .line 389 invoke-virtual {v1, v0}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v0 if-eqz v0, :cond_7 .line 390 invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v6 const-class v7, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; if-ne v6, v7, :cond_7 iget-object v6, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 392 invoke-virtual {v6}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->countOfEvents()I move-result v6 if-lez v6, :cond_6 const-string v6, "Events logged during startup before persistently cached events were restored. Overwriting logged events with cached events!" new-array v7, v2, [Ljava/lang/Object; .line 394 invoke-static {p0, v6, v7}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 396 :cond_6 check-cast v0, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; :cond_7 const-string v0, "queuedSessionObjects" .line 399 invoke-virtual {v1, v0}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v0 if-eqz v0, :cond_d .line 400 invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v6 if-ne v6, v5, :cond_d .line 403 check-cast v0, Ljava/util/ArrayList; .line 404 new-instance v6, Ljava/util/ArrayList; invoke-direct {v6}, Ljava/util/ArrayList;->()V .line 405 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v7 const-string v8, "firstSessionIDNumber" .line 407 invoke-virtual {v1, v8}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v8 const-class v9, Ljava/lang/Long; if-eqz v8, :cond_8 .line 409 invoke-virtual {v8}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v10 if-ne v10, v9, :cond_8 .line 411 check-cast v8, Ljava/lang/Long; invoke-virtual {v8}, Ljava/lang/Long;->longValue()J move-result-wide v10 iput-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J goto :goto_4 :cond_8 const-wide/16 v10, 0x0 iput-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J :goto_4 const-string v8, "lastSessionIDNumber" .line 419 invoke-virtual {v1, v8}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v8 if-eqz v8, :cond_9 .line 421 invoke-virtual {v8}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v10 if-ne v10, v9, :cond_9 .line 423 check-cast v8, Ljava/lang/Long; invoke-virtual {v8}, Ljava/lang/Long;->longValue()J move-result-wide v10 iput-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J goto :goto_5 :cond_9 iget-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J add-int/lit8 v8, v7, -0x1 int-to-long v12, v8 add-long/2addr v10, v12 iput-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J :goto_5 const-string v8, "totalSessionCount" .line 431 invoke-virtual {v1, v8}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v8 if-eqz v8, :cond_a .line 432 invoke-virtual {v8}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v10 if-ne v10, v9, :cond_a .line 434 check-cast v8, Ljava/lang/Long; invoke-virtual {v8}, Ljava/lang/Long;->longValue()J move-result-wide v8 iput-wide v8, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J goto :goto_6 :cond_a iget-wide v8, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_lastSessionIDNumber:J iget-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J sub-long/2addr v8, v10 const-wide/16 v10, 0x1 add-long/2addr v8, v10 iput-wide v8, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_totalSessions:J :goto_6 move v8, v2 :goto_7 if-ge v8, v7, :cond_c .line 443 invoke-virtual {v0, v8}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object; move-result-object v9 check-cast v9, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; iget v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_maxQueueLength:I if-ge v8, v10, :cond_b .line 448 invoke-virtual {v6, v9}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z goto :goto_8 :cond_b iget-wide v10, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_firstSessionIDNumber:J int-to-long v12, v8 add-long/2addr v10, v12 .line 454 invoke-direct {p0, v9, v10, v11}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveSessionToFile(Lcom/ea/nimble/tracking/TrackingBaseSessionObject;J)V :goto_8 add-int/lit8 v8, v8, 0x1 goto :goto_7 :cond_c iput-object v6, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 460 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->fillSessionsToPost()V :cond_d const-string v0, "eventQueue" .line 463 invoke-virtual {v1, v0}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v6 if-eqz v6, :cond_e .line 469 invoke-virtual {v6}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v7 if-ne v7, v5, :cond_e check-cast v6, Ljava/util/ArrayList; invoke-virtual {v6}, Ljava/util/ArrayList;->size()I move-result v7 if-lez v7, :cond_e .line 473 invoke-virtual {v6, v2}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object; move-result-object v7 if-eqz v7, :cond_e .line 474 instance-of v7, v7, Ljava/util/Map; if-eqz v7, :cond_e .line 479 new-instance v7, Ljava/util/ArrayList; invoke-direct {v7, v6}, Ljava/util/ArrayList;->(Ljava/util/Collection;)V .line 483 invoke-virtual {v1, v0, v3}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V goto :goto_9 :cond_e move-object v7, v3 :goto_9 if-eqz v7, :cond_10 .line 487 invoke-virtual {v7}, Ljava/util/ArrayList;->size()I move-result v0 if-lez v0, :cond_10 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 489 invoke-virtual {v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->countOfEvents()I move-result v0 if-lez v0, :cond_f const-string v0, "Restored old format event queue in addition to new format session object. Ignoring event queue." new-array v6, v2, [Ljava/lang/Object; .line 491 invoke-static {p0, v0, v6}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_a :cond_f const-string v0, "Restored old format event queue, storing in new format session object." new-array v6, v2, [Ljava/lang/Object; .line 495 invoke-static {p0, v0, v6}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 497 iput-object v7, v0, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->events:Ljava/util/List; :cond_10 :goto_a iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 509 invoke-virtual {v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->countOfEvents()I move-result v0 if-lez v0, :cond_12 .line 511 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer()V goto :goto_b .line 516 :cond_11 new-instance v0, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; invoke-direct {v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->()V iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; :cond_12 :goto_b const-string v0, "sessionData" .line 520 invoke-virtual {v1, v0}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v0 if-eqz v0, :cond_13 .line 526 invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v6 if-ne v6, v5, :cond_13 check-cast v0, Ljava/util/ArrayList; invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v5 if-lez v5, :cond_13 .line 530 invoke-virtual {v0, v2}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object; move-result-object v2 if-eqz v2, :cond_13 .line 531 instance-of v2, v2, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$SessionData; if-eqz v2, :cond_13 .line 536 new-instance v2, Ljava/util/ArrayList; invoke-direct {v2, v0}, Ljava/util/ArrayList;->(Ljava/util/Collection;)V iput-object v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_customSessionData:Ljava/util/ArrayList; :cond_13 const-string v0, "trackingAttributes" .line 546 invoke-virtual {v1, v0}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v0 if-eqz v0, :cond_14 .line 547 invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v2 const-class v5, Ljava/util/HashMap; if-ne v2, v5, :cond_14 check-cast v0, Ljava/util/HashMap; invoke-virtual {v0}, Ljava/util/HashMap;->size()I move-result v2 if-lez v2, :cond_14 iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_trackingAttributes:Ljava/util/HashMap; :cond_14 const-string v0, "loggedInToOrigin" .line 552 invoke-virtual {v1, v0}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object v1 if-eqz v1, :cond_15 .line 553 invoke-virtual {v1}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v2 if-ne v2, v4, :cond_15 .line 557 :try_start_0 move-object v2, v1 check-cast v2, Ljava/lang/Boolean; invoke-virtual {v2}, Ljava/lang/Boolean;->booleanValue()Z move-result v2 iput-boolean v2, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_loggedInToOrigin:Z :try_end_0 .catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_c .line 562 :catch_0 invoke-virtual {v1}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v1 invoke-virtual {v1}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String; move-result-object v1 filled-new-array {v0, v1}, [Ljava/lang/Object; move-result-object v0 const-string v1, "Invalid persistence value for %s, expected Boolean, got %s" .line 561 invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V :cond_15 :goto_c iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; if-nez v0, :cond_16 .line 569 new-instance v0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; invoke-direct {v0, p0, v3}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver;->(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;Lcom/ea/nimble/tracking/NimbleTrackingImplBase$1;)V iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; const-string v1, "nimble.notification.loginStatusChange" .line 570 invoke-static {v1, v0}, Lcom/ea/nimble/Utility;->registerReceiver(Ljava/lang/String;Landroid/content/BroadcastReceiver;)V :cond_16 return-void .end method .method public resume()V .locals 2 .line 602 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 603 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->updateFeatureDisableState()V .line 606 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->getEnable()Z move-result v0 if-eqz v0, :cond_0 .line 608 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer()V :cond_0 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; if-nez v0, :cond_1 .line 614 new-instance v0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; const/4 v1, 0x0 invoke-direct {v0, p0, v1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver;->(Lcom/ea/nimble/tracking/NimbleTrackingImplBase;Lcom/ea/nimble/tracking/NimbleTrackingImplBase$1;)V iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; const-string v1, "nimble.notification.loginStatusChange" .line 615 invoke-static {v1, v0}, Lcom/ea/nimble/Utility;->registerReceiver(Ljava/lang/String;Landroid/content/BroadcastReceiver;)V :cond_1 const-wide/high16 v0, 0x3ff0000000000000L # 1.0 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postRetryDelay:D return-void .end method .method public setEnable(Z)V .locals 4 .line 167 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V const/4 v0, 0x1 new-array v0, v0, [Ljava/lang/Object; if-eqz p1, :cond_0 const-string v1, "ENABLED" goto :goto_0 :cond_0 const-string v1, "DISABLED" :goto_0 const/4 v2, 0x0 aput-object v1, v0, v2 const-string v1, "setEnable called. enable = %s" .line 168 invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z if-ne v0, p1, :cond_1 return-void :cond_1 if-nez p1, :cond_4 .line 180 new-instance v0, Ljava/util/HashMap; invoke-direct {v0}, Ljava/util/HashMap;->()V const-string v1, "eventType" const-string v3, "NIMBLESTANDARD::USER_TRACKING_OPTOUT" .line 181 invoke-virtual {v0, v1, v3}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 182 invoke-virtual {p0, v3, v0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->logEvent(Ljava/lang/String;Ljava/util/Map;)V .line 185 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->packageCurrentSession()V .line 186 invoke-virtual {p0, v2}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->postPendingEvents(Z)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 187 invoke-virtual {v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->countOfEvents()I move-result v0 if-lez v0, :cond_2 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; .line 189 invoke-virtual {v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->countOfEvents()I move-result v0 invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v0 filled-new-array {v0}, [Ljava/lang/Object; move-result-object v0 const-string v1, "Removing %d remaining events that couldn\'t be sent from queue." invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 192 :cond_2 new-instance v0, Lcom/ea/nimble/tracking/TrackingBaseSessionObject; invoke-direct {v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;->()V iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_currentSessionObject:Lcom/ea/nimble/tracking/TrackingBaseSessionObject; iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; if-eqz v0, :cond_3 .line 194 invoke-virtual {v0}, Ljava/util/ArrayList;->size()I move-result v0 if-lez v0, :cond_3 const-string v0, "Removing unposted sessions." new-array v1, v2, [Ljava/lang/Object; .line 196 invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_sessionsToPost:Ljava/util/ArrayList; .line 197 invoke-virtual {v0}, Ljava/util/ArrayList;->clear()V .line 200 :cond_3 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->killPostTimer()V goto :goto_1 .line 204 :cond_4 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer()V :goto_1 iput-boolean p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_enable:Z .line 208 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveToPersistence()V return-void .end method .method public setPostEnable(Z)V .locals 2 .line 1052 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z if-eq v0, p1, :cond_0 iput-boolean p1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z .line 1057 invoke-virtual {p0}, Lcom/ea/nimble/Component;->getComponentId()Ljava/lang/String; move-result-object p1 sget-object v0, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; invoke-static {p1, v0}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence; move-result-object p1 iget-boolean v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postEnable:Z .line 1058 invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v0 const-string v1, "trackingPostEnabledFlag" invoke-virtual {p1, v1, v0}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V .line 1060 invoke-virtual {p1}, Lcom/ea/nimble/Persistence;->synchronize()V const/4 p1, 0x0 .line 1062 invoke-virtual {p0, p1}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->isAbleToPostEvent(Z)Z move-result p1 if-eqz p1, :cond_0 .line 1064 invoke-virtual {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->resetPostTimer()V :cond_0 return-void .end method .method public setTrackingAttribute(Ljava/lang/String;Ljava/lang/String;)V .locals 1 .line 1102 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V .line 1103 invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_0 invoke-static {p2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_trackingAttributes:Ljava/util/HashMap; .line 1105 invoke-virtual {v0, p1, p2}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; :cond_0 return-void .end method .method public setup()V .locals 2 .line 324 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const-wide/high16 v0, 0x3ff0000000000000L # 1.0 iput-wide v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_postRetryDelay:D .line 326 invoke-static {}, Lcom/ea/nimble/tracking/NimbleTrackingThreadManager;->acquireInstance()Lcom/ea/nimble/tracking/NimbleTrackingThreadManager; move-result-object v0 iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_threadManager:Lcom/ea/nimble/tracking/NimbleTrackingThreadManager; return-void .end method .method public suspend()V .locals 2 .line 577 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; const/4 v1, 0x0 if-eqz v0, :cond_0 .line 581 invoke-static {v0}, Lcom/ea/nimble/Utility;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V iput-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_networkStatusChangedReceiver:Landroid/content/BroadcastReceiver; :cond_0 iget-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; if-eqz v0, :cond_1 .line 588 invoke-static {v0}, Lcom/ea/nimble/Utility;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V iput-object v1, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_originLoginStatusChangedReceiver:Lcom/ea/nimble/tracking/NimbleTrackingImplBase$OriginLoginStatusChangedReceiver; .line 593 :cond_1 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->killPostTimer()V .line 596 invoke-direct {p0}, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->saveToPersistence()V return-void .end method .method public teardown()V .locals 1 .line 630 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 631 invoke-static {}, Lcom/ea/nimble/tracking/NimbleTrackingThreadManager;->releaseInstance()V const/4 v0, 0x0 iput-object v0, p0, Lcom/ea/nimble/tracking/NimbleTrackingImplBase;->m_threadManager:Lcom/ea/nimble/tracking/NimbleTrackingThreadManager; return-void .end method