TlsConnection.smali
.class public Lcom/imo/android/imoim/network/TlsConnection;
.super Lcom/imo/android/imoim/network/BaseConnection;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/imo/android/imoim/network/TlsConnection$SocketException;
}
.end annotation
# static fields
.field private static final TAG:Ljava/lang/String; = "TlsConnection"
.field private static final TLS_VERTIFIED:I = 0x3
# instance fields
.field private zlib:Lcom/imo/android/imoim/util/eu;
# direct methods
.method public constructor <init>(Lcom/imo/android/imoim/network/ConnectData3;Lcom/imo/android/imoim/util/eu;Lcom/imo/android/imoim/network/SocketHandler;)V
.registers 4
.line 31
invoke-direct {p0, p1, p3}, Lcom/imo/android/imoim/network/BaseConnection;-><init>(Lcom/imo/android/imoim/network/ConnectData3;Lcom/imo/android/imoim/network/SocketHandler;)V
.line 32
iput-object p2, p0, Lcom/imo/android/imoim/network/TlsConnection;->zlib:Lcom/imo/android/imoim/util/eu;
return-void
.end method
.method private encodeDecode([B[B[BZZ)[B
.registers 8
.line 94
new-instance v0, Ljavax/crypto/spec/SecretKeySpec;
const-string v1, "AES"
invoke-direct {v0, p1, v1}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
.line 95
new-instance p1, Ljavax/crypto/spec/IvParameterSpec;
invoke-direct {p1, p2}, Ljavax/crypto/spec/IvParameterSpec;-><init>([B)V
if-eqz p4, :cond_11
const-string p2, "AES/CBC/PKCS5Padding"
goto :goto_13
:cond_11
const-string p2, "AES/CBC/NoPadding"
:goto_13
const/4 p4, 0x1
.line 100
:try_start_14
invoke-static {p2}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object p2
if-eqz p5, :cond_1e
.line 102
invoke-virtual {p2, p4, v0, p1}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
goto :goto_22
:cond_1e
const/4 v1, 0x2
.line 104
invoke-virtual {p2, v1, v0, p1}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
.line 106
:goto_22
invoke-virtual {p2, p3}, Ljavax/crypto/Cipher;->doFinal([B)[B
move-result-object p1
:try_end_26
.catch Ljava/lang/Exception; {:try_start_14 .. :try_end_26} :catch_27
return-object p1
.line 108
:catch_27
invoke-static {p5}, Ljava/lang/String;->valueOf(Z)Ljava/lang/String;
move-result-object p1
const-string p2, "EncodeDecode failed. Encrypt="
invoke-virtual {p2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
const-string p2, "TlsConnection"
.line 3079
invoke-static {p2, p1, p4}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
const/4 p1, 0x0
new-array p1, p1, [B
return-object p1
.end method
# virtual methods
.method public close()I
.registers 4
.line 253
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->socketHandler:Lcom/imo/android/imoim/network/SocketHandler;
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v1, v1, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
invoke-interface {v0, v1}, Lcom/imo/android/imoim/network/SocketHandler;->handleClose(I)I
move-result v0
.line 254
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
const/4 v2, 0x1
iput-boolean v2, v1, Lcom/imo/android/imoim/network/ConnectData3;->closed:Z
.line 255
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v1, v1, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
invoke-virtual {v2}, Lcom/imo/android/imoim/network/ConnectData3;->getConnectionId()Ljava/lang/String;
move-result-object v2
invoke-virtual {p0, v1, v2}, Lcom/imo/android/imoim/network/TlsConnection;->onsocketclose(ILjava/lang/String;)V
return v0
.end method
.method public getConnectData()Lcom/imo/android/imoim/network/ConnectData3;
.registers 2
.line 248
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
return-object v0
.end method
.method public getIp()Ljava/lang/String;
.registers 2
.line 37
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget-object v0, v0, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
return-object v0
.end method
.method public getPort()I
.registers 2
.line 42
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v0, v0, Lcom/imo/android/imoim/network/ConnectData3;->port:I
return v0
.end method
.method public handleError(Ljava/lang/String;)V
.registers 5
.line 240
invoke-virtual {p0}, Lcom/imo/android/imoim/network/TlsConnection;->close()I
move-result v0
.line 241
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->errorListener:Lcom/imo/android/imoim/network/Connection$ErrorListener;
if-eqz v1, :cond_11
.line 242
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->errorListener:Lcom/imo/android/imoim/network/Connection$ErrorListener;
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v2, v2, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
invoke-interface {v1, v2, v0, p1}, Lcom/imo/android/imoim/network/Connection$ErrorListener;->onError(IILjava/lang/String;)V
:cond_11
return-void
.end method
.method public handleRead([B)V
.registers 6
const-string v0, "tls:onsocketreceivedataerror-"
.line 47
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->socketHandler:Lcom/imo/android/imoim/network/SocketHandler;
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v2, v2, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
invoke-interface {v1, v2, p1}, Lcom/imo/android/imoim/network/SocketHandler;->handleRead(I[B)I
move-result v1
const-string v2, "tls:readerror"
if-nez v1, :cond_1c
.line 49
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
:cond_1c
if-gez v1, :cond_2a
.line 54
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
.line 59
:cond_2a
:try_start_2a
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v2, v2, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
iget-object v3, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
invoke-virtual {v3}, Lcom/imo/android/imoim/network/ConnectData3;->getConnectionId()Ljava/lang/String;
move-result-object v3
invoke-virtual {p0, v2, p1, v1, v3}, Lcom/imo/android/imoim/network/TlsConnection;->onsocketreceivedata(I[BILjava/lang/String;)V
:try_end_37
.catch Lcom/imo/android/imoim/network/TlsConnection$SocketException; {:try_start_2a .. :try_end_37} :catch_4d
.catch Ljava/lang/Exception; {:try_start_2a .. :try_end_37} :catch_38
return-void
:catch_38
move-exception p1
const/4 v1, 0x1
const-string v2, "TlsConnection"
const-string v3, "tls:onsocketreceivedataerror"
.line 1083
invoke-static {v2, v3, p1, v1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
.line 64
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
:catch_4d
move-exception p1
.line 61
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1, v0}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget p1, p1, Lcom/imo/android/imoim/network/TlsConnection$SocketException;->errorCode:I
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
.end method
.method public handleWrite()V
.registers 12
const-string v0, "tls:onsocketconnected"
const-string v1, "tls:write_err"
.line 155
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget-boolean v2, v2, Lcom/imo/android/imoim/network/ConnectData3;->shouldSendNameChannel:Z
const/4 v3, 0x1
const-string v4, "TlsConnection"
if-eqz v2, :cond_7a
const-string v1, "tls:shouldSendNameChannel"
.line 4071
invoke-static {v4, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 157
invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;
move-result-object v2
invoke-virtual {v2, v4, v1}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V
.line 158
sget-object v1, Lcom/imo/android/imoim/j/a;->a:Ljavax/crypto/SecretKey;
invoke-interface {v1}, Ljavax/crypto/SecretKey;->getEncoded()[B
move-result-object v7
.line 161
:try_start_1f
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->zlib:Lcom/imo/android/imoim/util/eu;
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget-object v2, v2, Lcom/imo/android/imoim/network/ConnectData3;->ip:Ljava/lang/String;
iget-object v5, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
invoke-virtual {v5}, Lcom/imo/android/imoim/network/ConnectData3;->needPadding()Z
move-result v5
invoke-static {v2, v5}, Lcom/imo/android/imoim/network/Helper;->getNameChannel(Ljava/lang/String;Z)[B
move-result-object v2
invoke-virtual {v1, v2}, Lcom/imo/android/imoim/util/eu;->a([B)[B
move-result-object v8
:try_end_33
.catch Ljava/lang/Exception; {:try_start_1f .. :try_end_33} :catch_6e
.line 168
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
const/4 v2, 0x0
iput-boolean v2, v1, Lcom/imo/android/imoim/network/ConnectData3;->shouldSendNameChannel:Z
.line 169
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v5
iput-wide v5, v1, Lcom/imo/android/imoim/network/ConnectData3;->tcpConnectedTime:J
.line 171
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v6, v1, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget-object v9, v1, Lcom/imo/android/imoim/network/ConnectData3;->unblockConfig:Lcom/imo/android/imoim/imodns/UnblockConfig;
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
invoke-virtual {v1}, Lcom/imo/android/imoim/network/ConnectData3;->getConnectionId()Ljava/lang/String;
move-result-object v10
move-object v5, p0
invoke-virtual/range {v5 .. v10}, Lcom/imo/android/imoim/network/TlsConnection;->setupsslconfig(I[B[BLcom/imo/android/imoim/imodns/UnblockConfig;Ljava/lang/String;)V
.line 173
:try_start_52
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v1, v1, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
invoke-virtual {v2}, Lcom/imo/android/imoim/network/ConnectData3;->getConnectionId()Ljava/lang/String;
move-result-object v2
invoke-virtual {p0, v1, v2}, Lcom/imo/android/imoim/network/TlsConnection;->onsocketconnected(ILjava/lang/String;)V
:try_end_5f
.catch Lcom/imo/android/imoim/network/TlsConnection$SocketException; {:try_start_52 .. :try_end_5f} :catch_6a
.catch Ljava/lang/Exception; {:try_start_52 .. :try_end_5f} :catch_60
return-void
:catch_60
move-exception v1
const-string v2, "onsocketconnected"
.line 5083
invoke-static {v4, v2, v1, v3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
.line 178
invoke-virtual {p0, v0}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
.line 175
:catch_6a
invoke-virtual {p0, v0}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
:catch_6e
move-exception v0
const-string v1, "tls:compress NameChannel failed"
.line 4083
invoke-static {v4, v1, v0, v3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
const-string v0, "sendNC"
.line 164
invoke-virtual {p0, v0}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
:cond_7a
:goto_7a
const/4 v0, 0x0
.line 186
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget-object v2, v2, Lcom/imo/android/imoim/network/ConnectData3;->queue:Ljava/util/concurrent/ConcurrentLinkedQueue;
invoke-virtual {v2}, Ljava/util/concurrent/ConcurrentLinkedQueue;->poll()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/imo/android/imoim/util/y;
if-nez v2, :cond_88
return-void
.line 192
:cond_88
:try_start_88
iget-object v5, p0, Lcom/imo/android/imoim/network/TlsConnection;->zlib:Lcom/imo/android/imoim/util/eu;
invoke-virtual {v2, v3}, Lcom/imo/android/imoim/util/y;->a(Z)[B
move-result-object v6
invoke-virtual {v5, v6}, Lcom/imo/android/imoim/util/eu;->a([B)[B
move-result-object v0
:try_end_92
.catch Ljava/io/IOException; {:try_start_88 .. :try_end_92} :catch_93
goto :goto_99
:catch_93
move-exception v5
const-string v6, "tls:get and compress message failed"
.line 6083
invoke-static {v4, v6, v5, v3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
:goto_99
if-nez v0, :cond_9c
return-void
.line 201
:cond_9c
iget-object v5, v2, Lcom/imo/android/imoim/util/y;->o:Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
if-eqz v5, :cond_a8
.line 202
iget-object v2, v2, Lcom/imo/android/imoim/util/y;->o:Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v5
iput-wide v5, v2, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->realSendTs:J
.line 206
:cond_a8
:try_start_a8
iget-object v2, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget v2, v2, Lcom/imo/android/imoim/network/ConnectData3;->fd:I
iget-object v5, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
invoke-virtual {v5}, Lcom/imo/android/imoim/network/ConnectData3;->getConnectionId()Ljava/lang/String;
move-result-object v5
invoke-virtual {p0, v2, v0, v5}, Lcom/imo/android/imoim/network/TlsConnection;->onsocketsenddata(I[BLjava/lang/String;)Z
:try_end_b5
.catch Lcom/imo/android/imoim/network/TlsConnection$SocketException; {:try_start_a8 .. :try_end_b5} :catch_d0
.catch Ljava/lang/Exception; {:try_start_a8 .. :try_end_b5} :catch_b6
goto :goto_7a
:catch_b6
move-exception v0
const-string v2, "onsocketsenddata"
.line 7083
invoke-static {v4, v2, v0, v3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
.line 227
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
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;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
:catch_d0
move-exception v0
.line 208
iget v0, v0, Lcom/imo/android/imoim/network/TlsConnection$SocketException;->errorCode:I
if-eqz v0, :cond_e4
const/16 v2, 0xb
if-eq v0, v2, :cond_e4
.line 222
invoke-static {v0}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
:cond_e4
return-void
.end method
.method public isClosed()Z
.registers 2
.line 235
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
iget-boolean v0, v0, Lcom/imo/android/imoim/network/ConnectData3;->closed:Z
return v0
.end method
.method public onDecodeData([B[B[BZ)[B
.registers 11
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
const/4 v5, 0x0
move-object v0, p0
move-object v1, p1
move-object v2, p2
move-object v3, p3
move v4, p4
.line 120
invoke-direct/range {v0 .. v5}, Lcom/imo/android/imoim/network/TlsConnection;->encodeDecode([B[B[BZZ)[B
move-result-object p1
return-object p1
.end method
.method public onEncodeData([B[B[BZ)[B
.registers 11
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
const/4 v5, 0x1
move-object v0, p0
move-object v1, p1
move-object v2, p2
move-object v3, p3
move v4, p4
.line 115
invoke-direct/range {v0 .. v5}, Lcom/imo/android/imoim/network/TlsConnection;->encodeDecode([B[B[BZZ)[B
move-result-object p1
return-object p1
.end method
.method public onReceiveData(I[BII)V
.registers 12
.line 126
:try_start_0
new-instance v2, Ljava/lang/String;
iget-object p1, p0, Lcom/imo/android/imoim/network/TlsConnection;->zlib:Lcom/imo/android/imoim/util/eu;
invoke-virtual {p1, p2}, Lcom/imo/android/imoim/util/eu;->b([B)[B
move-result-object p1
const-string p2, "UTF-8"
invoke-direct {v2, p1, p2}, Ljava/lang/String;-><init>([BLjava/lang/String;)V
.line 127
iget-object p1, p0, Lcom/imo/android/imoim/network/TlsConnection;->messageListener:Lcom/imo/android/imoim/network/MessageListener;
if-eqz p1, :cond_1d
.line 128
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->messageListener:Lcom/imo/android/imoim/network/MessageListener;
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->attach:Lcom/imo/android/imoim/network/ConnectData3;
int-to-long v3, p3
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v5
invoke-interface/range {v0 .. v6}, Lcom/imo/android/imoim/network/MessageListener;->onReceiveMessage(Lcom/imo/android/imoim/network/ConnectData3;Ljava/lang/String;JJ)V
:try_end_1d
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_1d} :catch_1e
:cond_1d
return-void
:catch_1e
move-exception p1
const/4 p2, 0x1
const-string p3, "TlsConnection"
const-string p4, "onReceiveData error"
.line 3083
invoke-static {p3, p4, p1, p2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
const-string p1, "tls:recv_exception"
.line 132
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
.end method
.method public onSendData(I[BII)V
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/imo/android/imoim/network/TlsConnection$SocketException;
}
.end annotation
.line 70
invoke-static {p2}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;
move-result-object p2
iput-object p2, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
.line 72
:goto_6
iget-object p2, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
invoke-virtual {p2}, Ljava/nio/ByteBuffer;->hasRemaining()Z
move-result p2
if-eqz p2, :cond_65
.line 73
iget-object p2, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
invoke-virtual {p2}, Ljava/nio/ByteBuffer;->remaining()I
move-result p2
.line 74
iget-object p3, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
invoke-virtual {p3}, Ljava/nio/ByteBuffer;->array()[B
move-result-object p3
.line 75
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
invoke-virtual {v0}, Ljava/nio/ByteBuffer;->position()I
move-result v0
.line 78
iget-object v1, p0, Lcom/imo/android/imoim/network/TlsConnection;->socketHandler:Lcom/imo/android/imoim/network/SocketHandler;
invoke-interface {v1, p1, p3, v0, p2}, Lcom/imo/android/imoim/network/SocketHandler;->handleWrite(I[BII)I
move-result p2
if-gtz p2, :cond_5e
.line 80
new-instance p1, Ljava/lang/StringBuilder;
const-string p3, "onSendData returns "
invoke-direct {p1, p3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p3, ", tag="
invoke-virtual {p1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const/4 p3, 0x1
const-string v0, "TlsConnection"
.line 2079
invoke-static {v0, p1, p3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 81
new-instance p1, Ljava/lang/StringBuilder;
const-string p3, "tls:onSendData_"
invoke-direct {p1, p3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, "_"
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
.line 85
:cond_5e
iget-object p3, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
add-int/2addr v0, p2
invoke-virtual {p3, v0}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
goto :goto_6
:cond_65
const/4 p1, 0x0
.line 87
iput-object p1, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
return-void
.end method
.method public onTlsVerifyStateChanged(II)V
.registers 3
const/4 p1, 0x3
if-ne p2, p1, :cond_e
.line 144
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
move-result-object p1
invoke-virtual {p0}, Lcom/imo/android/imoim/network/TlsConnection;->getConnectData()Lcom/imo/android/imoim/network/ConnectData3;
move-result-object p2
invoke-virtual {p1, p2}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->markTlsVerify(Lcom/imo/android/imoim/network/ConnectData3;)V
:cond_e
return-void
.end method
.method public onTlsVerifyStateExceptionCallback(ILjava/lang/String;)V
.registers 3
.line 150
invoke-static {p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string p2, "tls:onTlsVerifyStateException:"
invoke-virtual {p2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
.end method
.method public onVerifyFailed(IILjava/lang/String;)V
.registers 5
.line 138
new-instance p1, Ljava/lang/StringBuilder;
const-string v0, "tls:onVerifyFailed_"
invoke-direct {p1, v0}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, ":"
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {p0, p1}, Lcom/imo/android/imoim/network/TlsConnection;->handleError(Ljava/lang/String;)V
return-void
.end method
.method native onsocketclose(ILjava/lang/String;)V
.end method
.method native onsocketconnected(ILjava/lang/String;)V
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/imo/android/imoim/network/TlsConnection$SocketException;
}
.end annotation
.end method
.method native onsocketreceivedata(I[BILjava/lang/String;)V
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/imo/android/imoim/network/TlsConnection$SocketException;
}
.end annotation
.end method
.method native onsocketsenddata(I[BLjava/lang/String;)Z
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/imo/android/imoim/network/TlsConnection$SocketException;
}
.end annotation
.end method
.method public remainWriteBuffer()Z
.registers 2
.line 261
iget-object v0, p0, Lcom/imo/android/imoim/network/TlsConnection;->writeBuffer:Ljava/nio/ByteBuffer;
if-eqz v0, :cond_6
const/4 v0, 0x1
return v0
:cond_6
const/4 v0, 0x0
return v0
.end method
.method native setupsslconfig(I[B[BLcom/imo/android/imoim/imodns/UnblockConfig;Ljava/lang/String;)V
.end method