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