TcpProxySession.smali
.class public Lcom/quickbird/mini/vpn/proxy/TcpProxySession;
.super Ljava/lang/Object;
.source "TcpProxySession.java"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/quickbird/mini/vpn/proxy/TcpProxySession$TooManyEmptyWritesException;
}
.end annotation
# static fields
.field private static final BUFFER_SIZE:I = 0x1f9c
.field private static final DATA_INCOMEING:I = 0x1
.field private static final DATA_OUTGOING:I = 0x2
.field private static final DEBUG:Z
.field private static final EMPTY_WRITES_SLEEP:J = 0x1f4L
.field private static final MAX_EMPTY_WRITES_COUNT:I = 0x64
.field public static final OUTPUT_BUFFER_SIZE:I = 0x3f38
.field private static final SELECT_TIMEOUT:I = 0x2710
.field private static final TAG:Ljava/lang/String; = "QbSdk"
# instance fields
.field private mContext:Landroid/content/Context;
.field private mFirstEncrypt:Z
.field private mIncomingCache:[B
.field private mLocalChannel:Ljava/nio/channels/SocketChannel;
.field private mLocalHostName:Ljava/lang/String;
.field private mPkg:Ljava/lang/String;
.field private mRemoteChannel:Ljava/nio/channels/SocketChannel;
.field private mRemoteHostName:Ljava/lang/String;
.field private mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
.field private mSafeVpnEncryptKey:[B
.field private mSafeVpnRsaKey:[B
.field private mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
.field private mTargetAdr:Ljava/net/InetAddress;
.field private mTargetPort:I
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 56
sget-boolean v0, Lcom/quickbird/sdk/QuickBird;->SDK_DEBUG:Z
sput-boolean v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
return-void
.end method
.method public constructor <init>(Ljava/nio/channels/SocketChannel;Ljava/lang/String;Landroid/content/Context;Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;)V
.registers 14
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
.prologue
const/4 v8, 0x1
.line 83
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 211
iput-boolean v8, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mFirstEncrypt:Z
.line 85
iput-object p4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
.line 87
iput-object p1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
.line 88
iput-object p2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mPkg:Ljava/lang/String;
.line 89
iput-object p3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
.line 91
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->jniParseSocketCacheTime:J
.line 93
invoke-virtual {p1}, Ljava/nio/channels/SocketChannel;->socket()Ljava/net/Socket;
move-result-object v0
.line 94
invoke-virtual {v0}, Ljava/net/Socket;->getInetAddress()Ljava/net/InetAddress;
move-result-object v1
.line 95
invoke-virtual {v0}, Ljava/net/Socket;->getPort()I
move-result v0
.line 98
new-instance v2, Lcom/quickbird/mini/vpn/vpn/TcpSocketCache;
invoke-direct {v2, v0}, Lcom/quickbird/mini/vpn/vpn/TcpSocketCache;-><init>(I)V
.line 99
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/vpn/TcpSocketCache;->isUsed()Z
move-result v3
if-nez v3, :cond_54
.line 100
new-instance v2, Ljava/lang/Exception;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "SocketChannel not found in cache : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v1}, Ljava/net/InetAddress;->getHostAddress()Ljava/lang/String;
move-result-object v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v3, ":"
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v2, v0}, Ljava/lang/Exception;-><init>(Ljava/lang/String;)V
throw v2
.line 103
:cond_54
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/vpn/TcpSocketCache;->getRemoteIP()Ljava/net/InetAddress;
move-result-object v3
iput-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mTargetAdr:Ljava/net/InetAddress;
.line 104
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/vpn/TcpSocketCache;->getRemotePort()I
move-result v2
iput v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mTargetPort:I
.line 106
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v6, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->jniParseSocketCacheTime:J
sub-long/2addr v4, v6
iput-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->jniParseSocketCacheTime:J
.line 107
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v8, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->jniParseSocketCacheCount:I
.line 109
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mTargetAdr:Ljava/net/InetAddress;
invoke-virtual {v3}, Ljava/net/InetAddress;->getHostAddress()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, ":"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
iget v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mTargetPort:I
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
iput-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteHostName:Ljava/lang/String;
.line 110
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1}, Ljava/net/InetAddress;->getHostAddress()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ":"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalHostName:Ljava/lang/String;
.line 112
new-instance v0, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mPkg:Ljava/lang/String;
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-direct {v0, v1, v2, v3}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;-><init>(Ljava/lang/String;Landroid/content/Context;Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;)V
iput-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
.line 113
return-void
.end method
.method private establishRemoteConnection(Ljava/net/InetSocketAddress;)Ljava/nio/channels/SocketChannel;
.registers 12
.annotation build Landroid/annotation/TargetApi;
value = 0xe
.end annotation
.prologue
const-wide/16 v8, 0x0
const/4 v2, 0x0
const/4 v1, 0x1
.line 119
.line 123
:try_start_4
invoke-static {}, Ljava/nio/channels/SocketChannel;->open()Ljava/nio/channels/SocketChannel;
move-result-object v0
.line 126
invoke-static {}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->getInstance()Lcom/quickbird/mini/vpn/vpn/LocalVpnService;
move-result-object v3
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->socket()Ljava/net/Socket;
move-result-object v4
invoke-virtual {v3, v4}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->protect(Ljava/net/Socket;)Z
move-result v3
if-nez v3, :cond_10f
.line 127
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->close()V
.line 128
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v3, 0x1
iput v3, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->socketProtectExceptionCount:I
.line 129
new-instance v0, Ljava/io/IOException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Protect failed for remote "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteHostName:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v0, v3}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_39
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_39} :catch_39
.catchall {:try_start_4 .. :try_end_39} :catchall_157
.line 150
:catch_39
move-exception v0
.line 151
:try_start_3a
invoke-static {v0}, Lcom/quickbird/sdk/utils/QBLogger;->getExceptionInfo(Ljava/lang/Throwable;)[Ljava/lang/String;
move-result-object v0
.line 152
if-eqz v0, :cond_287
.line 153
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v3}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v3
if-eqz v3, :cond_1b0
.line 154
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v3, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "establish:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v0, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 155
const/4 v3, 0x1
aget-object v3, v0, v3
if-eqz v3, :cond_75
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timed out"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_96
:cond_75
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timedout"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_96
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timeout"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_96
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "time out"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-eqz v3, :cond_28a
.line 158
:cond_96
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-object v6, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v6, v6, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
sub-long/2addr v4, v6
iput-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 159
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v4, 0x1
iput v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
:try_end_a8
.catchall {:try_start_3a .. :try_end_a8} :catchall_157
.line 162
:goto_a8
:try_start_a8
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v3, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->exceptionsDetails:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "establish:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v0, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, " : "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x1
aget-object v0, v0, v5
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 185
:goto_d2
sget-object v0, Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;->TCP_SESSION_REMOTE_CONNECT_EXCEPTION:Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v0, v3}, Lcom/quickbird/mini/vpn/vpn/ErrorStorage;->incrementCounter(Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;Landroid/content/Context;)I
.line 188
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v0}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v0
if-eqz v0, :cond_f3
.line 190
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v0}, Lcom/quickbird/sdk/utils/QBStatsReporter;->getInstance(Landroid/content/Context;)Lcom/quickbird/sdk/utils/QBStatsReporter;
move-result-object v0
const-string v3, "qbsdk"
const-string v4, "vcot_error"
const/4 v5, 0x1
invoke-static {v5}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v5
invoke-virtual {v0, v3, v4, v5}, Lcom/quickbird/sdk/utils/QBStatsReporter;->reportEvent(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Number;)V
:try_end_f3
.catchall {:try_start_a8 .. :try_end_f3} :catchall_284
.line 195
:cond_f3
const/4 v0, 0x0
.line 197
if-nez v1, :cond_10e
.line 198
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 199
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 200
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 201
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 202
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 203
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
.line 207
:cond_10e
:goto_10e
return-object v0
.line 132
:cond_10f
:try_start_10f
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->socket()Ljava/net/Socket;
move-result-object v3
const/4 v4, 0x1
invoke-virtual {v3, v4}, Ljava/net/Socket;->setKeepAlive(Z)V
.line 133
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->socket()Ljava/net/Socket;
move-result-object v3
const/4 v4, 0x1
invoke-virtual {v3, v4}, Ljava/net/Socket;->setReuseAddress(Z)V
.line 135
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v3}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v3
if-eqz v3, :cond_174
.line 136
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iput-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 145
:cond_12f
:goto_12f
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->socket()Ljava/net/Socket;
move-result-object v3
invoke-virtual {v3, p1}, Ljava/net/Socket;->connect(Ljava/net/SocketAddress;)V
.line 147
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->finishConnect()Z
move-result v3
if-nez v3, :cond_196
.line 148
new-instance v0, Ljava/io/IOException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "finishConnect failed for remote "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteHostName:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v0, v3}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_157
.catch Ljava/lang/Exception; {:try_start_10f .. :try_end_157} :catch_39
.catchall {:try_start_10f .. :try_end_157} :catchall_157
.line 197
:catchall_157
move-exception v0
move v1, v2
:goto_159
if-nez v1, :cond_173
.line 198
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 199
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 200
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 201
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 202
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 203
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
:cond_173
throw v0
.line 138
:cond_174
:try_start_174
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v3, v4, v8
if-lez v3, :cond_185
.line 139
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iput-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
goto :goto_12f
.line 140
:cond_185
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v3, v4, v8
if-lez v3, :cond_12f
.line 141
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iput-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
:try_end_195
.catch Ljava/lang/Exception; {:try_start_174 .. :try_end_195} :catch_39
.catchall {:try_start_174 .. :try_end_195} :catchall_157
goto :goto_12f
.line 198
:cond_196
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 199
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 200
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 201
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 202
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 203
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
goto/16 :goto_10e
.line 164
:cond_1b0
:try_start_1b0
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v3, v4, v8
if-lez v3, :cond_21a
.line 165
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v3, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "establish:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v0, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 166
const/4 v3, 0x1
aget-object v3, v0, v3
if-eqz v3, :cond_1e5
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timed out"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_206
:cond_1e5
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timedout"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_206
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timeout"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_206
const/4 v3, 0x1
aget-object v0, v0, v3
const-string v3, "time out"
invoke-virtual {v0, v3}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_287
.line 169
:cond_206
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v6, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
sub-long/2addr v4, v6
iput-wide v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 170
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v3, 0x1
iput v3, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
goto/16 :goto_d2
.line 173
:cond_21a
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v3, v4, v8
if-lez v3, :cond_287
.line 174
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v3, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "establish:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v0, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 175
const/4 v3, 0x1
aget-object v3, v0, v3
if-eqz v3, :cond_24f
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timed out"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_270
:cond_24f
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timedout"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_270
const/4 v3, 0x1
aget-object v3, v0, v3
const-string v4, "timeout"
invoke-virtual {v3, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-nez v3, :cond_270
const/4 v3, 0x1
aget-object v0, v0, v3
const-string v3, "time out"
invoke-virtual {v0, v3}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_287
.line 178
:cond_270
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v6, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
sub-long/2addr v4, v6
iput-wide v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 179
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v3, 0x1
iput v3, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
:try_end_282
.catchall {:try_start_1b0 .. :try_end_282} :catchall_157
goto/16 :goto_d2
.line 197
:catchall_284
move-exception v0
goto/16 :goto_159
:cond_287
move v1, v2
goto/16 :goto_d2
:cond_28a
move v1, v2
goto/16 :goto_a8
.end method
.method private handleNewData(ILjava/lang/String;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;)Z
.registers 23
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.prologue
.line 216
const/4 v5, 0x0
.line 218
const/4 v2, 0x1
invoke-static {v2}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v8
.line 221
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v2
if-nez v2, :cond_1a
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isSafeVpnProxy()Z
move-result v2
if-eqz v2, :cond_39b
.line 222
:cond_1a
const/4 v2, 0x2
move/from16 v0, p1
if-ne v0, v2, :cond_3f0
.line 223
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v6
iput-wide v6, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->prepareHeaderTime:J
.line 225
const/16 v2, 0x1f9c
invoke-static {v2}, Ljava/nio/CharBuffer;->allocate(I)Ljava/nio/CharBuffer;
move-result-object v2
.line 226
const/16 v3, 0x3f38
invoke-static {v3}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v3
.line 227
const/4 v4, 0x0
invoke-static {v4}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v4
.line 228
move-object/from16 v0, p0
iget-object v6, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
move-object/from16 v0, p4
invoke-virtual {v6, v0, v4, v2, v3}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->onOutgoingBulk(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;Ljava/nio/CharBuffer;Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
move-result-object v4
.line 231
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isSafeVpnProxy()Z
move-result v2
if-eqz v2, :cond_3ed
.line 232
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v2}, Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;->getInstance(Landroid/content/Context;)Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;
move-result-object v2
.line 233
invoke-virtual {v4}, Ljava/nio/ByteBuffer;->remaining()I
move-result v3
new-array v3, v3, [B
.line 234
array-length v6, v3
.line 235
invoke-virtual {v4}, Ljava/nio/ByteBuffer;->array()[B
move-result-object v7
const/4 v9, 0x0
const/4 v10, 0x0
array-length v11, v3
invoke-static {v7, v9, v3, v10, v11}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 236
sget-boolean v7, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v7, :cond_83
.line 237
const-string v7, "QbSdk"
new-instance v9, Ljava/lang/StringBuilder;
invoke-direct {v9}, Ljava/lang/StringBuilder;-><init>()V
const-string v10, "==== Safe vpn proxy outgoing data. Src length == "
invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v9
invoke-virtual {v9, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v9
invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v9
invoke-static {v7, v9}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 239
:cond_83
move-object/from16 v0, p0
iget-object v7, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnRsaKey:[B
move-object/from16 v0, p0
iget-object v9, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnEncryptKey:[B
invoke-virtual {v2, v3, v7, v9}, Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;->encrypt([B[B[B)[Ljava/lang/Object;
move-result-object v7
.line 240
const/4 v2, 0x0
aget-object v2, v7, v2
check-cast v2, [B
check-cast v2, [B
.line 241
array-length v9, v2
.line 242
const/4 v3, 0x1
aget-object v3, v7, v3
check-cast v3, [B
check-cast v3, [B
move-object/from16 v0, p0
iput-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnRsaKey:[B
.line 243
const/4 v3, 0x2
aget-object v3, v7, v3
check-cast v3, [B
check-cast v3, [B
move-object/from16 v0, p0
iput-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnEncryptKey:[B
.line 244
invoke-virtual {v4}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;
.line 245
invoke-static {}, Lcom/quickbird/mini/utils/ProxyUtils;->getSafeVpnEncryptFlag()[B
move-result-object v4
.line 246
const/4 v7, 0x4
.line 247
move-object/from16 v0, p0
iget-boolean v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mFirstEncrypt:Z
if-eqz v3, :cond_24c
.line 248
array-length v10, v2
move-object/from16 v0, p0
iget-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnRsaKey:[B
if-nez v3, :cond_245
const/4 v3, 0x0
:goto_c3
add-int/2addr v3, v10
array-length v10, v4
add-int/2addr v3, v10
add-int/2addr v3, v7
invoke-static {v3}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v3
.line 250
invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
.line 251
move-object/from16 v0, p0
iget-object v4, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnRsaKey:[B
invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
.line 252
const/4 v4, 0x0
move-object/from16 v0, p0
iput-boolean v4, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mFirstEncrypt:Z
.line 256
:goto_da
int-to-short v4, v6
invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->putShort(S)Ljava/nio/ByteBuffer;
.line 257
int-to-short v4, v9
invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->putShort(S)Ljava/nio/ByteBuffer;
.line 258
invoke-virtual {v3, v2}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
.line 259
invoke-virtual {v3}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;
.line 260
sget-boolean v2, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v2, :cond_104
.line 261
const-string v2, "QbSdk"
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "==== Safe vpn proxy outgoing data. Encrypt finish. ==Encrypt length = "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v2, v4}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 265
:cond_104
:goto_104
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v6
move-object/from16 v0, p0
iget-object v4, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v10, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->prepareHeaderTime:J
sub-long/2addr v6, v10
iput-wide v6, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->prepareHeaderTime:J
.line 266
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v4, 0x1
iput v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->prepareHeaderCount:I
move-object v2, v3
.line 269
:goto_11d
const/4 v3, 0x1
move/from16 v0, p1
if-ne v0, v3, :cond_3ea
.line 270
move-object/from16 v0, p0
iget-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v3}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isSafeVpnProxy()Z
move-result v3
if-eqz v3, :cond_378
.line 271
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v10
.line 272
sget-boolean v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v3, :cond_150
.line 273
const-string v3, "QbSdk"
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "\uff0a\uff0a\uff0a\uff0a\uff0a=== Safe vpn proxy income data === : "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual/range {p4 .. p4}, Ljava/nio/ByteBuffer;->remaining()I
move-result v6
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v3, v4}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 275
:cond_150
const/4 v4, 0x0
.line 277
:try_start_151
move-object/from16 v0, p0
iget-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v3}, Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;->getInstance(Landroid/content/Context;)Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;
move-result-object v9
.line 278
invoke-virtual/range {p4 .. p4}, Ljava/nio/ByteBuffer;->remaining()I
move-result v3
new-array v6, v3, [B
.line 279
invoke-virtual/range {p4 .. p4}, Ljava/nio/ByteBuffer;->array()[B
move-result-object v3
const/4 v7, 0x0
const/4 v12, 0x0
array-length v13, v6
invoke-static {v3, v7, v6, v12, v13}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 280
invoke-virtual/range {p4 .. p4}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;
.line 282
move-object/from16 v0, p0
iget-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
if-eqz v3, :cond_3e7
move-object/from16 v0, p0
iget-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
array-length v3, v3
if-lez v3, :cond_3e7
.line 283
sget-boolean v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v3, :cond_19a
.line 284
const-string v3, "QbSdk"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string v12, "=== Has cache === : "
invoke-virtual {v7, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
move-object/from16 v0, p0
iget-object v12, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
array-length v12, v12
invoke-virtual {v7, v12}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-static {v3, v7}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 286
:cond_19a
array-length v3, v6
move-object/from16 v0, p0
iget-object v7, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
array-length v7, v7
add-int/2addr v3, v7
new-array v3, v3, [B
.line 287
move-object/from16 v0, p0
iget-object v7, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
const/4 v12, 0x0
const/4 v13, 0x0
move-object/from16 v0, p0
iget-object v14, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
array-length v14, v14
invoke-static {v7, v12, v3, v13, v14}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 288
const/4 v7, 0x0
move-object/from16 v0, p0
iget-object v12, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
array-length v12, v12
array-length v13, v6
invoke-static {v6, v7, v3, v12, v13}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 290
const/4 v6, 0x0
move-object/from16 v0, p0
iput-object v6, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
move-object v7, v3
.line 292
:goto_1c1
array-length v3, v7
invoke-static {v3}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v4
.line 293
const/4 v6, 0x0
.line 294
const/4 v3, 0x0
.line 295
:goto_1c8
array-length v12, v7
if-ge v6, v12, :cond_1de
.line 296
add-int/lit8 v12, v6, 0x3
array-length v13, v7
if-lt v12, v13, :cond_254
.line 298
array-length v3, v7
sub-int/2addr v3, v6
new-array v3, v3, [B
.line 299
const/4 v9, 0x0
array-length v12, v7
sub-int/2addr v12, v6
invoke-static {v7, v6, v3, v9, v12}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 300
move-object/from16 v0, p0
iput-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
.line 334
:cond_1de
:goto_1de
sget-boolean v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v3, :cond_1e9
.line 335
const-string v3, "QbSdk"
const-string v6, "=== Decode finish ==="
invoke-static {v3, v6}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
:try_end_1e9
.catch Ljava/lang/Exception; {:try_start_151 .. :try_end_1e9} :catch_290
.catchall {:try_start_151 .. :try_end_1e9} :catchall_2d5
.line 342
:cond_1e9
sget-boolean v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v3, :cond_20b
.line 343
const-string v3, "QbSdk"
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "=== Decode finish === use time : "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v12
sub-long v10, v12, v10
invoke-virtual {v6, v10, v11}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v3, v6}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 346
:cond_20b
:goto_20b
if-eqz v4, :cond_218
.line 347
invoke-virtual {v4}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;
.line 348
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2, v4}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->decodeRespondGrayList(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
move-result-object v2
:cond_218
move v3, v5
.line 355
:goto_219
invoke-virtual {v2}, Ljava/nio/ByteBuffer;->hasRemaining()Z
move-result v4
if-eqz v4, :cond_396
.line 356
move-object/from16 v0, p3
invoke-virtual {v0, v2}, Ljava/nio/channels/SocketChannel;->write(Ljava/nio/ByteBuffer;)I
move-result v4
if-gez v4, :cond_38e
.line 358
add-int/lit8 v3, v3, 0x1
.line 359
const/16 v5, 0x64
if-le v3, v5, :cond_385
.line 360
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
.line 361
const/4 v3, 0x0
aput-object p2, v2, v3
.line 362
const/4 v3, 0x0
invoke-static {v3}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
.line 363
new-instance v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession$TooManyEmptyWritesException;
const-string v4, "dstSocket [%s] is stuck on empty writes!"
invoke-static {v4, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
move-object/from16 v0, p0
invoke-direct {v3, v0, v2}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession$TooManyEmptyWritesException;-><init>(Lcom/quickbird/mini/vpn/proxy/TcpProxySession;Ljava/lang/String;)V
throw v3
.line 248
:cond_245
move-object/from16 v0, p0
iget-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnRsaKey:[B
array-length v3, v3
goto/16 :goto_c3
.line 254
:cond_24c
array-length v3, v2
add-int/2addr v3, v7
invoke-static {v3}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v3
goto/16 :goto_da
.line 303
:cond_254
:try_start_254
invoke-static {v7, v6}, Lcom/quickbird/mini/utils/ProxyUtils;->getShort([BI)S
move-result v12
.line 304
add-int/lit8 v13, v6, 0x2
invoke-static {v7, v13}, Lcom/quickbird/mini/utils/ProxyUtils;->getShort([BI)S
move-result v13
.line 306
const/16 v14, 0x1010
if-gt v13, v14, :cond_268
if-gt v12, v13, :cond_268
if-ltz v12, :cond_268
if-gez v13, :cond_2c0
.line 307
:cond_268
sget-boolean v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v3, :cond_1de
.line 308
const-string v3, "QbSdk"
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "%%%%%%%%%=== encyLen error === relLen : "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, v12}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v6
const-string v7, " ,encylen : "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, v13}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v3, v6}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
:try_end_28e
.catch Ljava/lang/Exception; {:try_start_254 .. :try_end_28e} :catch_290
.catchall {:try_start_254 .. :try_end_28e} :catchall_2d5
goto/16 :goto_1de
.line 337
:catch_290
move-exception v3
.line 338
:try_start_291
sget-boolean v6, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v6, :cond_29c
.line 339
const-string v6, "QbSdk"
const-string v7, "=== Safe vpn Proxy income data. Decrypt error!"
invoke-static {v6, v7, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:try_end_29c
.catchall {:try_start_291 .. :try_end_29c} :catchall_2d5
.line 342
:cond_29c
sget-boolean v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v3, :cond_20b
.line 343
const-string v3, "QbSdk"
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "=== Decode finish === use time : "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v12
sub-long v10, v12, v10
invoke-virtual {v6, v10, v11}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v3, v6}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
goto/16 :goto_20b
.line 312
:cond_2c0
:try_start_2c0
array-length v14, v7
sub-int/2addr v14, v6
add-int/lit8 v14, v14, -0x4
if-le v13, v14, :cond_2f8
.line 313
array-length v3, v7
sub-int/2addr v3, v6
new-array v3, v3, [B
.line 314
const/4 v9, 0x0
array-length v12, v3
invoke-static {v7, v6, v3, v9, v12}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 315
move-object/from16 v0, p0
iput-object v3, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mIncomingCache:[B
:try_end_2d3
.catch Ljava/lang/Exception; {:try_start_2c0 .. :try_end_2d3} :catch_290
.catchall {:try_start_2c0 .. :try_end_2d3} :catchall_2d5
goto/16 :goto_1de
.line 342
:catchall_2d5
move-exception v2
sget-boolean v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v3, :cond_2f7
.line 343
const-string v3, "QbSdk"
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "=== Decode finish === use time : "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v6
sub-long/2addr v6, v10
invoke-virtual {v4, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v3, v4}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
:cond_2f7
throw v2
.line 318
:cond_2f8
:try_start_2f8
new-array v14, v13, [B
.line 319
add-int/lit8 v15, v6, 0x4
const/16 v16, 0x0
array-length v0, v14
move/from16 v17, v0
move/from16 v0, v16
move/from16 v1, v17
invoke-static {v7, v15, v14, v0, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 320
array-length v15, v14
add-int/lit8 v15, v15, 0x4
add-int/2addr v6, v15
.line 322
sget-boolean v15, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v15, :cond_342
.line 323
const-string v15, "QbSdk"
new-instance v16, Ljava/lang/StringBuilder;
invoke-direct/range {v16 .. v16}, Ljava/lang/StringBuilder;-><init>()V
const-string v17, "=== decrypt times === : "
invoke-virtual/range {v16 .. v17}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v16
move-object/from16 v0, v16
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v16
const-string v17, " ,relLen : "
invoke-virtual/range {v16 .. v17}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v16
move-object/from16 v0, v16
invoke-virtual {v0, v12}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v12
const-string v16, " ,encylen : "
move-object/from16 v0, v16
invoke-virtual {v12, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v12
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v12
invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v12
invoke-static {v15, v12}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 326
:cond_342
move-object/from16 v0, p0
iget-object v12, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSafeVpnEncryptKey:[B
invoke-virtual {v9, v14, v12}, Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;->decrypt([B[B)[B
move-result-object v12
.line 327
sget-boolean v13, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v13, :cond_371
.line 328
const-string v13, "QbSdk"
new-instance v14, Ljava/lang/StringBuilder;
invoke-direct {v14}, Ljava/lang/StringBuilder;-><init>()V
const-string v15, "=== decrypt times finished === : "
invoke-virtual {v14, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v14
invoke-virtual {v14, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v14
const-string v15, " ,decrypt len : "
invoke-virtual {v14, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v14
array-length v15, v12
invoke-virtual {v14, v15}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v14
invoke-virtual {v14}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v14
invoke-static {v13, v14}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 330
:cond_371
add-int/lit8 v3, v3, 0x1
.line 332
invoke-virtual {v4, v12}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
:try_end_376
.catch Ljava/lang/Exception; {:try_start_2f8 .. :try_end_376} :catch_290
.catchall {:try_start_2f8 .. :try_end_376} :catchall_2d5
goto/16 :goto_1c8
.line 351
:cond_378
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
move-object/from16 v0, p4
invoke-virtual {v2, v0}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->decodeRespondGrayList(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
move-result-object v2
move v3, v5
goto/16 :goto_219
.line 365
:cond_385
rem-int/lit8 v5, v3, 0x3
if-nez v5, :cond_38e
.line 367
const-wide/16 v6, 0x1f4
:try_start_38b
invoke-static {v6, v7}, Ljava/lang/Thread;->sleep(J)V
:try_end_38e
.catch Ljava/lang/InterruptedException; {:try_start_38b .. :try_end_38e} :catch_3e5
.line 374
:cond_38e
:goto_38e
sget-wide v6, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->CURRENT_TRAFFIC_COUNT:J
int-to-long v4, v4
add-long/2addr v4, v6
sput-wide v4, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->CURRENT_TRAFFIC_COUNT:J
goto/16 :goto_219
.line 377
:cond_396
invoke-virtual {v8}, Ljava/lang/Boolean;->booleanValue()Z
move-result v2
.line 403
:goto_39a
return v2
.line 380
:cond_39b
const/4 v2, 0x1
move/from16 v0, p1
if-ne v0, v2, :cond_3aa
.line 381
move-object/from16 v0, p0
iget-object v2, v0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
move-object/from16 v0, p4
invoke-virtual {v2, v0}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->decodeRespondGrayList(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
move-result-object p4
.line 384
:cond_3aa
:goto_3aa
invoke-virtual/range {p4 .. p4}, Ljava/nio/ByteBuffer;->hasRemaining()Z
move-result v2
if-eqz v2, :cond_3e0
.line 385
invoke-virtual/range {p3 .. p4}, Ljava/nio/channels/SocketChannel;->write(Ljava/nio/ByteBuffer;)I
move-result v2
if-gez v2, :cond_3aa
.line 386
add-int/lit8 v5, v5, 0x1
.line 387
const/16 v2, 0x64
if-le v5, v2, :cond_3d4
.line 388
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
.line 389
const/4 v3, 0x0
aput-object p2, v2, v3
.line 390
const/4 v3, 0x0
invoke-static {v3}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
.line 391
new-instance v3, Lcom/quickbird/mini/vpn/proxy/TcpProxySession$TooManyEmptyWritesException;
const-string v4, "dstSocket [%s] is stuck on empty writes!"
invoke-static {v4, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
move-object/from16 v0, p0
invoke-direct {v3, v0, v2}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession$TooManyEmptyWritesException;-><init>(Lcom/quickbird/mini/vpn/proxy/TcpProxySession;Ljava/lang/String;)V
throw v3
.line 393
:cond_3d4
rem-int/lit8 v2, v5, 0x3
.line 394
if-nez v2, :cond_3aa
.line 396
const-wide/16 v2, 0x1f4
:try_start_3da
invoke-static {v2, v3}, Ljava/lang/Thread;->sleep(J)V
:try_end_3dd
.catch Ljava/lang/InterruptedException; {:try_start_3da .. :try_end_3dd} :catch_3de
goto :goto_3aa
.line 397
:catch_3de
move-exception v2
goto :goto_3aa
.line 403
:cond_3e0
invoke-virtual {v8}, Ljava/lang/Boolean;->booleanValue()Z
move-result v2
goto :goto_39a
.line 368
:catch_3e5
move-exception v5
goto :goto_38e
:cond_3e7
move-object v7, v6
goto/16 :goto_1c1
:cond_3ea
move v3, v5
goto/16 :goto_219
:cond_3ed
move-object v3, v4
goto/16 :goto_104
:cond_3f0
move-object/from16 v2, p4
goto/16 :goto_11d
.end method
.method private pump(Ljava/nio/channels/SocketChannel;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;)V
.registers 14
.prologue
.line 410
const/4 v0, 0x1
.line 412
const/4 v1, 0x0
.line 414
:try_start_2
invoke-static {}, Ljava/nio/channels/Selector;->open()Ljava/nio/channels/Selector;
:try_end_5
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_5} :catch_133
.catchall {:try_start_2 .. :try_end_5} :catchall_fd
move-result-object v6
.line 415
const/4 v1, 0x1
:try_start_7
invoke-virtual {p1, v6, v1}, Ljava/nio/channels/SocketChannel;->register(Ljava/nio/channels/Selector;I)Ljava/nio/channels/SelectionKey;
move-result-object v7
.line 416
const/4 v1, 0x1
invoke-virtual {p2, v6, v1}, Ljava/nio/channels/SocketChannel;->register(Ljava/nio/channels/Selector;I)Ljava/nio/channels/SelectionKey;
move-result-object v8
move v1, v0
.line 418
:cond_11
:goto_11
if-eqz v1, :cond_cd
.line 419
const-wide/16 v2, 0x2710
invoke-virtual {v6, v2, v3}, Ljava/nio/channels/Selector;->select(J)I
move-result v0
.line 420
if-lez v0, :cond_bb
.line 421
invoke-virtual {v6}, Ljava/nio/channels/Selector;->selectedKeys()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v9
.line 423
invoke-interface {v9}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_136
.line 424
invoke-interface {v9}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/nio/channels/SelectionKey;
.line 426
if-ne v0, v7, :cond_47
.line 428
invoke-virtual {v0}, Ljava/nio/channels/SelectionKey;->isReadable()Z
move-result v0
if-eqz v0, :cond_136
.line 429
const/4 v1, 0x2
iget-object v5, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteHostName:Ljava/lang/String;
move-object v0, p0
move-object v2, p1
move-object v3, p2
move-object v4, p3
invoke-direct/range {v0 .. v5}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->pumpBulk(ILjava/nio/channels/SocketChannel;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;Ljava/lang/String;)Z
move-result v0
.line 430
invoke-interface {v9}, Ljava/util/Iterator;->remove()V
:goto_45
move v1, v0
.line 440
goto :goto_11
.line 432
:cond_47
if-ne v0, v8, :cond_136
.line 434
invoke-virtual {v0}, Ljava/nio/channels/SelectionKey;->isReadable()Z
move-result v0
if-eqz v0, :cond_136
.line 435
const/4 v1, 0x1
iget-object v5, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalHostName:Ljava/lang/String;
move-object v0, p0
move-object v2, p2
move-object v3, p1
move-object v4, p3
invoke-direct/range {v0 .. v5}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->pumpBulk(ILjava/nio/channels/SocketChannel;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;Ljava/lang/String;)Z
move-result v0
.line 436
invoke-interface {v9}, Ljava/util/Iterator;->remove()V
:try_end_5d
.catch Ljava/io/IOException; {:try_start_7 .. :try_end_5d} :catch_5e
.catchall {:try_start_7 .. :try_end_5d} :catchall_130
goto :goto_45
.line 447
:catch_5e
move-exception v0
move-object v1, v6
.line 448
:goto_60
:try_start_60
invoke-static {v0}, Lcom/quickbird/sdk/utils/QBLogger;->getExceptionInfo(Ljava/lang/Throwable;)[Ljava/lang/String;
move-result-object v0
.line 449
if-eqz v0, :cond_b5
.line 450
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v2
if-eqz v2, :cond_d5
.line 451
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x0
aget-object v4, v0, v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 452
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->exceptionsDetails:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x0
aget-object v4, v0, v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string v4, " : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x1
aget-object v0, v0, v4
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
:try_end_b5
.catchall {:try_start_60 .. :try_end_b5} :catchall_fd
.line 463
:cond_b5
:goto_b5
if-eqz v1, :cond_ba
.line 465
:try_start_b7
invoke-virtual {v1}, Ljava/nio/channels/Selector;->close()V
:try_end_ba
.catch Ljava/io/IOException; {:try_start_b7 .. :try_end_ba} :catch_12c
.line 471
:cond_ba
:goto_ba
return-void
.line 441
:cond_bb
:try_start_bb
invoke-virtual {p1}, Ljava/nio/channels/SocketChannel;->isOpen()Z
move-result v0
if-eqz v0, :cond_c7
invoke-virtual {p2}, Ljava/nio/channels/SocketChannel;->isOpen()Z
move-result v0
if-nez v0, :cond_11
.line 442
:cond_c7
invoke-virtual {v6}, Ljava/nio/channels/Selector;->close()V
:try_end_ca
.catch Ljava/io/IOException; {:try_start_bb .. :try_end_ca} :catch_5e
.catchall {:try_start_bb .. :try_end_ca} :catchall_130
.line 443
const/4 v1, 0x0
goto/16 :goto_11
.line 463
:cond_cd
if-eqz v6, :cond_ba
.line 465
:try_start_cf
invoke-virtual {v6}, Ljava/nio/channels/Selector;->close()V
:try_end_d2
.catch Ljava/io/IOException; {:try_start_cf .. :try_end_d2} :catch_d3
goto :goto_ba
.line 466
:catch_d3
move-exception v0
goto :goto_ba
.line 454
:cond_d5
:try_start_d5
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
const-wide/16 v4, 0x0
cmp-long v2, v2, v4
if-lez v2, :cond_104
.line 455
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x0
aget-object v0, v0, v4
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
:try_end_fc
.catchall {:try_start_d5 .. :try_end_fc} :catchall_fd
goto :goto_b5
.line 463
:catchall_fd
move-exception v0
:goto_fe
if-eqz v1, :cond_103
.line 465
:try_start_100
invoke-virtual {v1}, Ljava/nio/channels/Selector;->close()V
:try_end_103
.catch Ljava/io/IOException; {:try_start_100 .. :try_end_103} :catch_12e
.line 467
:cond_103
:goto_103
throw v0
.line 456
:cond_104
:try_start_104
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
const-wide/16 v4, 0x0
cmp-long v2, v2, v4
if-lez v2, :cond_b5
.line 457
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x0
aget-object v0, v0, v4
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
:try_end_12b
.catchall {:try_start_104 .. :try_end_12b} :catchall_fd
goto :goto_b5
.line 466
:catch_12c
move-exception v0
goto :goto_ba
:catch_12e
move-exception v1
goto :goto_103
.line 463
:catchall_130
move-exception v0
move-object v1, v6
goto :goto_fe
.line 447
:catch_133
move-exception v0
goto/16 :goto_60
:cond_136
move v0, v1
goto/16 :goto_45
.end method
.method private pumpBulk(ILjava/nio/channels/SocketChannel;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;Ljava/lang/String;)Z
.registers 16
.prologue
const-wide/16 v8, 0x0
const/4 v0, 0x1
const/4 v1, 0x0
.line 475
.line 476
invoke-virtual {p4}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;
.line 479
:try_start_7
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v2
if-eqz v2, :cond_7f
.line 480
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iput-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 489
:cond_17
:goto_17
invoke-virtual {p2, p4}, Ljava/nio/channels/SocketChannel;->read(Ljava/nio/ByteBuffer;)I
move-result v2
if-gtz v2, :cond_17
.line 490
invoke-virtual {p4}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;
.line 491
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isSafeVpnProxy()Z
move-result v2
if-eqz v2, :cond_51
.line 492
const-string v3, "QbSdk"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Read len : "
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {p4}, Ljava/nio/ByteBuffer;->remaining()I
move-result v4
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v2
const-string v4, " ,Is incoming : "
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
if-ne p1, v0, :cond_1ae
move v2, v0
:goto_46
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v3, v2}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 495
:cond_51
invoke-virtual {p4}, Ljava/nio/ByteBuffer;->hasRemaining()Z
move-result v2
if-eqz v2, :cond_313
.line 496
invoke-direct {p0, p1, p5, p3, p4}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->handleNewData(ILjava/lang/String;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;)Z
.line 498
invoke-virtual {p4}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;
move v2, v1
.line 502
:goto_5e
if-nez v2, :cond_1b1
.line 503
invoke-virtual {p2}, Ljava/nio/channels/SocketChannel;->isOpen()Z
:try_end_63
.catch Ljava/net/SocketException; {:try_start_7 .. :try_end_63} :catch_90
.catch Ljava/lang/Exception; {:try_start_7 .. :try_end_63} :catch_160
.catchall {:try_start_7 .. :try_end_63} :catchall_2c7
move-result v2
if-eqz v2, :cond_1b1
.line 562
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 563
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 564
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 565
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 566
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 567
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
.line 570
:goto_7e
return v0
.line 482
:cond_7f
:try_start_7f
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v2, v2, v8
if-lez v2, :cond_14e
.line 483
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iput-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
:try_end_8f
.catch Ljava/net/SocketException; {:try_start_7f .. :try_end_8f} :catch_90
.catch Ljava/lang/Exception; {:try_start_7f .. :try_end_8f} :catch_160
.catchall {:try_start_7f .. :try_end_8f} :catchall_2c7
goto :goto_17
.line 506
:catch_90
move-exception v2
.line 507
:try_start_91
invoke-static {v2}, Lcom/quickbird/sdk/utils/QBLogger;->getExceptionInfo(Ljava/lang/Throwable;)[Ljava/lang/String;
move-result-object v3
.line 508
if-eqz v3, :cond_30d
.line 509
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v2
if-eqz v2, :cond_1ca
.line 510
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "bulk:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v3, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v2, v4}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 511
const/4 v2, 0x1
aget-object v2, v3, v2
if-eqz v2, :cond_cc
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timed out"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_ed
:cond_cc
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timedout"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_ed
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timeout"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_ed
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "time out"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_310
.line 514
:cond_ed
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-object v6, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v6, v6, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
sub-long/2addr v4, v6
iput-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 515
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v4, 0x1
iput v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
:try_end_ff
.catchall {:try_start_91 .. :try_end_ff} :catchall_2c7
move v2, v0
.line 518
:goto_100
:try_start_100
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->exceptionsDetails:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "bulk:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v3, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, " : "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x1
aget-object v3, v3, v5
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 541
:goto_12a
sget-object v0, Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;->TCP_SESSION_PUMP_EXCEPTION:Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v0, v3}, Lcom/quickbird/mini/vpn/vpn/ErrorStorage;->incrementCounter(Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;Landroid/content/Context;)I
:try_end_131
.catchall {:try_start_100 .. :try_end_131} :catchall_30b
.line 561
if-nez v2, :cond_14b
.line 562
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 563
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 564
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 565
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 566
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 567
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
:cond_14b
move v0, v1
goto/16 :goto_7e
.line 484
:cond_14e
:try_start_14e
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
cmp-long v2, v2, v8
if-lez v2, :cond_17
.line 485
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iput-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
:try_end_15e
.catch Ljava/net/SocketException; {:try_start_14e .. :try_end_15e} :catch_90
.catch Ljava/lang/Exception; {:try_start_14e .. :try_end_15e} :catch_160
.catchall {:try_start_14e .. :try_end_15e} :catchall_2c7
goto/16 :goto_17
.line 545
:catch_160
move-exception v0
.line 546
:try_start_161
invoke-static {v0}, Lcom/quickbird/sdk/utils/QBLogger;->getExceptionInfo(Ljava/lang/Throwable;)[Ljava/lang/String;
move-result-object v0
.line 547
if-eqz v0, :cond_18c
.line 548
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v2
if-eqz v2, :cond_2a0
.line 549
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "bulk:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x0
aget-object v0, v0, v4
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 558
:cond_18c
:goto_18c
sget-object v0, Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;->TCP_SESSION_PUMP_EXCEPTION:Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v0, v2}, Lcom/quickbird/mini/vpn/vpn/ErrorStorage;->incrementCounter(Lcom/quickbird/mini/vpn/vpn/ErrorStorage$ErrorType;Landroid/content/Context;)I
:try_end_193
.catchall {:try_start_161 .. :try_end_193} :catchall_2c7
.line 562
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 563
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 564
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 565
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 566
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 567
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
:goto_1ab
move v0, v1
.line 570
goto/16 :goto_7e
:cond_1ae
move v2, v1
.line 492
goto/16 :goto_46
.line 562
:cond_1b1
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 563
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 564
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 565
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 566
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 567
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
goto :goto_1ab
.line 520
:cond_1ca
:try_start_1ca
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v2, v4, v8
if-lez v2, :cond_235
.line 521
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "bulk:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v3, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v2, v4}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 522
const/4 v2, 0x1
aget-object v2, v3, v2
if-eqz v2, :cond_1ff
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timed out"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_220
:cond_1ff
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timedout"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_220
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timeout"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_220
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v3, "time out"
invoke-virtual {v2, v3}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_30d
.line 525
:cond_220
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v6, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
sub-long/2addr v4, v6
iput-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 526
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v3, 0x1
iput v3, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
move v2, v0
.line 527
goto/16 :goto_12a
.line 529
:cond_235
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v2, v4, v8
if-lez v2, :cond_30d
.line 530
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "bulk:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const/4 v5, 0x0
aget-object v5, v3, v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v2, v4}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 531
const/4 v2, 0x1
aget-object v2, v3, v2
if-eqz v2, :cond_26a
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timed out"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_28b
:cond_26a
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timedout"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_28b
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v4, "timeout"
invoke-virtual {v2, v4}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_28b
const/4 v2, 0x1
aget-object v2, v3, v2
const-string v3, "time out"
invoke-virtual {v2, v3}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_30d
.line 534
:cond_28b
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
iget-object v3, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v6, v3, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
sub-long/2addr v4, v6
iput-wide v4, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 535
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v3, 0x1
iput v3, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
move v2, v0
.line 536
goto/16 :goto_12a
.line 551
:cond_2a0
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v2, v2, v8
if-lez v2, :cond_2e4
.line 552
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "bulk:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x0
aget-object v0, v0, v4
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
:try_end_2c5
.catchall {:try_start_1ca .. :try_end_2c5} :catchall_2c7
goto/16 :goto_18c
.line 561
:catchall_2c7
move-exception v0
move v2, v1
:goto_2c9
if-nez v2, :cond_2e3
.line 562
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutTime:J
.line 563
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyTimeoutCount:I
.line 564
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutTime:J
.line 565
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnTimeoutCount:I
.line 566
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v8, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutTime:J
.line 567
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v1, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiTimeoutCount:I
:cond_2e3
throw v0
.line 553
:cond_2e4
:try_start_2e4
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v2, v2, v8
if-lez v2, :cond_18c
.line 554
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "bulk:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const/4 v4, 0x0
aget-object v0, v0, v4
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
:try_end_309
.catchall {:try_start_2e4 .. :try_end_309} :catchall_2c7
goto/16 :goto_18c
.line 561
:catchall_30b
move-exception v0
goto :goto_2c9
:cond_30d
move v2, v1
goto/16 :goto_12a
:cond_310
move v2, v1
goto/16 :goto_100
:cond_313
move v2, v0
goto/16 :goto_5e
.end method
.method private runSession()V
.registers 16
.prologue
const-wide/16 v12, 0x0
const/4 v7, 0x0
const/4 v6, 0x1
.line 613
new-instance v3, Ljava/net/InetSocketAddress;
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mTargetAdr:Ljava/net/InetAddress;
iget v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mTargetPort:I
invoke-direct {v3, v0, v1}, Ljava/net/InetSocketAddress;-><init>(Ljava/net/InetAddress;I)V
.line 615
invoke-virtual {v3}, Ljava/net/InetSocketAddress;->isUnresolved()Z
move-result v0
if-eqz v0, :cond_1c
.line 616
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->targetAddressUnresolvedCount:I
.line 618
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v12, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->localRequestTime:J
.line 737
:cond_1b
:goto_1b
return-void
.line 623
:cond_1c
const/16 v0, 0x1f9c
invoke-static {v0}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v5
.line 625
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v8
iput-wide v8, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->matchNameListTime:J
.line 628
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mPkg:Ljava/lang/String;
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
invoke-virtual/range {v0 .. v5}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->onNewConnection(Landroid/content/Context;Ljava/lang/String;Ljava/net/InetSocketAddress;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;)Ljava/net/InetSocketAddress;
move-result-object v0
.line 631
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v8
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v10, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->matchNameListTime:J
sub-long/2addr v8, v10
iput-wide v8, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->matchNameListTime:J
.line 632
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v6, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->matchNameListCount:I
.line 634
if-eqz v0, :cond_4f
invoke-virtual {v0}, Ljava/net/InetSocketAddress;->getAddress()Ljava/net/InetAddress;
move-result-object v1
if-nez v1, :cond_50
:cond_4f
move-object v0, v3
.line 637
:cond_50
invoke-virtual {v5}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;
.line 638
if-eq v0, v3, :cond_7a
.line 639
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0}, Ljava/net/InetSocketAddress;->getAddress()Ljava/net/InetAddress;
move-result-object v2
invoke-virtual {v2}, Ljava/net/InetAddress;->getHostAddress()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ":"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v0}, Ljava/net/InetSocketAddress;->getPort()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
iput-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteHostName:Ljava/lang/String;
.line 643
:cond_7a
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v8, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->localRequestTime:J
sub-long/2addr v2, v8
iput-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->localRequestTime:J
.line 644
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v6, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->localRequestCount:I
.line 646
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v1}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v1
if-eqz v1, :cond_19c
.line 647
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iput-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
.line 657
:cond_9b
:goto_9b
invoke-direct {p0, v0}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->establishRemoteConnection(Ljava/net/InetSocketAddress;)Ljava/nio/channels/SocketChannel;
move-result-object v0
iput-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
.line 658
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
if-eqz v0, :cond_1b
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
if-eqz v0, :cond_1b
.line 660
:try_start_a9
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
const/4 v1, 0x0
invoke-virtual {v0, v1}, Ljava/nio/channels/SocketChannel;->configureBlocking(Z)Ljava/nio/channels/SelectableChannel;
.line 661
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
const/4 v1, 0x0
invoke-virtual {v0, v1}, Ljava/nio/channels/SocketChannel;->configureBlocking(Z)Ljava/nio/channels/SelectableChannel;
.line 663
invoke-virtual {v5}, Ljava/nio/ByteBuffer;->hasRemaining()Z
move-result v0
if-eqz v0, :cond_207
.line 664
const/4 v0, 0x2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteHostName:Ljava/lang/String;
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-direct {p0, v0, v1, v2, v5}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->handleNewData(ILjava/lang/String;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;)Z
:try_end_c3
.catch Ljava/io/IOException; {:try_start_a9 .. :try_end_c3} :catch_2a0
move-result v1
.line 666
:try_start_c4
invoke-virtual {v5}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;
.line 667
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->isOpen()Z
move-result v0
if-eqz v0, :cond_d7
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-virtual {v0}, Ljava/nio/channels/SocketChannel;->isOpen()Z
:try_end_d4
.catch Ljava/io/IOException; {:try_start_c4 .. :try_end_d4} :catch_2a5
move-result v0
if-nez v0, :cond_d8
:cond_d7
move v1, v7
.line 671
:cond_d8
if-eqz v1, :cond_1b
.line 672
:try_start_da
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-direct {p0, v0, v2, v5}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->pump(Ljava/nio/channels/SocketChannel;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;)V
.line 673
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v0}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v0
if-eqz v0, :cond_1bb
.line 674
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-nez v0, :cond_1b
.line 675
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v8, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
sub-long/2addr v2, v8
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
.line 676
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v2, 0x1
iput v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessCount:I
:try_end_105
.catch Ljava/io/IOException; {:try_start_da .. :try_end_105} :catch_107
goto/16 :goto_1b
.line 695
:catch_107
move-exception v0
move-object v14, v0
move v0, v1
move-object v1, v14
.line 696
:goto_10b
invoke-static {v1}, Lcom/quickbird/sdk/utils/QBLogger;->getExceptionInfo(Ljava/lang/Throwable;)[Ljava/lang/String;
move-result-object v1
.line 697
if-eqz v1, :cond_15d
.line 698
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v2}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v2
if-eqz v2, :cond_20a
.line 699
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
aget-object v4, v1, v7
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 700
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->exceptionsDetails:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
aget-object v4, v1, v7
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string v4, " : "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
aget-object v1, v1, v6
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 711
:cond_15d
:goto_15d
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
invoke-virtual {v1}, Ljava/nio/channels/SocketChannel;->isOpen()Z
move-result v1
if-eqz v1, :cond_16d
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-virtual {v1}, Ljava/nio/channels/SocketChannel;->isOpen()Z
move-result v1
if-nez v1, :cond_16e
:cond_16d
move v0, v7
.line 715
:cond_16e
if-eqz v0, :cond_1b
.line 716
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-direct {p0, v0, v1, v5}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->pump(Ljava/nio/channels/SocketChannel;Ljava/nio/channels/SocketChannel;Ljava/nio/ByteBuffer;)V
.line 717
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v0}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v0
if-eqz v0, :cond_256
.line 718
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-nez v0, :cond_1b
.line 719
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
.line 720
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessCount:I
goto/16 :goto_1b
.line 649
:cond_19c
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v1}, Lcom/quickbird/sdk/utils/QBNetworkUtils;->getSimpleNetworkType(Landroid/content/Context;)I
move-result v1
.line 650
const/4 v2, 0x4
if-ne v1, v2, :cond_1af
.line 651
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iput-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
goto/16 :goto_9b
.line 652
:cond_1af
if-ne v1, v6, :cond_9b
.line 653
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iput-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
goto/16 :goto_9b
.line 679
:cond_1bb
:try_start_1bb
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v0, v2, v12
if-lez v0, :cond_1e1
.line 680
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-nez v0, :cond_1b
.line 681
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v8, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
sub-long/2addr v2, v8
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
.line 682
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v2, 0x1
iput v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessCount:I
goto/16 :goto_1b
.line 684
:cond_1e1
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v0, v2, v12
if-lez v0, :cond_1b
.line 685
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-nez v0, :cond_1b
.line 686
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v8, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
sub-long/2addr v2, v8
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
.line 687
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v2, 0x1
iput v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessCount:I
:try_end_205
.catch Ljava/io/IOException; {:try_start_1bb .. :try_end_205} :catch_107
goto/16 :goto_1b
:cond_207
move v0, v6
.line 709
goto/16 :goto_15d
.line 702
:cond_20a
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v2, v2, v12
if-lez v2, :cond_230
.line 703
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
aget-object v1, v1, v7
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
goto/16 :goto_15d
.line 704
:cond_230
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v2, v2, v12
if-lez v2, :cond_15d
.line 705
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v2, v2, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "pump:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
aget-object v1, v1, v7
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
goto/16 :goto_15d
.line 723
:cond_256
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v0, v0, v12
if-lez v0, :cond_27b
.line 724
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-nez v0, :cond_1b
.line 725
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
.line 726
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessCount:I
goto/16 :goto_1b
.line 728
:cond_27b
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v0, v0, v12
if-lez v0, :cond_1b
.line 729
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-nez v0, :cond_1b
.line 730
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
.line 731
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessCount:I
goto/16 :goto_1b
.line 695
:catch_2a0
move-exception v0
move-object v1, v0
move v0, v6
goto/16 :goto_10b
:catch_2a5
move-exception v0
move-object v14, v0
move v0, v1
move-object v1, v14
goto/16 :goto_10b
.end method
.method private safeClose(Ljava/nio/channels/SocketChannel;)V
.registers 4
.prologue
.line 741
if-eqz p1, :cond_e
.line 742
:try_start_2
invoke-virtual {p1}, Ljava/nio/channels/SocketChannel;->socket()Ljava/net/Socket;
:try_end_5
.catch Ljava/lang/Exception; {:try_start_2 .. :try_end_5} :catch_18
move-result-object v0
.line 744
if-eqz v0, :cond_b
.line 745
:try_start_8
invoke-virtual {v0}, Ljava/net/Socket;->close()V
:try_end_b
.catch Ljava/io/IOException; {:try_start_8 .. :try_end_b} :catch_f
.catch Ljava/lang/Exception; {:try_start_8 .. :try_end_b} :catch_18
.line 750
:cond_b
:goto_b
:try_start_b
invoke-virtual {p1}, Ljava/nio/channels/SocketChannel;->close()V
.line 755
:cond_e
:goto_e
return-void
.line 747
:catch_f
move-exception v0
.line 748
sget-boolean v1, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v1, :cond_b
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
:try_end_17
.catch Ljava/lang/Exception; {:try_start_b .. :try_end_17} :catch_18
goto :goto_b
.line 752
:catch_18
move-exception v0
.line 753
sget-boolean v1, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v1, :cond_e
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
goto :goto_e
.end method
# virtual methods
.method public run()V
.registers 9
.prologue
const/4 v4, 0x1
const-wide/16 v6, 0x0
.line 577
:try_start_3
invoke-direct {p0}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->runSession()V
:try_end_6
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_6} :catch_49
.catchall {:try_start_3 .. :try_end_6} :catchall_af
.line 584
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v0}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v0
if-eqz v0, :cond_1ad
.line 585
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-lez v0, :cond_33
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessCount:I
if-nez v0, :cond_33
.line 586
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectFailCount:I
.line 587
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectFailTime:J
.line 588
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
.line 605
:cond_33
:goto_33
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v0}, Lcom/quickbird/sdk/utils/ProxyReportMgr;->getInstance(Landroid/content/Context;)Lcom/quickbird/sdk/utils/ProxyReportMgr;
move-result-object v0
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-virtual {v0, v1}, Lcom/quickbird/sdk/utils/ProxyReportMgr;->updateProxyReport(Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;)V
.line 606
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-direct {p0, v0}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->safeClose(Ljava/nio/channels/SocketChannel;)V
.line 607
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
:goto_45
invoke-direct {p0, v0}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->safeClose(Ljava/nio/channels/SocketChannel;)V
.line 609
return-void
.line 578
:catch_49
move-exception v0
.line 579
:try_start_4a
sget-boolean v1, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->DEBUG:Z
if-eqz v1, :cond_6a
.line 580
const-string v1, "QbSdk"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Run Session error ! "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v1, v0}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 582
:cond_6a
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
const/4 v1, 0x1
iput v1, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->errorCount:I
:try_end_6f
.catchall {:try_start_4a .. :try_end_6f} :catchall_af
.line 584
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v0}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v0
if-eqz v0, :cond_14f
.line 585
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-lez v0, :cond_9c
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessCount:I
if-nez v0, :cond_9c
.line 586
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectFailCount:I
.line 587
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectFailTime:J
.line 588
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
.line 605
:cond_9c
:goto_9c
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v0}, Lcom/quickbird/sdk/utils/ProxyReportMgr;->getInstance(Landroid/content/Context;)Lcom/quickbird/sdk/utils/ProxyReportMgr;
move-result-object v0
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-virtual {v0, v1}, Lcom/quickbird/sdk/utils/ProxyReportMgr;->updateProxyReport(Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;)V
.line 606
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-direct {p0, v0}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->safeClose(Ljava/nio/channels/SocketChannel;)V
.line 607
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
goto :goto_45
.line 584
:catchall_af
move-exception v0
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mSessionHandler:Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;
invoke-virtual {v1}, Lcom/quickbird/mini/vpn/proxy/HttpProxySessionHandler;->isProxy()Z
move-result v1
if-eqz v1, :cond_f3
.line 585
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v1, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyExceptions:Ljava/util/HashSet;
invoke-virtual {v1}, Ljava/util/HashSet;->size()I
move-result v1
if-lez v1, :cond_dd
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v1, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessCount:I
if-nez v1, :cond_dd
.line 586
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectFailCount:I
.line 587
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectFailTime:J
.line 588
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->proxyConnectSuccessTime:J
.line 605
:cond_dd
:goto_dd
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mContext:Landroid/content/Context;
invoke-static {v1}, Lcom/quickbird/sdk/utils/ProxyReportMgr;->getInstance(Landroid/content/Context;)Lcom/quickbird/sdk/utils/ProxyReportMgr;
move-result-object v1
iget-object v2, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-virtual {v1, v2}, Lcom/quickbird/sdk/utils/ProxyReportMgr;->updateProxyReport(Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;)V
.line 606
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mRemoteChannel:Ljava/nio/channels/SocketChannel;
invoke-direct {p0, v1}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->safeClose(Ljava/nio/channels/SocketChannel;)V
.line 607
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mLocalChannel:Ljava/nio/channels/SocketChannel;
invoke-direct {p0, v1}, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->safeClose(Ljava/nio/channels/SocketChannel;)V
.line 584
throw v0
.line 591
:cond_f3
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v1, v2, v6
if-lez v1, :cond_121
.line 592
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v1, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
invoke-virtual {v1}, Ljava/util/HashSet;->size()I
move-result v1
if-lez v1, :cond_dd
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v1, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessCount:I
if-nez v1, :cond_dd
.line 593
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectFailCount:I
.line 594
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectFailTime:J
.line 595
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
goto :goto_dd
.line 597
:cond_121
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v1, v2, v6
if-lez v1, :cond_dd
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v1, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessCount:I
if-nez v1, :cond_dd
.line 598
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v1, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
invoke-virtual {v1}, Ljava/util/HashSet;->size()I
move-result v1
if-lez v1, :cond_dd
.line 599
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectFailCount:I
.line 600
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v4, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v4, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectFailTime:J
.line 601
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
goto :goto_dd
.line 591
:cond_14f
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v0, v0, v6
if-lez v0, :cond_17e
.line 592
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-lez v0, :cond_9c
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessCount:I
if-nez v0, :cond_9c
.line 593
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectFailCount:I
.line 594
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectFailTime:J
.line 595
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
goto/16 :goto_9c
.line 597
:cond_17e
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v0, v0, v6
if-lez v0, :cond_9c
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessCount:I
if-nez v0, :cond_9c
.line 598
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-lez v0, :cond_9c
.line 599
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectFailCount:I
.line 600
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectFailTime:J
.line 601
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
goto/16 :goto_9c
.line 591
:cond_1ad
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
cmp-long v0, v0, v6
if-lez v0, :cond_1dc
.line 592
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-lez v0, :cond_33
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessCount:I
if-nez v0, :cond_33
.line 593
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectFailCount:I
.line 594
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectFailTime:J
.line 595
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->apnConnectSuccessTime:J
goto/16 :goto_33
.line 597
:cond_1dc
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
cmp-long v0, v0, v6
if-lez v0, :cond_33
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessCount:I
if-nez v0, :cond_33
.line 598
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-object v0, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiExceptions:Ljava/util/HashSet;
invoke-virtual {v0}, Ljava/util/HashSet;->size()I
move-result v0
if-lez v0, :cond_33
.line 599
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput v4, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectFailCount:I
.line 600
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-object v1, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iget-wide v4, v1, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
sub-long/2addr v2, v4
iput-wide v2, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectFailTime:J
.line 601
iget-object v0, p0, Lcom/quickbird/mini/vpn/proxy/TcpProxySession;->mReportInfo:Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;
iput-wide v6, v0, Lcom/quickbird/sdk/utils/ProxyReportMgr$ProxyReportInfo;->wifiConnectSuccessTime:J
goto/16 :goto_33
.end method