j.smali
.class public Lcom/subgraph/orchid/directory/downloader/j;
.super Ljava/lang/Object;
.source "DirectoryDownloaderImpl.java"
# interfaces
.implements Lcom/subgraph/orchid/l;
# static fields
.field private static final logger:Ljava/util/logging/Logger;
# instance fields
.field private HU:Z
.field private final bBr:Lcom/subgraph/orchid/TorConfig;
.field private final bBt:Lcom/subgraph/orchid/circuits/u;
.field public bBv:Lcom/subgraph/orchid/e;
.field private bJB:Lcom/subgraph/orchid/directory/downloader/f;
.field private bJC:Ljava/lang/Thread;
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 26
const-class v0, Lcom/subgraph/orchid/directory/downloader/j;
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/directory/downloader/j;->logger:Ljava/util/logging/Logger;
return-void
.end method
.method public constructor <init>(Lcom/subgraph/orchid/TorConfig;Lcom/subgraph/orchid/circuits/u;)V
.registers 3
.prologue
.line 37
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 38
iput-object p1, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBr:Lcom/subgraph/orchid/TorConfig;
.line 39
iput-object p2, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBt:Lcom/subgraph/orchid/circuits/u;
.line 40
return-void
.end method
.method private NJ()Lcom/subgraph/orchid/k;
.registers 4
.prologue
.line 131
:try_start_0
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBv:Lcom/subgraph/orchid/e;
invoke-interface {v0}, Lcom/subgraph/orchid/e;->Ix()Lcom/subgraph/orchid/k;
:try_end_5
.catch Lcom/subgraph/orchid/OpenFailedException; {:try_start_0 .. :try_end_5} :catch_7
move-result-object v0
return-object v0
.line 132
:catch_7
move-exception v0
.line 133
new-instance v1, Lcom/subgraph/orchid/directory/downloader/DirectoryRequestFailedException;
const-string v2, "Failed to open directory circuit"
invoke-direct {v1, v2, v0}, Lcom/subgraph/orchid/directory/downloader/DirectoryRequestFailedException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.end method
.method private static a(Ljava/util/Set;Ljava/util/List;)Ljava/util/List;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"<T::",
"Lcom/subgraph/orchid/Descriptor;",
">(",
"Ljava/util/Set",
"<",
"Lcom/subgraph/orchid/d/c;",
">;",
"Ljava/util/List",
"<TT;>;)",
"Ljava/util/List",
"<TT;>;"
}
.end annotation
.prologue
.line 114
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
.line 115
const/4 v0, 0x0
.line 116
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v3
move v1, v0
:goto_b
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_29
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/subgraph/orchid/Descriptor;
.line 117
invoke-interface {v0}, Lcom/subgraph/orchid/Descriptor;->IS()Lcom/subgraph/orchid/d/c;
move-result-object v4
invoke-interface {p0, v4}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v4
if-eqz v4, :cond_25
.line 118
invoke-interface {v2, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_b
.line 120
:cond_25
add-int/lit8 v0, v1, 0x1
move v1, v0
.line 122
goto :goto_b
.line 123
:cond_29
if-lez v1, :cond_45
.line 124
sget-object v0, Lcom/subgraph/orchid/directory/downloader/j;->logger:Ljava/util/logging/Logger;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Discarding "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v3, " received descriptor(s) with fingerprints that did not match requested descriptors"
invoke-virtual {v1, v3}, 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 126
:cond_45
return-object v2
.end method
.method private l(Lcom/subgraph/orchid/v;)Lcom/subgraph/orchid/k;
.registers 6
.prologue
.line 139
:try_start_0
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBv:Lcom/subgraph/orchid/e;
const/4 v1, 0x1
new-array v1, v1, [Lcom/subgraph/orchid/v;
const/4 v2, 0x0
aput-object p1, v1, v2
invoke-static {v1}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v1
invoke-interface {v0, v1}, Lcom/subgraph/orchid/e;->ac(Ljava/util/List;)Lcom/subgraph/orchid/k;
:try_end_f
.catch Lcom/subgraph/orchid/OpenFailedException; {:try_start_0 .. :try_end_f} :catch_11
move-result-object v0
return-object v0
.line 140
:catch_11
move-exception v0
.line 141
new-instance v1, Lcom/subgraph/orchid/directory/downloader/DirectoryRequestFailedException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Failed to open directory circuit to bridge "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2, v0}, Lcom/subgraph/orchid/directory/downloader/DirectoryRequestFailedException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.end method
# virtual methods
.method public final declared-synchronized a(Lcom/subgraph/orchid/j;)V
.registers 4
.prologue
.line 47
monitor-enter p0
:try_start_1
iget-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->HU:Z
if-eqz v0, :cond_e
.line 48
sget-object v0, Lcom/subgraph/orchid/directory/downloader/j;->logger:Ljava/util/logging/Logger;
const-string v1, "Directory downloader already running"
invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V
:try_end_c
.catchall {:try_start_1 .. :try_end_c} :catchall_1a
.line 59
:goto_c
monitor-exit p0
return-void
.line 51
:cond_e
:try_start_e
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBv:Lcom/subgraph/orchid/e;
if-nez v0, :cond_1d
.line 52
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Must set CircuitManager instance with setCircuitManager() before starting."
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_1a
.catchall {:try_start_e .. :try_end_1a} :catchall_1a
.line 47
:catchall_1a
move-exception v0
monitor-exit p0
throw v0
.line 55
:cond_1d
:try_start_1d
new-instance v0, Lcom/subgraph/orchid/directory/downloader/f;
iget-object v1, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBr:Lcom/subgraph/orchid/TorConfig;
invoke-direct {v0, v1, p1, p0}, Lcom/subgraph/orchid/directory/downloader/f;-><init>(Lcom/subgraph/orchid/TorConfig;Lcom/subgraph/orchid/j;Lcom/subgraph/orchid/l;)V
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bJB:Lcom/subgraph/orchid/directory/downloader/f;
.line 56
new-instance v0, Ljava/lang/Thread;
iget-object v1, p0, Lcom/subgraph/orchid/directory/downloader/j;->bJB:Lcom/subgraph/orchid/directory/downloader/f;
invoke-direct {v0, v1}, Ljava/lang/Thread;-><init>(Ljava/lang/Runnable;)V
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bJC:Ljava/lang/Thread;
.line 57
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bJC:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->start()V
.line 58
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->HU:Z
:try_end_37
.catchall {:try_start_1d .. :try_end_37} :catchall_1a
goto :goto_c
.end method
.method public final b(Lcom/subgraph/orchid/v;)Lcom/subgraph/orchid/w;
.registers 5
.prologue
.line 70
new-instance v0, Lcom/subgraph/orchid/directory/downloader/e;
invoke-direct {p0, p1}, Lcom/subgraph/orchid/directory/downloader/j;->l(Lcom/subgraph/orchid/v;)Lcom/subgraph/orchid/k;
move-result-object v1
invoke-direct {v0, v1}, Lcom/subgraph/orchid/directory/downloader/e;-><init>(Lcom/subgraph/orchid/k;)V
.line 1042
new-instance v1, Lcom/subgraph/orchid/directory/downloader/a;
invoke-direct {v1}, Lcom/subgraph/orchid/directory/downloader/a;-><init>()V
.line 1062
const/4 v2, 0x0
invoke-virtual {v0, v1, v2}, Lcom/subgraph/orchid/directory/downloader/e;->a(Lcom/subgraph/orchid/directory/downloader/k;I)Ljava/lang/Object;
move-result-object v0
.line 1042
check-cast v0, Lcom/subgraph/orchid/w;
.line 71
return-object v0
.end method
.method public final bd(Z)Lcom/subgraph/orchid/ConsensusDocument;
.registers 5
.prologue
.line 76
invoke-direct {p0}, Lcom/subgraph/orchid/directory/downloader/j;->NJ()Lcom/subgraph/orchid/k;
move-result-object v0
.line 1080
new-instance v1, Lcom/subgraph/orchid/directory/downloader/e;
iget-object v2, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBt:Lcom/subgraph/orchid/circuits/u;
invoke-direct {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;-><init>(Lcom/subgraph/orchid/k;Lcom/subgraph/orchid/circuits/u;)V
.line 2046
new-instance v0, Lcom/subgraph/orchid/directory/downloader/c;
invoke-direct {v0, p1}, Lcom/subgraph/orchid/directory/downloader/c;-><init>(Z)V
const/4 v2, 0x1
invoke-virtual {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;->a(Lcom/subgraph/orchid/directory/downloader/k;I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/subgraph/orchid/ConsensusDocument;
.line 76
return-object v0
.end method
.method public final c(Ljava/util/Set;)Ljava/util/List;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Set",
"<",
"Lcom/subgraph/orchid/i;",
">;)",
"Ljava/util/List",
"<",
"Lcom/subgraph/orchid/s;",
">;"
}
.end annotation
.prologue
.line 85
invoke-direct {p0}, Lcom/subgraph/orchid/directory/downloader/j;->NJ()Lcom/subgraph/orchid/k;
move-result-object v0
.line 2089
new-instance v1, Lcom/subgraph/orchid/directory/downloader/e;
iget-object v2, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBt:Lcom/subgraph/orchid/circuits/u;
invoke-direct {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;-><init>(Lcom/subgraph/orchid/k;Lcom/subgraph/orchid/circuits/u;)V
.line 3050
new-instance v0, Lcom/subgraph/orchid/directory/downloader/b;
invoke-direct {v0, p1}, Lcom/subgraph/orchid/directory/downloader/b;-><init>(Ljava/util/Set;)V
const/4 v2, 0x2
invoke-virtual {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;->b(Lcom/subgraph/orchid/directory/downloader/k;I)Ljava/util/List;
move-result-object v0
.line 85
return-object v0
.end method
.method public final d(Ljava/util/Set;)Ljava/util/List;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Set",
"<",
"Lcom/subgraph/orchid/d/c;",
">;)",
"Ljava/util/List",
"<",
"Lcom/subgraph/orchid/w;",
">;"
}
.end annotation
.prologue
.line 94
invoke-direct {p0}, Lcom/subgraph/orchid/directory/downloader/j;->NJ()Lcom/subgraph/orchid/k;
move-result-object v0
.line 3098
new-instance v1, Lcom/subgraph/orchid/directory/downloader/e;
iget-object v2, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBt:Lcom/subgraph/orchid/circuits/u;
invoke-direct {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;-><init>(Lcom/subgraph/orchid/k;Lcom/subgraph/orchid/circuits/u;)V
.line 4054
new-instance v0, Lcom/subgraph/orchid/directory/downloader/n;
invoke-direct {v0, p1}, Lcom/subgraph/orchid/directory/downloader/n;-><init>(Ljava/util/Collection;)V
const/4 v2, 0x3
invoke-virtual {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;->b(Lcom/subgraph/orchid/directory/downloader/k;I)Ljava/util/List;
move-result-object v0
.line 3100
invoke-static {p1, v0}, Lcom/subgraph/orchid/directory/downloader/j;->a(Ljava/util/Set;Ljava/util/List;)Ljava/util/List;
move-result-object v0
.line 94
return-object v0
.end method
.method public final e(Ljava/util/Set;)Ljava/util/List;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Set",
"<",
"Lcom/subgraph/orchid/d/c;",
">;)",
"Ljava/util/List",
"<",
"Lcom/subgraph/orchid/x;",
">;"
}
.end annotation
.prologue
.line 104
invoke-direct {p0}, Lcom/subgraph/orchid/directory/downloader/j;->NJ()Lcom/subgraph/orchid/k;
move-result-object v0
.line 4108
new-instance v1, Lcom/subgraph/orchid/directory/downloader/e;
iget-object v2, p0, Lcom/subgraph/orchid/directory/downloader/j;->bBt:Lcom/subgraph/orchid/circuits/u;
invoke-direct {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;-><init>(Lcom/subgraph/orchid/k;Lcom/subgraph/orchid/circuits/u;)V
.line 5058
new-instance v0, Lcom/subgraph/orchid/directory/downloader/m;
invoke-direct {v0, p1}, Lcom/subgraph/orchid/directory/downloader/m;-><init>(Ljava/util/Collection;)V
const/4 v2, 0x3
invoke-virtual {v1, v0, v2}, Lcom/subgraph/orchid/directory/downloader/e;->b(Lcom/subgraph/orchid/directory/downloader/k;I)Ljava/util/List;
move-result-object v0
.line 4110
invoke-static {p1, v0}, Lcom/subgraph/orchid/directory/downloader/j;->a(Ljava/util/Set;Ljava/util/List;)Ljava/util/List;
move-result-object v0
.line 104
return-object v0
.end method
.method public final declared-synchronized stop()V
.registers 2
.prologue
.line 62
monitor-enter p0
:try_start_1
iget-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->HU:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_12
if-nez v0, :cond_7
.line 67
:goto_5
monitor-exit p0
return-void
.line 65
:cond_7
:try_start_7
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bJB:Lcom/subgraph/orchid/directory/downloader/f;
invoke-virtual {v0}, Lcom/subgraph/orchid/directory/downloader/f;->stop()V
.line 66
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/j;->bJC:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
:try_end_11
.catchall {:try_start_7 .. :try_end_11} :catchall_12
goto :goto_5
.line 62
:catchall_12
move-exception v0
monitor-exit p0
throw v0
.end method