c.smali
.class public Lcom/subgraph/orchid/socks/c;
.super Ljava/lang/Object;
.source "SocksClientTask.java"
# interfaces
.implements Ljava/lang/Runnable;
# static fields
.field private static final logger:Ljava/util/logging/Logger;
# instance fields
.field private final bBr:Lcom/subgraph/orchid/TorConfig;
.field private final bBv:Lcom/subgraph/orchid/e;
.field private final socket:Ljava/net/Socket;
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 16
const-class v0, Lcom/subgraph/orchid/socks/c;
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;
move-result-object v0
sput-object v0, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
return-void
.end method
.method constructor <init>(Lcom/subgraph/orchid/TorConfig;Ljava/net/Socket;Lcom/subgraph/orchid/e;)V
.registers 4
.prologue
.line 22
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 23
iput-object p1, p0, Lcom/subgraph/orchid/socks/c;->bBr:Lcom/subgraph/orchid/TorConfig;
.line 24
iput-object p2, p0, Lcom/subgraph/orchid/socks/c;->socket:Ljava/net/Socket;
.line 25
iput-object p3, p0, Lcom/subgraph/orchid/socks/c;->bBv:Lcom/subgraph/orchid/e;
.line 26
return-void
.end method
.method private HC()I
.registers 5
.prologue
.line 36
:try_start_0
iget-object v0, p0, Lcom/subgraph/orchid/socks/c;->socket:Ljava/net/Socket;
invoke-virtual {v0}, Ljava/net/Socket;->getInputStream()Ljava/io/InputStream;
move-result-object v0
invoke-virtual {v0}, Ljava/io/InputStream;->read()I
:try_end_9
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_9} :catch_b
move-result v0
.line 39
:goto_a
return v0
.line 37
:catch_b
move-exception v0
.line 38
sget-object v1, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "IO error reading version byte: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/io/IOException;->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-virtual {v1, v0}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V
.line 39
const/4 v0, -0x1
goto :goto_a
.end method
.method private a(Lcom/subgraph/orchid/socks/f;)V
.registers 7
.prologue
const/4 v0, 0x1
const/4 v1, 0x0
.line 64
:try_start_2
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->Oe()V
.line 65
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->Oa()Z
move-result v2
if-nez v2, :cond_2e
.line 66
sget-object v0, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Non connect command ("
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->Ob()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)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 {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V
.line 67
const/4 v0, 0x1
invoke-virtual {p1, v0}, Lcom/subgraph/orchid/socks/f;->bk(Z)V
:try_end_2d
.catch Lcom/subgraph/orchid/socks/SocksRequestException; {:try_start_2 .. :try_end_2d} :catch_b3
.line 94
:goto_2d
return-void
.line 3044
:cond_2e
:try_start_2e
iget-object v2, p1, Lcom/subgraph/orchid/socks/f;->hostname:Ljava/lang/String;
if-eqz v2, :cond_dc
.line 2102
:goto_32
if-eqz v0, :cond_df
.line 2103
sget-object v0, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "SOCKS CONNECT request to "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 3048
iget-object v2, p1, Lcom/subgraph/orchid/socks/f;->hostname:Ljava/lang/String;
.line 2103
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
.line 4036
iget v2, p1, Lcom/subgraph/orchid/socks/f;->port:I
.line 2103
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
invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->fine(Ljava/lang/String;)V
.line 2104
iget-object v0, p0, Lcom/subgraph/orchid/socks/c;->bBv:Lcom/subgraph/orchid/e;
.line 4048
iget-object v1, p1, Lcom/subgraph/orchid/socks/f;->hostname:Ljava/lang/String;
.line 5036
iget v2, p1, Lcom/subgraph/orchid/socks/f;->port:I
.line 2104
invoke-interface {v0, v1, v2}, Lcom/subgraph/orchid/e;->o(Ljava/lang/String;I)Lcom/subgraph/orchid/aa;
move-result-object v0
.line 73
:goto_60
sget-object v1, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "SOCKS CONNECT to "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->getTarget()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, " completed"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/util/logging/Logger;->fine(Ljava/lang/String;)V
.line 74
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->Od()V
.line 7098
iget-object v1, p0, Lcom/subgraph/orchid/socks/c;->socket:Ljava/net/Socket;
invoke-static {v1, v0}, Lcom/subgraph/orchid/socks/g;->a(Ljava/net/Socket;Lcom/subgraph/orchid/aa;)V
:try_end_86
.catch Ljava/lang/InterruptedException; {:try_start_2e .. :try_end_86} :catch_87
.catch Ljava/util/concurrent/TimeoutException; {:try_start_2e .. :try_end_86} :catch_10d
.catch Lcom/subgraph/orchid/OpenFailedException; {:try_start_2e .. :try_end_86} :catch_132
.catch Lcom/subgraph/orchid/socks/SocksRequestException; {:try_start_2e .. :try_end_86} :catch_b3
goto :goto_2d
.line 77
:catch_87
move-exception v0
:try_start_88
sget-object v0, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "SOCKS CONNECT to "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->getTarget()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, " was thread interrupted"
invoke-virtual {v1, v2}, 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 {v0, v1}, Ljava/util/logging/Logger;->info(Ljava/lang/String;)V
.line 78
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
.line 79
const/4 v0, 0x0
invoke-virtual {p1, v0}, Lcom/subgraph/orchid/socks/f;->bk(Z)V
:try_end_b1
.catch Lcom/subgraph/orchid/socks/SocksRequestException; {:try_start_88 .. :try_end_b1} :catch_b3
goto/16 :goto_2d
.line 87
:catch_b3
move-exception v0
.line 88
sget-object v1, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
sget-object v2, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Failure reading SOCKS request: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Lcom/subgraph/orchid/socks/SocksRequestException;->getMessage()Ljava/lang/String;
move-result-object v0
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 {v1, v2, v0}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;)V
.line 90
const/4 v0, 0x0
:try_start_cf
invoke-virtual {p1, v0}, Lcom/subgraph/orchid/socks/f;->bk(Z)V
.line 91
iget-object v0, p0, Lcom/subgraph/orchid/socks/c;->socket:Ljava/net/Socket;
invoke-virtual {v0}, Ljava/net/Socket;->close()V
:try_end_d7
.catch Ljava/lang/Exception; {:try_start_cf .. :try_end_d7} :catch_d9
goto/16 :goto_2d
.line 94
:catch_d9
move-exception v0
goto/16 :goto_2d
:cond_dc
move v0, v1
.line 3044
goto/16 :goto_32
.line 2106
:cond_df
:try_start_df
sget-object v0, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "SOCKS CONNECT request to "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 5040
iget-object v2, p1, Lcom/subgraph/orchid/socks/f;->bCT:Lcom/subgraph/orchid/d/d;
.line 2106
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)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
.line 6036
iget v2, p1, Lcom/subgraph/orchid/socks/f;->port:I
.line 2106
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
invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->fine(Ljava/lang/String;)V
.line 2107
iget-object v0, p0, Lcom/subgraph/orchid/socks/c;->bBv:Lcom/subgraph/orchid/e;
.line 6040
iget-object v1, p1, Lcom/subgraph/orchid/socks/f;->bCT:Lcom/subgraph/orchid/d/d;
.line 7036
iget v2, p1, Lcom/subgraph/orchid/socks/f;->port:I
.line 2107
invoke-interface {v0, v1, v2}, Lcom/subgraph/orchid/e;->a(Lcom/subgraph/orchid/d/d;I)Lcom/subgraph/orchid/aa;
:try_end_10a
.catch Ljava/lang/InterruptedException; {:try_start_df .. :try_end_10a} :catch_87
.catch Ljava/util/concurrent/TimeoutException; {:try_start_df .. :try_end_10a} :catch_10d
.catch Lcom/subgraph/orchid/OpenFailedException; {:try_start_df .. :try_end_10a} :catch_132
.catch Lcom/subgraph/orchid/socks/SocksRequestException; {:try_start_df .. :try_end_10a} :catch_b3
move-result-object v0
goto/16 :goto_60
.line 81
:catch_10d
move-exception v0
:try_start_10e
sget-object v0, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "SOCKS CONNECT to "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->getTarget()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, " timed out"
invoke-virtual {v1, v2}, 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 {v0, v1}, Ljava/util/logging/Logger;->info(Ljava/lang/String;)V
.line 82
const/4 v0, 0x0
invoke-virtual {p1, v0}, Lcom/subgraph/orchid/socks/f;->bk(Z)V
goto/16 :goto_2d
.line 83
:catch_132
move-exception v0
.line 84
sget-object v1, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "SOCKS CONNECT to "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->getTarget()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, " failed: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v0}, Lcom/subgraph/orchid/OpenFailedException;->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-virtual {v1, v0}, Ljava/util/logging/Logger;->info(Ljava/lang/String;)V
.line 85
invoke-virtual {p1}, Lcom/subgraph/orchid/socks/f;->Oc()V
:try_end_15c
.catch Lcom/subgraph/orchid/socks/SocksRequestException; {:try_start_10e .. :try_end_15c} :catch_b3
goto/16 :goto_2d
.end method
# virtual methods
.method public run()V
.registers 5
.prologue
.line 29
invoke-direct {p0}, Lcom/subgraph/orchid/socks/c;->HC()I
move-result v0
.line 1044
sparse-switch v0, :sswitch_data_4a
.line 1117
:goto_7
:try_start_7
iget-object v0, p0, Lcom/subgraph/orchid/socks/c;->socket:Ljava/net/Socket;
invoke-virtual {v0}, Ljava/net/Socket;->close()V
:try_end_c
.catch Ljava/io/IOException; {:try_start_7 .. :try_end_c} :catch_2f
.line 1120
:goto_c
return-void
.line 1112
:sswitch_d
new-instance v0, Lcom/subgraph/orchid/TorException;
const-string v1, "Returning HTTP page not implemented"
invoke-direct {v0, v1}, Lcom/subgraph/orchid/TorException;-><init>(Ljava/lang/String;)V
throw v0
.line 1051
:sswitch_15
new-instance v0, Lcom/subgraph/orchid/socks/a;
iget-object v1, p0, Lcom/subgraph/orchid/socks/c;->bBr:Lcom/subgraph/orchid/TorConfig;
iget-object v2, p0, Lcom/subgraph/orchid/socks/c;->socket:Ljava/net/Socket;
invoke-direct {v0, v1, v2}, Lcom/subgraph/orchid/socks/a;-><init>(Lcom/subgraph/orchid/TorConfig;Ljava/net/Socket;)V
invoke-direct {p0, v0}, Lcom/subgraph/orchid/socks/c;->a(Lcom/subgraph/orchid/socks/f;)V
goto :goto_7
.line 1054
:sswitch_22
new-instance v0, Lcom/subgraph/orchid/socks/b;
iget-object v1, p0, Lcom/subgraph/orchid/socks/c;->bBr:Lcom/subgraph/orchid/TorConfig;
iget-object v2, p0, Lcom/subgraph/orchid/socks/c;->socket:Ljava/net/Socket;
invoke-direct {v0, v1, v2}, Lcom/subgraph/orchid/socks/b;-><init>(Lcom/subgraph/orchid/TorConfig;Ljava/net/Socket;)V
invoke-direct {p0, v0}, Lcom/subgraph/orchid/socks/c;->a(Lcom/subgraph/orchid/socks/f;)V
goto :goto_7
.line 1118
:catch_2f
move-exception v0
.line 1119
sget-object v1, Lcom/subgraph/orchid/socks/c;->logger:Ljava/util/logging/Logger;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Error closing SOCKS socket: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/io/IOException;->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-virtual {v1, v0}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V
goto :goto_c
.line 1044
nop
:sswitch_data_4a
.sparse-switch
0x4 -> :sswitch_15
0x5 -> :sswitch_22
0x47 -> :sswitch_d
0x48 -> :sswitch_d
0x50 -> :sswitch_d
.end sparse-switch
.end method