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