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