HttpConnection$HttpSenderThread.smali
.class Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;
.super Ljava/lang/Thread;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/imo/android/imoim/network/HttpConnection;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x0
name = "HttpSenderThread"
.end annotation
# instance fields
.field shouldExit:Z
.field final synthetic this$0:Lcom/imo/android/imoim/network/HttpConnection;
# direct methods
.method constructor <init>(Lcom/imo/android/imoim/network/HttpConnection;)V
.registers 2
.line 135
iput-object p1, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
invoke-direct {p0}, Ljava/lang/Thread;-><init>()V
const/4 p1, 0x0
.line 137
iput-boolean p1, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->shouldExit:Z
return-void
.end method
.method private mainLoop(Ljava/io/OutputStream;)V
.registers 8
const-string v0, "HttpConnection"
:cond_2
:goto_2
const/4 v1, 0x1
.line 200
:try_start_3
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Thread;->isInterrupted()Z
move-result v2
if-nez v2, :cond_71
iget-boolean v2, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->shouldExit:Z
:try_end_f
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_f} :catch_5b
if-nez v2, :cond_71
.line 203
:try_start_11
iget-object v2, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->connectDataHttp:Lcom/imo/android/imoim/network/ConnectDataHttp;
invoke-static {v2}, Lcom/imo/android/imoim/network/HttpConnection;->access$000(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/ConnectDataHttp;
move-result-object v2
iget-object v2, v2, Lcom/imo/android/imoim/network/ConnectDataHttp;->queue:Ljava/util/concurrent/LinkedBlockingQueue;
invoke-virtual {v2}, Ljava/util/concurrent/LinkedBlockingQueue;->take()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/imo/android/imoim/util/y;
:try_end_1f
.catch Ljava/lang/InterruptedException; {:try_start_11 .. :try_end_1f} :catch_4d
.catch Ljava/io/IOException; {:try_start_11 .. :try_end_1f} :catch_5b
if-eqz v2, :cond_2
.line 214
:try_start_21
invoke-virtual {v2, v1}, Lcom/imo/android/imoim/util/y;->a(Z)[B
move-result-object v3
if-eqz v3, :cond_2
.line 216
iget-object v4, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
iget-object v5, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->zlib:Lcom/imo/android/imoim/util/eu;
invoke-static {v5}, Lcom/imo/android/imoim/network/HttpConnection;->access$300(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/util/eu;
move-result-object v5
invoke-virtual {v5, v3}, Lcom/imo/android/imoim/util/eu;->c([B)[B
move-result-object v3
# invokes: Lcom/imo/android/imoim/network/HttpConnection;->prefixLength([B)[B
invoke-static {v4, v3}, Lcom/imo/android/imoim/network/HttpConnection;->access$400(Lcom/imo/android/imoim/network/HttpConnection;[B)[B
move-result-object v3
.line 217
array-length v4, v3
if-eqz v4, :cond_2
.line 220
iget-object v4, v2, Lcom/imo/android/imoim/util/y;->o:Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;
if-eqz v4, :cond_46
.line 221
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 v4
iput-wide v4, v2, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->realSendTs:J
.line 223
:cond_46
invoke-virtual {p1, v3}, Ljava/io/OutputStream;->write([B)V
.line 224
invoke-virtual {p1}, Ljava/io/OutputStream;->flush()V
goto :goto_2
:catch_4d
move-exception v2
const-string v3, "mainLoop take message failed"
.line 2083
invoke-static {v0, v3, v2, v1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
.line 206
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Thread;->interrupt()V
:try_end_5a
.catch Ljava/io/IOException; {:try_start_21 .. :try_end_5a} :catch_5b
goto :goto_2
:catch_5b
move-exception p1
.line 228
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "IOException in mainLoop"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Ljava/io/IOException;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 3079
invoke-static {v0, p1, v1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 230
:cond_71
new-instance p1, Ljava/lang/StringBuilder;
const-string v1, "Exited mainLoop int:"
invoke-direct {p1, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Thread;->isInterrupted()Z
move-result v1
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v1, " shouldExit:"
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-boolean v1, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->shouldExit:Z
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 4071
invoke-static {v0, p1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method public exit()V
.registers 2
const/4 v0, 0x1
.line 140
iput-boolean v0, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->shouldExit:Z
.line 141
invoke-virtual {p0}, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->isInterrupted()Z
move-result v0
if-nez v0, :cond_c
.line 142
invoke-virtual {p0}, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->interrupt()V
.line 144
:cond_c
iget-object v0, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->connectDataHttp:Lcom/imo/android/imoim/network/ConnectDataHttp;
invoke-static {v0}, Lcom/imo/android/imoim/network/HttpConnection;->access$000(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/ConnectDataHttp;
move-result-object v0
iget-object v0, v0, Lcom/imo/android/imoim/network/ConnectDataHttp;->queue:Ljava/util/concurrent/LinkedBlockingQueue;
invoke-virtual {v0}, Ljava/util/concurrent/LinkedBlockingQueue;->clear()V
return-void
.end method
.method public run()V
.registers 2
.line 149
iget-boolean v0, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->shouldExit:Z
if-nez v0, :cond_7
.line 150
invoke-virtual {p0}, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->startHttpUpload()V
:cond_7
return-void
.end method
.method public send(Lcom/imo/android/imoim/util/y;)V
.registers 3
.line 234
iget-object v0, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->connectDataHttp:Lcom/imo/android/imoim/network/ConnectDataHttp;
invoke-static {v0}, Lcom/imo/android/imoim/network/HttpConnection;->access$000(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/ConnectDataHttp;
move-result-object v0
iget-boolean v0, v0, Lcom/imo/android/imoim/network/ConnectDataHttp;->hasSendFirstMsg:Z
if-nez v0, :cond_15
iget-boolean v0, p1, Lcom/imo/android/imoim/util/y;->i:Z
if-nez v0, :cond_15
const/4 v0, 0x1
.line 235
iput-boolean v0, p1, Lcom/imo/android/imoim/util/y;->i:Z
const/4 v0, 0x0
.line 236
invoke-virtual {p1, v0}, Lcom/imo/android/imoim/util/y;->a(Z)[B
.line 238
:cond_15
iget-object v0, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->connectDataHttp:Lcom/imo/android/imoim/network/ConnectDataHttp;
invoke-static {v0}, Lcom/imo/android/imoim/network/HttpConnection;->access$000(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/ConnectDataHttp;
move-result-object v0
invoke-virtual {v0}, Lcom/imo/android/imoim/network/ConnectDataHttp;->markHasSendFirstMessage()V
.line 239
iget-object v0, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->connectDataHttp:Lcom/imo/android/imoim/network/ConnectDataHttp;
invoke-static {v0}, Lcom/imo/android/imoim/network/HttpConnection;->access$000(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/ConnectDataHttp;
move-result-object v0
iget-object v0, v0, Lcom/imo/android/imoim/network/ConnectDataHttp;->queue:Ljava/util/concurrent/LinkedBlockingQueue;
invoke-virtual {v0, p1}, Ljava/util/concurrent/LinkedBlockingQueue;->offer(Ljava/lang/Object;)Z
return-void
.end method
.method protected startHttpUpload()V
.registers 10
const-string v0, "HttpConnection"
const/4 v1, 0x1
const/4 v2, 0x0
.line 160
:try_start_4
iget-object v3, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->sendUrl:Ljava/net/URL;
invoke-static {v3}, Lcom/imo/android/imoim/network/HttpConnection;->access$100(Lcom/imo/android/imoim/network/HttpConnection;)Ljava/net/URL;
move-result-object v3
invoke-virtual {v3}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection;
move-result-object v3
check-cast v3, Ljava/net/HttpURLConnection;
:try_end_10
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_10} :catch_6f
.catchall {:try_start_4 .. :try_end_10} :catchall_6c
const/4 v4, 0x0
.line 162
:try_start_11
invoke-virtual {v3, v4}, Ljava/net/HttpURLConnection;->setChunkedStreamingMode(I)V
const-string v5, "POST"
.line 163
invoke-virtual {v3, v5}, Ljava/net/HttpURLConnection;->setRequestMethod(Ljava/lang/String;)V
const-string v5, "Connection"
const-string v6, "close"
.line 164
invoke-virtual {v3, v5, v6}, Ljava/net/HttpURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
const-string v5, "Transfer-Encoding"
const-string v6, "chunked"
.line 166
invoke-virtual {v3, v5, v6}, Ljava/net/HttpURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
.line 167
invoke-virtual {v3, v1}, Ljava/net/HttpURLConnection;->setDoOutput(Z)V
const-string v5, "Host"
.line 168
iget-object v6, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->connectDataHttp:Lcom/imo/android/imoim/network/ConnectDataHttp;
invoke-static {v6}, Lcom/imo/android/imoim/network/HttpConnection;->access$000(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/ConnectDataHttp;
move-result-object v6
iget-object v6, v6, Lcom/imo/android/imoim/network/ConnectDataHttp;->host:Ljava/lang/String;
invoke-virtual {v3, v5, v6}, Ljava/net/HttpURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
.line 169
invoke-virtual {v3}, Ljava/net/HttpURLConnection;->getOutputStream()Ljava/io/OutputStream;
move-result-object v2
.line 170
iget-object v5, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
iget-object v6, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->zlib:Lcom/imo/android/imoim/util/eu;
invoke-static {v6}, Lcom/imo/android/imoim/network/HttpConnection;->access$300(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/util/eu;
move-result-object v6
iget-object v7, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->connectionId:Ljava/lang/String;
invoke-static {v7}, Lcom/imo/android/imoim/network/HttpConnection;->access$200(Lcom/imo/android/imoim/network/HttpConnection;)Ljava/lang/String;
move-result-object v7
const-string v8, "uplink"
invoke-static {v7, v8, v4}, Lcom/imo/android/imoim/network/Helper;->getHttpNameChannel(Ljava/lang/String;Ljava/lang/String;Z)[B
move-result-object v4
invoke-virtual {v6, v4}, Lcom/imo/android/imoim/util/eu;->c([B)[B
move-result-object v4
# invokes: Lcom/imo/android/imoim/network/HttpConnection;->prefixLength([B)[B
invoke-static {v5, v4}, Lcom/imo/android/imoim/network/HttpConnection;->access$400(Lcom/imo/android/imoim/network/HttpConnection;[B)[B
move-result-object v4
invoke-virtual {v2, v4}, Ljava/io/OutputStream;->write([B)V
.line 171
invoke-virtual {v2}, Ljava/io/OutputStream;->flush()V
.line 172
invoke-direct {p0, v2}, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->mainLoop(Ljava/io/OutputStream;)V
:try_end_60
.catch Ljava/lang/Exception; {:try_start_11 .. :try_end_60} :catch_6a
.catchall {:try_start_11 .. :try_end_60} :catchall_bd
if-eqz v2, :cond_67
.line 178
:try_start_62
invoke-virtual {v2}, Ljava/io/OutputStream;->close()V
:try_end_65
.catch Ljava/io/IOException; {:try_start_62 .. :try_end_65} :catch_66
goto :goto_67
:catch_66
nop
:cond_67
:goto_67
if-eqz v3, :cond_82
goto :goto_7f
:catch_6a
move-exception v4
goto :goto_71
:catchall_6c
move-exception v0
move-object v3, v2
goto :goto_be
:catch_6f
move-exception v4
move-object v3, v2
:goto_71
:try_start_71
const-string v5, "Exception in send http "
.line 1083
invoke-static {v0, v5, v4, v1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Z)V
:try_end_76
.catchall {:try_start_71 .. :try_end_76} :catchall_bd
if-eqz v2, :cond_7d
.line 178
:try_start_78
invoke-virtual {v2}, Ljava/io/OutputStream;->close()V
:try_end_7b
.catch Ljava/io/IOException; {:try_start_78 .. :try_end_7b} :catch_7c
goto :goto_7d
:catch_7c
nop
:cond_7d
:goto_7d
if-eqz v3, :cond_82
.line 189
:goto_7f
invoke-virtual {v3}, Ljava/net/HttpURLConnection;->disconnect()V
.line 192
:cond_82
iget-boolean v1, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->shouldExit:Z
if-nez v1, :cond_99
iget-object v1, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->errorListener:Lcom/imo/android/imoim/network/HttpConnection$ErrorListener;
invoke-static {v1}, Lcom/imo/android/imoim/network/HttpConnection;->access$500(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/HttpConnection$ErrorListener;
move-result-object v1
if-eqz v1, :cond_99
.line 193
iget-object v1, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
# getter for: Lcom/imo/android/imoim/network/HttpConnection;->errorListener:Lcom/imo/android/imoim/network/HttpConnection$ErrorListener;
invoke-static {v1}, Lcom/imo/android/imoim/network/HttpConnection;->access$500(Lcom/imo/android/imoim/network/HttpConnection;)Lcom/imo/android/imoim/network/HttpConnection$ErrorListener;
move-result-object v1
iget-object v2, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->this$0:Lcom/imo/android/imoim/network/HttpConnection;
invoke-interface {v1, v2}, Lcom/imo/android/imoim/network/HttpConnection$ErrorListener;->onSenderError(Lcom/imo/android/imoim/network/HttpConnection;)V
.line 195
:cond_99
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Exited http upload isInterrupted:"
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Thread;->isInterrupted()Z
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v2, "shouldExit:"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-boolean v2, p0, Lcom/imo/android/imoim/network/HttpConnection$HttpSenderThread;->shouldExit:Z
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 2071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
:catchall_bd
move-exception v0
:goto_be
if-eqz v2, :cond_c5
.line 178
:try_start_c0
invoke-virtual {v2}, Ljava/io/OutputStream;->close()V
:try_end_c3
.catch Ljava/io/IOException; {:try_start_c0 .. :try_end_c3} :catch_c4
goto :goto_c5
:catch_c4
nop
:cond_c5
:goto_c5
if-eqz v3, :cond_ca
.line 189
invoke-virtual {v3}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_ca
throw v0
.end method