Dispatcher4.smali
.class public Lcom/imo/android/imoim/network/Dispatcher4;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/imo/android/imoim/network/Dispatcher4$MessageHolder;,
Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;,
Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;,
Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
}
.end annotation
# static fields
.field private static final CONNECTION_TIMEOUT:I = 0xa028
.field private static CUR_MAXIMUM_RETRY_INTERVAL:J = 0x493e0L
.field public static final DEFAULT_KEEP_ALIVE:J = 0x2bf20L
.field private static final INITIAL_RETRY_INTERVAL:J = 0x1f4L
.field private static final LOG_DISPATCHER_DURATION_LAG_THRESH_HOLE:J = 0x14L
.field private static final LOG_DISPATCHER_DURATION_WARNING_THRESH_HOLE:J = 0x64L
.field private static final MAXIMUM_RETRY_INTERVAL_ACTIVE:J = 0x2710L
.field private static final MAXIMUM_RETRY_INTERVAL_INACTIVE:J = 0x493e0L
.field private static final MAX_NUMBER_TRANSMISSIONS:I = 0xa
.field private static final MSG_ON_MESSAGE:I = 0x0
.field public static final RECONNECT_REASON_APP_ACTIVITY:Ljava/lang/String; = "app_activity"
.field public static final RECONNECT_REASON_GOT_TOKEN:Ljava/lang/String; = "got_token"
.field public static final RECONNECT_REASON_KEEP_ALIVE_RECV:Ljava/lang/String; = "keep_alive_recv"
.field public static final RECONNECT_REASON_KEEP_ALIVE_SEND:Ljava/lang/String; = "keep_alive_send"
.field public static final RECONNECT_REASON_NETWORK_CHANGE:Ljava/lang/String; = "network_change"
.field public static final RECONNECT_REASON_NORMAL:Ljava/lang/String; = "normal"
.field private static final TAG:Ljava/lang/String; = "Dispatcher4"
.field private static keepalive:J = 0x2bf20L
# instance fields
.field private volatile ackInfoMap:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/Integer;",
"Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;",
">;"
}
.end annotation
.end field
.field private ackRecv:I
.field private backoff:J
.field private connectStateMonitor:Lcom/imo/android/imoim/network/ConnectStateMonitor;
.field private final connectivityChangedReceiver:Landroid/content/BroadcastReceiver;
.field private disableGCM:Z
.field private gcmNetwork:Lcom/imo/android/imoim/f;
.field private final handler:Landroid/os/Handler;
.field private highestSeqSent:I
.field private incomingQueue:Ljava/util/Queue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Queue<",
"Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;",
">;"
}
.end annotation
.end field
.field private isConnecting:Z
.field private isRunning:Z
.field private lastConnectTime:J
.field private lastIPv6Sent:Ljava/lang/String;
.field private lastNetworkReceiveTime:J
.field private lastNetworkSendTime:J
.field private volatile logHandler:Landroid/os/Handler;
.field private networkManager:Lcom/imo/android/imoim/network/NetworkManager;
.field private volatile outgoingQueue:Ljava/util/Queue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Queue<",
"Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;",
">;"
}
.end annotation
.end field
.field private processedIncomingSeq:I
.field private protoQueenMonitor:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;
.field private volatile requestInfoMap:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;",
">;"
}
.end annotation
.end field
.field private routeNum:I
.field private seq:I
.field private ssid:Ljava/lang/String;
.field private statsHelper:Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;
.field private tryCount:I
.field private usePadding:Z
.field private usingGCM:Z
# direct methods
.method static constructor <clinit>()V
.registers 0
return-void
.end method
.method public constructor <init>()V
.registers 5
.line 190
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-wide/16 v0, 0x1f4
.line 145
iput-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
.line 318
new-instance v0, Lcom/imo/android/imoim/network/Dispatcher4$3;
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v1
invoke-direct {v0, p0, v1}, Lcom/imo/android/imoim/network/Dispatcher4$3;-><init>(Lcom/imo/android/imoim/network/Dispatcher4;Landroid/os/Looper;)V
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->handler:Landroid/os/Handler;
const/4 v0, 0x0
.line 1069
iput v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->tryCount:I
.line 1240
new-instance v1, Lcom/imo/android/imoim/network/Dispatcher4$7;
invoke-direct {v1, p0}, Lcom/imo/android/imoim/network/Dispatcher4$7;-><init>(Lcom/imo/android/imoim/network/Dispatcher4;)V
iput-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->connectivityChangedReceiver:Landroid/content/BroadcastReceiver;
.line 191
new-instance v1, Ljava/util/LinkedList;
invoke-direct {v1}, Ljava/util/LinkedList;-><init>()V
iput-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
.line 192
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
iput-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
.line 193
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
iput-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ackInfoMap:Ljava/util/Map;
.line 194
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->createIncomingQueue()Ljava/util/Queue;
move-result-object v1
iput-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
.line 195
iput v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->seq:I
const/4 v1, -0x1
.line 196
iput v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->highestSeqSent:I
.line 197
iput v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->processedIncomingSeq:I
.line 198
iput v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ackRecv:I
.line 200
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->setupSession()V
.line 202
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v0
iget-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->connectivityChangedReceiver:Landroid/content/BroadcastReceiver;
new-instance v2, Landroid/content/IntentFilter;
const-string v3, "android.net.conn.CONNECTIVITY_CHANGE"
invoke-direct {v2, v3}, Landroid/content/IntentFilter;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, v1, v2}, Lcom/imo/android/imoim/IMO;->registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)Landroid/content/Intent;
return-void
.end method
.method static synthetic access$000(Lcom/imo/android/imoim/network/Dispatcher4;)Ljava/util/Queue;
.registers 1
.line 79
iget-object p0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
return-object p0
.end method
.method static synthetic access$100(Lcom/imo/android/imoim/network/Dispatcher4;Ljava/lang/String;Lorg/json/JSONObject;ZJJJ)V
.registers 10
.line 79
invoke-direct/range {p0 .. p9}, Lcom/imo/android/imoim/network/Dispatcher4;->onMessage(Ljava/lang/String;Lorg/json/JSONObject;ZJJJ)V
return-void
.end method
.method static synthetic access$200(Lcom/imo/android/imoim/network/Dispatcher4;)J
.registers 3
.line 79
iget-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
return-wide v0
.end method
.method static synthetic access$300(Lcom/imo/android/imoim/network/Dispatcher4;Lorg/json/JSONObject;)Z
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/json/JSONException;
}
.end annotation
.line 79
invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/Dispatcher4;->replaceBase64ForLog(Lorg/json/JSONObject;)Z
move-result p0
return p0
.end method
.method private addToIncomingQueue(Lorg/json/JSONObject;ZJLjava/lang/String;)V
.registers 14
const/4 v0, -0x1
const-string v1, "seq"
.line 12069
invoke-virtual {p1, v1, v0}, Lorg/json/JSONObject;->optInt(Ljava/lang/String;I)I
move-result v2
const-string v3, "flags"
.line 628
invoke-virtual {p1, v3}, Lorg/json/JSONObject;->optJSONArray(Ljava/lang/String;)Lorg/json/JSONArray;
move-result-object v3
const-string v4, "Dispatcher4"
if-eqz v3, :cond_3c
const/4 v5, 0x0
.line 632
:goto_12
invoke-virtual {v3}, Lorg/json/JSONArray;->length()I
move-result v6
if-ge v5, v6, :cond_3c
.line 633
invoke-virtual {v3, v5}, Lorg/json/JSONArray;->optString(I)Ljava/lang/String;
move-result-object v6
const-string v7, "RST"
invoke-virtual {v6, v7}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v6
if-eqz v6, :cond_39
const/4 p1, 0x1
const-string p2, "reset backend_rst"
.line 12079
invoke-static {v4, p2, p1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 635
sget-object p1, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;
const-string p2, "reset"
const-string p3, "backend_rst"
invoke-virtual {p1, p2, p3}, Lcom/imo/android/imoim/managers/bb;->a(Ljava/lang/String;Ljava/lang/String;)V
const-string p1, "rst"
.line 636
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/Dispatcher4;->reset(Ljava/lang/String;)V
return-void
:cond_39
add-int/lit8 v5, v5, 0x1
goto :goto_12
.line 642
:cond_3c
iget v3, p0, Lcom/imo/android/imoim/network/Dispatcher4;->processedIncomingSeq:I
if-ge v2, v3, :cond_41
return-void
.line 651
:cond_41
iget-object v3, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
invoke-interface {v3}, Ljava/util/Queue;->iterator()Ljava/util/Iterator;
move-result-object v3
:cond_47
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v5
if-eqz v5, :cond_69
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v5
check-cast v5, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;
.line 652
iget-object v5, v5, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;->message:Lorg/json/JSONObject;
.line 13069
invoke-virtual {v5, v1, v0}, Lorg/json/JSONObject;->optInt(Ljava/lang/String;I)I
move-result v5
if-ne v5, v2, :cond_47
.line 653
invoke-static {v2}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object p1
const-string p2, "don\'t queue duplicate message seq: "
invoke-virtual {p2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 13075
invoke-static {v4, p1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 659
:cond_69
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
new-instance v7, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;
move-object v1, v7
move-object v2, p1
move v3, p2
move-wide v4, p3
move-object v6, p5
invoke-direct/range {v1 .. v6}, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;-><init>(Lorg/json/JSONObject;ZJLjava/lang/String;)V
invoke-interface {v0, v7}, Ljava/util/Queue;->offer(Ljava/lang/Object;)Z
return-void
.end method
.method private addToOutgoingQueue(Lcom/imo/android/imoim/util/y;Lb/a;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/imo/android/imoim/util/y;",
"Lb/a<",
"Lorg/json/JSONObject;",
"Ljava/lang/Void;",
">;)V"
}
.end annotation
.line 601
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->statsHelper:Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;
invoke-virtual {v0, p1}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->markEnqueue(Lcom/imo/android/imoim/util/y;)V
.line 603
new-instance v0, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
invoke-direct {v0, p1, p2}, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;-><init>(Lcom/imo/android/imoim/util/y;Lb/a;)V
.line 605
iget-object p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {p1, v0}, Ljava/util/Queue;->offer(Ljava/lang/Object;)Z
return-void
.end method
.method private canUseGCM()Z
.registers 6
.line 1185
invoke-static {}, Lcom/imo/android/imoim/util/bd;->d()Z
move-result v0
.line 1186
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v1
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "canUseGCM="
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-boolean v3, p0, Lcom/imo/android/imoim/network/Dispatcher4;->disableGCM:Z
const/4 v4, 0x1
xor-int/2addr v3, v4
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v3, " enableByConfig="
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
const-string v3, "Dispatcher4"
invoke-virtual {v1, v3, v2}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 1187
iget-boolean v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->disableGCM:Z
if-nez v1, :cond_2e
if-eqz v0, :cond_2e
return v4
:cond_2e
const/4 v0, 0x0
return v0
.end method
.method private cancelKeepAlive()V
.registers 3
.line 538
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v0
const-string v1, "com.imo.android.imoim.KEEPALIVE"
invoke-static {v1, v0}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;Landroid/content/Context;)V
return-void
.end method
.method private cancelRetransmit()V
.registers 3
.line 1177
sget-boolean v0, Lcom/imo/android/imoim/network/NetworkHandler;->nativeLoaded:Z
if-eqz v0, :cond_b
.line 1178
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
const/4 v1, 0x5
invoke-virtual {v0, v1}, Lcom/imo/android/imoim/network/NetworkManager;->cancelAlarm(I)V
return-void
.line 1180
:cond_b
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v0
const-string v1, "com.imo.android.imoim.RETRANSMIT"
invoke-static {v1, v0}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;Landroid/content/Context;)V
return-void
.end method
.method private checkIncomingSsid(Ljava/util/List;Z)Z
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Lorg/json/JSONObject;",
">;Z)Z"
}
.end annotation
.line 381
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getSSID()Ljava/lang/String;
move-result-object v0
.line 383
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:cond_8
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_53
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lorg/json/JSONObject;
const-string v2, "to"
.line 4119
invoke-virtual {v1, v2}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v2
const-string v3, "ssid"
.line 385
invoke-static {v3, v2}, Lcom/imo/android/imoim/util/cg;->a(Ljava/lang/String;Lorg/json/JSONObject;)Ljava/lang/String;
move-result-object v2
.line 387
invoke-static {v2, v0}, Landroid/text/TextUtils;->equals(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_8
.line 388
new-instance p1, Ljava/lang/StringBuilder;
const-string v3, "mismatched SSIDS! isGcm: "
invoke-direct {p1, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string p2, " incomingSsid: "
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p2, " currentSsid: "
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p2, " msg: "
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "Dispatcher4"
.line 5075
invoke-static {p2, p1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
const/4 p1, 0x0
return p1
:cond_53
const/4 p1, 0x1
return p1
.end method
.method private createIncomingQueue()Ljava/util/Queue;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Queue<",
"Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;",
">;"
}
.end annotation
.line 1027
new-instance v0, Ljava/util/PriorityQueue;
new-instance v1, Lcom/imo/android/imoim/network/Dispatcher4$4;
invoke-direct {v1, p0}, Lcom/imo/android/imoim/network/Dispatcher4$4;-><init>(Lcom/imo/android/imoim/network/Dispatcher4;)V
const/16 v2, 0xc8
invoke-direct {v0, v2, v1}, Ljava/util/PriorityQueue;-><init>(ILjava/util/Comparator;)V
return-object v0
.end method
.method private doBackoff(Ljava/lang/String;)V
.registers 6
.line 1225
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "backoff: "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " for "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff: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, "Dispatcher4"
.line 26071
invoke-static {v1, v0}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 1226
iget-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
.line 1227
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v2
const-string v3, "com.imo.android.imoim.RECONNECT"
.line 1226
invoke-static {v3, v0, v1, p1, v2}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;JLjava/lang/String;Landroid/content/Context;)V
return-void
.end method
.method private forwardToClient(ILjava/util/List;ZLjava/lang/String;JJ)V
.registers 26
.annotation system Ldalvik/annotation/Signature;
value = {
"(I",
"Ljava/util/List<",
"Lorg/json/JSONObject;",
">;Z",
"Ljava/lang/String;",
"JJ)V"
}
.end annotation
move-object/from16 v6, p0
move/from16 v7, p1
move/from16 v8, p3
.line 928
invoke-direct {v6, v7, v8}, Lcom/imo/android/imoim/network/Dispatcher4;->updateAckRecv(IZ)V
.line 930
invoke-interface/range {p2 .. p2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v9
:goto_d
invoke-interface {v9}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_26
invoke-interface {v9}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
move-object v1, v0
check-cast v1, Lorg/json/JSONObject;
move-object/from16 v0, p0
move/from16 v2, p3
move-wide/from16 v3, p7
move-object/from16 v5, p4
.line 931
invoke-direct/range {v0 .. v5}, Lcom/imo/android/imoim/network/Dispatcher4;->addToIncomingQueue(Lorg/json/JSONObject;ZJLjava/lang/String;)V
goto :goto_d
.line 934
:cond_26
invoke-direct/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getNextIncomingMessages()Ljava/util/List;
move-result-object v0
.line 939
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v1
const/4 v2, 0x0
const/4 v3, 0x1
if-nez v1, :cond_35
.line 942
invoke-direct {v6, v3, v2, v2}, Lcom/imo/android/imoim/network/Dispatcher4;->sendMessagesToWebServer(ZZZ)V
:cond_35
add-int/lit8 v1, v7, -0x1
.line 946
iget-object v3, v6, Lcom/imo/android/imoim/network/Dispatcher4;->statsHelper:Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;
move-object/from16 v4, p4
invoke-virtual {v3, v1, v8, v4}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->markRecv(IZLjava/lang/String;)V
.line 948
iget-object v3, v6, Lcom/imo/android/imoim/network/Dispatcher4;->ackInfoMap:Ljava/util/Map;
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
invoke-interface {v3, v4}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
if-eqz v3, :cond_5e
.line 950
iget-object v4, v3, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
if-eqz v4, :cond_55
.line 951
iget-object v3, v3, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
invoke-interface {v3}, Lcom/imo/android/imoim/managers/a/c;->a()V
.line 953
:cond_55
iget-object v3, v6, Lcom/imo/android/imoim/network/Dispatcher4;->ackInfoMap:Ljava/util/Map;
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
invoke-interface {v3, v1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 958
:cond_5e
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_62
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v3
const-string v4, "request_id"
const-string v5, "data"
if-eqz v3, :cond_99
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;
.line 959
iget-object v3, v3, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;->message:Lorg/json/JSONObject;
.line 17119
invoke-virtual {v3, v5}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v3
.line 960
invoke-static {v4, v3}, Lcom/imo/android/imoim/util/cg;->a(Ljava/lang/String;Lorg/json/JSONObject;)Ljava/lang/String;
move-result-object v3
if-eqz v3, :cond_94
.line 962
iget-object v4, v6, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
invoke-interface {v4, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
if-eqz v3, :cond_94
.line 963
iget-object v4, v3, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
if-eqz v4, :cond_94
.line 964
iget-object v3, v3, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
move-wide/from16 v7, p5
invoke-interface {v3, v2, v7, v8}, Lcom/imo/android/imoim/managers/a/c;->a(IJ)V
goto :goto_96
:cond_94
move-wide/from16 v7, p5
:goto_96
add-int/lit8 v2, v2, 0x1
goto :goto_62
.line 971
:cond_99
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
.line 972
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_a2
:goto_a2
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_157
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;
.line 973
iget-object v3, v2, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;->message:Lorg/json/JSONObject;
.line 18119
invoke-virtual {v3, v5}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v3
.line 974
invoke-static {v4, v3}, Lcom/imo/android/imoim/util/cg;->a(Ljava/lang/String;Lorg/json/JSONObject;)Ljava/lang/String;
move-result-object v7
if-eqz v7, :cond_14d
.line 18222
invoke-static {}, Lcom/imo/android/imoim/techinfocollector/a/h;->e()V
.line 980
iget-object v8, v6, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
invoke-interface {v8, v7}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v8
check-cast v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
if-eqz v8, :cond_a2
.line 984
iget-object v9, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
if-eqz v9, :cond_d0
.line 985
iget-object v9, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
invoke-interface {v9, v7, v1}, Lcom/imo/android/imoim/managers/a/c;->a(Ljava/lang/String;Ljava/util/List;)V
.line 987
:cond_d0
invoke-static {v8}, Lcom/imo/android/imoim/network/DispatcherTask;->parseRequestInfo(Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;)Lcom/imo/android/imoim/network/DispatcherTask;
move-result-object v9
.line 989
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v10
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v10
invoke-virtual {v9, v10}, Lcom/imo/android/imoim/network/DispatcherTask;->setStartTime(Ljava/lang/Long;)V
.line 990
iget-object v10, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->successCallback:Lb/a;
if-eqz v10, :cond_126
if-eqz v3, :cond_117
.line 991
iget-boolean v10, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->backExtra:Z
if-eqz v10, :cond_117
.line 993
:try_start_e9
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v10
const-string v12, "net_type"
.line 994
iget-object v13, v2, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;->type:Ljava/lang/String;
invoke-virtual {v3, v12, v13}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v12, "total_ts"
.line 995
iget-object v13, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->requestTime:Ljava/lang/Long;
invoke-virtual {v13}, Ljava/lang/Long;->longValue()J
move-result-wide v13
sub-long v13, v10, v13
invoke-virtual {v3, v12, v13, v14}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
const-string v12, "before_send_ts"
.line 996
iget-wide v13, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->realSendTs:J
iget-object v15, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->requestTime:Ljava/lang/Long;
invoke-virtual {v15}, Ljava/lang/Long;->longValue()J
move-result-wide v15
sub-long/2addr v13, v15
invoke-virtual {v3, v12, v13, v14}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
const-string v12, "after_rec_ts"
.line 997
iget-wide v13, v2, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;->recTs:J
sub-long/2addr v10, v13
invoke-virtual {v3, v12, v10, v11}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
:try_end_117
.catch Lorg/json/JSONException; {:try_start_e9 .. :try_end_117} :catch_117
.line 1002
:catch_117
:cond_117
iget-object v2, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->successCallback:Lb/a;
invoke-virtual {v2, v3}, Lb/a;->a(Ljava/lang/Object;)Ljava/lang/Object;
.line 1003
sget-object v2, Lcom/imo/android/imoim/network/mock/ProtoLogHelper;->INSTANCE:Lcom/imo/android/imoim/network/mock/ProtoLogHelper;
new-instance v10, Lcom/imo/android/imoim/network/mock/mapper/DispatcherInfo;
invoke-direct {v10, v8, v3}, Lcom/imo/android/imoim/network/mock/mapper/DispatcherInfo;-><init>(Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;Lorg/json/JSONObject;)V
invoke-virtual {v2, v10}, Lcom/imo/android/imoim/network/mock/ProtoLogHelper;->sendData(Lcom/imo/android/imoim/network/mock/mapper/DispatcherInfo;)V
.line 1006
:cond_126
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
invoke-virtual {v9, v2}, Lcom/imo/android/imoim/network/DispatcherTask;->setEndTime(Ljava/lang/Long;)V
.line 1007
invoke-interface {v1, v9}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 1009
iget-object v2, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->requestTime:Ljava/lang/Long;
if-eqz v2, :cond_146
.line 1010
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v8, v8, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->requestTime:Ljava/lang/Long;
invoke-virtual {v8}, Ljava/lang/Long;->longValue()J
move-result-wide v8
sub-long/2addr v2, v8
invoke-static {v2, v3}, Lcom/imo/android/imoim/filetransfer/d/c;->b(J)V
.line 1013
:cond_146
iget-object v2, v6, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
invoke-interface {v2, v7}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
goto/16 :goto_a2
.line 19214
:cond_14d
invoke-static {}, Lcom/imo/android/imoim/techinfocollector/a/h;->c()V
.line 1022
iget-boolean v2, v2, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;->isGcm:Z
invoke-static {v3, v2}, Lcom/imo/android/imoim/managers/y;->a(Lorg/json/JSONObject;Z)V
goto/16 :goto_a2
:cond_157
return-void
.end method
.method private generateRequestId()Ljava/lang/String;
.registers 3
:cond_0
const/16 v0, 0x8
.line 311
invoke-static {v0}, Lcom/imo/android/imoim/util/ei;->c(I)Ljava/lang/String;
move-result-object v0
.line 312
iget-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
invoke-interface {v1, v0}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_0
return-object v0
.end method
.method private getIPv6DispatcherMessageIfChanged()Lorg/json/JSONObject;
.registers 5
.line 691
invoke-static {}, Lcom/imo/android/imoim/util/ei;->aQ()Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_3b
.line 692
iget-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastIPv6Sent:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_3b
.line 693
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastIPv6Sent:Ljava/lang/String;
.line 694
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
.line 695
sget-object v2, Lcom/imo/android/imoim/IMO;->c:Lcom/imo/android/imoim/network/Dispatcher4;
invoke-virtual {v2}, Lcom/imo/android/imoim/network/Dispatcher4;->getSSID()Ljava/lang/String;
move-result-object v2
const-string v3, "ssid"
invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 696
sget-object v2, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;
invoke-virtual {v2}, Lcom/imo/android/imoim/managers/c;->i()Ljava/lang/String;
move-result-object v2
const-string v3, "uid"
invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v2, "ipv6_address"
.line 697
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "set_ipv6_address"
const-string v2, "im"
const-string v3, "client"
.line 700
invoke-static {v0, v1, v2, v3}, Lcom/imo/android/imoim/util/cr;->a(Ljava/lang/String;Ljava/util/Map;Ljava/lang/String;Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v0
return-object v0
:cond_3b
const/4 v0, 0x0
return-object v0
.end method
.method public static getKeepAliveInterval()J
.registers 2
.line 530
invoke-static {}, Lcom/imo/android/imoim/util/ei;->cx()Z
.line 534
sget-wide v0, Lcom/imo/android/imoim/network/Dispatcher4;->keepalive:J
return-wide v0
.end method
.method private getNextIncomingMessages()Ljava/util/List;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;",
">;"
}
.end annotation
.line 664
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 665
iget v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->processedIncomingSeq:I
.line 667
:goto_7
iget-object v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
invoke-interface {v2}, Ljava/util/Queue;->isEmpty()Z
move-result v2
if-nez v2, :cond_36
.line 668
iget-object v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
invoke-interface {v2}, Ljava/util/Queue;->peek()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;
.line 669
iget-object v3, v2, Lcom/imo/android/imoim/network/Dispatcher4$IncomingImoMessage;->message:Lorg/json/JSONObject;
const/4 v4, -0x1
const-string v5, "seq"
.line 14069
invoke-virtual {v3, v5, v4}, Lorg/json/JSONObject;->optInt(Ljava/lang/String;I)I
move-result v3
if-gt v3, v1, :cond_28
.line 674
iget-object v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
invoke-interface {v2}, Ljava/util/Queue;->poll()Ljava/lang/Object;
goto :goto_7
:cond_28
add-int/lit8 v4, v1, 0x1
if-ne v3, v4, :cond_36
.line 677
iget-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
invoke-interface {v1}, Ljava/util/Queue;->poll()Ljava/lang/Object;
.line 678
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
move v1, v4
goto :goto_7
.line 686
:cond_36
iput v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->processedIncomingSeq:I
return-object v0
.end method
.method private getNextOutgoingMessages(Z)Ljava/util/List;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(Z)",
"Ljava/util/List<",
"Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;",
">;"
}
.end annotation
.line 611
new-instance v0, Ljava/util/LinkedList;
invoke-direct {v0}, Ljava/util/LinkedList;-><init>()V
.line 613
iget-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {v1}, Ljava/util/Queue;->iterator()Ljava/util/Iterator;
move-result-object v1
:cond_b
:goto_b
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_29
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
.line 614
iget v3, v2, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I
const/16 v4, 0xa
if-le v3, v4, :cond_1f
const/4 p1, 0x0
return-object p1
:cond_1f
if-nez p1, :cond_25
.line 618
iget v3, v2, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I
if-nez v3, :cond_b
.line 619
:cond_25
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_b
:cond_29
return-object v0
.end method
.method private getObj(Lcom/imo/android/imoim/util/y;Z)V
.registers 5
.line 834
iget v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->processedIncomingSeq:I
const/4 v1, 0x1
add-int/2addr v0, v1
iput v0, p1, Lcom/imo/android/imoim/util/y;->f:I
.line 835
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ssid:Ljava/lang/String;
iput-object v0, p1, Lcom/imo/android/imoim/util/y;->g:Ljava/lang/String;
if-eqz p2, :cond_1a
.line 838
iput-boolean v1, p1, Lcom/imo/android/imoim/util/y;->i:Z
.line 839
iget-boolean p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
iput-boolean p2, p1, Lcom/imo/android/imoim/util/y;->j:Z
.line 840
iget-boolean p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
iput-boolean p2, p1, Lcom/imo/android/imoim/util/y;->k:Z
.line 841
iget p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->routeNum:I
iput p2, p1, Lcom/imo/android/imoim/util/y;->h:I
.line 844
:cond_1a
iget-boolean p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
if-nez p2, :cond_29
.line 845
iget-boolean p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usePadding:Z
if-eqz p2, :cond_2f
.line 846
invoke-static {}, Lcom/imo/android/imoim/network/Helper;->getRandom()Ljava/lang/String;
move-result-object p2
iput-object p2, p1, Lcom/imo/android/imoim/util/y;->l:Ljava/lang/String;
goto :goto_2f
.line 849
:cond_29
iget-object p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->gcmNetwork:Lcom/imo/android/imoim/f;
iget-object p2, p2, Lcom/imo/android/imoim/f;->b:Ljava/lang/String;
iput-object p2, p1, Lcom/imo/android/imoim/util/y;->m:Ljava/lang/String;
:cond_2f
:goto_2f
const/4 p2, 0x0
.line 855
invoke-virtual {p1, p2}, Lcom/imo/android/imoim/util/y;->a(Z)[B
return-void
.end method
.method private getRetransmit()J
.registers 3
.line 1043
sget-object v0, Lcom/imo/android/imoim/IMO;->o:Lcom/imo/android/imoim/managers/f;
invoke-virtual {v0}, Lcom/imo/android/imoim/managers/f;->d()Z
move-result v0
if-eqz v0, :cond_b
const-wide/16 v0, 0x2710
return-wide v0
:cond_b
const-wide/16 v0, 0x4e20
return-wide v0
.end method
.method private handleConnected(ZLcom/imo/android/imoim/network/ConnectData3;)V
.registers 12
.line 453
iget-wide v0, p2, Lcom/imo/android/imoim/network/ConnectData3;->keepAliveInterval:J
sput-wide v0, Lcom/imo/android/imoim/network/Dispatcher4;->keepalive:J
.line 454
iget v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->routeNum:I
const/4 v1, 0x1
add-int/2addr v0, v1
iput v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->routeNum:I
.line 455
new-instance v0, Ljava/lang/StringBuilder;
const-string v2, "incremented route to "
invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->routeNum:I
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const-string v2, "Dispatcher4"
.line 6071
invoke-static {v2, v0}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 v0, 0x4
new-array v3, v0, [Ljava/lang/Object;
.line 456
iget-object v4, p2, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
const/4 v5, 0x0
aput-object v4, v3, v5
iget v4, p2, Lcom/imo/android/imoim/network/ConnectData3;->port:I
invoke-static {v4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
aput-object v4, v3, v1
iget v4, p2, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
invoke-static {v4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
const/4 v6, 0x2
aput-object v4, v3, v6
iget v4, p0, Lcom/imo/android/imoim/network/Dispatcher4;->routeNum:I
invoke-static {v4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
const/4 v7, 0x3
aput-object v4, v3, v7
const-string v4, "handleConnected %s:%s fd=%s,routeNum=%s"
invoke-static {v4, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
.line 7071
invoke-static {v2, v3}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 458
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v3
new-array v0, v0, [Ljava/lang/Object;
iget-object v8, p2, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
aput-object v8, v0, v5
iget v8, p2, Lcom/imo/android/imoim/network/ConnectData3;->port:I
.line 459
invoke-static {v8}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v8
aput-object v8, v0, v1
iget v8, p2, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
invoke-static {v8}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v8
aput-object v8, v0, v6
iget v6, p0, Lcom/imo/android/imoim/network/Dispatcher4;->routeNum:I
invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v6
aput-object v6, v0, v7
invoke-static {v4, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
.line 458
invoke-virtual {v3, v2, v0}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 462
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v0
const-string v2, "com.imo.android.imoim.RECONNECT"
invoke-static {v2, v0}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;Landroid/content/Context;)V
.line 463
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->resetBackoff()V
.line 464
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v0, p2}, Lcom/imo/android/imoim/network/NetworkManager;->switchConnection(Lcom/imo/android/imoim/network/ConnectData3;)V
.line 467
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v0
const-string v2, "com.imo.android.imoim.TIMEOUT_TCP"
invoke-static {v2, v0}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;Landroid/content/Context;)V
.line 468
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v0
const-string v2, "com.imo.android.imoim.TIMEOUT_GCM"
invoke-static {v2, v0}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;Landroid/content/Context;)V
.line 470
invoke-direct {p0, v1, v1, v1}, Lcom/imo/android/imoim/network/Dispatcher4;->sendMessagesToWebServer(ZZZ)V
.line 472
new-instance v0, Landroid/util/Pair;
iget-object v2, p2, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
iget p2, p2, Lcom/imo/android/imoim/network/ConnectData3;->port:I
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
invoke-direct {v0, v2, p2}, Landroid/util/Pair;-><init>(Ljava/lang/Object;Ljava/lang/Object;)V
.line 473
sget-object p2, Lcom/imo/android/imoim/IMO;->N:Lcom/imo/android/imoim/imodns/g;
.line 7392
iget v0, p2, Lcom/imo/android/imoim/imodns/g;->b:I
add-int/2addr v0, v1
iput v0, p2, Lcom/imo/android/imoim/imodns/g;->b:I
.line 475
iget p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->tryCount:I
if-lez p2, :cond_b3
.line 477
iput v5, p0, Lcom/imo/android/imoim/network/Dispatcher4;->tryCount:I
.line 480
:cond_b3
invoke-static {}, Lcom/imo/android/imoim/util/dl;->a()V
if-eqz p1, :cond_bb
.line 482
sget-object p1, Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;->GCM_CONNECTED:Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;
goto :goto_bd
:cond_bb
sget-object p1, Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;->TCP_CONNECTED:Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;
:goto_bd
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/Dispatcher4;->onConnectStateChange(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;)V
.line 484
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->cancelKeepAlive()V
.line 485
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->scheduleKeepAlive()V
return-void
.end method
.method private initProtoQueenMonitor()V
.registers 3
.line 217
new-instance v0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;
new-instance v1, Lcom/imo/android/imoim/network/Dispatcher4$1;
invoke-direct {v1, p0}, Lcom/imo/android/imoim/network/Dispatcher4$1;-><init>(Lcom/imo/android/imoim/network/Dispatcher4;)V
invoke-direct {v0, v1}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;-><init>(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;)V
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->protoQueenMonitor:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;
return-void
.end method
.method private logConnectTime(Lcom/imo/android/imoim/network/ConnectData3;ZJZ)V
.registers 14
.line 1344
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
.line 1346
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getLastConnectTime()J
move-result-wide v2
sub-long v2, v0, v2
.line 1348
iget-wide v4, p1, Lcom/imo/android/imoim/network/ConnectData3;->tcpConnectedTime:J
sub-long/2addr v0, v4
.line 1349
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "connected time: "
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v4, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v5, " reason: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p1, Lcom/imo/android/imoim/network/ConnectData3;->connectReason:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, " tcp time: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v5, " ip: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p1, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, " port: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v5, p1, Lcom/imo/android/imoim/network/ConnectData3;->port:I
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v5, " unblockConfig:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p1, Lcom/imo/android/imoim/network/ConnectData3;->unblockConfig:Lcom/imo/android/imoim/imodns/UnblockConfig;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v5, " isGcm: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, p2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
const-string v5, "Dispatcher4"
.line 28071
invoke-static {v5, v4}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 v4, 0x7
const/16 v6, 0x64
.line 1361
invoke-static {v4, v6}, Lcom/imo/android/imoim/util/ei;->a(II)Z
move-result v4
if-nez v4, :cond_62
return-void
.line 1365
:cond_62
new-instance v4, Lorg/json/JSONObject;
invoke-direct {v4}, Lorg/json/JSONObject;-><init>()V
const/4 v6, 0x1
:try_start_68
const-string v7, "time_ms"
.line 1367
invoke-virtual {v4, v7, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
if-nez p2, :cond_74
const-string v2, "tcp_time_ms"
.line 1369
invoke-virtual {v4, v2, v0, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
:cond_74
const-string v0, "time_handler_ms"
.line 1370
invoke-virtual {v4, v0, p3, p4}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
.line 1372
invoke-static {}, Lcom/imo/android/imoim/util/ei;->J()Ljava/lang/String;
move-result-object p3
const-string p4, "network_type"
if-nez p3, :cond_83
const-string p3, "unknown"
.line 1373
:cond_83
invoke-virtual {v4, p4, p3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 1374
iget-object p3, p1, Lcom/imo/android/imoim/network/ConnectData3;->connectReason:Ljava/lang/String;
const-string p4, "#"
invoke-virtual {p3, p4}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object p3
const-string p4, "connect_reason"
const/4 v0, 0x0
.line 1375
aget-object v0, p3, v0
invoke-virtual {v4, p4, v0}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 1376
array-length p4, p3
const/4 v0, 0x2
if-le p4, v0, :cond_ac
const-string p4, "method"
.line 1377
aget-object v1, p3, v6
invoke-virtual {v4, p4, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string p4, "qSize"
.line 1378
aget-object p3, p3, v0
invoke-static {p3}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result p3
invoke-virtual {v4, p4, p3}, Lorg/json/JSONObject;->put(Ljava/lang/String;I)Lorg/json/JSONObject;
:cond_ac
const-string p3, "address"
.line 1380
iget-object p4, p1, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
invoke-virtual {v4, p3, p4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string p3, "port"
.line 1381
iget p4, p1, Lcom/imo/android/imoim/network/ConnectData3;->port:I
invoke-virtual {v4, p3, p4}, Lorg/json/JSONObject;->put(Ljava/lang/String;I)Lorg/json/JSONObject;
const-string p3, "carrier_name"
.line 1382
invoke-static {}, Lcom/imo/android/imoim/util/ei;->U()Ljava/lang/String;
move-result-object p4
invoke-virtual {v4, p3, p4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string p3, "carrier_code"
.line 1383
invoke-static {}, Lcom/imo/android/imoim/util/ei;->W()Ljava/lang/String;
move-result-object p4
invoke-virtual {v4, p3, p4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string p3, "sim_iso"
.line 1384
invoke-static {}, Lcom/imo/android/imoim/util/ei;->al()Ljava/lang/String;
move-result-object p4
invoke-virtual {v4, p3, p4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string p3, "is_gcm"
.line 1385
invoke-virtual {v4, p3, p2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Z)Lorg/json/JSONObject;
const-string p2, "is_conn"
.line 1386
invoke-virtual {v4, p2, p5}, Lorg/json/JSONObject;->put(Ljava/lang/String;Z)Lorg/json/JSONObject;
const-string p2, "routenum"
.line 1387
iget p3, p0, Lcom/imo/android/imoim/network/Dispatcher4;->routeNum:I
invoke-virtual {v4, p2, p3}, Lorg/json/JSONObject;->put(Ljava/lang/String;I)Lorg/json/JSONObject;
.line 1388
iget-boolean p2, p1, Lcom/imo/android/imoim/network/ConnectData3;->isGCM:Z
:try_end_e8
.catch Lorg/json/JSONException; {:try_start_68 .. :try_end_e8} :catch_117
const-string p3, "name"
if-eqz p2, :cond_f2
:try_start_ec
const-string p1, "gcm"
.line 1389
invoke-virtual {v4, p3, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
goto :goto_11f
.line 1391
:cond_f2
invoke-virtual {p1}, Lcom/imo/android/imoim/network/ConnectData3;->getUnblockFlag()Ljava/lang/String;
move-result-object p2
.line 1392
invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p4
if-nez p4, :cond_111
invoke-virtual {p1}, Lcom/imo/android/imoim/network/ConnectData3;->isTls()Z
move-result p1
if-nez p1, :cond_103
goto :goto_111
:cond_103
const-string p1, "faster.tls."
.line 1395
invoke-static {p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p2
invoke-virtual {p1, p2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v4, p3, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
goto :goto_11f
:cond_111
:goto_111
const-string p1, "faster.default"
.line 1393
invoke-virtual {v4, p3, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
:try_end_116
.catch Lorg/json/JSONException; {:try_start_ec .. :try_end_116} :catch_117
goto :goto_11f
:catch_117
move-exception p1
.line 1400
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
.line 28079
invoke-static {v5, p1, v6}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 1402
:goto_11f
invoke-static {v4}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string p2, "logConnect "
invoke-virtual {p2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 29071
invoke-static {v5, p1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 1403
sget-object p1, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;
const-string p2, "socket_stable2_s1"
invoke-virtual {p1, p2, v4}, Lcom/imo/android/imoim/managers/bb;->b(Ljava/lang/String;Lorg/json/JSONObject;)V
return-void
.end method
.method private logResponse(Ljava/lang/String;Lorg/json/JSONObject;)V
.registers 3
return-void
.end method
.method private onMessage(Ljava/lang/String;Lorg/json/JSONObject;ZJJJ)V
.registers 24
move-object/from16 v0, p2
move/from16 v9, p3
.line 354
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v10
.line 355
invoke-static {}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->get()Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
move-result-object v1
invoke-virtual {v1}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->markAddRecvMessageStart()V
.line 356
invoke-direct/range {p0 .. p2}, Lcom/imo/android/imoim/network/Dispatcher4;->logResponse(Ljava/lang/String;Lorg/json/JSONObject;)V
.line 358
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->updateLastRecvTime()V
const-string v1, "id"
.line 360
invoke-virtual {v0, v1}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_2d
.line 362
invoke-static/range {p2 .. p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
const-string v2, "found isReply "
invoke-virtual {v2, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
const/4 v2, 0x1
const-string v3, "Dispatcher4"
.line 3079
invoke-static {v3, v1, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
:cond_2d
const-string v1, "data"
.line 3119
invoke-virtual {v0, v1}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v12
const/4 v0, -0x1
const-string v1, "ack"
.line 4069
invoke-virtual {v12, v1, v0}, Lorg/json/JSONObject;->optInt(Ljava/lang/String;I)I
move-result v1
const-string v0, "messages"
.line 4106
invoke-virtual {v12, v0}, Lorg/json/JSONObject;->optJSONArray(Ljava/lang/String;)Lorg/json/JSONArray;
move-result-object v0
.line 368
invoke-static {v0}, Lcom/imo/android/imoim/util/cg;->a(Lorg/json/JSONArray;)Ljava/util/List;
move-result-object v2
move-object v13, p0
.line 369
invoke-direct {p0, v2, v9}, Lcom/imo/android/imoim/network/Dispatcher4;->checkIncomingSsid(Ljava/util/List;Z)Z
move-result v0
if-eqz v0, :cond_62
move-object v0, p0
move/from16 v3, p3
move-object v4, p1
move-wide/from16 v5, p6
move-wide/from16 v7, p8
.line 370
invoke-direct/range {v0 .. v8}, Lcom/imo/android/imoim/network/Dispatcher4;->forwardToClient(ILjava/util/List;ZLjava/lang/String;JJ)V
.line 371
invoke-static {}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->get()Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
move-result-object v0
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v1
sub-long/2addr v1, v10
invoke-virtual {v0, v1, v2}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->addReceiveMessageEvent(J)V
:cond_62
move-wide/from16 v0, p4
.line 374
invoke-static {v12, v9, v0, v1}, Lcom/imo/android/imoim/network/stat/TrafficReport;->reportRespondTraffic(Lorg/json/JSONObject;ZJ)V
return-void
.end method
.method private replaceBase64ForLog(Lorg/json/JSONObject;)Z
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/json/JSONException;
}
.end annotation
const-string v0, "data"
.line 1446
invoke-virtual {p1, v0}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object p1
const/4 v1, 0x0
if-eqz p1, :cond_52
const-string v2, "messages"
.line 1448
invoke-virtual {p1, v2}, Lorg/json/JSONObject;->optJSONArray(Ljava/lang/String;)Lorg/json/JSONArray;
move-result-object p1
if-eqz p1, :cond_52
const/4 v2, 0x0
.line 1450
:goto_12
invoke-virtual {p1}, Lorg/json/JSONArray;->length()I
move-result v3
if-ge v2, v3, :cond_52
.line 1451
invoke-virtual {p1, v2}, Lorg/json/JSONArray;->optJSONObject(I)Lorg/json/JSONObject;
move-result-object v3
if-eqz v3, :cond_4f
.line 1453
invoke-virtual {v3, v0}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v3
if-eqz v3, :cond_4f
const-string v4, "response"
.line 1455
invoke-virtual {v3, v4}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v3
if-eqz v3, :cond_4f
const-string v4, "base64"
.line 1456
invoke-virtual {v3, v4}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z
move-result v5
if-eqz v5, :cond_4f
.line 1457
new-instance p1, Ljava/lang/StringBuilder;
const-string v0, "len#"
invoke-direct {p1, v0}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v4}, Lorg/json/JSONObject;->optString(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v0
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v3, v4, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const/4 p1, 0x1
return p1
:cond_4f
add-int/lit8 v2, v2, 0x1
goto :goto_12
:cond_52
return v1
.end method
.method private scheduleKeepAlive()V
.registers 6
.line 542
invoke-static {}, Lcom/imo/android/imoim/network/Dispatcher4;->getKeepAliveInterval()J
move-result-wide v0
.line 543
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v2
const-string v3, "com.imo.android.imoim.KEEPALIVE"
const/4 v4, 0x0
.line 542
invoke-static {v3, v0, v1, v4, v2}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;JLjava/lang/String;Landroid/content/Context;)V
return-void
.end method
.method private scheduleRetransmit(JLjava/lang/String;I)V
.registers 6
.line 1168
sget-boolean v0, Lcom/imo/android/imoim/network/NetworkHandler;->nativeLoaded:Z
if-eqz v0, :cond_c
.line 1169
iget-object p3, p0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
const/4 p4, 0x5
long-to-int p2, p1
invoke-virtual {p3, p4, p2}, Lcom/imo/android/imoim/network/NetworkManager;->scheduleAlarm(II)V
return-void
.line 1171
:cond_c
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p3, "#"
invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p3
.line 1172
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object p4
const-string v0, "com.imo.android.imoim.RETRANSMIT"
.line 1171
invoke-static {v0, p1, p2, p3, p4}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;JLjava/lang/String;Landroid/content/Context;)V
return-void
.end method
.method private sendKeepAlive()V
.registers 5
.line 586
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {v0}, Ljava/util/Queue;->isEmpty()Z
move-result v0
if-nez v0, :cond_9
return-void
.line 589
:cond_9
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
.line 590
sget-object v1, Lcom/imo/android/imoim/IMO;->c:Lcom/imo/android/imoim/network/Dispatcher4;
invoke-virtual {v1}, Lcom/imo/android/imoim/network/Dispatcher4;->getSSID()Ljava/lang/String;
move-result-object v1
const-string v2, "ssid"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 591
sget-object v1, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;
invoke-virtual {v1}, Lcom/imo/android/imoim/managers/c;->i()Ljava/lang/String;
move-result-object v1
const-string v2, "uid"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const/4 v1, 0x0
const-string v2, "dispatcher"
const-string v3, "keep_alive"
.line 592
invoke-static {v2, v3, v0, v1}, Lcom/imo/android/imoim/managers/h;->send(Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Lb/a;)V
return-void
.end method
.method private sendMessagesToWebServer(ZZZ)V
.registers 20
move-object/from16 v0, p0
move/from16 v1, p2
.line 717
iget-boolean v2, v0, Lcom/imo/android/imoim/network/Dispatcher4;->isRunning:Z
const-string v3, "Dispatcher4"
if-nez v2, :cond_10
const-string v1, "dispatcher is not running yet"
.line 14071
invoke-static {v3, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 722
:cond_10
invoke-static {}, Lcom/imo/android/imoim/util/ei;->s()V
.line 731
invoke-direct {v0, v1}, Lcom/imo/android/imoim/network/Dispatcher4;->getNextOutgoingMessages(Z)Ljava/util/List;
move-result-object v2
const/4 v4, 0x1
if-nez v2, :cond_25
const-string v1, "we tried too many times to send a message! resetting..."
.line 14079
invoke-static {v3, v1, v4}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
const-string v1, "reset"
.line 736
invoke-virtual {v0, v1}, Lcom/imo/android/imoim/network/Dispatcher4;->reset(Ljava/lang/String;)V
return-void
.line 740
:cond_25
invoke-interface {v2}, Ljava/util/List;->isEmpty()Z
move-result v5
if-eqz v5, :cond_33
if-nez p1, :cond_33
const-string v1, "nothing to send"
.line 15079
invoke-static {v3, v1, v4}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
return-void
.line 746
:cond_33
invoke-virtual/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->updateLastSendTime()V
const/4 v5, 0x0
if-nez v1, :cond_4a
.line 748
iget-boolean v6, v0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
if-nez v6, :cond_4a
if-nez p3, :cond_4a
iget-object v6, v0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v6}, Lcom/imo/android/imoim/network/NetworkManager;->shouldSetHeaders()Z
move-result v6
if-eqz v6, :cond_48
goto :goto_4a
:cond_48
const/4 v6, 0x0
goto :goto_4b
:cond_4a
:goto_4a
const/4 v6, 0x1
.line 750
:goto_4b
invoke-interface {v2}, Ljava/util/List;->isEmpty()Z
move-result v7
if-eqz v7, :cond_74
if-eqz p1, :cond_74
.line 752
new-instance v7, Lcom/imo/android/imoim/util/y;
const/4 v9, 0x0
const/4 v10, 0x0
const/4 v11, 0x0
const/4 v12, 0x0
const/4 v13, 0x0
const/4 v14, -0x1
const/4 v15, 0x0
move-object v8, v7
invoke-direct/range {v8 .. v15}, Lcom/imo/android/imoim/util/y;-><init>(Ljava/lang/String;Ljava/util/Map;Lcom/imo/android/imoim/util/ch;Ljava/lang/String;Ljava/lang/String;ILcom/imo/android/imoim/network/Dispatcher4$RequestInfo;)V
.line 753
invoke-direct {v0, v7, v6}, Lcom/imo/android/imoim/network/Dispatcher4;->getObj(Lcom/imo/android/imoim/util/y;Z)V
.line 754
invoke-virtual/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM()Z
move-result v8
if-eqz v8, :cond_6f
.line 755
iget-object v8, v0, Lcom/imo/android/imoim/network/Dispatcher4;->gcmNetwork:Lcom/imo/android/imoim/f;
invoke-virtual {v8, v7}, Lcom/imo/android/imoim/f;->a(Lcom/imo/android/imoim/util/y;)V
goto :goto_74
.line 757
:cond_6f
iget-object v8, v0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v8, v7}, Lcom/imo/android/imoim/network/NetworkManager;->send(Lcom/imo/android/imoim/util/y;)V
.line 776
:cond_74
:goto_74
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v7
.line 779
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v9
const/4 v10, 0x0
:goto_7d
invoke-interface {v9}, Ljava/util/Iterator;->hasNext()Z
move-result v11
if-eqz v11, :cond_106
invoke-interface {v9}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v11
check-cast v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
.line 780
iget-object v12, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
invoke-direct {v0, v12, v6}, Lcom/imo/android/imoim/network/Dispatcher4;->getObj(Lcom/imo/android/imoim/util/y;Z)V
.line 15210
invoke-static {}, Lcom/imo/android/imoim/techinfocollector/a/h;->b()V
.line 785
iget-object v12, v0, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
iget-object v13, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget-object v13, v13, Lcom/imo/android/imoim/util/y;->d:Ljava/lang/String;
invoke-interface {v12, v13}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v12
check-cast v12, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
const-string v13, "gcm"
if-eqz v12, :cond_c7
.line 786
iget-object v14, v12, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
if-eqz v14, :cond_c7
.line 787
iget-object v14, v0, Lcom/imo/android/imoim/network/Dispatcher4;->ackInfoMap:Ljava/util/Map;
iget-object v15, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget v15, v15, Lcom/imo/android/imoim/util/y;->e:I
invoke-static {v15}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v15
invoke-interface {v14, v15, v12}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 788
iget-boolean v14, v0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
if-eqz v14, :cond_b8
move-object v14, v13
goto :goto_be
:cond_b8
iget-object v14, v0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v14}, Lcom/imo/android/imoim/network/NetworkManager;->getConnectType()Ljava/lang/String;
move-result-object v14
.line 789
:goto_be
iget-object v12, v12, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
iget-object v15, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget-object v15, v15, Lcom/imo/android/imoim/util/y;->d:Ljava/lang/String;
invoke-interface {v12, v14, v15, v10}, Lcom/imo/android/imoim/managers/a/c;->a(Ljava/lang/String;Ljava/lang/String;I)V
:cond_c7
add-int/lit8 v10, v10, 0x1
.line 794
iget-object v12, v0, Lcom/imo/android/imoim/network/Dispatcher4;->statsHelper:Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;
iget-object v14, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget v14, v14, Lcom/imo/android/imoim/util/y;->e:I
iget-boolean v15, v0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
if-eqz v15, :cond_d4
goto :goto_da
:cond_d4
iget-object v13, v0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v13}, Lcom/imo/android/imoim/network/NetworkManager;->getConnectType()Ljava/lang/String;
move-result-object v13
:goto_da
invoke-virtual {v12, v14, v15, v13}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;->markSend(IZLjava/lang/String;)V
.line 796
iget-boolean v12, v0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
if-eqz v12, :cond_e9
.line 797
iget-object v12, v0, Lcom/imo/android/imoim/network/Dispatcher4;->gcmNetwork:Lcom/imo/android/imoim/f;
iget-object v13, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
invoke-virtual {v12, v13}, Lcom/imo/android/imoim/f;->a(Lcom/imo/android/imoim/util/y;)V
goto :goto_f1
.line 801
:cond_e9
iget-object v6, v0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
iget-object v12, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
invoke-virtual {v6, v12}, Lcom/imo/android/imoim/network/NetworkManager;->send(Lcom/imo/android/imoim/util/y;)V
const/4 v6, 0x0
.line 805
:goto_f1
iget v12, v0, Lcom/imo/android/imoim/network/Dispatcher4;->highestSeqSent:I
iget-object v13, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget v13, v13, Lcom/imo/android/imoim/util/y;->e:I
invoke-static {v12, v13}, Ljava/lang/Math;->max(II)I
move-result v12
iput v12, v0, Lcom/imo/android/imoim/network/Dispatcher4;->highestSeqSent:I
.line 806
iget v12, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I
add-int/2addr v12, v4
iput v12, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I
.line 807
iput-wide v7, v11, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->lastSendTime:J
goto/16 :goto_7d
.line 813
:cond_106
invoke-interface {v2}, Ljava/util/List;->isEmpty()Z
move-result v6
if-nez v6, :cond_13c
.line 814
iget-boolean v6, v0, Lcom/imo/android/imoim/network/Dispatcher4;->isConnecting:Z
if-eqz v6, :cond_116
const-string v1, "not scheduling retransmit becase it is connecting"
.line 16071
invoke-static {v3, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 821
:cond_116
iget-object v3, v0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {v3}, Ljava/util/Queue;->size()I
move-result v3
if-eq v3, v4, :cond_120
if-eqz v1, :cond_13c
.line 822
:cond_120
invoke-interface {v2, v5}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
.line 823
iget-object v2, v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget-object v2, v2, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;
.line 824
iget-object v3, v0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {v3}, Ljava/util/Queue;->size()I
move-result v3
.line 825
invoke-virtual {v1}, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->extraTimeMilis()J
move-result-wide v4
.line 826
invoke-direct/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getRetransmit()J
move-result-wide v6
add-long/2addr v4, v6
.line 827
invoke-direct {v0, v4, v5, v2, v3}, Lcom/imo/android/imoim/network/Dispatcher4;->scheduleRetransmit(JLjava/lang/String;I)V
:cond_13c
return-void
.end method
.method private setSsid(Ljava/lang/String;)V
.registers 2
.line 239
iput-object p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ssid:Ljava/lang/String;
return-void
.end method
.method private setupSession()V
.registers 2
.line 1037
sget-object v0, Lcom/imo/android/imoim/IMO;->N:Lcom/imo/android/imoim/imodns/g;
invoke-virtual {v0}, Lcom/imo/android/imoim/imodns/g;->g()Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v0}, Lcom/imo/android/imoim/network/Dispatcher4;->setSsid(Ljava/lang/String;)V
return-void
.end method
.method private shouldBackoff()Z
.registers 6
.line 1220
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
.line 1221
iget-wide v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastConnectTime:J
sub-long/2addr v0, v2
iget-wide v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
cmp-long v4, v0, v2
if-gez v4, :cond_f
const/4 v0, 0x1
return v0
:cond_f
const/4 v0, 0x0
return v0
.end method
.method private updateAckRecv(IZ)V
.registers 8
.line 863
iget p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ackRecv:I
if-ne p1, p2, :cond_5
return-void
:cond_5
if-ge p1, p2, :cond_8
return-void
.line 876
:cond_8
iget p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->highestSeqSent:I
const/4 v0, 0x1
add-int/2addr p2, v0
if-le p1, p2, :cond_38
.line 877
new-instance p2, Ljava/lang/StringBuilder;
const-string v1, "out of range ackRecv: "
invoke-direct {p2, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p1, " must be in range "
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ackRecv:I
add-int/2addr p1, v0
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p1, ": "
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->highestSeqSent:I
add-int/2addr p1, v0
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "Dispatcher4"
.line 16075
invoke-static {p2, p1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 885
:cond_38
iput p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ackRecv:I
const/4 p1, 0x0
.line 889
:goto_3b
iget-object p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {p2}, Ljava/util/Queue;->isEmpty()Z
move-result p2
if-nez p2, :cond_6f
iget-object p2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
.line 890
invoke-interface {p2}, Ljava/util/Queue;->peek()Ljava/lang/Object;
move-result-object p2
check-cast p2, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
iget-object p2, p2, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget p2, p2, Lcom/imo/android/imoim/util/y;->e:I
iget v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ackRecv:I
if-ge p2, v1, :cond_6f
.line 891
iget-object p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {p1}, Ljava/util/Queue;->poll()Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
.line 892
iget-object p2, p1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->dispatcherAck:Lb/a;
if-eqz p2, :cond_65
.line 893
iget-object p1, p1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->dispatcherAck:Lb/a;
const/4 p2, 0x0
invoke-virtual {p1, p2}, Lb/a;->a(Ljava/lang/Object;)Ljava/lang/Object;
.line 16218
:cond_65
invoke-static {}, Lcom/imo/android/imoim/techinfocollector/a/h;->d()V
.line 898
iget-object p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->protoQueenMonitor:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;
invoke-virtual {p1}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->markProtoSentSuc()V
const/4 p1, 0x1
goto :goto_3b
:cond_6f
if-eqz p1, :cond_9b
.line 905
iget-object p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {p1}, Ljava/util/Queue;->size()I
move-result p1
if-lez p1, :cond_98
.line 906
iget-object p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {p1}, Ljava/util/Queue;->peek()Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
.line 907
iget-object p2, p1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget-object p2, p2, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;
.line 908
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {v0}, Ljava/util/Queue;->size()I
move-result v0
.line 909
invoke-virtual {p1}, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->extraTimeMilis()J
move-result-wide v1
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getRetransmit()J
move-result-wide v3
add-long/2addr v1, v3
.line 910
invoke-direct {p0, v1, v2, p2, v0}, Lcom/imo/android/imoim/network/Dispatcher4;->scheduleRetransmit(JLjava/lang/String;I)V
return-void
.line 912
:cond_98
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->cancelRetransmit()V
:cond_9b
return-void
.end method
.method private updateBackoff()V
.registers 5
.line 1231
iget-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
const-wide/16 v2, 0x2
mul-long v0, v0, v2
iput-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
.line 1232
sget-wide v2, Lcom/imo/android/imoim/network/Dispatcher4;->CUR_MAXIMUM_RETRY_INTERVAL:J
invoke-static {v0, v1, v2, v3}, Ljava/lang/Math;->min(JJ)J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
return-void
.end method
# virtual methods
.method public disableGCM()V
.registers 2
const/4 v0, 0x1
.line 1203
iput-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->disableGCM:Z
return-void
.end method
.method public enableGCM()V
.registers 3
const/4 v0, 0x0
.line 1195
iput-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->disableGCM:Z
.line 1197
iget-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->isRunning:Z
if-nez v0, :cond_13
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->canUseGCM()Z
move-result v0
if-eqz v0, :cond_13
const/4 v0, 0x1
const-string v1, "got_token"
.line 1198
invoke-virtual {p0, v1, v0}, Lcom/imo/android/imoim/network/Dispatcher4;->reconnect(Ljava/lang/String;Z)V
:cond_13
return-void
.end method
.method public getAndIncrementSeq()I
.registers 3
.line 1337
iget v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->seq:I
add-int/lit8 v1, v0, 0x1
.line 1338
iput v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->seq:I
return v0
.end method
.method public getAntiBlockConnectState()I
.registers 9
.line 1292
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getConnectType()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_8
const/4 v0, 0x0
return v0
:cond_8
const/4 v0, 0x0
const/4 v1, 0x1
.line 1298
:try_start_a
sget-object v2, Lcom/imo/android/imoim/IMO;->N:Lcom/imo/android/imoim/imodns/g;
invoke-virtual {v2}, Lcom/imo/android/imoim/imodns/g;->a()Ljava/lang/String;
move-result-object v2
invoke-static {v2}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v2
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
:try_end_18
.catch Ljava/lang/NumberFormatException; {:try_start_a .. :try_end_18} :catch_19
goto :goto_21
:catch_19
move-exception v2
const-string v3, "Dispatcher4"
const-string v4, "getAntiBlockConnectState: e"
.line 27083
invoke-static {v3, v4, v2, v1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
:goto_21
const/4 v2, 0x2
const-wide/16 v3, 0x1
if-eqz v0, :cond_32
.line 1303
invoke-virtual {v0}, Ljava/lang/Long;->longValue()J
move-result-wide v5
const/4 v7, 0x3
shr-long/2addr v5, v7
and-long/2addr v5, v3
cmp-long v7, v5, v3
if-nez v7, :cond_32
return v2
.line 1309
:cond_32
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getConnectType()Ljava/lang/String;
move-result-object v5
const-string v6, "gcm"
invoke-virtual {v6, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v5
if-nez v5, :cond_76
.line 1310
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getConnectType()Ljava/lang/String;
move-result-object v5
const-string v6, "https"
invoke-virtual {v6, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v5
if-nez v5, :cond_76
.line 1311
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getConnectType()Ljava/lang/String;
move-result-object v5
const-string v6, "tls"
invoke-virtual {v6, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v5
if-eqz v5, :cond_57
goto :goto_76
.line 1316
:cond_57
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->getConnectType()Ljava/lang/String;
move-result-object v5
const-string v6, "tcp"
invoke-virtual {v6, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v5
if-eqz v5, :cond_73
if-eqz v0, :cond_72
.line 1317
invoke-virtual {v0}, Ljava/lang/Long;->longValue()J
move-result-wide v5
const/16 v0, 0x9
shr-long/2addr v5, v0
and-long/2addr v5, v3
cmp-long v0, v5, v3
if-nez v0, :cond_72
return v2
:cond_72
return v1
:cond_73
const/16 v0, -0xb
return v0
:cond_76
:goto_76
return v2
.end method
.method public getConnectType()Ljava/lang/String;
.registers 2
.line 1277
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM()Z
move-result v0
if-eqz v0, :cond_9
const-string v0, "gcm"
return-object v0
.line 1280
:cond_9
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v0}, Lcom/imo/android/imoim/network/NetworkManager;->getConnectType()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getLastConnectTime()J
.registers 3
.line 1333
iget-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastConnectTime:J
return-wide v0
.end method
.method public getSSID()Ljava/lang/String;
.registers 3
.line 524
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ssid:Ljava/lang/String;
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_b
.line 526
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ssid:Ljava/lang/String;
return-object v0
.line 525
:cond_b
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "ssid is null"
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public handleGcmMessage(Ljava/lang/String;)V
.registers 5
.line 1237
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->gcmNetwork:Lcom/imo/android/imoim/f;
.line 26121
iget-object v1, v0, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;
const/4 v2, 0x1
if-nez v1, :cond_f
const-string p1, "GCMNetwork4"
const-string v0, "Handler is null"
.line 27079
invoke-static {p1, v0, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
return-void
.line 26125
:cond_f
iget-object v1, v0, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;
invoke-virtual {v1, v2, p1}, Lcom/imo/android/imoim/f$b;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
.line 26126
iget-object v0, v0, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;
invoke-virtual {v0, p1}, Lcom/imo/android/imoim/f$b;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method public hasQueuedMessages()Z
.registers 2
.line 596
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
invoke-interface {v0}, Ljava/util/Queue;->isEmpty()Z
move-result v0
if-nez v0, :cond_a
const/4 v0, 0x1
return v0
:cond_a
const/4 v0, 0x0
return v0
.end method
.method public initNetwork()V
.registers 4
.line 207
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v0
const-string v1, "Dispatcher4"
const-string v2, "-----------------------------------------"
invoke-virtual {v0, v1, v2}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 208
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v0
const-string v2, "initNetwork"
invoke-virtual {v0, v1, v2}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 209
new-instance v0, Lcom/imo/android/imoim/network/NetworkManager;
invoke-direct {v0}, Lcom/imo/android/imoim/network/NetworkManager;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
.line 210
new-instance v0, Lcom/imo/android/imoim/f;
invoke-direct {v0}, Lcom/imo/android/imoim/f;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->gcmNetwork:Lcom/imo/android/imoim/f;
.line 211
new-instance v0, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;
invoke-direct {v0}, Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->statsHelper:Lcom/imo/android/imoim/network/stat/ProtoStatsHelper;
.line 212
new-instance v0, Lcom/imo/android/imoim/network/ConnectStateMonitor;
invoke-direct {v0}, Lcom/imo/android/imoim/network/ConnectStateMonitor;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->connectStateMonitor:Lcom/imo/android/imoim/network/ConnectStateMonitor;
.line 213
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->initProtoQueenMonitor()V
return-void
.end method
.method public isConnected()Z
.registers 2
.line 1211
iget-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
if-nez v0, :cond_11
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
if-eqz v0, :cond_f
invoke-virtual {v0}, Lcom/imo/android/imoim/network/NetworkManager;->isNetValid()Z
move-result v0
if-eqz v0, :cond_f
goto :goto_11
:cond_f
const/4 v0, 0x0
return v0
:cond_11
:goto_11
const/4 v0, 0x1
return v0
.end method
.method public isConnecting()Z
.registers 2
.line 1207
iget-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->isConnecting:Z
return v0
.end method
.method public keepAlive()V
.registers 13
const-string v0, "Dispatcher4"
const-string v1, "keepAlive"
.line 9071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 548
sget-object v1, Lcom/imo/android/imoim/util/df$ad;->KEEP_ALIVE_HIT:Lcom/imo/android/imoim/util/df$ad;
invoke-static {v1}, Lcom/imo/android/imoim/util/df;->a(Ljava/lang/Enum;)I
.line 549
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->scheduleKeepAlive()V
.line 551
const-class v1, Lcom/imo/android/imoim/managers/ak;
invoke-static {v1}, Lsg/bigo/mobile/android/a/a/a;->a(Ljava/lang/Class;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/imo/android/imoim/managers/ak;
invoke-interface {v1}, Lcom/imo/android/imoim/managers/ak;->b()V
.line 553
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->isConnected()Z
move-result v1
if-eqz v1, :cond_26
.line 554
sget-object v1, Lcom/imo/android/imoim/IMO;->aa:Lcom/imo/android/imoim/abtest/b;
const/4 v2, 0x0
invoke-virtual {v1, v2}, Lcom/imo/android/imoim/abtest/b;->a(Z)V
.line 557
:cond_26
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v1
const-wide/16 v3, 0x2
.line 558
invoke-static {}, Lcom/imo/android/imoim/network/Dispatcher4;->getKeepAliveInterval()J
move-result-wide v5
mul-long v5, v5, v3
.line 559
iget-wide v3, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastNetworkSendTime:J
const-wide/16 v7, 0x0
cmp-long v9, v3, v7
if-gtz v9, :cond_3b
return-void
.line 564
:cond_3b
iget-wide v9, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastNetworkReceiveTime:J
cmp-long v11, v9, v7
if-gtz v11, :cond_42
return-void
:cond_42
sub-long v3, v1, v3
const/4 v7, 0x1
cmp-long v8, v3, v5
if-ltz v8, :cond_5b
const-string v1, "lastNetworkSendTime reconnect"
.line 10071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 571
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;->get()Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;
move-result-object v0
invoke-virtual {v0}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;->markDisConnect()V
const-string v0, "keep_alive_send"
.line 572
invoke-virtual {p0, v0, v7}, Lcom/imo/android/imoim/network/Dispatcher4;->reconnect(Ljava/lang/String;Z)V
return-void
:cond_5b
sub-long/2addr v1, v9
cmp-long v3, v1, v5
if-ltz v3, :cond_72
const-string v1, "socket timeout! resetting the connection"
.line 11071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 577
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;->get()Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;
move-result-object v0
invoke-virtual {v0}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;->markDisConnect()V
const-string v0, "keep_alive_recv"
.line 578
invoke-virtual {p0, v0, v7}, Lcom/imo/android/imoim/network/Dispatcher4;->reconnect(Ljava/lang/String;Z)V
return-void
.line 580
:cond_72
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->sendKeepAlive()V
return-void
.end method
.method public keepAliveFromOtherThread()V
.registers 3
.line 1051
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->handler:Landroid/os/Handler;
new-instance v1, Lcom/imo/android/imoim/network/Dispatcher4$5;
invoke-direct {v1, p0}, Lcom/imo/android/imoim/network/Dispatcher4$5;-><init>(Lcom/imo/android/imoim/network/Dispatcher4;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method public synthetic lambda$senderStarted$0$Dispatcher4(JLjava/lang/String;Lcom/imo/android/imoim/network/ConnectData3;Z)V
.registers 14
.line 402
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
sub-long v5, v0, p1
.line 404
iget-wide p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastConnectTime:J
sub-long/2addr v0, p1
const-string p1, "Dispatcher4"
const-wide/16 v2, 0x1f4
cmp-long p2, v5, v2
if-lez p2, :cond_1e
.line 407
invoke-static {v5, v6}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object p2
const-string v2, "took too long "
invoke-virtual {v2, p2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p2
.line 30071
invoke-static {p1, p2}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 410
:cond_1e
new-instance p2, Ljava/lang/StringBuilder;
const-string v2, "senderStarted "
invoke-direct {p2, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 411
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p3}, Ljava/lang/String;->toUpperCase()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 412
invoke-virtual {p4}, Lcom/imo/android/imoim/network/ConnectData3;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " time: "
.line 413
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 414
invoke-virtual {p2, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const/4 v0, 0x1
.line 416
iput-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->isRunning:Z
.line 417
iget-boolean v7, p0, Lcom/imo/android/imoim/network/Dispatcher4;->isConnecting:Z
if-eqz v7, :cond_aa
const/4 v0, 0x0
.line 421
iput-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->isConnecting:Z
.line 422
iput-boolean p5, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
.line 423
invoke-virtual {p4}, Lcom/imo/android/imoim/network/ConnectData3;->needPadding()Z
move-result v0
iput-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usePadding:Z
.line 424
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "connect suc "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 31071
invoke-static {p1, v0}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 425
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v0, p3}, Lcom/imo/android/imoim/network/NetworkManager;->setNetworkType(Ljava/lang/String;)V
.line 426
invoke-direct {p0, p5, p4}, Lcom/imo/android/imoim/network/Dispatcher4;->handleConnected(ZLcom/imo/android/imoim/network/ConnectData3;)V
.line 427
sput-object p4, Lcom/imo/android/imoim/techinfocollector/a/h;->c:Lcom/imo/android/imoim/network/ConnectData3;
.line 428
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object p3
invoke-virtual {p3, p4}, Lcom/imo/android/imoim/network/NetworkLogger;->setTheConnection(Lcom/imo/android/imoim/network/ConnectData3;)V
.line 429
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
move-result-object p3
invoke-virtual {p3, p4}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->markConnectSuc(Lcom/imo/android/imoim/network/ConnectData3;)V
.line 430
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;
move-result-object p3
const-string v0, "linked"
invoke-virtual {p3, v0}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatHelper;->setConnectState(Ljava/lang/String;)V
.line 431
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;->get()Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;
move-result-object p3
invoke-virtual {p4}, Lcom/imo/android/imoim/network/ConnectData3;->getType()Ljava/lang/String;
move-result-object v0
iget-object v1, p4, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
iget v2, p4, Lcom/imo/android/imoim/network/ConnectData3;->port:I
.line 432
invoke-virtual {p4}, Lcom/imo/android/imoim/network/ConnectData3;->getDomain()Ljava/lang/String;
move-result-object v3
.line 431
invoke-virtual {p3, v0, v1, v2, v3}, Lcom/imo/android/imoim/network/stat/connect/FrontConnStatsHelper2;->markConnectSuccess(Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
goto :goto_af
:cond_aa
const-string p3, " - ignore"
.line 434
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 437
:goto_af
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p3
.line 32071
invoke-static {p1, p3}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 439
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object p3
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-virtual {p3, p1, p2}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
move-object v2, p0
move-object v3, p4
move v4, p5
.line 440
invoke-direct/range {v2 .. v7}, Lcom/imo/android/imoim/network/Dispatcher4;->logConnectTime(Lcom/imo/android/imoim/network/ConnectData3;ZJZ)V
return-void
.end method
.method public logSendMessage(Ljava/lang/String;Lcom/imo/android/imoim/util/y;)V
.registers 3
return-void
.end method
.method public notifyActive(Z)V
.registers 6
.line 1074
sget-object v0, Lcom/imo/android/imoim/setting/IMOSettingsDelegate;->INSTANCE:Lcom/imo/android/imoim/setting/IMOSettingsDelegate;
invoke-virtual {v0}, Lcom/imo/android/imoim/setting/IMOSettingsDelegate;->getBackOffNew()Z
move-result v0
const-wide/32 v1, 0x493e0
if-eqz v0, :cond_1d
if-eqz p1, :cond_1a
const-wide/16 v0, 0x2710
.line 1076
sput-wide v0, Lcom/imo/android/imoim/network/Dispatcher4;->CUR_MAXIMUM_RETRY_INTERVAL:J
.line 1077
iget-wide v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
cmp-long p1, v2, v0
if-ltz p1, :cond_1f
.line 1078
iput-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
return-void
.line 1081
:cond_1a
sput-wide v1, Lcom/imo/android/imoim/network/Dispatcher4;->CUR_MAXIMUM_RETRY_INTERVAL:J
return-void
.line 1084
:cond_1d
sput-wide v1, Lcom/imo/android/imoim/network/Dispatcher4;->CUR_MAXIMUM_RETRY_INTERVAL:J
:cond_1f
return-void
.end method
.method public onConnectStateChange(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;)V
.registers 3
.line 1164
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->connectStateMonitor:Lcom/imo/android/imoim/network/ConnectStateMonitor;
invoke-virtual {v0, p1}, Lcom/imo/android/imoim/network/ConnectStateMonitor;->onConnectStateChange(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;)V
return-void
.end method
.method public onMessageFromOtherThread(Ljava/lang/String;Lorg/json/JSONObject;ZJJ)V
.registers 19
.line 349
new-instance v10, Lcom/imo/android/imoim/network/Dispatcher4$MessageHolder;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v6
move-object v0, v10
move-object v1, p1
move-object v2, p2
move v3, p3
move-wide v4, p4
move-wide/from16 v8, p6
invoke-direct/range {v0 .. v9}, Lcom/imo/android/imoim/network/Dispatcher4$MessageHolder;-><init>(Ljava/lang/String;Lorg/json/JSONObject;ZJJJ)V
move-object v0, p0
.line 350
iget-object v1, v0, Lcom/imo/android/imoim/network/Dispatcher4;->handler:Landroid/os/Handler;
const/4 v2, 0x0
invoke-static {v1, v2, v10}, Landroid/os/Message;->obtain(Landroid/os/Handler;ILjava/lang/Object;)Landroid/os/Message;
move-result-object v2
invoke-virtual {v1, v2}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method public reconnect(Ljava/lang/String;Z)V
.registers 23
move-object/from16 v1, p0
move-object/from16 v11, p1
move/from16 v0, p2
const-string v12, "sendNameChannel"
.line 1089
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "reconnect "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " skipBackoff "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v3, " isconnecting "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-boolean v3, v1, Lcom/imo/android/imoim/network/Dispatcher4;->isConnecting:Z
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
const-string v3, "Dispatcher4"
.line 20071
invoke-static {v3, v2}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 1091
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v2
const/4 v13, 0x2
new-array v4, v13, [Ljava/lang/Object;
const/4 v14, 0x0
aput-object v11, v4, v14
.line 1092
invoke-static/range {p2 .. p2}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v5
const/4 v15, 0x1
aput-object v5, v4, v15
const-string v5, "reconnect reason=%s,skipBackoff=%s"
invoke-static {v5, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v4
.line 1091
invoke-virtual {v2, v3, v4}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
if-eqz v0, :cond_4d
.line 1094
invoke-virtual/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->resetBackoff()V
goto :goto_5a
.line 1095
:cond_4d
invoke-direct/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->shouldBackoff()Z
move-result v2
if-eqz v2, :cond_5a
.line 1096
invoke-direct/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->updateBackoff()V
.line 1097
invoke-direct/range {p0 .. p1}, Lcom/imo/android/imoim/network/Dispatcher4;->doBackoff(Ljava/lang/String;)V
return-void
.line 1111
:cond_5a
:goto_5a
invoke-direct/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->updateBackoff()V
.line 1113
iput-boolean v15, v1, Lcom/imo/android/imoim/network/Dispatcher4;->isConnecting:Z
.line 1114
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iput-wide v2, v1, Lcom/imo/android/imoim/network/Dispatcher4;->lastConnectTime:J
.line 1119
invoke-direct/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->cancelRetransmit()V
.line 1120
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v2
const-string v3, "com.imo.android.imoim.RECONNECT"
invoke-static {v3, v2}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;Landroid/content/Context;)V
.line 1123
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v2
const/4 v10, 0x0
const-wide/32 v8, 0xa028
const-string v3, "com.imo.android.imoim.TIMEOUT_TCP"
.line 1122
invoke-static {v3, v8, v9, v10, v2}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;JLjava/lang/String;Landroid/content/Context;)V
.line 1125
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
move-result-object v2
invoke-virtual {v2}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->cancelDoMonitorLikeeState()V
.line 1127
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
move-result-object v2
invoke-virtual {v2}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->log()V
.line 1129
invoke-direct/range {p0 .. p0}, Lcom/imo/android/imoim/network/Dispatcher4;->canUseGCM()Z
move-result v2
const/4 v7, 0x3
if-eqz v2, :cond_217
.line 1130
iget-object v2, v1, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v2, v11, v0}, Lcom/imo/android/imoim/network/NetworkManager;->reconnect(Ljava/lang/String;Z)V
.line 1131
iget-object v6, v1, Lcom/imo/android/imoim/network/Dispatcher4;->gcmNetwork:Lcom/imo/android/imoim/f;
.line 20075
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "connect reason: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " isConnecting "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-boolean v3, v6, Lcom/imo/android/imoim/f;->g:Z
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v3, " skipbackoff "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v3, " activityshowing "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v3, Lcom/imo/android/imoim/IMO;->o:Lcom/imo/android/imoim/managers/f;
.line 20077
invoke-virtual {v3}, Lcom/imo/android/imoim/managers/f;->d()Z
move-result v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
const-string v5, "GCMNetwork4"
.line 21071
invoke-static {v5, v2}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 20078
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v2
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "connect reason="
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, ",isConnecting="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-boolean v4, v6, Lcom/imo/android/imoim/f;->g:Z
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v4, ",skipbackoff="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v0, ",activityshowing="
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v0, Lcom/imo/android/imoim/IMO;->o:Lcom/imo/android/imoim/managers/f;
.line 20080
invoke-virtual {v0}, Lcom/imo/android/imoim/managers/f;->d()Z
move-result v0
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 20078
invoke-virtual {v2, v5, v0}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 20081
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
move-result-object v2
const/4 v0, -0x1
const/16 v16, 0x1
const/16 v17, 0x0
const/16 v18, 0x0
const-string v3, "local"
const-string v4, "gcm"
const-string v19, "gcm"
move-object v13, v5
move-object/from16 v5, v19
move-object v15, v6
move v6, v0
move-object/from16 v7, p1
move/from16 v8, v16
move/from16 v9, v17
move-object v0, v10
move-object/from16 v10, v18
invoke-virtual/range {v2 .. v10}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->markStart(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;ZZLjava/lang/String;)V
.line 20082
iput-object v11, v15, Lcom/imo/android/imoim/f;->d:Ljava/lang/String;
const-string v2, "timeout"
.line 20083
invoke-virtual {v11, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_130
.line 20084
iput-boolean v14, v15, Lcom/imo/android/imoim/f;->g:Z
.line 20087
:cond_130
iget-boolean v2, v15, Lcom/imo/android/imoim/f;->g:Z
if-eqz v2, :cond_150
.line 20088
invoke-static/range {p1 .. p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
const-string v3, "already connecting! "
invoke-virtual {v3, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v2
.line 22071
invoke-static {v13, v2}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 20089
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v2
invoke-static/range {p1 .. p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v13, v3}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 20093
:cond_150
invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;
move-result-object v2
const-string v3, "com.imo.android.imoim.TIMEOUT_GCM"
const-wide/32 v4, 0xa028
.line 20092
invoke-static {v3, v4, v5, v0, v2}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;JLjava/lang/String;Landroid/content/Context;)V
const/4 v2, 0x1
.line 20095
iput-boolean v2, v15, Lcom/imo/android/imoim/f;->g:Z
.line 20098
:try_start_15f
new-instance v0, Lorg/json/JSONObject;
:try_end_161
.catch Lorg/json/JSONException; {:try_start_15f .. :try_end_161} :catch_207
.catch Ljava/io/UnsupportedEncodingException; {:try_start_15f .. :try_end_161} :catch_1fc
:try_start_161
invoke-direct {v0}, Lorg/json/JSONObject;-><init>()V
const-string v2, "method"
const-string v3, "name_channel"
invoke-virtual {v0, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
move-result-object v0
const-string v2, "%s.0"
const/4 v3, 0x1
new-array v4, v3, [Ljava/lang/Object;
const/16 v3, 0x10
.line 20100
invoke-static {v3}, Lcom/imo/android/imoim/util/ei;->c(I)Ljava/lang/String;
move-result-object v3
aput-object v3, v4, v14
invoke-static {v2, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
iput-object v2, v15, Lcom/imo/android/imoim/f;->c:Ljava/lang/String;
.line 20101
new-instance v2, Lorg/json/JSONObject;
invoke-direct {v2}, Lorg/json/JSONObject;-><init>()V
const-string v3, "connection_id"
.line 20102
iget-object v4, v15, Lcom/imo/android/imoim/f;->c:Ljava/lang/String;
invoke-virtual {v2, v3, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v3, "sim_iso"
.line 20103
invoke-static {}, Lcom/imo/android/imoim/util/ei;->al()Ljava/lang/String;
move-result-object v4
invoke-virtual {v2, v3, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v3, "uid"
.line 20104
sget-object v4, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;
invoke-virtual {v4}, Lcom/imo/android/imoim/managers/c;->i()Ljava/lang/String;
move-result-object v4
invoke-virtual {v2, v3, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v3, "data"
.line 20105
invoke-virtual {v0, v3, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v2, "udid"
.line 20106
invoke-static {}, Lcom/imo/android/imoim/util/ei;->a()Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v2, "ssid"
.line 20107
sget-object v3, Lcom/imo/android/imoim/IMO;->c:Lcom/imo/android/imoim/network/Dispatcher4;
invoke-virtual {v3}, Lcom/imo/android/imoim/network/Dispatcher4;->getSSID()Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 20108
sget-object v2, Lcom/imo/android/imoim/IMO;->N:Lcom/imo/android/imoim/imodns/g;
.line 22167
iget-object v3, v2, Lcom/imo/android/imoim/imodns/g;->a:Lcom/imo/android/imoim/imodns/j;
:try_end_1bc
.catch Lorg/json/JSONException; {:try_start_161 .. :try_end_1bc} :catch_1f8
.catch Ljava/io/UnsupportedEncodingException; {:try_start_161 .. :try_end_1bc} :catch_1fc
const-wide/16 v4, 0x0
if-eqz v3, :cond_1c5
.line 22168
:try_start_1c0
iget-object v2, v2, Lcom/imo/android/imoim/imodns/g;->a:Lcom/imo/android/imoim/imodns/j;
.line 22248
iget-wide v2, v2, Lcom/imo/android/imoim/imodns/j;->h:J
goto :goto_1c6
:cond_1c5
move-wide v2, v4
:goto_1c6
cmp-long v6, v2, v4
if-lez v6, :cond_1cf
const-string v4, "gcm_backoff"
.line 20110
invoke-virtual {v0, v4, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
:try_end_1cf
.catch Lorg/json/JSONException; {:try_start_1c0 .. :try_end_1cf} :catch_207
.catch Ljava/io/UnsupportedEncodingException; {:try_start_1c0 .. :try_end_1cf} :catch_1fc
.line 20112
:cond_1cf
:try_start_1cf
invoke-virtual {v0}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
move-result-object v0
const-string v2, "UTF-8"
invoke-virtual {v0, v2}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v0
.line 24071
invoke-static {v13, v12}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 23195
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v2
invoke-virtual {v2, v13, v12}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 23196
iget-object v2, v15, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;
invoke-static {v0}, Lcom/imo/android/imoim/f;->a([B)Ljava/lang/String;
move-result-object v0
:try_end_1e9
.catch Lorg/json/JSONException; {:try_start_1cf .. :try_end_1e9} :catch_1f8
.catch Ljava/io/UnsupportedEncodingException; {:try_start_1cf .. :try_end_1e9} :catch_1fc
const/4 v3, 0x3
:try_start_1ea
invoke-virtual {v2, v3, v0}, Lcom/imo/android/imoim/f$b;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v0
.line 23197
iget-object v2, v15, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;
invoke-virtual {v2, v0}, Lcom/imo/android/imoim/f$b;->sendMessage(Landroid/os/Message;)Z
:try_end_1f3
.catch Lorg/json/JSONException; {:try_start_1ea .. :try_end_1f3} :catch_1f6
.catch Ljava/io/UnsupportedEncodingException; {:try_start_1ea .. :try_end_1f3} :catch_1f4
goto :goto_211
:catch_1f4
move-exception v0
goto :goto_1fe
:catch_1f6
move-exception v0
goto :goto_1fa
:catch_1f8
move-exception v0
const/4 v3, 0x3
:goto_1fa
const/4 v2, 0x1
goto :goto_20a
:catch_1fc
move-exception v0
const/4 v3, 0x3
.line 20116
:goto_1fe
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
const/4 v2, 0x1
.line 25079
invoke-static {v13, v0, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
goto :goto_211
:catch_207
move-exception v0
const/4 v2, 0x1
const/4 v3, 0x3
.line 20114
:goto_20a
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
.line 24079
invoke-static {v13, v0, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 1132
:goto_211
sget-object v0, Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;->TCP_AND_GCM_CONNECTING:Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;
invoke-virtual {v1, v0}, Lcom/imo/android/imoim/network/Dispatcher4;->onConnectStateChange(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;)V
goto :goto_222
:cond_217
const/4 v3, 0x3
.line 1134
iget-object v2, v1, Lcom/imo/android/imoim/network/Dispatcher4;->networkManager:Lcom/imo/android/imoim/network/NetworkManager;
invoke-virtual {v2, v11, v0}, Lcom/imo/android/imoim/network/NetworkManager;->reconnect(Ljava/lang/String;Z)V
.line 1135
sget-object v0, Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;->TCP_CONNECTING:Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;
invoke-virtual {v1, v0}, Lcom/imo/android/imoim/network/Dispatcher4;->onConnectStateChange(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectState;)V
:goto_222
const/4 v0, -0x1
.line 1138
invoke-virtual/range {p1 .. p1}, Ljava/lang/String;->hashCode()I
move-result v2
const/4 v4, 0x5
const/4 v5, 0x4
sparse-switch v2, :sswitch_data_284
goto :goto_268
:sswitch_22d
const-string v2, "got_token"
invoke-virtual {v11, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_268
const/4 v14, 0x4
goto :goto_269
:sswitch_237
const-string v2, "keep_alive_send"
invoke-virtual {v11, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_268
const/4 v14, 0x2
goto :goto_269
:sswitch_241
const-string v2, "keep_alive_recv"
invoke-virtual {v11, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_268
const/4 v14, 0x3
goto :goto_269
:sswitch_24b
const-string v2, "normal"
invoke-virtual {v11, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_268
goto :goto_269
:sswitch_254
const-string v2, "app_activity"
invoke-virtual {v11, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_268
const/4 v14, 0x1
goto :goto_269
:sswitch_25e
const-string v2, "network_change"
invoke-virtual {v11, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_268
const/4 v14, 0x5
goto :goto_269
:cond_268
:goto_268
const/4 v14, -0x1
:goto_269
if-eqz v14, :cond_282
const/4 v2, 0x1
if-eq v14, v2, :cond_282
const/4 v6, 0x2
if-eq v14, v6, :cond_282
if-eq v14, v3, :cond_282
if-eq v14, v5, :cond_282
if-eq v14, v4, :cond_282
.line 1147
invoke-static {}, Lcom/imo/android/imoim/util/ei;->I()Z
move-result v0
if-eqz v0, :cond_282
.line 1148
iget v0, v1, Lcom/imo/android/imoim/network/Dispatcher4;->tryCount:I
add-int/2addr v0, v2
iput v0, v1, Lcom/imo/android/imoim/network/Dispatcher4;->tryCount:I
:cond_282
return-void
nop
:sswitch_data_284
.sparse-switch
-0x787d791f -> :sswitch_25e
-0x6ecf8093 -> :sswitch_254
-0x3df94319 -> :sswitch_24b
0x2f752712 -> :sswitch_241
0x2f759cb4 -> :sswitch_237
0x53311486 -> :sswitch_22d
.end sparse-switch
.end method
.method public reconnectFromOtherThread(Ljava/lang/String;Z)V
.registers 5
.line 1061
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->handler:Landroid/os/Handler;
new-instance v1, Lcom/imo/android/imoim/network/Dispatcher4$6;
invoke-direct {v1, p0, p1, p2}, Lcom/imo/android/imoim/network/Dispatcher4$6;-><init>(Lcom/imo/android/imoim/network/Dispatcher4;Ljava/lang/String;Z)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method public registerConnectStateWatcher(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectStateWatcher;)V
.registers 3
.line 1156
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->connectStateMonitor:Lcom/imo/android/imoim/network/ConnectStateMonitor;
invoke-virtual {v0, p1}, Lcom/imo/android/imoim/network/ConnectStateMonitor;->registerWatcher(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectStateWatcher;)V
return-void
.end method
.method public reset(Ljava/lang/String;)V
.registers 6
.line 490
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v0
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
const-string v2, "reset reason="
invoke-virtual {v2, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
const-string v2, "Dispatcher4"
invoke-virtual {v0, v2, v1}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
const-string v0, "reset"
.line 8075
invoke-static {v2, v0}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 493
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->cancelRetransmit()V
const/4 v0, 0x0
.line 494
iput-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ssid:Ljava/lang/String;
.line 501
new-instance v1, Ljava/util/LinkedList;
invoke-direct {v1}, Ljava/util/LinkedList;-><init>()V
iput-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->outgoingQueue:Ljava/util/Queue;
.line 503
iget-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v1
invoke-interface {v1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v1
:cond_2f
:goto_2f
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_45
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
.line 504
iget-object v3, v2, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->timeoutCallback:Lb/a;
if-eqz v3, :cond_2f
.line 505
iget-object v2, v2, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->timeoutCallback:Lb/a;
invoke-virtual {v2, p1}, Lb/a;->a(Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_2f
.line 508
:cond_45
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
iput-object v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
const/4 v1, 0x0
.line 509
iput v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->seq:I
.line 512
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->createIncomingQueue()Ljava/util/Queue;
move-result-object v2
iput-object v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->incomingQueue:Ljava/util/Queue;
const/4 v2, -0x1
.line 513
iput v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->highestSeqSent:I
.line 514
iput v2, p0, Lcom/imo/android/imoim/network/Dispatcher4;->processedIncomingSeq:I
.line 515
iput v1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->ackRecv:I
.line 516
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->setupSession()V
.line 518
sget-object v1, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;
const/4 v2, 0x1
invoke-virtual {v1, p1, v2}, Lcom/imo/android/imoim/managers/c;->a(Ljava/lang/String;Z)V
.line 519
sget-object p1, Lcom/imo/android/imoim/IMO;->w:Lcom/imo/android/imoim/managers/i;
.line 8401
invoke-virtual {p1, v2, v0}, Lcom/imo/android/imoim/managers/i;->a(ILjava/lang/Object;)V
.line 520
sget-object p1, Lcom/imo/android/imoim/IMO;->x:Lcom/imo/android/imoim/managers/j;
invoke-virtual {p1}, Lcom/imo/android/imoim/managers/j;->b()V
return-void
.end method
.method public resetBackoff()V
.registers 3
const-wide/16 v0, 0x1f4
.line 1216
iput-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->backoff:J
return-void
.end method
.method public sendMessage(Ljava/lang/Object;Lb/a;Z)V
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Object;",
"Lb/a<",
"Lorg/json/JSONObject;",
"Ljava/lang/Void;",
">;Z)V"
}
.end annotation
.line 252
invoke-static {}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->get()Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
move-result-object v0
invoke-virtual {v0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->markAddSendMessageStart()V
.line 253
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
.line 254
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
.line 255
invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v2
const-string v3, "main"
invoke-virtual {v3, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-nez v2, :cond_23
const/4 v2, 0x1
const-string v3, "Dispatcher4"
const-string v4, "not main thread"
.line 2079
invoke-static {v3, v4, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 269
:cond_23
check-cast p1, Lcom/imo/android/imoim/util/y;
.line 271
invoke-direct {p0, p1, p2}, Lcom/imo/android/imoim/network/Dispatcher4;->addToOutgoingQueue(Lcom/imo/android/imoim/util/y;Lb/a;)V
const/4 p2, 0x0
.line 272
invoke-direct {p0, p2, p2, p3}, Lcom/imo/android/imoim/network/Dispatcher4;->sendMessagesToWebServer(ZZZ)V
.line 274
sget-object p2, Lcom/imo/android/imoim/network/mock/ProtoLogHelper;->INSTANCE:Lcom/imo/android/imoim/network/mock/ProtoLogHelper;
invoke-virtual {p2, p1}, Lcom/imo/android/imoim/network/mock/ProtoLogHelper;->sendData(Lcom/imo/android/imoim/util/y;)V
.line 276
invoke-static {}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->get()Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
move-result-object p1
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide p2
sub-long/2addr p2, v0
invoke-virtual {p1, p2, p3}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->addSendMessageEvent(J)V
return-void
.end method
.method public senderStarted(Ljava/lang/String;ZLcom/imo/android/imoim/network/ConnectData3;)V
.registers 13
.line 398
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
.line 400
iget-object v7, p0, Lcom/imo/android/imoim/network/Dispatcher4;->handler:Landroid/os/Handler;
new-instance v8, Lcom/imo/android/imoim/network/-$$Lambda$Dispatcher4$oSn5Le5D78deSu_DDIHo_CzOLIQ;
move-object v0, v8
move-object v1, p0
move-object v4, p1
move-object v5, p3
move v6, p2
invoke-direct/range {v0 .. v6}, Lcom/imo/android/imoim/network/-$$Lambda$Dispatcher4$oSn5Le5D78deSu_DDIHo_CzOLIQ;-><init>(Lcom/imo/android/imoim/network/Dispatcher4;JLjava/lang/String;Lcom/imo/android/imoim/network/ConnectData3;Z)V
invoke-virtual {v7, v8}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
.line 443
invoke-virtual {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->updateLastRecvTime()V
return-void
.end method
.method public start()V
.registers 4
.line 233
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v0
const-string v1, "Dispatcher4"
const-string v2, "start"
invoke-virtual {v0, v1, v2}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
const-string v0, "normal"
const/4 v1, 0x1
.line 234
invoke-virtual {p0, v0, v1}, Lcom/imo/android/imoim/network/Dispatcher4;->reconnect(Ljava/lang/String;Z)V
.line 235
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->scheduleKeepAlive()V
return-void
.end method
.method public storeCallback(Lb/a;Lb/a;Lcom/imo/android/imoim/managers/a/c;Ljava/lang/String;Ljava/lang/String;Z)Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lb/a<",
"Lorg/json/JSONObject;",
"Ljava/lang/Void;",
">;",
"Lb/a<",
"Ljava/lang/String;",
"Ljava/lang/Void;",
">;",
"Lcom/imo/android/imoim/managers/a/c;",
"Ljava/lang/String;",
"Ljava/lang/String;",
"Z)",
"Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;"
}
.end annotation
.line 294
invoke-direct {p0}, Lcom/imo/android/imoim/network/Dispatcher4;->generateRequestId()Ljava/lang/String;
move-result-object v0
.line 295
new-instance v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
invoke-direct {v1}, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;-><init>()V
.line 296
iput-object v0, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->requestId:Ljava/lang/String;
.line 297
iput-object p4, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->service:Ljava/lang/String;
.line 298
iput-object p5, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->method:Ljava/lang/String;
.line 299
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide p4
invoke-static {p4, p5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object p4
iput-object p4, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->requestTime:Ljava/lang/Long;
.line 300
iput-object p1, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->successCallback:Lb/a;
.line 301
iput-object p2, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->timeoutCallback:Lb/a;
.line 302
iput-object p3, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->sendRecvListener:Lcom/imo/android/imoim/managers/a/c;
.line 303
iput-boolean p6, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->backExtra:Z
.line 304
iget-object p1, p0, Lcom/imo/android/imoim/network/Dispatcher4;->requestInfoMap:Ljava/util/Map;
invoke-interface {p1, v0, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
return-object v1
.end method
.method public storeCallback(Lb/a;Lb/a;Ljava/lang/String;Ljava/lang/String;)Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
.registers 12
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lb/a<",
"Lorg/json/JSONObject;",
"Ljava/lang/Void;",
">;",
"Lb/a<",
"Ljava/lang/String;",
"Ljava/lang/Void;",
">;",
"Ljava/lang/String;",
"Ljava/lang/String;",
")",
"Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;"
}
.end annotation
const/4 v3, 0x0
const/4 v6, 0x0
move-object v0, p0
move-object v1, p1
move-object v2, p2
move-object v4, p3
move-object v5, p4
.line 286
invoke-virtual/range {v0 .. v6}, Lcom/imo/android/imoim/network/Dispatcher4;->storeCallback(Lb/a;Lb/a;Lcom/imo/android/imoim/managers/a/c;Ljava/lang/String;Ljava/lang/String;Z)Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
move-result-object p1
return-object p1
.end method
.method public storeCallback(Lb/a;Ljava/lang/String;Ljava/lang/String;)Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lb/a<",
"Lorg/json/JSONObject;",
"Ljava/lang/Void;",
">;",
"Ljava/lang/String;",
"Ljava/lang/String;",
")",
"Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;"
}
.end annotation
const/4 v0, 0x0
.line 281
invoke-virtual {p0, p1, v0, p2, p3}, Lcom/imo/android/imoim/network/Dispatcher4;->storeCallback(Lb/a;Lb/a;Ljava/lang/String;Ljava/lang/String;)Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
move-result-object p1
return-object p1
.end method
.method public switchToForeground(Z)V
.registers 3
.line 227
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->protoQueenMonitor:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;
if-eqz v0, :cond_7
.line 228
invoke-virtual {v0, p1}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->switchToForegroundAndMonitor(Z)V
:cond_7
return-void
.end method
.method public unregisterConnectStateWatcher(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectStateWatcher;)V
.registers 3
.line 1160
iget-object v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->connectStateMonitor:Lcom/imo/android/imoim/network/ConnectStateMonitor;
invoke-virtual {v0, p1}, Lcom/imo/android/imoim/network/ConnectStateMonitor;->unregisterWatcher(Lcom/imo/android/imoim/network/ConnectStateMonitor$ConnectStateWatcher;)V
return-void
.end method
.method public updateLastRecvTime()V
.registers 3
.line 1270
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastNetworkReceiveTime:J
.line 1271
invoke-static {v0, v1}, Lcom/imo/android/imoim/filetransfer/d/c;->a(J)V
return-void
.end method
.method public updateLastSendTime()V
.registers 3
.line 1329
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->lastNetworkSendTime:J
return-void
.end method
.method public usingGCM()Z
.registers 2
.line 1191
iget-boolean v0, p0, Lcom/imo/android/imoim/network/Dispatcher4;->usingGCM:Z
return v0
.end method