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