ProtoQueenMonitor.smali

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


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


# static fields
.field private static final CHECK_QUEEN_LOOP_GAP:J = 0x493e0L

.field private static final CHECK_QUEEN_START_GAP:J = 0x2710L

.field private static final SEND_STAT_CNT_LIMIT:I = 0xf

.field private static final TAG:Ljava/lang/String; = "ProtoQueenMonitor"


# instance fields
.field private lastSentSucTs:J

.field private lastSucProtoTsSortSet:Ljava/util/SortedSet;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/SortedSet<",
            "Ljava/lang/Long;",
            ">;"
        }
    .end annotation
.end field

.field private loopCheckRunnable:Ljava/lang/Runnable;

.field private protoQueenEvn:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;

.field private reportCntFromEnterFg:I

.field private reportCntFromStart:I

.field private switchToFgTs:J


# direct methods
.method public constructor <init>(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;)V
    .registers 4

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

    const-wide/16 v0, 0x0

    .line 37
    iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->switchToFgTs:J

    .line 39
    iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSentSucTs:J

    const/4 v0, 0x0

    .line 41
    iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I

    .line 42
    iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I

    .line 44
    new-instance v0, Ljava/util/TreeSet;

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

    iput-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;

    .line 123
    new-instance v0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$1;

    invoke-direct {v0, p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$1;-><init>(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)V

    iput-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;

    .line 56
    iput-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->protoQueenEvn:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;

    return-void
.end method

.method static synthetic access$000(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)V
    .registers 1

    .line 29
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->snapshotProtoQueenStateAndReport()V

    return-void
.end method

.method static synthetic access$100(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)Z
    .registers 1

    .line 29
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->needMonitor()Z

    move-result p0

    return p0
.end method

.method static synthetic access$200(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)Ljava/lang/Runnable;
    .registers 1

    .line 29
    iget-object p0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;

    return-object p0
.end method

.method private clearMoreThan5MinProtoForLastSucProtoTsSortSet()V
    .registers 11

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

    move-result-wide v0

    .line 90
    new-instance v2, Ljava/util/ArrayList;

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

    .line 91
    iget-object v3, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;

    invoke-interface {v3}, Ljava/util/SortedSet;->iterator()Ljava/util/Iterator;

    move-result-object v3

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

    move-result v4

    if-eqz v4, :cond_2c

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

    move-result-object v4

    check-cast v4, Ljava/lang/Long;

    .line 92
    invoke-virtual {v4}, Ljava/lang/Long;->longValue()J

    move-result-wide v5

    sub-long v5, v0, v5

    const-wide/32 v7, 0x493e0

    cmp-long v9, v5, v7

    if-lez v9, :cond_2c

    .line 93
    invoke-virtual {v2, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    goto :goto_f

    .line 98
    :cond_2c
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;

    invoke-interface {v0, v2}, Ljava/util/SortedSet;->removeAll(Ljava/util/Collection;)Z

    return-void
.end method

.method private needMonitor()Z
    .registers 3

    .line 61
    sget-object v0, Lcom/imo/android/imoim/IMO;->Q:Lcom/imo/android/imoim/abtest/h;

    const-string v1, "cc.protos.queen.monitor.disable"

    invoke-virtual {v0, v1}, Lcom/imo/android/imoim/abtest/h;->a(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object v0

    const-string v1, "1"

    invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v0

    const/4 v1, 0x0

    if-eqz v0, :cond_11

    :cond_11
    return v1
.end method

.method private snapshotProtoQueenStateAndReport()V
    .registers 9

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

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

    .line 138
    new-instance v1, Ljava/util/LinkedList;

    iget-object v2, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->protoQueenEvn:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;

    invoke-interface {v2}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;->getProtoQueen()Ljava/util/Queue;

    move-result-object v2

    invoke-direct {v1, v2}, Ljava/util/LinkedList;-><init>(Ljava/util/Collection;)V

    .line 140
    invoke-virtual {v1}, Ljava/util/LinkedList;->size()I

    move-result v2

    invoke-static {v2}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v2

    const-string v3, "size"

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

    .line 142
    new-instance v2, Ljava/util/HashMap;

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

    .line 143
    invoke-virtual {v1}, Ljava/util/LinkedList;->iterator()Ljava/util/Iterator;

    move-result-object v3

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

    move-result v4

    const/4 v5, 0x1

    if-eqz v4, :cond_69

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

    move-result-object v4

    check-cast v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;

    .line 144
    new-instance v6, Ljava/lang/StringBuilder;

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

    iget-object v7, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;

    iget-object v7, v7, Lcom/imo/android/imoim/util/y;->c:Ljava/lang/String;

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v7, "#"

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v4, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;

    iget-object v4, v4, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;

    invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

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

    move-result-object v4

    .line 145
    invoke-virtual {v2, v4}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v6

    check-cast v6, Ljava/lang/Integer;

    if-nez v6, :cond_5c

    const/4 v6, 0x0

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

    move-result-object v6

    .line 149
    :cond_5c
    invoke-virtual {v6}, Ljava/lang/Integer;->intValue()I

    move-result v6

    add-int/2addr v6, v5

    invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v5

    .line 150
    invoke-virtual {v2, v4, v5}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    goto :goto_26

    .line 153
    :cond_69
    invoke-virtual {v2}, Ljava/util/HashMap;->size()I

    move-result v3

    if-lez v3, :cond_7d

    .line 154
    new-instance v3, Lorg/json/JSONObject;

    invoke-direct {v3, v2}, Lorg/json/JSONObject;-><init>(Ljava/util/Map;)V

    .line 155
    invoke-virtual {v3}, Lorg/json/JSONObject;->toString()Ljava/lang/String;

    move-result-object v2

    const-string v3, "protocol_map"

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

    .line 159
    :cond_7d
    invoke-virtual {v1}, Ljava/util/LinkedList;->size()I

    move-result v2

    if-lez v2, :cond_ca

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

    move-result-wide v2

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

    move-result-wide v6

    sub-long/2addr v2, v6

    .line 163
    invoke-virtual {v1}, Ljava/util/LinkedList;->getFirst()Ljava/lang/Object;

    move-result-object v4

    check-cast v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;

    if-eqz v4, :cond_ab

    .line 165
    iget-wide v6, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->lastSendTime:J

    add-long/2addr v6, v2

    invoke-static {v6, v7}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;

    move-result-object v6

    const-string v7, "oldest_proto_ts"

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

    .line 166
    iget v4, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I

    invoke-static {v4}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v4

    const-string v6, "oldest_proto_retry_cnt"

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

    .line 169
    :cond_ab
    invoke-virtual {v1}, Ljava/util/LinkedList;->getLast()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;

    if-eqz v1, :cond_ca

    .line 171
    iget-wide v6, v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->lastSendTime:J

    add-long/2addr v6, v2

    invoke-static {v6, v7}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;

    move-result-object v2

    const-string v3, "latest_proto_ts"

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

    .line 172
    iget v1, v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I

    invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "latest_proto_retry_cnt"

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

    .line 176
    :cond_ca
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->clearMoreThan5MinProtoForLastSucProtoTsSortSet()V

    .line 177
    iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSentSucTs:J

    invoke-static {v1, v2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;

    move-result-object v1

    const-string v2, "last_proto_suc_ts"

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

    .line 178
    iget-object v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;

    invoke-interface {v1}, Ljava/util/SortedSet;->size()I

    move-result v1

    invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "last_5_min_suc_proto_cnt"

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

    .line 180
    invoke-static {}, Lcom/imo/android/imoim/util/ei;->J()Ljava/lang/String;

    move-result-object v1

    if-eqz v1, :cond_ee

    goto :goto_f0

    :cond_ee
    const-string v1, ""

    :goto_f0
    const-string v2, "net"

    .line 181
    invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 182
    invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;

    move-result-object v1

    invoke-virtual {v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getTcpConnectState()I

    move-result v1

    invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "tcp"

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

    .line 183
    invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;

    move-result-object v1

    invoke-virtual {v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getGCMConnectState()I

    move-result v1

    invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "gcm"

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

    .line 185
    iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->switchToFgTs:J

    invoke-static {v1, v2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;

    move-result-object v1

    const-string v2, "switch_fg_ts"

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

    .line 186
    iget v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I

    invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "report_cnt_from_start"

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

    .line 187
    iget v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I

    invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "report_cnt_from_enter_fg"

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

    .line 192
    sget-object v1, Lcom/imo/android/imoim/IMO;->O:Lcom/imo/android/imoim/managers/m;

    const-string v2, "proto_queen_monitor"

    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 v5, v0, Lcom/imo/android/imoim/managers/m$a;->f:Z

    .line 192
    invoke-virtual {v0}, Lcom/imo/android/imoim/managers/m$a;->c()V

    .line 195
    iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;

    invoke-interface {v0}, Ljava/util/SortedSet;->clear()V

    .line 196
    iget v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I

    add-int/2addr v0, v5

    iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I

    .line 197
    iget v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I

    add-int/2addr v0, v5

    iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I

    return-void
.end method


# virtual methods
.method public markProtoSentSuc()V
    .registers 4

    .line 78
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->needMonitor()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

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

    move-result-wide v0

    iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSentSucTs:J

    .line 84
    iget-object v2, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;

    invoke-static {v0, v1}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v0

    invoke-interface {v2, v0}, Ljava/util/SortedSet;->add(Ljava/lang/Object;)Z

    return-void
.end method

.method public switchToForegroundAndMonitor(Z)V
    .registers 4

    .line 108
    invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->needMonitor()Z

    move-result v0

    if-nez v0, :cond_7

    return-void

    :cond_7
    if-eqz p1, :cond_1a

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

    move-result-wide v0

    iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->switchToFgTs:J

    const/4 p1, 0x0

    .line 115
    iput p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I

    .line 117
    iget-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;

    const-wide/16 v0, 0x2710

    invoke-static {p1, v0, v1}, Lcom/imo/android/imoim/util/ec;->a(Ljava/lang/Runnable;J)V

    return-void

    .line 119
    :cond_1a
    iget-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;

    .line 1029
    invoke-static {}, Lcom/imo/android/imoim/util/ec$a;->a()Landroid/os/Handler;

    move-result-object v0

    invoke-virtual {v0, p1}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V

    return-void
.end method