FrontConnStatHelper.smali
.class public Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper$Holder;
}
.end annotation
# static fields
.field private static final EVENT_ID:Ljava/lang/String; = "05802023"
.field public static final LINKED:Ljava/lang/String; = "linked"
.field private static final NAMESPACE:Ljava/lang/String; = "front_connection"
.field public static final NONE:Ljava/lang/String; = "none"
# instance fields
.field private canLog:Z
.field private connectTotalTime:J
.field private curState:Ljava/lang/String;
.field private enterAt:J
.field private hasNet:Z
.field private isAlive:Z
.field private isFirst:Z
.field private lastConnectAt:J
.field private linkCostTime:J
# direct methods
.method private constructor <init>()V
.registers 11
.line 35
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-string v0, "none"
.line 46
iput-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->curState:Ljava/lang/String;
const-wide/16 v0, -0x1
.line 47
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->linkCostTime:J
const-wide/16 v0, 0x0
.line 48
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->enterAt:J
const/4 v2, 0x0
.line 49
iput-boolean v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isAlive:Z
.line 50
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
.line 51
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->connectTotalTime:J
.line 52
iput-boolean v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->hasNet:Z
const/4 v0, 0x1
.line 53
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isFirst:Z
.line 54
iput-boolean v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->canLog:Z
.line 36
sget-object v1, Lcom/imo/android/imoim/IMO;->O:Lcom/imo/android/imoim/managers/m;
new-instance v9, Lcom/imo/android/imoim/feeds/e/a;
const-string v4, "05802023"
const-string v5, "front_connection"
const/4 v6, 0x1
const/4 v7, 0x1
const/4 v8, 0x1
move-object v3, v9
invoke-direct/range {v3 .. v8}, Lcom/imo/android/imoim/feeds/e/a;-><init>(Ljava/lang/String;Ljava/lang/String;ZZZ)V
invoke-static {v9}, Ljava/util/Collections;->singletonList(Ljava/lang/Object;)Ljava/util/List;
move-result-object v3
invoke-virtual {v1, v3}, Lcom/imo/android/imoim/managers/m;->a(Ljava/util/List;)V
.line 38
sget-object v1, Lcom/imo/android/imoim/setting/IMOSettingsDelegate;->INSTANCE:Lcom/imo/android/imoim/setting/IMOSettingsDelegate;
invoke-virtual {v1}, Lcom/imo/android/imoim/setting/IMOSettingsDelegate;->getPercentageNetworkReport()I
move-result v1
.line 40
:try_start_39
sget-object v3, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;
invoke-virtual {v3}, Lcom/imo/android/imoim/managers/c;->j()Ljava/lang/String;
move-result-object v3
invoke-static {v3}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v3
const-wide/16 v5, 0x64
rem-long/2addr v3, v5
int-to-long v5, v1
cmp-long v1, v3, v5
if-gez v1, :cond_4c
goto :goto_4d
:cond_4c
const/4 v0, 0x0
:goto_4d
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->canLog:Z
:try_end_4f
.catch Ljava/lang/NumberFormatException; {:try_start_39 .. :try_end_4f} :catch_50
return-void
.line 42
:catch_50
iput-boolean v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->canLog:Z
return-void
.end method
.method synthetic constructor <init>(Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper$1;)V
.registers 2
.line 19
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;-><init>()V
return-void
.end method
.method private doLog()V
.registers 9
.line 111
iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->canLog:Z
if-nez v0, :cond_5
return-void
.line 113
:cond_5
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
.line 114
iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->linkCostTime:J
const/4 v3, 0x1
const-wide/16 v4, 0x0
cmp-long v6, v1, v4
if-ltz v6, :cond_15
const/4 v1, 0x1
goto :goto_16
:cond_15
const/4 v1, 0x0
:goto_16
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
const-string v2, "linked"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 115
iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->linkCostTime:J
cmp-long v6, v1, v4
if-ltz v6, :cond_2e
.line 116
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "linkCostTime"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 118
:cond_2e
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v1
iget-wide v6, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->enterAt:J
sub-long/2addr v1, v6
invoke-static {v1, v2, v4, v5}, Ljava/lang/Math;->max(JJ)J
move-result-wide v1
.line 119
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "aliveTime"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 120
iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->connectTotalTime:J
cmp-long v6, v1, v4
if-ltz v6, :cond_51
.line 121
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "connectTotalTime"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 124
:cond_51
iget-boolean v1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->hasNet:Z
invoke-static {v1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v1
const-string v2, "hasNet"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 125
iget-boolean v1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isFirst:Z
invoke-static {v1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v1
const-string v2, "isFirst"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 127
sget-object v1, Lcom/imo/android/imoim/IMO;->O:Lcom/imo/android/imoim/managers/m;
const-string v2, "front_connection"
invoke-virtual {v1, v2}, Lcom/imo/android/imoim/managers/m;->a(Ljava/lang/String;)Lcom/imo/android/imoim/managers/m$a;
move-result-object v1
invoke-virtual {v1, v0}, Lcom/imo/android/imoim/managers/m$a;->a(Ljava/util/Map;)Lcom/imo/android/imoim/managers/m$a;
move-result-object v0
.line 1635
iput-boolean v3, v0, Lcom/imo/android/imoim/managers/m$a;->f:Z
.line 127
invoke-virtual {v0}, Lcom/imo/android/imoim/managers/m$a;->c()V
return-void
.end method
.method public static get()Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;
.registers 1
.line 32
# getter for: Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper$Holder;->instance:Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper$Holder;->access$100()Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;
move-result-object v0
return-object v0
.end method
# virtual methods
.method public checkNet(Z)V
.registers 3
.line 105
iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isAlive:Z
if-eqz v0, :cond_10
.line 106
iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->hasNet:Z
if-nez v0, :cond_d
if-eqz p1, :cond_b
goto :goto_d
:cond_b
const/4 p1, 0x0
goto :goto_e
:cond_d
:goto_d
const/4 p1, 0x1
:goto_e
iput-boolean p1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->hasNet:Z
:cond_10
return-void
.end method
.method public markEnter()V
.registers 6
const/4 v0, 0x1
.line 57
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isAlive:Z
.line 58
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->enterAt:J
.line 59
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->curState:Ljava/lang/String;
const-string v1, "none"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
const-wide/16 v1, 0x0
if-nez v0, :cond_1c
.line 60
iget-wide v3, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->enterAt:J
iput-wide v3, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
.line 61
iput-wide v1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->linkCostTime:J
goto :goto_1e
.line 63
:cond_1c
iput-wide v1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
.line 66
:goto_1e
invoke-static {}, Lcom/imo/android/imoim/util/ei;->I()Z
move-result v0
invoke-virtual {p0, v0}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->checkNet(Z)V
return-void
.end method
.method public markLeave()V
.registers 9
.line 70
iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-lez v4, :cond_18
.line 71
iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->connectTotalTime:J
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-wide v6, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
sub-long/2addr v4, v6
invoke-static {v4, v5, v2, v3}, Ljava/lang/Math;->max(JJ)J
move-result-wide v4
add-long/2addr v0, v4
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->connectTotalTime:J
.line 74
:cond_18
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->doLog()V
const/4 v0, 0x0
.line 76
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isAlive:Z
const-wide/16 v4, -0x1
.line 77
iput-wide v4, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->linkCostTime:J
.line 78
iput-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
.line 79
iput-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->enterAt:J
.line 80
iput-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->connectTotalTime:J
.line 81
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->hasNet:Z
.line 82
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isFirst:Z
return-void
.end method
.method public setConnectState(Ljava/lang/String;)V
.registers 10
.line 87
iput-object p1, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->curState:Ljava/lang/String;
.line 89
iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->isAlive:Z
if-eqz v0, :cond_45
.line 90
invoke-static {}, Lcom/imo/android/imoim/util/ei;->I()Z
move-result v0
invoke-virtual {p0, v0}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->checkNet(Z)V
const-string v0, "none"
.line 92
invoke-virtual {v0, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
const-wide/16 v0, 0x0
if-nez p1, :cond_2d
.line 93
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iput-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
.line 94
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->linkCostTime:J
cmp-long p1, v2, v0
if-gez p1, :cond_45
.line 95
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->enterAt:J
sub-long/2addr v0, v2
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->linkCostTime:J
return-void
.line 97
:cond_2d
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
cmp-long p1, v2, v0
if-lez p1, :cond_45
.line 98
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->connectTotalTime:J
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-wide v6, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
sub-long/2addr v4, v6
invoke-static {v4, v5, v0, v1}, Ljava/lang/Math;->max(JJ)J
move-result-wide v4
add-long/2addr v2, v4
iput-wide v2, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->connectTotalTime:J
.line 99
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->lastConnectAt:J
:cond_45
return-void
.end method