ConnectStatHelper.smali

.class public Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
.super Ljava/lang/Object;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper$INSTANCE;
    }
.end annotation


# static fields
.field public static final GCM:Ljava/lang/String; = "gcm"

.field private static final MAX_SAVED:I = 0xa

.field private static final MONITOR_LIKEE_STATE:I = 0x105

.field private static final MONITOR_LIKEE_STATE_DELAY_TIME:I = 0x1388

.field private static final MSG_CONNECT_FAILED:I = 0x101

.field private static final MSG_CONNECT_SUCCESS:I = 0x104

.field private static final MSG_DISCONNECT:I = 0x110

.field private static final MSG_DO_LOG:I = 0x106

.field private static final MSG_GET_CHANNEL_NAME:I = 0x103

.field private static final MSG_LOAD:I = 0x108

.field private static final MSG_MARK_CONNECT_START:I = 0x100

.field private static final MSG_SAVE:I = 0x107

.field private static final MSG_TCP_CONNECT_SUCCESS:I = 0x102

.field private static final MSG_TLS_VERIFY:I = 0x109

.field public static final NETWORK_STATE_FAIL:I = 0x0

.field public static final NETWORK_STATE_SUCCESS:I = 0x1

.field public static final NETWORK_STATE_UNUSED:I = -0x1


# instance fields
.field private canLog:Z

.field private final canLogFlagTs:J

.field private final mCanMonitorFlagTs:J

.field private mGCMConnectState:I

.field private mGson:Lcom/google/gson/f;

.field private mHandler:Landroid/os/Handler;

.field private mLoaded:Z

.field private mTcpConnectState:I

.field private statUnitMap:Ljava/util/Map;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Map<",
            "Ljava/lang/String;",
            "Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;",
            ">;"
        }
    .end annotation
.end field


