ProtoStatsHelper.smali
.class public Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field private static final DEFAULT_REPORT_INTERVAL:J = 0xea60L
.field private static final KEY_IS_GCM:Ljava/lang/String; = "isGcm"
.field private static final KEY_TIME:Ljava/lang/String; = "time"
.field private static final KEY_TYPE:Ljava/lang/String; = "type"
.field private static final MSG_MARK_ENQUEUE:I = 0x7d0
.field private static final MSG_MARK_RESP:I = 0x7d2
.field private static final MSG_MARK_SEND:I = 0x7d1
.field private static final MSG_TIMER:I = 0x7d4
.field public static final NAMESPACE:Ljava/lang/String; = "proto_stats"
.field private static final TAG:Ljava/lang/String; = "ProtoStatsHelper"
# instance fields
.field private final canLogFlagTs:J
.field private mHandler:Landroid/os/Handler;
.field private final mInterval:J
.field private mStatModel:Lcom/imo/android/imoim/network/stat/ProtoStatModel;
# direct methods
.method public constructor <init>()V
.registers 5
.line 52
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 41
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->canLogFlagTs:J
.line 45
new-instance v0, Lcom/imo/android/imoim/network/stat/ProtoStatModel;
invoke-direct {v0}, Lcom/imo/android/imoim/network/stat/ProtoStatModel;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mStatModel:Lcom/imo/android/imoim/network/stat/ProtoStatModel;
.line 53
new-instance v0, Landroid/os/HandlerThread;
const-string v1, "ProtoStat"
invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
.line 54
invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V
.line 56
new-instance v1, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper$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/ProtoStatsHelper$1;-><init>(Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;Landroid/os/Looper;)V
iput-object v1, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
.line 95
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->getStatInterval()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mInterval:J
.line 96
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "proto stat report interval: "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mInterval:J
invoke-virtual {v0, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "ProtoStatsHelper"
.line 1071
invoke-static {v1, v0}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 98
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mInterval:J
const/16 v3, 0x7d4
invoke-virtual {v0, v3, v1, v2}, Landroid/os/Handler;->sendEmptyMessageDelayed(IJ)Z
return-void
.end method
.method static synthetic access$000(Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;Lcom/imo/android/imoim/util/y;J)V
.registers 4
.line 28
invoke-direct {p0, p1, p2, p3}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->doMarkEnqueue(Lcom/imo/android/imoim/util/y;J)V
return-void
.end method
.method static synthetic access$100(Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;IZLjava/lang/String;)V
.registers 4
.line 28
invoke-direct {p0, p1, p2, p3}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->doMarkSend(IZLjava/lang/String;)V
return-void
.end method
.method static synthetic access$200(Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;IZJLjava/lang/String;)V
.registers 6
.line 28
invoke-direct/range {p0 .. p5}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->doMarkRecv(IZJLjava/lang/String;)V
return-void
.end method
.method static synthetic access$300(Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;)Landroid/os/Handler;
.registers 1
.line 28
iget-object p0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
return-object p0
.end method
.method static synthetic access$400(Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;)V
.registers 1
.line 28
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->doReport()V
return-void
.end method
.method static synthetic access$500(Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;)J
.registers 3
.line 28
iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mInterval:J
return-wide v0
.end method
.method private doMarkEnqueue(Lcom/imo/android/imoim/util/y;J)V
.registers 10
.line 151
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mStatModel:Lcom/imo/android/imoim/network/stat/ProtoStatModel;
iget-object v1, p1, Lcom/imo/android/imoim/util/y;->c:Ljava/lang/String;
iget-object v2, p1, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;
iget v3, p1, Lcom/imo/android/imoim/util/y;->e:I
move-wide v4, p2
invoke-virtual/range {v0 .. v5}, Lcom/imo/android/imoim/network/stat/ProtoStatModel;->markEnqueue(Ljava/lang/String;Ljava/lang/String;IJ)V
return-void
.end method
.method private doMarkRecv(IZJLjava/lang/String;)V
.registers 12
.line 161
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mStatModel:Lcom/imo/android/imoim/network/stat/ProtoStatModel;
move v1, p1
move v2, p2
move-wide v3, p3
move-object v5, p5
invoke-virtual/range {v0 .. v5}, Lcom/imo/android/imoim/network/stat/ProtoStatModel;->markRecv(IZJLjava/lang/String;)V
return-void
.end method
.method private doMarkSend(IZLjava/lang/String;)V
.registers 5
.line 156
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mStatModel:Lcom/imo/android/imoim/network/stat/ProtoStatModel;
invoke-virtual {v0, p1, p2, p3}, Lcom/imo/android/imoim/network/stat/ProtoStatModel;->markSend(IZLjava/lang/String;)V
return-void
.end method
.method private doReport()V
.registers 4
const/16 v0, 0xa
.line 166
invoke-static {v0}, Lcom/imo/android/imoim/util/ei;->k(I)Z
move-result v0
if-nez v0, :cond_9
return-void
.line 170
:cond_9
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mStatModel:Lcom/imo/android/imoim/network/stat/ProtoStatModel;
invoke-virtual {v0}, Lcom/imo/android/imoim/network/stat/ProtoStatModel;->getLogEvents()Ljava/util/List;
move-result-object v0
.line 171
invoke-static {v0}, Lcom/imo/android/imoim/util/common/i;->a(Ljava/util/Collection;)Z
move-result v1
if-eqz v1, :cond_16
return-void
.line 176
:cond_16
sget-object v1, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;
const-string v2, "ns_proto_stat_all"
invoke-virtual {v1, v2, v0}, Lcom/imo/android/imoim/managers/bb;->a(Ljava/lang/String;Ljava/util/List;)V
return-void
.end method
.method private getStatInterval()J
.registers 5
const-wide/32 v0, 0xea60
.line 188
:try_start_3
sget-object v2, Lcom/imo/android/imoim/IMO;->Q:Lcom/imo/android/imoim/abtest/h;
const-string v3, "cc.proto.stat.interval"
invoke-virtual {v2, v3}, Lcom/imo/android/imoim/abtest/h;->a(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v2
if-eqz v2, :cond_18
.line 190
check-cast v2, Ljava/lang/String;
invoke-static {v2}, Ljava/lang/Long;->valueOf(Ljava/lang/String;)Ljava/lang/Long;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Long;->longValue()J
move-result-wide v2
:try_end_17
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_17} :catch_18
goto :goto_19
:catch_18
:cond_18
move-wide v2, v0
.line 197
:goto_19
invoke-static {v2, v3, v0, v1}, Ljava/lang/Math;->max(JJ)J
move-result-wide v0
return-wide v0
.end method
# virtual methods
.method public markEnqueue(Lcom/imo/android/imoim/util/y;)V
.registers 7
.line 102
iget-object v0, p1, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_1f
.line 103
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "method null. should not happen. "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object p1, p1, Lcom/imo/android/imoim/util/y;->d:Ljava/lang/String;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const/4 v0, 0x1
const-string v1, "ProtoStatsHelper"
.line 1079
invoke-static {v1, p1, v0}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
return-void
.line 109
:cond_1f
iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->canLogFlagTs:J
const/4 v2, 0x6
const/16 v3, 0x64
iget-object v4, p1, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;
invoke-static {v0, v1, v2, v3, v4}, Lcom/imo/android/imoim/util/ei;->a(JIILjava/lang/String;)Z
move-result v0
if-nez v0, :cond_2d
return-void
.line 114
:cond_2d
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
.line 115
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
.line 117
iget-object v1, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
const/16 v2, 0x7d0
invoke-virtual {v1, v2, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v1
.line 118
iput-object p1, v1, Landroid/os/Message;->obj:Ljava/lang/Object;
.line 119
invoke-virtual {v1, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V
.line 121
iget-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
invoke-virtual {p1, v1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method public markRecv(IZLjava/lang/String;)V
.registers 8
.line 136
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
.line 138
new-instance v2, Landroid/os/Bundle;
invoke-direct {v2}, Landroid/os/Bundle;-><init>()V
const-string v3, "isGcm"
.line 139
invoke-virtual {v2, v3, p2}, Landroid/os/Bundle;->putBoolean(Ljava/lang/String;Z)V
const-string p2, "time"
.line 140
invoke-virtual {v2, p2, v0, v1}, Landroid/os/Bundle;->putLong(Ljava/lang/String;J)V
const-string p2, "type"
.line 141
invoke-virtual {v2, p2, p3}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 143
iget-object p2, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
const/16 p3, 0x7d2
invoke-virtual {p2, p3}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;
move-result-object p2
.line 144
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
iput-object p1, p2, Landroid/os/Message;->obj:Ljava/lang/Object;
.line 145
invoke-virtual {p2, v2}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V
.line 146
iget-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
invoke-virtual {p1, p2}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method public markSend(IZLjava/lang/String;)V
.registers 6
.line 125
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
const-string v1, "isGcm"
.line 126
invoke-virtual {v0, v1, p2}, Landroid/os/Bundle;->putBoolean(Ljava/lang/String;Z)V
const-string p2, "type"
.line 127
invoke-virtual {v0, p2, p3}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 129
iget-object p2, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
const/16 p3, 0x7d1
invoke-virtual {p2, p3}, Landroid/os/Handler;->obtainMessage(I)Landroid/os/Message;
move-result-object p2
.line 130
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
iput-object p1, p2, Landroid/os/Message;->obj:Ljava/lang/Object;
.line 131
invoke-virtual {p2, v0}, Landroid/os/Message;->setData(Landroid/os/Bundle;)V
.line 132
iget-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->mHandler:Landroid/os/Handler;
invoke-virtual {p1, p2}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method