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