a.smali

.class public Lcom/subgraph/orchid/b/a;
.super Ljava/lang/Object;
.source "ConnectionCacheImpl.java"

# interfaces
.implements Lcom/subgraph/orchid/c/c;
.implements Lcom/subgraph/orchid/h;


# static fields
.field private static final logger:Ljava/util/logging/Logger;


# instance fields
.field private final bBr:Lcom/subgraph/orchid/TorConfig;

.field private final bBt:Lcom/subgraph/orchid/circuits/u;

.field private volatile bCb:Z

.field private final bCm:Ljava/util/concurrent/ScheduledExecutorService;

.field private final bFr:Ljava/util/concurrent/ConcurrentMap;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/ConcurrentMap",
            "<",
            "Lcom/subgraph/orchid/v;",
            "Ljava/util/concurrent/Future",
            "<",
            "Lcom/subgraph/orchid/b/h;",
            ">;>;"
        }
    .end annotation
.end field

.field private final bFs:Lcom/subgraph/orchid/b/i;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .prologue
    .line 33
    const-class v0, Lcom/subgraph/orchid/b/a;

    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/b/a;->logger:Ljava/util/logging/Logger;

    return-void
.end method

.method public constructor <init>(Lcom/subgraph/orchid/TorConfig;Lcom/subgraph/orchid/circuits/u;)V
    .registers 10

    .prologue
    const-wide/16 v2, 0x1388

    .line 75
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 66
    new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {v0}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V

    iput-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    .line 67
    new-instance v0, Lcom/subgraph/orchid/b/i;

    invoke-direct {v0}, Lcom/subgraph/orchid/b/i;-><init>()V

    iput-object v0, p0, Lcom/subgraph/orchid/b/a;->bFs:Lcom/subgraph/orchid/b/i;

    .line 68
    invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;

    move-result-object v0

    iput-object v0, p0, Lcom/subgraph/orchid/b/a;->bCm:Ljava/util/concurrent/ScheduledExecutorService;

    .line 76
    iput-object p1, p0, Lcom/subgraph/orchid/b/a;->bBr:Lcom/subgraph/orchid/TorConfig;

    .line 77
    iput-object p2, p0, Lcom/subgraph/orchid/b/a;->bBt:Lcom/subgraph/orchid/circuits/u;

    .line 78
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bCm:Ljava/util/concurrent/ScheduledExecutorService;

    new-instance v1, Lcom/subgraph/orchid/b/b;

    const/4 v4, 0x0

    invoke-direct {v1, p0, v4}, Lcom/subgraph/orchid/b/b;-><init>(Lcom/subgraph/orchid/b/a;B)V

    sget-object v6, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;

    move-wide v4, v2

    invoke-interface/range {v0 .. v6}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;

    .line 79
    return-void
.end method

.method static synthetic a(Lcom/subgraph/orchid/b/a;)Lcom/subgraph/orchid/b/i;
    .registers 2

    .prologue
    .line 32
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFs:Lcom/subgraph/orchid/b/i;

    return-object v0
.end method

.method static synthetic b(Lcom/subgraph/orchid/b/a;)Lcom/subgraph/orchid/TorConfig;
    .registers 2

    .prologue
    .line 32
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bBr:Lcom/subgraph/orchid/TorConfig;

    return-object v0
.end method

.method static synthetic c(Lcom/subgraph/orchid/b/a;)Lcom/subgraph/orchid/circuits/u;
    .registers 2

    .prologue
    .line 32
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bBt:Lcom/subgraph/orchid/circuits/u;

    return-object v0
.end method

.method static synthetic d(Lcom/subgraph/orchid/b/a;)Ljava/util/concurrent/ConcurrentMap;
    .registers 2

    .prologue
    .line 32
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    return-object v0
.end method


