Files
rr3-apk/smali_classes2/com/ea/nimble/tracking/NimbleTrackingImplBase.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

3780 lines
103 KiB
Smali

.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 <init>()V
.locals 4
.line 130
invoke-direct {p0}, Lcom/ea/nimble/Component;-><init>()V
.line 46
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()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;-><init>()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;-><init>()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;-><init>()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;-><init>()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;-><init>()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;-><init>()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;-><init>(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;-><init>(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;-><init>()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;-><init>()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;-><init>()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;-><init>()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;-><init>(Ljava/util/Map;)V
.line 1137
new-instance v1, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;
invoke-direct {v1, v0}, Lcom/ea/nimble/tracking/TrackingBaseSessionObject;-><init>(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;-><init>(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;-><init>()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;-><init>(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;-><init>()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;-><init>(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;-><init>(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;-><init>(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;-><init>()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;-><init>()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