# direct methods
.method private constructor <init>()V
    .registers 5

    .line 73
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 56
    new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {v0}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V

    iput-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    .line 62
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v0

    iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLogFlagTs:J

    .line 63
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v0

    iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mCanMonitorFlagTs:J

    const/4 v0, -0x1

    .line 65
    iput v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGCMConnectState:I

    .line 66
    iput v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mTcpConnectState:I

    const/4 v0, 0x0

    .line 70
    iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mLoaded:Z

    .line 71
    iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog:Z

    .line 74
    iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLogFlagTs:J

    const/4 v2, 0x3

    const/16 v3, 0x3e8

    invoke-static {v0, v1, v2, v3}, Lcom/imo/android/imoim/util/ei;->a(JII)Z

    move-result v0

    iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog:Z

    .line 76
    invoke-virtual {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->load()V

    return-void
.end method

.method synthetic constructor <init>(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper$1;)V
    .registers 2

    .line 30
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;-><init>()V

    return-void
.end method

.method static synthetic access$1000(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;)V
    .registers 1

    .line 30
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doSave()V

    return-void
.end method

.method static synthetic access$1100(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;)V
    .registers 1

    .line 30
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doLoad()V

    return-void
.end method

.method static synthetic access$1200(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Bundle;)V
    .registers 2

    .line 30
    invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMarkTlsVerify(Landroid/os/Bundle;)V

    return-void
.end method

.method static synthetic access$200(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Bundle;)V
    .registers 2

    .line 30
    invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMarkConnectStart(Landroid/os/Bundle;)V

    return-void
.end method

.method static synthetic access$300(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Bundle;)V
    .registers 2

    .line 30
    invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMarkTcpConnectSuc(Landroid/os/Bundle;)V

    return-void
.end method

.method static synthetic access$400(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Bundle;)V
    .registers 2

    .line 30
    invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMarkConnectFailed(Landroid/os/Bundle;)V

    return-void
.end method

.method static synthetic access$500(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Bundle;)V
    .registers 2

    .line 30
    invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMarkGetChannelName(Landroid/os/Bundle;)V

    return-void
.end method

.method static synthetic access$600(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Bundle;)V
    .registers 2

    .line 30
    invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMarkConnectSuc(Landroid/os/Bundle;)V

    return-void
.end method

.method static synthetic access$700(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;)V
    .registers 1

    .line 30
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMonitorLikeeState()V

    return-void
.end method

.method static synthetic access$800(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;ZZ)V
    .registers 3

    .line 30
    invoke-direct {p0, p1, p2}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doLog(ZZ)V

    return-void
.end method

.method static synthetic access$900(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Bundle;)V
    .registers 2

    .line 30
    invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doMarkDisconnect(Landroid/os/Bundle;)V

    return-void
.end method

.method private canLog()Z
    .registers 2

    .line 377
    iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog:Z

    return v0
.end method

.method private canMonitorLikeeState()Z
    .registers 5

    .line 381
    iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mCanMonitorFlagTs:J

    const/4 v2, 0x3

    const/16 v3, 0x2710

    invoke-static {v0, v1, v2, v3}, Lcom/imo/android/imoim/util/ei;->a(JII)Z

    move-result v0

    return v0
.end method

.method private doLoad()V
    .registers 8

    .line 344
    iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mLoaded:Z

    if-eqz v0, :cond_5

    return-void

    :cond_5
    const/4 v0, 0x1

    .line 346
    iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mLoaded:Z

    .line 348
    sget-object v1, Lcom/imo/android/imoim/util/df$ad;->CONNECTION:Lcom/imo/android/imoim/util/df$ad;

    invoke-static {v1}, Lcom/imo/android/imoim/util/v;->a(Ljava/lang/Enum;)Ljava/util/Map;

    move-result-object v1

    .line 349
    sget-object v2, Lcom/imo/android/imoim/util/df$ad;->CONNECTION:Lcom/imo/android/imoim/util/df$ad;

    const/4 v3, 0x0

    invoke-static {v2, v3}, Lcom/imo/android/imoim/util/v;->a(Ljava/lang/Enum;Ljava/lang/Object;)V

    .line 351
    invoke-interface {v1}, Ljava/util/Map;->entrySet()Ljava/util/Set;

    move-result-object v1

    invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;

    move-result-object v1

    :goto_1c
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v2

    if-eqz v2, :cond_4b

    invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Ljava/util/Map$Entry;

    .line 353
    :try_start_28
    iget-object v3, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-interface {v2}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;

    move-result-object v4

    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getGson()Lcom/google/gson/f;

    move-result-object v5

    invoke-interface {v2}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Ljava/lang/String;

    const-class v6, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    invoke-virtual {v5, v2, v6}, Lcom/google/gson/f;->a(Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;

    move-result-object v2

    invoke-interface {v3, v4, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
    :try_end_41
    .catch Ljava/lang/Exception; {:try_start_28 .. :try_end_41} :catch_42

    goto :goto_1c

    :catch_42
    move-exception v2

    const-string v3, "ConnectStatHelper"

    const-string v4, "load failed"

    .line 1083
    invoke-static {v3, v4, v2, v0}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V

    goto :goto_1c

    :cond_4b
    const/4 v0, 0x0

    .line 359
    invoke-direct {p0, v0, v0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->doLog(ZZ)V

    return-void
.end method

.method private doLog(ZZ)V
    .registers 11

    .line 364
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;

    move-result-object v0

    :cond_a
    :goto_a
    invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z

    move-result v1

    if-eqz v1, :cond_5b

    invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Ljava/util/Map$Entry;

    .line 365
    invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    if-eqz v2, :cond_a

    .line 366
    iget-object v3, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->key:Ljava/lang/String;

    invoke-static {v3}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v3

    if-nez v3, :cond_a

    const-wide/16 v3, 0x0

    if-eqz p2, :cond_30

    .line 368
    iget-wide v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->failAt:J

    cmp-long v7, v5, v3

    if-lez v7, :cond_a

    :cond_30
    if-eqz p1, :cond_36

    iget-boolean v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->isGcm:Z

    if-nez v5, :cond_a

    :cond_36
    iget-wide v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->failAt:J

    cmp-long v7, v5, v3

    if-gtz v7, :cond_42

    iget-wide v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->connectAt:J

    cmp-long v7, v5, v3

    if-lez v7, :cond_a

    .line 369
    :cond_42
    invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    invoke-virtual {v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->toLogMap()Ljava/util/Map;

    move-result-object v1

    .line 370
    sget-object v3, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;

    const-string v4, "ns_connection_session_stat_all"

    invoke-virtual {v3, v4, v1}, Lcom/imo/android/imoim/managers/bb;->b(Ljava/lang/String;Ljava/util/Map;)V

    .line 371
    iget-object v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    iget-object v2, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->key:Ljava/lang/String;

    invoke-interface {v1, v2}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;

    goto :goto_a

    :cond_5b
    return-void
.end method

.method private doMarkConnectFailed(Landroid/os/Bundle;)V
    .registers 7

    const-string v0, "ip"

    .line 283
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "port"

    .line 284
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I

    move-result v1

    const-string v2, "reason"

    .line 285
    invoke-virtual {p1, v2}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v2

    .line 286
    invoke-direct {p0, v0, v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->generateKey(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object v0

    const-string v1, "time"

    .line 287
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getLong(Ljava/lang/String;)J

    move-result-wide v3

    .line 288
    iget-object p1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1

    check-cast p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    if-eqz p1, :cond_2f

    .line 291
    iput-object v2, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->failReason:Ljava/lang/String;

    const/4 v0, 0x0

    .line 292
    iput-boolean v0, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->success:Z

    .line 293
    iput-wide v3, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->failAt:J

    .line 294
    iput-wide v3, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->endAt:J

    :cond_2f
    return-void
.end method

.method private doMarkConnectStart(Landroid/os/Bundle;)V
    .registers 15

    const-string v0, "source"

    .line 222
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v2

    const-string v0, "ip"

    .line 223
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "port"

    .line 224
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I

    move-result v9

    const-string v1, "reason"

    .line 225
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v10

    const-string v1, "isGcm"

    .line 226
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getBoolean(Ljava/lang/String;)Z

    move-result v6

    const-string v1, "time"

    .line 227
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getLong(Ljava/lang/String;)J

    move-result-wide v11

    const-string v1, "flag"

    const/4 v3, 0x0

    .line 228
    invoke-virtual {p1, v1, v3}, Landroid/os/Bundle;->getString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v8

    const-string v1, "isTls"

    const/4 v3, 0x0

    .line 229
    invoke-virtual {p1, v1, v3}, Landroid/os/Bundle;->getBoolean(Ljava/lang/String;Z)Z

    move-result v7

    const-string v1, "type"

    .line 230
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v3

    .line 232
    new-instance p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    move-object v1, p1

    move-object v4, v0

    move v5, v9

    invoke-direct/range {v1 .. v8}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;IZZLjava/lang/String;)V

    .line 233
    iput-object v10, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->connReason:Ljava/lang/String;

    .line 234
    iput-wide v11, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->startConnectAt:J

    .line 235
    iget-object v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-direct {p0, v0, v9}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->generateKey(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object v0

    invoke-interface {v1, v0, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    return-void
.end method

.method private doMarkConnectSuc(Landroid/os/Bundle;)V
    .registers 6

    const-string v0, "ip"

    .line 251
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "port"

    .line 252
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I

    move-result v1

    const-string v2, "time"

    .line 253
    invoke-virtual {p1, v2}, Landroid/os/Bundle;->getLong(Ljava/lang/String;)J

    move-result-wide v2

    .line 254
    invoke-direct {p0, v0, v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->generateKey(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object p1

    .line 256
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1

    check-cast p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    if-eqz p1, :cond_27

    .line 258
    iput-wide v2, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->connectAt:J

    const/4 v0, 0x1

    .line 259
    iput-boolean v0, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->success:Z

    .line 260
    iput-wide v2, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->endAt:J

    :cond_27
    return-void
.end method

.method private doMarkDisconnect(Landroid/os/Bundle;)V
    .registers 7

    const-string v0, "ip"

    .line 266
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "port"

    .line 267
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I

    move-result v1

    const-string v2, "time"

    .line 268
    invoke-virtual {p1, v2}, Landroid/os/Bundle;->getLong(Ljava/lang/String;)J

    move-result-wide v2

    const-string v4, "reason"

    .line 269
    invoke-virtual {p1, v4}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    .line 270
    invoke-direct {p0, v0, v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->generateKey(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object v0

    .line 271
    iget-object v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-interface {v1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    if-eqz v0, :cond_2f

    .line 274
    iput-object p1, v0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->failReason:Ljava/lang/String;

    const/4 p1, 0x1

    .line 275
    iput-boolean p1, v0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->disconnect:Z

    .line 276
    iput-wide v2, v0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->failAt:J

    .line 277
    iput-wide v2, v0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->endAt:J

    :cond_2f
    return-void
.end method

.method private doMarkGetChannelName(Landroid/os/Bundle;)V
    .registers 6

    const-string v0, "ip"

    .line 300
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "port"

    .line 301
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I

    move-result v1

    const-string v2, "time"

    .line 302
    invoke-virtual {p1, v2}, Landroid/os/Bundle;->getLong(Ljava/lang/String;)J

    move-result-wide v2

    .line 304
    iget-object p1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-direct {p0, v0, v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->generateKey(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object v0

    invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1

    check-cast p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    if-eqz p1, :cond_24

    .line 306
    iput-wide v2, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->getNameChannelAt:J

    .line 307
    iput-wide v2, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->endAt:J

    :cond_24
    return-void
.end method

.method private doMarkTcpConnectSuc(Landroid/os/Bundle;)V
    .registers 6

    const-string v0, "ip"

    .line 240
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "port"

    .line 241
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I

    move-result v1

    const-string v2, "time"

    .line 242
    invoke-virtual {p1, v2}, Landroid/os/Bundle;->getLong(Ljava/lang/String;)J

    move-result-wide v2

    .line 243
    iget-object p1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-direct {p0, v0, v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->generateKey(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object v0

    invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1

    check-cast p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    if-eqz p1, :cond_22

    .line 245
    iput-wide v2, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->tcpConnectSucAt:J

    :cond_22
    return-void
.end method

.method private doMarkTlsVerify(Landroid/os/Bundle;)V
    .registers 6

    const-string v0, "ip"

    .line 313
    invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "port"

    .line 314
    invoke-virtual {p1, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I

    move-result v1

    const-string v2, "time"

    .line 315
    invoke-virtual {p1, v2}, Landroid/os/Bundle;->getLong(Ljava/lang/String;)J

    move-result-wide v2

    .line 317
    iget-object p1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-direct {p0, v0, v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->generateKey(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object v0

    invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1

    check-cast p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    if-eqz p1, :cond_22

    .line 319
    iput-wide v2, p1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->tlsVerifyAt:J

    :cond_22
    return-void
.end method

.method private doMonitorLikeeState()V
    .registers 5

    .line 395
    invoke-static {}, Lcom/imo/android/imoim/feeds/a;->b()Lcom/imo/android/imoim/feeds/e;

    move-result-object v0

    invoke-interface {v0}, Lcom/imo/android/imoim/feeds/e;->i()I

    move-result v0

    const/4 v1, -0x1

    if-ne v0, v1, :cond_c

    return-void

    .line 399
    :cond_c
    sget-object v1, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;

    .line 400
    invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v0

    const-string v2, "likee_connection_state"

    const-string v3, "likee_state"

    .line 399
    invoke-virtual {v1, v2, v3, v0}, Lcom/imo/android/imoim/managers/bb;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;)V

    return-void
.end method

.method private doSave()V
    .registers 11

    .line 326
    new-instance v0, Ljava/util/HashMap;

    invoke-direct {v0}, Ljava/util/HashMap;-><init>()V

    .line 327
    iget-object v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->statUnitMap:Ljava/util/Map;

    invoke-interface {v1}, Ljava/util/Map;->entrySet()Ljava/util/Set;

    move-result-object v1

    invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;

    move-result-object v1

    const/4 v2, 0x0

    :goto_10
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v3

    if-eqz v3, :cond_5b

    invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v3

    check-cast v3, Ljava/util/Map$Entry;

    add-int/lit8 v4, v2, 0x1

    const/16 v5, 0xa

    if-ge v2, v5, :cond_5b

    .line 330
    invoke-interface {v3}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;

    .line 331
    iget-wide v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->connectAt:J

    const-wide/16 v7, 0x0

    cmp-long v9, v5, v7

    if-gtz v9, :cond_36

    iget-wide v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->failAt:J

    cmp-long v9, v5, v7

    if-lez v9, :cond_59

    .line 332
    :cond_36
    iget-wide v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->getNameChannelAt:J

    cmp-long v9, v5, v7

    if-lez v9, :cond_4a

    iget-boolean v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->success:Z

    if-eqz v5, :cond_4a

    iget-boolean v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->disconnect:Z

    if-nez v5, :cond_4a

    .line 333
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v5

    iput-wide v5, v2, Lcom/imo/android/imoim/network/stat/connect/ConnectStatUnit;->endAt:J

    .line 336
    :cond_4a
    invoke-interface {v3}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;

    move-result-object v3

    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getGson()Lcom/google/gson/f;

    move-result-object v5

    invoke-virtual {v5, v2}, Lcom/google/gson/f;->b(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v2

    invoke-interface {v0, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    :cond_59
    move v2, v4

    goto :goto_10

    .line 339
    :cond_5b
    sget-object v1, Lcom/imo/android/imoim/util/df$ad;->CONNECTION:Lcom/imo/android/imoim/util/df$ad;

    invoke-static {v1, v0}, Lcom/imo/android/imoim/util/v;->a(Ljava/lang/Enum;Ljava/lang/Object;)V

    return-void
.end method

.method private generateKey(Ljava/lang/String;I)Ljava/lang/String;
    .registers 4

    .line 217
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    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, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object p1

    return-object p1
.end method

.method public static get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
    .registers 1

    .line 59
    # getter for: Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper$INSTANCE;->instance:Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
    invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper$INSTANCE;->access$100()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;

    move-result-object v0

    return-object v0
.end method

.method private getGson()Lcom/google/gson/f;
    .registers 2

    .line 472
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGson:Lcom/google/gson/f;

    if-nez v0, :cond_b

    .line 473
    new-instance v0, Lcom/google/gson/f;

    invoke-direct {v0}, Lcom/google/gson/f;-><init>()V

    iput-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGson:Lcom/google/gson/f;

    .line 475
    :cond_b
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGson:Lcom/google/gson/f;

    return-object v0
.end method

.method private getHandler()Landroid/os/Handler;
    .registers 3

    .line 420
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mHandler:Landroid/os/Handler;

    if-nez v0, :cond_19

    .line 422
    new-instance v0, Landroid/os/HandlerThread;

    const-string v1, "ConnectStat"

    invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V

    .line 423
    invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V

    .line 425
    new-instance v1, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper$1;

    invoke-virtual {v0}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;

    move-result-object v0

    invoke-direct {v1, p0, v0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper$1;-><init>(Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;Landroid/os/Looper;)V

    iput-object v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mHandler:Landroid/os/Handler;

    .line 468
    :cond_19
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mHandler:Landroid/os/Handler;

    return-object v0
.end method


# virtual methods
.method public cancelDoMonitorLikeeState()V
    .registers 3

    .line 388
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canMonitorLikeeState()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    .line 391
    :cond_7
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v0

    const/16 v1, 0x105

    invoke-virtual {v0, v1}, Landroid/os/Handler;->removeMessages(I)V

    return-void
.end method

.method public getGCMConnectState()I
    .registers 2

    .line 404
    iget v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGCMConnectState:I

    return v0
.end method

.method public getTcpConnectState()I
    .registers 2

    .line 412
    iget v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mTcpConnectState:I

    return v0
.end method

.method public load()V
    .registers 3

    .line 97
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-eqz v0, :cond_1c

    iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mLoaded:Z

    if-eqz v0, :cond_b

    goto :goto_1c

    .line 99
    :cond_b
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v0

    const/16 v1, 0x108

    invoke-virtual {v0, v1}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object v0

    .line 100
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v1

    invoke-virtual {v1, v0}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    :cond_1c
    :goto_1c
    return-void
.end method

.method public log()V
    .registers 3

    .line 80
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    .line 82
    :cond_7
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v0

    const/16 v1, 0x106

    invoke-virtual {v0, v1}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object v0

    .line 84
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v1

    invoke-virtual {v1, v0}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    .line 86
    invoke-virtual {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->save()V

    return-void
.end method

.method public markConnectFailed(Ljava/lang/String;ILjava/lang/String;)V
    .registers 8

    const-string v0, "gcm"

    .line 141
    invoke-static {v0, p1}, Landroid/text/TextUtils;->equals(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Z

    move-result v0

    const/4 v1, 0x0

    if-eqz v0, :cond_c

    .line 142
    iput v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGCMConnectState:I

    goto :goto_e

    .line 144
    :cond_c
    iput v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mTcpConnectState:I

    .line 146
    :goto_e
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_15

    return-void

    .line 148
    :cond_15
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 149
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v1

    const-string v3, "time"

    invoke-virtual {v0, v3, v1, v2}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V

    const-string v1, "ip"

    .line 150
    invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    const-string p1, "port"

    .line 151
    invoke-virtual {v0, p1, p2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    const-string p1, "reason"

    .line 152
    invoke-virtual {v0, p1, p3}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 153
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p1

    const/16 p2, 0x101

    invoke-virtual {p1, p2}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object p1

    .line 154
    invoke-virtual {p1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V

    .line 155
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p2

    invoke-virtual {p2, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public markConnectSuc(Lcom/imo/android/imoim/network/ConnectData3;)V
    .registers 6

    .line 173
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canMonitorLikeeState()Z

    move-result v0

    if-eqz v0, :cond_15

    iget-boolean v0, p1, Lcom/imo/android/imoim/network/ConnectData3;->isGCM:Z

    if-nez v0, :cond_15

    .line 174
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v0

    const/16 v1, 0x105

    const-wide/16 v2, 0x1388

    invoke-virtual {v0, v1, v2, v3}, Landroid/os/Handler;->sendEmptyMessageDelayed(IJ)Z

    .line 177
    :cond_15
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_1c

    return-void

    .line 179
    :cond_1c
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 180
    iget-object v1, p1, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;

    const-string v2, "ip"

    invoke-virtual {v0, v2, v1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 181
    iget p1, p1, Lcom/imo/android/imoim/network/ConnectData3;->port:I

    const-string v1, "port"

    invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 182
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v1

    const-string p1, "time"

    invoke-virtual {v0, p1, v1, v2}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V

    .line 183
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p1

    const/16 v1, 0x104

    invoke-virtual {p1, v1}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object p1

    .line 184
    invoke-virtual {p1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V

    .line 186
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v0

    invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public markDisconnect(Lcom/imo/android/imoim/network/ConnectData3;Ljava/lang/String;)V
    .registers 6

    .line 190
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    .line 192
    :cond_7
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 193
    iget-object v1, p1, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;

    const-string v2, "ip"

    invoke-virtual {v0, v2, v1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 194
    iget p1, p1, Lcom/imo/android/imoim/network/ConnectData3;->port:I

    const-string v1, "port"

    invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 195
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v1

    const-string p1, "time"

    invoke-virtual {v0, p1, v1, v2}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V

    const-string p1, "reason"

    .line 196
    invoke-virtual {v0, p1, p2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 197
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p1

    const/16 p2, 0x110

    invoke-virtual {p1, p2}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object p1

    .line 198
    invoke-virtual {p1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V

    .line 200
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p2

    invoke-virtual {p2, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public markGetChannelName(Ljava/lang/String;I)V
    .registers 5

    .line 159
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    .line 161
    :cond_7
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    const-string v1, "ip"

    .line 162
    invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    const-string p1, "port"

    .line 163
    invoke-virtual {v0, p1, p2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 164
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide p1

    const-string v1, "time"

    invoke-virtual {v0, v1, p1, p2}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V

    .line 165
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p1

    const/16 p2, 0x103

    invoke-virtual {p1, p2}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object p1

    .line 166
    invoke-virtual {p1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V

    .line 168
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p2

    invoke-virtual {p2, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public markStart(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;ZZLjava/lang/String;)V
    .registers 13

    .line 104
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    .line 106
    :cond_7
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 107
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v1

    const-string v3, "time"

    invoke-virtual {v0, v3, v1, v2}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V

    const-string v1, "reason"

    .line 108
    invoke-virtual {v0, v1, p5}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    const-string p5, "ip"

    .line 109
    invoke-virtual {v0, p5, p3}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    const-string p3, "port"

    .line 110
    invoke-virtual {v0, p3, p4}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    const-string p3, "source"

    .line 111
    invoke-virtual {v0, p3, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    const-string p1, "isGcm"

    .line 112
    invoke-virtual {v0, p1, p6}, Landroid/os/Bundle;->putBoolean(Ljava/lang/String;Z)V

    const-string p1, "flag"

    .line 113
    invoke-virtual {v0, p1, p8}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    const-string p1, "isTls"

    .line 114
    invoke-virtual {v0, p1, p7}, Landroid/os/Bundle;->putBoolean(Ljava/lang/String;Z)V

    const-string p1, "type"

    .line 115
    invoke-virtual {v0, p1, p2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 116
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p1

    const/16 p2, 0x100

    invoke-virtual {p1, p2}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object p1

    .line 117
    invoke-virtual {p1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V

    .line 119
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p2

    invoke-virtual {p2, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public markTcpConnectSuc(Ljava/lang/String;I)V
    .registers 7

    const-string v0, "gcm"

    .line 123
    invoke-static {v0, p1}, Landroid/text/TextUtils;->equals(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Z

    move-result v0

    const/4 v1, 0x1

    if-eqz v0, :cond_c

    .line 124
    iput v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGCMConnectState:I

    goto :goto_e

    .line 126
    :cond_c
    iput v1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mTcpConnectState:I

    .line 128
    :goto_e
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_15

    return-void

    .line 130
    :cond_15
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 131
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v1

    const-string v3, "time"

    invoke-virtual {v0, v3, v1, v2}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V

    const-string v1, "ip"

    .line 132
    invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    const-string p1, "port"

    .line 133
    invoke-virtual {v0, p1, p2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 134
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p1

    const/16 p2, 0x102

    invoke-virtual {p1, p2}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object p1

    .line 135
    invoke-virtual {p1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V

    .line 137
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p2

    invoke-virtual {p2, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public markTlsVerify(Lcom/imo/android/imoim/network/ConnectData3;)V
    .registers 5

    .line 204
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    .line 206
    :cond_7
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 207
    iget-object v1, p1, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;

    const-string v2, "ip"

    invoke-virtual {v0, v2, v1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 208
    iget p1, p1, Lcom/imo/android/imoim/network/ConnectData3;->port:I

    const-string v1, "port"

    invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 209
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v1

    const-string p1, "time"

    invoke-virtual {v0, p1, v1, v2}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V

    .line 210
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object p1

    const/16 v1, 0x109

    invoke-virtual {p1, v1}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object p1

    .line 211
    invoke-virtual {p1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V

    .line 213
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v0

    invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public save()V
    .registers 3

    .line 90
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->canLog()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    .line 92
    :cond_7
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v0

    const/16 v1, 0x107

    invoke-virtual {v0, v1}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;

    move-result-object v0

    .line 93
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getHandler()Landroid/os/Handler;

    move-result-object v1

    invoke-virtual {v1, v0}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    return-void
.end method

.method public setGCMConnectState(I)V
    .registers 2

    .line 408
    iput p1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mGCMConnectState:I

    return-void
.end method

.method public setTcpConnectState(I)V
    .registers 2

    .line 416
    iput p1, p0, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->mTcpConnectState:I

    return-void
.end method