- 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
3780 lines
103 KiB
Smali
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
|