# virtual methods
.method public final a(Lcom/subgraph/orchid/v;Z)Lcom/subgraph/orchid/g;
    .registers 7

    .prologue
    .line 113
    iget-boolean v0, p0, Lcom/subgraph/orchid/b/a;->bCb:Z

    if-eqz v0, :cond_c

    .line 114
    new-instance v0, Ljava/lang/IllegalStateException;

    const-string v1, "ConnectionCache has been closed"

    invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V

    throw v0

    .line 116
    :cond_c
    sget-object v0, Lcom/subgraph/orchid/b/a;->logger:Ljava/util/logging/Logger;

    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "Get connection to "

    invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-interface {p1}, Lcom/subgraph/orchid/v;->JC()Lcom/subgraph/orchid/d/d;

    move-result-object v2

    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

    invoke-interface {p1}, Lcom/subgraph/orchid/v;->JD()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-interface {p1}, Lcom/subgraph/orchid/v;->JB()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

    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 1144
    :goto_40
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0, p1}, Ljava/util/concurrent/ConcurrentMap;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/util/concurrent/Future;

    .line 1145
    if-eqz v0, :cond_64

    move-object v1, v0

    .line 120
    :goto_4b
    :try_start_4b
    invoke-interface {v1}, Ljava/util/concurrent/Future;->get()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/subgraph/orchid/g;

    .line 121
    invoke-interface {v0}, Lcom/subgraph/orchid/g;->isClosed()Z

    move-result v2

    if-eqz v2, :cond_b3

    .line 122
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0, p1, v1}, Ljava/util/concurrent/ConcurrentMap;->remove(Ljava/lang/Object;Ljava/lang/Object;)Z
    :try_end_5c
    .catch Ljava/util/concurrent/CancellationException; {:try_start_4b .. :try_end_5c} :catch_5d
    .catch Ljava/util/concurrent/ExecutionException; {:try_start_4b .. :try_end_5c} :catch_7e

    goto :goto_40

    .line 127
    :catch_5d
    move-exception v0

    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0, p1, v1}, Ljava/util/concurrent/ConcurrentMap;->remove(Ljava/lang/Object;Ljava/lang/Object;)Z

    goto :goto_40

    .line 1152
    :cond_64
    new-instance v0, Lcom/subgraph/orchid/b/c;

    invoke-direct {v0, p0, p1, p2}, Lcom/subgraph/orchid/b/c;-><init>(Lcom/subgraph/orchid/b/a;Lcom/subgraph/orchid/v;Z)V

    .line 1153
    new-instance v1, Ljava/util/concurrent/FutureTask;

    invoke-direct {v1, v0}, Ljava/util/concurrent/FutureTask;-><init>(Ljava/util/concurrent/Callable;)V

    .line 1155
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0, p1, v1}, Ljava/util/concurrent/ConcurrentMap;->putIfAbsent(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/util/concurrent/Future;

    .line 1156
    if-eqz v0, :cond_7a

    move-object v1, v0

    .line 1157
    goto :goto_4b

    .line 1160
    :cond_7a
    invoke-virtual {v1}, Ljava/util/concurrent/FutureTask;->run()V

    goto :goto_4b

    .line 128
    :catch_7e
    move-exception v0

    move-object v2, v0

    .line 129
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0, p1, v1}, Ljava/util/concurrent/ConcurrentMap;->remove(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 130
    invoke-virtual {v2}, Ljava/util/concurrent/ExecutionException;->getCause()Ljava/lang/Throwable;

    move-result-object v0

    .line 131
    instance-of v1, v0, Lcom/subgraph/orchid/ConnectionTimeoutException;

    if-eqz v1, :cond_90

    .line 132
    check-cast v0, Lcom/subgraph/orchid/ConnectionTimeoutException;

    throw v0

    .line 133
    :cond_90
    instance-of v1, v0, Lcom/subgraph/orchid/ConnectionFailedException;

    if-eqz v1, :cond_97

    .line 134
    check-cast v0, Lcom/subgraph/orchid/ConnectionFailedException;

    throw v0

    .line 135
    :cond_97
    instance-of v1, v0, Lcom/subgraph/orchid/ConnectionHandshakeException;

    if-eqz v1, :cond_9e

    .line 136
    check-cast v0, Lcom/subgraph/orchid/ConnectionHandshakeException;

    throw v0

    .line 138
    :cond_9e
    new-instance v0, Ljava/lang/RuntimeException;

    new-instance v1, Ljava/lang/StringBuilder;

    const-string v3, "Unexpected exception: "

    invoke-direct {v1, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v1

    invoke-direct {v0, v1, v2}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V

    throw v0

    .line 124
    :cond_b3
    return-object v0
.end method

.method public final a(Lcom/subgraph/orchid/c/d;Ljava/io/PrintWriter;I)V
    .registers 8

    .prologue
    .line 165
    and-int/lit8 v0, p3, 0x1

    if-nez v0, :cond_5

    .line 175
    :goto_4
    return-void

    .line 1178
    :cond_5
    and-int/lit8 v0, p3, 0x2

    if-eqz v0, :cond_4c

    const/4 v0, 0x1

    .line 1179
    :goto_a
    if-eqz v0, :cond_4e

    .line 1180
    const-string v0, "[Connection Cache (verbose)]"

    invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->println(Ljava/lang/String;)V

    .line 1184
    :goto_11
    invoke-virtual {p2}, Ljava/io/PrintWriter;->println()V

    .line 1188
    new-instance v1, Ljava/util/ArrayList;

    invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V

    .line 1189
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0}, Ljava/util/concurrent/ConcurrentMap;->values()Ljava/util/Collection;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;

    move-result-object v2

    :cond_23
    :goto_23
    invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_54

    invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/util/concurrent/Future;

    .line 1197
    :try_start_2f
    invoke-interface {v0}, Ljava/util/concurrent/Future;->isDone()Z

    move-result v3

    if-eqz v3, :cond_23

    invoke-interface {v0}, Ljava/util/concurrent/Future;->isCancelled()Z

    move-result v3

    if-nez v3, :cond_23

    .line 1198
    invoke-interface {v0}, Ljava/util/concurrent/Future;->get()Ljava/lang/Object;

    move-result-object v0

    invoke-interface {v1, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
    :try_end_42
    .catch Ljava/lang/InterruptedException; {:try_start_2f .. :try_end_42} :catch_43
    .catch Ljava/util/concurrent/ExecutionException; {:try_start_2f .. :try_end_42} :catch_72

    goto :goto_23

    .line 1201
    :catch_43
    move-exception v0

    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V

    goto :goto_23

    .line 1178
    :cond_4c
    const/4 v0, 0x0

    goto :goto_a

    .line 1182
    :cond_4e
    const-string v0, "[Connection Cache]"

    invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->println(Ljava/lang/String;)V

    goto :goto_11

    .line 169
    :cond_54
    invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v1

    :cond_58
    :goto_58
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_6e

    invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/subgraph/orchid/g;

    .line 170
    invoke-interface {v0}, Lcom/subgraph/orchid/g;->isClosed()Z

    move-result v2

    if-nez v2, :cond_58

    .line 171
    invoke-interface {p1, p2, p3, v0}, Lcom/subgraph/orchid/c/d;->a(Ljava/io/PrintWriter;ILjava/lang/Object;)V

    goto :goto_58

    .line 174
    :cond_6e
    invoke-virtual {p2}, Ljava/io/PrintWriter;->println()V

    goto :goto_4

    .line 1191
    :catch_72
    move-exception v0

    goto :goto_23
.end method

.method public final close()V
    .registers 7

    .prologue
    const/4 v5, 0x1

    .line 82
    iget-boolean v0, p0, Lcom/subgraph/orchid/b/a;->bCb:Z

    if-eqz v0, :cond_6

    .line 105
    :goto_5
    return-void

    .line 85
    :cond_6
    iput-boolean v5, p0, Lcom/subgraph/orchid/b/a;->bCb:Z

    .line 86
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0}, Ljava/util/concurrent/ConcurrentMap;->values()Ljava/util/Collection;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;

    move-result-object v1

    :goto_12
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_55

    invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/util/concurrent/Future;

    .line 87
    invoke-interface {v0}, Ljava/util/concurrent/Future;->isDone()Z

    move-result v2

    if-eqz v2, :cond_51

    .line 89
    :try_start_24
    invoke-interface {v0}, Ljava/util/concurrent/Future;->get()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/subgraph/orchid/b/h;

    .line 90
    invoke-virtual {v0}, Lcom/subgraph/orchid/b/h;->LM()V
    :try_end_2d
    .catch Ljava/lang/InterruptedException; {:try_start_24 .. :try_end_2d} :catch_2e
    .catch Ljava/util/concurrent/ExecutionException; {:try_start_24 .. :try_end_2d} :catch_37

    goto :goto_12

    .line 92
    :catch_2e
    move-exception v0

    sget-object v0, Lcom/subgraph/orchid/b/a;->logger:Ljava/util/logging/Logger;

    const-string v2, "Unexpected interruption while closing connection"

    invoke-virtual {v0, v2}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V

    goto :goto_12

    .line 93
    :catch_37
    move-exception v0

    .line 94
    sget-object v2, Lcom/subgraph/orchid/b/a;->logger:Ljava/util/logging/Logger;

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "Exception closing connection: "

    invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-virtual {v0}, Ljava/util/concurrent/ExecutionException;->getCause()Ljava/lang/Throwable;

    move-result-object v0

    invoke-virtual {v3, 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

    invoke-virtual {v2, v0}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V

    goto :goto_12

    .line 100
    :cond_51
    invoke-interface {v0, v5}, Ljava/util/concurrent/Future;->cancel(Z)Z

    goto :goto_12

    .line 103
    :cond_55
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bFr:Ljava/util/concurrent/ConcurrentMap;

    invoke-interface {v0}, Ljava/util/concurrent/ConcurrentMap;->clear()V

    .line 104
    iget-object v0, p0, Lcom/subgraph/orchid/b/a;->bCm:Ljava/util/concurrent/ScheduledExecutorService;

    invoke-interface {v0}, Ljava/util/concurrent/ScheduledExecutorService;->shutdownNow()Ljava/util/List;

    goto :goto_5
.end method

.method public final isClosed()Z
    .registers 2

    .prologue
    .line 109
    iget-boolean v0, p0, Lcom/subgraph/orchid/b/a;->bCb:Z

    return v0
.end method