f.smali
.class public Lcom/subgraph/orchid/directory/downloader/f;
.super Ljava/lang/Object;
.source "DirectoryDownloadTask.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 bBs:Lcom/subgraph/orchid/j;
.field private volatile bBz:Z
.field private final bCk:Lcom/subgraph/orchid/crypto/q;
.field private bEw:Lcom/subgraph/orchid/ConsensusDocument;
.field private final bJt:Lcom/subgraph/orchid/l;
.field private final bJu:Lcom/subgraph/orchid/directory/downloader/d;
.field private volatile bJv:Z
.field private volatile bJw:Z
.field private final bJx:Ljava/util/concurrent/atomic/AtomicInteger;
.field private bJy:Ljava/util/Date;
.field private final executor:Ljava/util/concurrent/ExecutorService;
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 24
const-class v0, Lcom/subgraph/orchid/directory/downloader/f;
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/f;->logger:Ljava/util/logging/Logger;
return-void
.end method
.method constructor <init>(Lcom/subgraph/orchid/TorConfig;Lcom/subgraph/orchid/j;Lcom/subgraph/orchid/l;)V
.registers 5
.prologue
.line 45
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 34
const-string v0, "DirectoryDownloadTask worker"
invoke-static {v0}, Lcom/subgraph/orchid/ab;->gr(Ljava/lang/String;)Ljava/util/concurrent/ExecutorService;
move-result-object v0
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->executor:Ljava/util/concurrent/ExecutorService;
.line 46
iput-object p1, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBr:Lcom/subgraph/orchid/TorConfig;
.line 47
iput-object p2, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBs:Lcom/subgraph/orchid/j;
.line 48
iput-object p3, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJt:Lcom/subgraph/orchid/l;
.line 49
new-instance v0, Lcom/subgraph/orchid/crypto/q;
invoke-direct {v0}, Lcom/subgraph/orchid/crypto/q;-><init>()V
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bCk:Lcom/subgraph/orchid/crypto/q;
.line 50
new-instance v0, Ljava/util/concurrent/atomic/AtomicInteger;
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>()V
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJx:Ljava/util/concurrent/atomic/AtomicInteger;
.line 51
new-instance v0, Lcom/subgraph/orchid/directory/downloader/d;
invoke-direct {v0, p1, p2}, Lcom/subgraph/orchid/directory/downloader/d;-><init>(Lcom/subgraph/orchid/TorConfig;Lcom/subgraph/orchid/j;)V
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJu:Lcom/subgraph/orchid/directory/downloader/d;
.line 52
return-void
.end method
.method private NG()V
.registers 9
.prologue
const/4 v0, 0x1
.line 157
iget-object v1, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJx:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v1}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I
move-result v1
if-lez v1, :cond_a
.line 169
:cond_9
return-void
.line 160
:cond_a
iget-object v1, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJu:Lcom/subgraph/orchid/directory/downloader/d;
.line 6100
iget-object v2, v1, Lcom/subgraph/orchid/directory/downloader/d;->bBs:Lcom/subgraph/orchid/j;
invoke-interface {v2}, Lcom/subgraph/orchid/j;->Jd()Lcom/subgraph/orchid/ConsensusDocument;
move-result-object v2
.line 6101
if-eqz v2, :cond_1a
invoke-interface {v2}, Lcom/subgraph/orchid/ConsensusDocument;->IK()Z
move-result v2
if-nez v2, :cond_48
.line 6102
:cond_1a
invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
move-result-object v0
.line 162
:goto_1e
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v1
if-nez v1, :cond_9
.line 165
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_28
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_9
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/List;
.line 166
iget-object v2, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJx:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v2}, Ljava/util/concurrent/atomic/AtomicInteger;->incrementAndGet()I
.line 167
iget-object v2, p0, Lcom/subgraph/orchid/directory/downloader/f;->executor:Ljava/util/concurrent/ExecutorService;
new-instance v3, Lcom/subgraph/orchid/directory/downloader/i;
invoke-direct {p0}, Lcom/subgraph/orchid/directory/downloader/f;->NH()Z
move-result v4
invoke-direct {v3, p0, v0, v4}, Lcom/subgraph/orchid/directory/downloader/i;-><init>(Lcom/subgraph/orchid/directory/downloader/f;Ljava/util/Collection;Z)V
invoke-interface {v2, v3}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
goto :goto_28
.line 6104
:cond_48
iget-object v2, v1, Lcom/subgraph/orchid/directory/downloader/d;->bBs:Lcom/subgraph/orchid/j;
invoke-interface {v2}, Lcom/subgraph/orchid/j;->Jf()Ljava/util/List;
move-result-object v2
.line 6105
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v3
.line 7033
const/16 v4, 0x10
if-lt v3, v4, :cond_5d
.line 6105
:cond_56
:goto_56
if-nez v0, :cond_7c
.line 6106
invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
move-result-object v0
goto :goto_1e
.line 7035
:cond_5d
if-eqz v3, :cond_7a
.line 7037
iget-object v3, v1, Lcom/subgraph/orchid/directory/downloader/d;->bJr:Ljava/util/Date;
if-eqz v3, :cond_56
.line 7039
new-instance v3, Ljava/util/Date;
invoke-direct {v3}, Ljava/util/Date;-><init>()V
.line 7040
invoke-virtual {v3}, Ljava/util/Date;->getTime()J
move-result-wide v4
iget-object v3, v1, Lcom/subgraph/orchid/directory/downloader/d;->bJr:Ljava/util/Date;
invoke-virtual {v3}, Ljava/util/Date;->getTime()J
move-result-wide v6
sub-long/2addr v4, v6
.line 7041
const-wide/32 v6, 0x927c0
cmp-long v3, v4, v6
if-gtz v3, :cond_56
:cond_7a
const/4 v0, 0x0
goto :goto_56
.line 6109
:cond_7c
new-instance v0, Ljava/util/Date;
invoke-direct {v0}, Ljava/util/Date;-><init>()V
iput-object v0, v1, Lcom/subgraph/orchid/directory/downloader/d;->bJr:Ljava/util/Date;
.line 6110
invoke-virtual {v1, v2}, Lcom/subgraph/orchid/directory/downloader/d;->al(Ljava/util/List;)Ljava/util/List;
move-result-object v0
goto :goto_1e
.end method
.method private NH()Z
.registers 3
.prologue
.line 172
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBr:Lcom/subgraph/orchid/TorConfig;
invoke-interface {v0}, Lcom/subgraph/orchid/TorConfig;->Kt()Lcom/subgraph/orchid/TorConfig$AutoBoolValue;
move-result-object v0
sget-object v1, Lcom/subgraph/orchid/TorConfig$AutoBoolValue;->FALSE:Lcom/subgraph/orchid/TorConfig$AutoBoolValue;
if-eq v0, v1, :cond_c
const/4 v0, 0x1
:goto_b
return v0
:cond_c
const/4 v0, 0x0
goto :goto_b
.end method
.method static synthetic NI()Ljava/util/logging/Logger;
.registers 1
.prologue
.line 23
sget-object v0, Lcom/subgraph/orchid/directory/downloader/f;->logger:Ljava/util/logging/Logger;
return-object v0
.end method
.method static synthetic a(Lcom/subgraph/orchid/directory/downloader/f;)Z
.registers 2
.prologue
.line 23
invoke-direct {p0}, Lcom/subgraph/orchid/directory/downloader/f;->NH()Z
move-result v0
return v0
.end method
.method static synthetic b(Lcom/subgraph/orchid/directory/downloader/f;)Lcom/subgraph/orchid/l;
.registers 2
.prologue
.line 23
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJt:Lcom/subgraph/orchid/l;
return-object v0
.end method
.method static synthetic c(Lcom/subgraph/orchid/directory/downloader/f;)Lcom/subgraph/orchid/j;
.registers 2
.prologue
.line 23
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBs:Lcom/subgraph/orchid/j;
return-object v0
.end method
.method static synthetic d(Lcom/subgraph/orchid/directory/downloader/f;)Z
.registers 2
.prologue
.line 23
const/4 v0, 0x0
iput-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJw:Z
return v0
.end method
.method static synthetic e(Lcom/subgraph/orchid/directory/downloader/f;)Ljava/util/concurrent/atomic/AtomicInteger;
.registers 2
.prologue
.line 23
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJx:Ljava/util/concurrent/atomic/AtomicInteger;
return-object v0
.end method
.method static synthetic f(Lcom/subgraph/orchid/directory/downloader/f;)Z
.registers 2
.prologue
.line 23
const/4 v0, 0x0
iput-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJv:Z
return v0
.end method
# virtual methods
.method final a(Lcom/subgraph/orchid/ConsensusDocument;)V
.registers 10
.prologue
const/4 v0, 0x0
.line 90
if-eqz p1, :cond_49
.line 91
iput-object p1, p0, Lcom/subgraph/orchid/directory/downloader/f;->bEw:Lcom/subgraph/orchid/ConsensusDocument;
.line 3117
invoke-interface {p1}, Lcom/subgraph/orchid/ConsensusDocument;->IH()Lcom/subgraph/orchid/d/f;
move-result-object v0
.line 3144
invoke-virtual {v0}, Lcom/subgraph/orchid/d/f;->getDate()Ljava/util/Date;
move-result-object v0
invoke-virtual {v0}, Ljava/util/Date;->getTime()J
move-result-wide v0
.line 3118
invoke-interface {p1}, Lcom/subgraph/orchid/ConsensusDocument;->II()Lcom/subgraph/orchid/d/f;
move-result-object v2
.line 4144
invoke-virtual {v2}, Lcom/subgraph/orchid/d/f;->getDate()Ljava/util/Date;
move-result-object v2
invoke-virtual {v2}, Ljava/util/Date;->getTime()J
move-result-wide v2
.line 3119
invoke-interface {p1}, Lcom/subgraph/orchid/ConsensusDocument;->IJ()Lcom/subgraph/orchid/d/f;
move-result-object v4
.line 5144
invoke-virtual {v4}, Lcom/subgraph/orchid/d/f;->getDate()Ljava/util/Date;
move-result-object v4
invoke-virtual {v4}, Ljava/util/Date;->getTime()J
move-result-wide v4
.line 3120
sub-long v0, v2, v0
.line 3121
const-wide/16 v6, 0x3
mul-long/2addr v0, v6
const-wide/16 v6, 0x4
div-long/2addr v0, v6
add-long/2addr v0, v2
.line 3122
sub-long v2, v4, v0
const-wide/16 v4, 0x7
mul-long/2addr v2, v4
const-wide/16 v4, 0x8
div-long/2addr v2, v4
.line 3123
iget-object v4, p0, Lcom/subgraph/orchid/directory/downloader/f;->bCk:Lcom/subgraph/orchid/crypto/q;
invoke-virtual {v4, v2, v3}, Lcom/subgraph/orchid/crypto/q;->nextLong(J)J
move-result-wide v2
.line 3124
add-long/2addr v0, v2
.line 3125
new-instance v2, Ljava/util/Date;
invoke-direct {v2, v0, v1}, Ljava/util/Date;-><init>(J)V
.line 92
iput-object v2, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJy:Ljava/util/Date;
.line 97
:goto_48
return-void
.line 94
:cond_49
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bEw:Lcom/subgraph/orchid/ConsensusDocument;
.line 95
iput-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJy:Ljava/util/Date;
goto :goto_48
.end method
.method public run()V
.registers 7
.prologue
const/4 v2, 0x1
const/4 v1, 0x0
.line 63
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBs:Lcom/subgraph/orchid/j;
invoke-interface {v0}, Lcom/subgraph/orchid/j;->IZ()V
.line 64
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBs:Lcom/subgraph/orchid/j;
invoke-interface {v0}, Lcom/subgraph/orchid/j;->Ja()V
.line 65
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBs:Lcom/subgraph/orchid/j;
invoke-interface {v0}, Lcom/subgraph/orchid/j;->Jd()Lcom/subgraph/orchid/ConsensusDocument;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/subgraph/orchid/directory/downloader/f;->a(Lcom/subgraph/orchid/ConsensusDocument;)V
.line 66
:goto_15
iget-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBz:Z
if-nez v0, :cond_49
.line 1080
iget-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJv:Z
if-nez v0, :cond_29
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBs:Lcom/subgraph/orchid/j;
.line 1081
invoke-interface {v0}, Lcom/subgraph/orchid/j;->IN()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->isEmpty()Z
move-result v0
if-eqz v0, :cond_4a
.line 1148
:cond_29
:goto_29
iget-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJw:Z
if-nez v0, :cond_38
.line 2129
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBs:Lcom/subgraph/orchid/j;
invoke-interface {v0}, Lcom/subgraph/orchid/j;->Je()Z
move-result v0
if-eqz v0, :cond_57
move v0, v1
.line 1148
:goto_36
if-nez v0, :cond_84
.line 69
:cond_38
:goto_38
invoke-direct {p0}, Lcom/subgraph/orchid/directory/downloader/f;->NG()V
.line 71
const-wide/16 v4, 0x1388
:try_start_3d
invoke-static {v4, v5}, Ljava/lang/Thread;->sleep(J)V
:try_end_40
.catch Ljava/lang/InterruptedException; {:try_start_3d .. :try_end_40} :catch_41
goto :goto_15
.line 73
:catch_41
move-exception v0
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
.line 77
:cond_49
return-void
.line 1085
:cond_4a
iput-boolean v2, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJv:Z
.line 1086
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->executor:Ljava/util/concurrent/ExecutorService;
new-instance v3, Lcom/subgraph/orchid/directory/downloader/g;
invoke-direct {v3, p0, v1}, Lcom/subgraph/orchid/directory/downloader/g;-><init>(Lcom/subgraph/orchid/directory/downloader/f;B)V
invoke-interface {v0, v3}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
goto :goto_29
.line 2132
:cond_57
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bEw:Lcom/subgraph/orchid/ConsensusDocument;
if-eqz v0, :cond_63
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bEw:Lcom/subgraph/orchid/ConsensusDocument;
invoke-interface {v0}, Lcom/subgraph/orchid/ConsensusDocument;->IK()Z
move-result v0
if-nez v0, :cond_78
.line 2133
:cond_63
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bEw:Lcom/subgraph/orchid/ConsensusDocument;
if-nez v0, :cond_70
.line 2134
sget-object v0, Lcom/subgraph/orchid/directory/downloader/f;->logger:Ljava/util/logging/Logger;
const-string v3, "Downloading consensus because we have no consensus document"
invoke-virtual {v0, v3}, Ljava/util/logging/Logger;->info(Ljava/lang/String;)V
:goto_6e
move v0, v2
.line 2138
goto :goto_36
.line 2136
:cond_70
sget-object v0, Lcom/subgraph/orchid/directory/downloader/f;->logger:Ljava/util/logging/Logger;
const-string v3, "Downloading consensus because the document we have is not live"
invoke-virtual {v0, v3}, Ljava/util/logging/Logger;->info(Ljava/lang/String;)V
goto :goto_6e
.line 2140
:cond_78
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJy:Ljava/util/Date;
new-instance v3, Ljava/util/Date;
invoke-direct {v3}, Ljava/util/Date;-><init>()V
invoke-virtual {v0, v3}, Ljava/util/Date;->before(Ljava/util/Date;)Z
move-result v0
goto :goto_36
.line 1152
:cond_84
iput-boolean v2, p0, Lcom/subgraph/orchid/directory/downloader/f;->bJw:Z
.line 1153
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->executor:Ljava/util/concurrent/ExecutorService;
new-instance v3, Lcom/subgraph/orchid/directory/downloader/h;
invoke-direct {v3, p0, v1}, Lcom/subgraph/orchid/directory/downloader/h;-><init>(Lcom/subgraph/orchid/directory/downloader/f;B)V
invoke-interface {v0, v3}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
goto :goto_38
.end method
.method public final declared-synchronized stop()V
.registers 2
.prologue
.line 55
monitor-enter p0
:try_start_1
iget-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBz:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_10
if-eqz v0, :cond_7
.line 60
:goto_5
monitor-exit p0
return-void
.line 58
:cond_7
:try_start_7
iget-object v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->executor:Ljava/util/concurrent/ExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->shutdownNow()Ljava/util/List;
.line 59
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/subgraph/orchid/directory/downloader/f;->bBz:Z
:try_end_f
.catchall {:try_start_7 .. :try_end_f} :catchall_10
goto :goto_5
.line 55
:catchall_10
move-exception v0
monitor-exit p0
throw v0
.end method