- 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
1062 lines
25 KiB
Smali
1062 lines
25 KiB
Smali
.class Lcom/ea/nimble/OperationalTelemetryDispatchImpl;
|
|
.super Lcom/ea/nimble/Component;
|
|
.source "SourceFile"
|
|
|
|
# interfaces
|
|
.implements Lcom/ea/nimble/IOperationalTelemetryDispatch;
|
|
.implements Lcom/ea/nimble/LogSource;
|
|
|
|
|
|
# instance fields
|
|
.field private m_maxEventQueueSizeDict:Ljava/util/Map;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/Integer;",
|
|
">;"
|
|
}
|
|
.end annotation
|
|
.end field
|
|
|
|
.field private m_networkMetricsArray:Ljava/util/List;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"Ljava/util/List<",
|
|
"Lcom/ea/nimble/OperationalTelemetryEvent;",
|
|
">;"
|
|
}
|
|
.end annotation
|
|
.end field
|
|
|
|
.field private m_networkPayloadsArray:Ljava/util/List;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"Ljava/util/List<",
|
|
"Lcom/ea/nimble/OperationalTelemetryEvent;",
|
|
">;"
|
|
}
|
|
.end annotation
|
|
.end field
|
|
|
|
|
|
# direct methods
|
|
.method public constructor <init>()V
|
|
.locals 3
|
|
|
|
.line 24
|
|
invoke-direct {p0}, Lcom/ea/nimble/Component;-><init>()V
|
|
|
|
.line 25
|
|
new-instance v0, Ljava/util/ArrayList;
|
|
|
|
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkMetricsArray:Ljava/util/List;
|
|
|
|
.line 26
|
|
new-instance v0, Ljava/util/ArrayList;
|
|
|
|
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkPayloadsArray:Ljava/util/List;
|
|
|
|
.line 27
|
|
new-instance v0, Ljava/util/HashMap;
|
|
|
|
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_maxEventQueueSizeDict:Ljava/util/Map;
|
|
|
|
const/16 v1, 0x64
|
|
|
|
.line 28
|
|
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
|
|
|
|
move-result-object v1
|
|
|
|
const-string v2, "com.ea.nimble.network"
|
|
|
|
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_maxEventQueueSizeDict:Ljava/util/Map;
|
|
|
|
const-string v2, "com.ea.nimble.trackingimpl.synergy"
|
|
|
|
.line 29
|
|
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private canLogEvent(Ljava/lang/String;)Z
|
|
.locals 4
|
|
|
|
.line 225
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
|
|
|
|
.line 227
|
|
invoke-virtual {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->getMaxEventCount(Ljava/lang/String;)I
|
|
|
|
move-result v0
|
|
|
|
const-string v1, "com.ea.nimble.network"
|
|
|
|
.line 228
|
|
invoke-virtual {p1, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v1
|
|
|
|
const/4 v2, 0x0
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkMetricsArray:Ljava/util/List;
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
const-string v1, "com.ea.nimble.trackingimpl.synergy"
|
|
|
|
.line 232
|
|
invoke-virtual {p1, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_6
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkPayloadsArray:Ljava/util/List;
|
|
|
|
.line 242
|
|
:goto_0
|
|
invoke-interface {p1}, Ljava/util/List;->size()I
|
|
|
|
move-result p1
|
|
|
|
const/4 v1, 0x1
|
|
|
|
if-ge p1, v0, :cond_1
|
|
|
|
move p1, v1
|
|
|
|
goto :goto_1
|
|
|
|
:cond_1
|
|
move p1, v2
|
|
|
|
:goto_1
|
|
if-gez v0, :cond_2
|
|
|
|
move v3, v1
|
|
|
|
goto :goto_2
|
|
|
|
:cond_2
|
|
move v3, v2
|
|
|
|
:goto_2
|
|
if-nez v0, :cond_3
|
|
|
|
move v0, v1
|
|
|
|
goto :goto_3
|
|
|
|
:cond_3
|
|
move v0, v2
|
|
|
|
:goto_3
|
|
if-nez p1, :cond_4
|
|
|
|
if-eqz v3, :cond_5
|
|
|
|
:cond_4
|
|
if-nez v0, :cond_5
|
|
|
|
move v2, v1
|
|
|
|
:cond_5
|
|
return v2
|
|
|
|
.line 238
|
|
:cond_6
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v1, "canLogEvent, unsupported OT eventType, "
|
|
|
|
invoke-virtual {v0, v1}, 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 p1, "."
|
|
|
|
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v0, v2, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return v2
|
|
.end method
|
|
|
|
.method private purgeOldestEvent(Ljava/util/List;)V
|
|
.locals 5
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/util/List<",
|
|
"Lcom/ea/nimble/OperationalTelemetryEvent;",
|
|
">;)V"
|
|
}
|
|
.end annotation
|
|
|
|
.line 355
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
|
|
|
|
.line 356
|
|
monitor-enter p0
|
|
|
|
.line 359
|
|
:try_start_0
|
|
invoke-interface {p1}, Ljava/util/List;->size()I
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const-string p1, "purgeOldestEvent called with empty event array."
|
|
|
|
const/4 v0, 0x0
|
|
|
|
new-array v0, v0, [Ljava/lang/Object;
|
|
|
|
.line 361
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 362
|
|
monitor-exit p0
|
|
|
|
return-void
|
|
|
|
:catchall_0
|
|
move-exception p1
|
|
|
|
goto :goto_1
|
|
|
|
.line 367
|
|
:cond_0
|
|
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object v0
|
|
|
|
const/4 v1, 0x0
|
|
|
|
:cond_1
|
|
:goto_0
|
|
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_3
|
|
|
|
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v2
|
|
|
|
check-cast v2, Lcom/ea/nimble/OperationalTelemetryEvent;
|
|
|
|
if-eqz v1, :cond_2
|
|
|
|
.line 369
|
|
invoke-interface {v2}, Lcom/ea/nimble/OperationalTelemetryEvent;->getLoggedTime()Ljava/util/Date;
|
|
|
|
move-result-object v3
|
|
|
|
invoke-interface {v1}, Lcom/ea/nimble/OperationalTelemetryEvent;->getLoggedTime()Ljava/util/Date;
|
|
|
|
move-result-object v4
|
|
|
|
invoke-virtual {v3, v4}, Ljava/util/Date;->before(Ljava/util/Date;)Z
|
|
|
|
move-result v3
|
|
|
|
if-eqz v3, :cond_1
|
|
|
|
:cond_2
|
|
move-object v1, v2
|
|
|
|
goto :goto_0
|
|
|
|
:cond_3
|
|
if-eqz v1, :cond_4
|
|
|
|
.line 378
|
|
invoke-interface {p1, v1}, Ljava/util/List;->remove(Ljava/lang/Object;)Z
|
|
|
|
.line 381
|
|
:cond_4
|
|
monitor-exit p0
|
|
|
|
return-void
|
|
|
|
:goto_1
|
|
monitor-exit p0
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
throw p1
|
|
.end method
|
|
|
|
.method private trimEventQueue(Ljava/lang/String;)V
|
|
.locals 4
|
|
|
|
.line 292
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
|
|
|
|
.line 294
|
|
invoke-virtual {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->getMaxEventCount(Ljava/lang/String;)I
|
|
|
|
move-result v0
|
|
|
|
const-string v1, "com.ea.nimble.network"
|
|
|
|
.line 295
|
|
invoke-virtual {p1, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v1
|
|
|
|
const/4 v2, 0x0
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkMetricsArray:Ljava/util/List;
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
const-string v1, "com.ea.nimble.trackingimpl.synergy"
|
|
|
|
.line 299
|
|
invoke-virtual {p1, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_6
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkPayloadsArray:Ljava/util/List;
|
|
|
|
:goto_0
|
|
if-gez v0, :cond_1
|
|
|
|
return-void
|
|
|
|
.line 315
|
|
:cond_1
|
|
invoke-interface {p1}, Ljava/util/List;->size()I
|
|
|
|
move-result v1
|
|
|
|
if-nez v1, :cond_2
|
|
|
|
return-void
|
|
|
|
.line 321
|
|
:cond_2
|
|
invoke-interface {p1}, Ljava/util/List;->size()I
|
|
|
|
move-result v1
|
|
|
|
sub-int/2addr v1, v0
|
|
|
|
if-gez v1, :cond_3
|
|
|
|
return-void
|
|
|
|
.line 328
|
|
:cond_3
|
|
monitor-enter p0
|
|
|
|
if-nez v0, :cond_4
|
|
|
|
.line 333
|
|
:try_start_0
|
|
invoke-interface {p1}, Ljava/util/List;->clear()V
|
|
|
|
goto :goto_2
|
|
|
|
:catchall_0
|
|
move-exception p1
|
|
|
|
goto :goto_3
|
|
|
|
.line 338
|
|
:cond_4
|
|
div-int/lit8 v0, v0, 0x2
|
|
|
|
.line 339
|
|
new-instance v1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v3, "trimEventQueues, queue threshold surprassed, purging "
|
|
|
|
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
|
|
|
|
const-string v3, " older events "
|
|
|
|
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
new-array v3, v2, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, v1, v3}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
:goto_1
|
|
if-ge v2, v0, :cond_5
|
|
|
|
.line 343
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->purgeOldestEvent(Ljava/util/List;)V
|
|
|
|
add-int/lit8 v2, v2, 0x1
|
|
|
|
goto :goto_1
|
|
|
|
.line 346
|
|
:cond_5
|
|
:goto_2
|
|
monitor-exit p0
|
|
|
|
return-void
|
|
|
|
:goto_3
|
|
monitor-exit p0
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
throw p1
|
|
|
|
.line 305
|
|
:cond_6
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v1, "trimEventQueue, unsupported OT eventType, "
|
|
|
|
invoke-virtual {v0, v1}, 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 p1, "."
|
|
|
|
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v0, v2, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private updateEventThresholdListeners()V
|
|
.locals 10
|
|
|
|
.line 253
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
|
|
|
|
const-string v0, "com.ea.nimble.network"
|
|
|
|
.line 254
|
|
invoke-virtual {p0, v0}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->getMaxEventCount(Ljava/lang/String;)I
|
|
|
|
move-result v1
|
|
|
|
const/4 v2, 0x0
|
|
|
|
const-string v3, "updateEventThresholdListeners, notifying listeners event queue is approaching threshold."
|
|
|
|
const-string v4, "nimble.notification.ot.eventthresholdwarning"
|
|
|
|
const-string v5, "eventType"
|
|
|
|
const-wide/high16 v6, 0x3fe8000000000000L # 0.75
|
|
|
|
if-lez v1, :cond_0
|
|
|
|
int-to-double v8, v1
|
|
|
|
mul-double/2addr v8, v6
|
|
|
|
double-to-int v1, v8
|
|
|
|
iget-object v8, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkMetricsArray:Ljava/util/List;
|
|
|
|
.line 259
|
|
invoke-interface {v8}, Ljava/util/List;->size()I
|
|
|
|
move-result v8
|
|
|
|
if-lt v8, v1, :cond_0
|
|
|
|
.line 263
|
|
new-instance v1, Ljava/util/HashMap;
|
|
|
|
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
|
|
|
|
.line 264
|
|
invoke-interface {v1, v5, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
.line 265
|
|
invoke-static {v4, v1}, Lcom/ea/nimble/Utility;->sendBroadcast(Ljava/lang/String;Ljava/util/Map;)V
|
|
|
|
new-array v0, v2, [Ljava/lang/Object;
|
|
|
|
.line 266
|
|
invoke-static {p0, v3, v0}, Lcom/ea/nimble/Log$Helper;->LOGV(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
:cond_0
|
|
const-string v0, "com.ea.nimble.trackingimpl.synergy"
|
|
|
|
.line 270
|
|
invoke-virtual {p0, v0}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->getMaxEventCount(Ljava/lang/String;)I
|
|
|
|
move-result v1
|
|
|
|
if-lez v1, :cond_1
|
|
|
|
int-to-double v8, v1
|
|
|
|
mul-double/2addr v8, v6
|
|
|
|
double-to-int v1, v8
|
|
|
|
iget-object v6, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkPayloadsArray:Ljava/util/List;
|
|
|
|
.line 275
|
|
invoke-interface {v6}, Ljava/util/List;->size()I
|
|
|
|
move-result v6
|
|
|
|
if-lt v6, v1, :cond_1
|
|
|
|
.line 279
|
|
new-instance v1, Ljava/util/HashMap;
|
|
|
|
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
|
|
|
|
.line 280
|
|
invoke-interface {v1, v5, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
.line 281
|
|
invoke-static {v4, v1}, Lcom/ea/nimble/Utility;->sendBroadcast(Ljava/lang/String;Ljava/util/Map;)V
|
|
|
|
new-array v0, v2, [Ljava/lang/Object;
|
|
|
|
.line 282
|
|
invoke-static {p0, v3, v0}, Lcom/ea/nimble/Log$Helper;->LOGV(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
:cond_1
|
|
return-void
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public cleanup()V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public getComponentId()Ljava/lang/String;
|
|
.locals 1
|
|
|
|
const-string v0, "com.ea.nimble.operationaltelemetrydispatch"
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getEvents(Ljava/lang/String;)Ljava/util/List;
|
|
.locals 4
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
")",
|
|
"Ljava/util/List<",
|
|
"Lcom/ea/nimble/OperationalTelemetryEvent;",
|
|
">;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 151
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
|
|
|
|
.line 153
|
|
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
const/4 v1, 0x0
|
|
|
|
const/4 v2, 0x0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const-string p1, "getEvents called with null or empty eventType."
|
|
|
|
new-array v0, v1, [Ljava/lang/Object;
|
|
|
|
.line 155
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-object v2
|
|
|
|
.line 161
|
|
:cond_0
|
|
monitor-enter p0
|
|
|
|
:try_start_0
|
|
const-string v0, "com.ea.nimble.network"
|
|
|
|
.line 164
|
|
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_1
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkMetricsArray:Ljava/util/List;
|
|
|
|
.line 167
|
|
new-instance v3, Ljava/util/ArrayList;
|
|
|
|
invoke-direct {v3}, Ljava/util/ArrayList;-><init>()V
|
|
|
|
iput-object v3, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkMetricsArray:Ljava/util/List;
|
|
|
|
goto :goto_0
|
|
|
|
:catchall_0
|
|
move-exception p1
|
|
|
|
goto :goto_1
|
|
|
|
:cond_1
|
|
const-string v0, "com.ea.nimble.trackingimpl.synergy"
|
|
|
|
.line 169
|
|
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_2
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkPayloadsArray:Ljava/util/List;
|
|
|
|
.line 172
|
|
new-instance v3, Ljava/util/ArrayList;
|
|
|
|
invoke-direct {v3}, Ljava/util/ArrayList;-><init>()V
|
|
|
|
iput-object v3, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkPayloadsArray:Ljava/util/List;
|
|
|
|
goto :goto_0
|
|
|
|
:cond_2
|
|
move-object v0, v2
|
|
|
|
.line 174
|
|
:goto_0
|
|
monitor-exit p0
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
if-nez v0, :cond_3
|
|
|
|
.line 178
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v3, "getEvents, unsupported OT eventType, "
|
|
|
|
invoke-virtual {v0, v3}, 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 p1, "."
|
|
|
|
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v0, v1, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-object v2
|
|
|
|
.line 182
|
|
:cond_3
|
|
invoke-static {v0}, Ljava/util/Collections;->unmodifiableList(Ljava/util/List;)Ljava/util/List;
|
|
|
|
move-result-object p1
|
|
|
|
return-object p1
|
|
|
|
.line 174
|
|
:goto_1
|
|
:try_start_1
|
|
monitor-exit p0
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
throw p1
|
|
.end method
|
|
|
|
.method public getLogSourceTitle()Ljava/lang/String;
|
|
.locals 1
|
|
|
|
const-string v0, "OTDispatch"
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getMaxEventCount(Ljava/lang/String;)I
|
|
.locals 2
|
|
|
|
.line 205
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
|
|
|
|
.line 206
|
|
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
const/16 v1, 0x64
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const/4 p1, 0x0
|
|
|
|
new-array p1, p1, [Ljava/lang/Object;
|
|
|
|
const-string v0, "getMaxEventCount called with null or empty eventType."
|
|
|
|
.line 208
|
|
invoke-static {p0, v0, p1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return v1
|
|
|
|
:cond_0
|
|
iget-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_maxEventQueueSizeDict:Ljava/util/Map;
|
|
|
|
.line 212
|
|
invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object p1
|
|
|
|
check-cast p1, Ljava/lang/Integer;
|
|
|
|
if-nez p1, :cond_1
|
|
|
|
return v1
|
|
|
|
.line 217
|
|
:cond_1
|
|
invoke-virtual {p1}, Ljava/lang/Integer;->intValue()I
|
|
|
|
move-result p1
|
|
|
|
return p1
|
|
.end method
|
|
|
|
.method public logEvent(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 3
|
|
|
|
.line 73
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
|
|
|
|
.line 79
|
|
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
const/4 v1, 0x0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const-string p1, "logEvent called with null or empty eventType."
|
|
|
|
new-array p2, v1, [Ljava/lang/Object;
|
|
|
|
.line 81
|
|
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
.line 88
|
|
:cond_0
|
|
:try_start_0
|
|
new-instance v0, Lorg/json/JSONObject;
|
|
|
|
invoke-direct {v0, p2}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V
|
|
:try_end_0
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
.line 96
|
|
invoke-virtual {v0}, Lorg/json/JSONObject;->length()I
|
|
|
|
move-result p2
|
|
|
|
if-nez p2, :cond_1
|
|
|
|
const-string p1, "logEvent called with null or empty eventDictionary."
|
|
|
|
new-array p2, v1, [Ljava/lang/Object;
|
|
|
|
.line 98
|
|
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
.line 103
|
|
:cond_1
|
|
new-instance p2, Lcom/ea/nimble/OperationalTelemetryEventImpl;
|
|
|
|
new-instance v2, Ljava/util/Date;
|
|
|
|
invoke-direct {v2}, Ljava/util/Date;-><init>()V
|
|
|
|
invoke-direct {p2, p1, v0, v2}, Lcom/ea/nimble/OperationalTelemetryEventImpl;-><init>(Ljava/lang/String;Lorg/json/JSONObject;Ljava/util/Date;)V
|
|
|
|
.line 107
|
|
monitor-enter p0
|
|
|
|
:try_start_1
|
|
const-string v0, "com.ea.nimble.network"
|
|
|
|
.line 110
|
|
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v0
|
|
|
|
const/4 v2, 0x1
|
|
|
|
if-eqz v0, :cond_3
|
|
|
|
.line 112
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->canLogEvent(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_2
|
|
|
|
.line 114
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->trimEventQueue(Ljava/lang/String;)V
|
|
|
|
goto :goto_0
|
|
|
|
:catchall_0
|
|
move-exception p1
|
|
|
|
goto :goto_2
|
|
|
|
.line 116
|
|
:cond_2
|
|
:goto_0
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->canLogEvent(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_6
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkMetricsArray:Ljava/util/List;
|
|
|
|
.line 118
|
|
invoke-interface {v0, p2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
|
|
|
|
goto :goto_1
|
|
|
|
:cond_3
|
|
const-string v0, "com.ea.nimble.trackingimpl.synergy"
|
|
|
|
.line 122
|
|
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_5
|
|
|
|
.line 124
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->canLogEvent(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_4
|
|
|
|
.line 126
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->trimEventQueue(Ljava/lang/String;)V
|
|
|
|
.line 128
|
|
:cond_4
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->canLogEvent(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_6
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_networkPayloadsArray:Ljava/util/List;
|
|
|
|
.line 130
|
|
invoke-interface {v0, p2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
|
|
|
|
goto :goto_1
|
|
|
|
:cond_5
|
|
move v2, v1
|
|
|
|
.line 134
|
|
:cond_6
|
|
:goto_1
|
|
monitor-exit p0
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
if-nez v2, :cond_7
|
|
|
|
.line 138
|
|
new-instance p2, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v0, "logEvent, unsupported OT eventType, "
|
|
|
|
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string p1, "."
|
|
|
|
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array p2, v1, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 141
|
|
:cond_7
|
|
invoke-direct {p0}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->updateEventThresholdListeners()V
|
|
|
|
return-void
|
|
|
|
.line 134
|
|
:goto_2
|
|
:try_start_2
|
|
monitor-exit p0
|
|
:try_end_2
|
|
.catchall {:try_start_2 .. :try_end_2} :catchall_0
|
|
|
|
throw p1
|
|
|
|
.line 92
|
|
:catch_0
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v0, "logEvent could not build JSONObject from payload: "
|
|
|
|
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array p2, v1, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public restore()V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public resume()V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public setMaxEventCount(Ljava/lang/String;I)V
|
|
.locals 1
|
|
|
|
.line 190
|
|
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
|
|
|
|
.line 191
|
|
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const/4 p1, 0x0
|
|
|
|
new-array p1, p1, [Ljava/lang/Object;
|
|
|
|
const-string p2, "setMaxEventCount called with null or empty eventType."
|
|
|
|
.line 193
|
|
invoke-static {p0, p2, p1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
:cond_0
|
|
iget-object v0, p0, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->m_maxEventQueueSizeDict:Ljava/util/Map;
|
|
|
|
.line 196
|
|
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
|
|
|
|
move-result-object p2
|
|
|
|
invoke-interface {v0, p1, p2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
.line 197
|
|
invoke-direct {p0, p1}, Lcom/ea/nimble/OperationalTelemetryDispatchImpl;->trimEventQueue(Ljava/lang/String;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public suspend()V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|