DeterministicKeyChain.smali
.class public Lorg/bitcoinj/wallet/DeterministicKeyChain;
.super Ljava/lang/Object;
.source "DeterministicKeyChain.java"
# interfaces
.implements Lorg/bitcoinj/wallet/EncryptableKeyChain;
# static fields
.field public static final ACCOUNT_ZERO_PATH:Lcom/google/common/collect/ImmutableList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;"
}
.end annotation
.end field
.field public static final BIP44_ACCOUNT_ZERO_PATH:Lcom/google/common/collect/ImmutableList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;"
}
.end annotation
.end field
.field public static final DEFAULT_PASSPHRASE_FOR_MNEMONIC:Ljava/lang/String; = ""
.field public static final EXTERNAL_PATH:Lcom/google/common/collect/ImmutableList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;"
}
.end annotation
.end field
.field public static final EXTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;"
}
.end annotation
.end field
.field public static final INTERNAL_PATH:Lcom/google/common/collect/ImmutableList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;"
}
.end annotation
.end field
.field public static final INTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;"
}
.end annotation
.end field
.field private static final LAZY_CALCULATE_LOOKAHEAD:I = -0x1
.field private static final log:Lorg/slf4j/Logger;
# instance fields
.field private final basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
.field private externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.field private hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
.field private internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.field private isFollowing:Z
.field private issuedExternalKeys:I
.field private issuedInternalKeys:I
.field private keyLookaheadEpoch:I
.field protected final lock:Ljava/util/concurrent/locks/ReentrantLock;
.field protected lookaheadSize:I
.field protected lookaheadThreshold:I
.field private rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
.field private seed:Lorg/bitcoinj/wallet/DeterministicSeed;
.field protected sigsRequiredToSpend:I
# direct methods
.method static constructor <clinit>()V
.registers 3
.prologue
.line 99
const-class v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->getLogger(Ljava/lang/Class;)Lorg/slf4j/Logger;
move-result-object v0
sput-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->log:Lorg/slf4j/Logger;
.line 114
sget-object v0, Lorg/bitcoinj/crypto/ChildNumber;->ZERO_HARDENED:Lorg/bitcoinj/crypto/ChildNumber;
invoke-static {v0}, Lcom/google/common/collect/ImmutableList;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
sput-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->ACCOUNT_ZERO_PATH:Lcom/google/common/collect/ImmutableList;
.line 115
sget-object v0, Lorg/bitcoinj/crypto/ChildNumber;->ZERO:Lorg/bitcoinj/crypto/ChildNumber;
invoke-static {v0}, Lcom/google/common/collect/ImmutableList;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
sput-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->EXTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
.line 116
sget-object v0, Lorg/bitcoinj/crypto/ChildNumber;->ONE:Lorg/bitcoinj/crypto/ChildNumber;
invoke-static {v0}, Lcom/google/common/collect/ImmutableList;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
sput-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->INTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
.line 117
sget-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->ACCOUNT_ZERO_PATH:Lcom/google/common/collect/ImmutableList;
sget-object v1, Lorg/bitcoinj/wallet/DeterministicKeyChain;->EXTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
invoke-static {v0, v1}, Lorg/bitcoinj/crypto/HDUtils;->concat(Ljava/util/List;Ljava/util/List;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
sput-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->EXTERNAL_PATH:Lcom/google/common/collect/ImmutableList;
.line 118
sget-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->ACCOUNT_ZERO_PATH:Lcom/google/common/collect/ImmutableList;
sget-object v1, Lorg/bitcoinj/wallet/DeterministicKeyChain;->INTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
invoke-static {v0, v1}, Lorg/bitcoinj/crypto/HDUtils;->concat(Ljava/util/List;Ljava/util/List;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
sput-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->INTERNAL_PATH:Lcom/google/common/collect/ImmutableList;
.line 120
new-instance v0, Lorg/bitcoinj/crypto/ChildNumber;
const/16 v1, 0x2c
const/4 v2, 0x1
invoke-direct {v0, v1, v2}, Lorg/bitcoinj/crypto/ChildNumber;-><init>(IZ)V
sget-object v1, Lorg/bitcoinj/crypto/ChildNumber;->ZERO_HARDENED:Lorg/bitcoinj/crypto/ChildNumber;
sget-object v2, Lorg/bitcoinj/crypto/ChildNumber;->ZERO_HARDENED:Lorg/bitcoinj/crypto/ChildNumber;
.line 121
invoke-static {v0, v1, v2}, Lcom/google/common/collect/ImmutableList;->of(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
sput-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->BIP44_ACCOUNT_ZERO_PATH:Lcom/google/common/collect/ImmutableList;
.line 120
return-void
.end method
.method public constructor <init>(Ljava/security/SecureRandom;)V
.registers 8
.prologue
.line 275
const/16 v2, 0x80
const-string v3, ""
invoke-static {}, Lorg/bitcoinj/core/Utils;->currentTimeSeconds()J
move-result-wide v4
move-object v0, p0
move-object v1, p1
invoke-direct/range {v0 .. v5}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Ljava/security/SecureRandom;ILjava/lang/String;J)V
.line 276
return-void
.end method
.method public constructor <init>(Ljava/security/SecureRandom;I)V
.registers 9
.prologue
.line 283
const-string v3, ""
invoke-static {}, Lorg/bitcoinj/core/Utils;->currentTimeSeconds()J
move-result-wide v4
move-object v0, p0
move-object v1, p1
move v2, p2
invoke-direct/range {v0 .. v5}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Ljava/security/SecureRandom;ILjava/lang/String;J)V
.line 284
return-void
.end method
.method public constructor <init>(Ljava/security/SecureRandom;ILjava/lang/String;J)V
.registers 12
.prologue
.line 292
new-instance v0, Lorg/bitcoinj/wallet/DeterministicSeed;
move-object v1, p1
move v2, p2
move-object v3, p3
move-wide v4, p4
invoke-direct/range {v0 .. v5}, Lorg/bitcoinj/wallet/DeterministicSeed;-><init>(Ljava/security/SecureRandom;ILjava/lang/String;J)V
invoke-direct {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/wallet/DeterministicSeed;)V
.line 293
return-void
.end method
.method public constructor <init>(Lorg/bitcoinj/crypto/DeterministicKey;)V
.registers 6
.prologue
const/4 v3, 0x0
const/4 v0, 0x1
.line 317
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 102
const-string v1, "DeterministicKeyChain"
invoke-static {v1}, Lorg/bitcoinj/utils/Threading;->lock(Ljava/lang/String;)Ljava/util/concurrent/locks/ReentrantLock;
move-result-object v1
iput-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
.line 128
const/16 v1, 0x64
iput v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
.line 132
invoke-direct {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->calcDefaultLookaheadThreshold()I
move-result v1
iput v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
.line 160
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->sigsRequiredToSpend:I
.line 318
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->isPubKeyOnly()Z
move-result v1
const-string v2, "Private subtrees not currently supported: if you got this key from DKC.getWatchingKey() then use .dropPrivate().dropParent() on it first."
invoke-static {v1, v2}, Lcom/google/common/base/n;->checkArgument(ZLjava/lang/Object;)V
.line 319
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-virtual {v1}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v1
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v2
invoke-virtual {v2}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v2
if-ne v1, v2, :cond_52
:goto_34
const-string v1, "You can only watch an account key currently"
invoke-static {v0, v1}, Lcom/google/common/base/n;->checkArgument(ZLjava/lang/Object;)V
.line 320
new-instance v0, Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-direct {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;-><init>()V
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
.line 321
iput-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
.line 322
iput-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 323
invoke-direct {p0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->addToBasicChain(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 324
new-instance v0, Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-direct {v0, p1}, Lorg/bitcoinj/crypto/DeterministicHierarchy;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;)V
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
.line 325
invoke-direct {p0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->initializeHierarchyUnencrypted(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 326
return-void
.line 319
:cond_52
const/4 v0, 0x0
goto :goto_34
.end method
.method protected constructor <init>(Lorg/bitcoinj/crypto/DeterministicKey;Z)V
.registers 3
.prologue
.line 334
invoke-direct {p0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 335
iput-boolean p2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->isFollowing:Z
.line 336
return-void
.end method
.method protected constructor <init>(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/wallet/DeterministicKeyChain;)V
.registers 9
.prologue
const/4 v1, 0x1
const/4 v2, 0x0
.line 381
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 102
const-string v0, "DeterministicKeyChain"
invoke-static {v0}, Lorg/bitcoinj/utils/Threading;->lock(Ljava/lang/String;)Ljava/util/concurrent/locks/ReentrantLock;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
.line 128
const/16 v0, 0x64
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
.line 132
invoke-direct {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->calcDefaultLookaheadThreshold()I
move-result v0
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
.line 160
iput v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->sigsRequiredToSpend:I
.line 383
iget-object v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 384
iget-object v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 386
iget-object v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->isEncrypted()Z
move-result v0
if-nez v0, :cond_83
move v0, v1
:goto_2c
const-string v3, "Chain already encrypted"
invoke-static {v0, v3}, Lcom/google/common/base/n;->checkArgument(ZLjava/lang/Object;)V
.line 388
iget v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
.line 389
iget v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
.line 391
iget v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
.line 392
iget v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
.line 394
iget-object v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v0, p1, p2}, Lorg/bitcoinj/wallet/DeterministicSeed;->encrypt(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicSeed;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
.line 395
new-instance v0, Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-direct {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;-><init>(Lorg/bitcoinj/crypto/KeyCrypter;)V
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
.line 397
iget-object v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
const/4 v3, 0x0
invoke-virtual {v0, p1, p2, v3}, Lorg/bitcoinj/crypto/DeterministicKey;->encrypt(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 398
new-instance v0, Lorg/bitcoinj/crypto/DeterministicHierarchy;
iget-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-direct {v0, v3}, Lorg/bitcoinj/crypto/DeterministicHierarchy;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;)V
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
.line 399
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
iget-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v0, v3}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKey(Lorg/bitcoinj/core/ECKey;)V
.line 401
:goto_69
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v0
invoke-virtual {v0}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v0
if-ge v1, v0, :cond_85
.line 402
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v3
invoke-virtual {v3, v2, v1}, Lcom/google/common/collect/ImmutableList;->subList(II)Lcom/google/common/collect/ImmutableList;
move-result-object v3
invoke-direct {p0, p2, p3, v0, v3}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->encryptNonLeaf(Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/wallet/DeterministicKeyChain;Lorg/bitcoinj/crypto/DeterministicKey;Lcom/google/common/collect/ImmutableList;)Lorg/bitcoinj/crypto/DeterministicKey;
.line 401
add-int/lit8 v1, v1, 0x1
goto :goto_69
:cond_83
move v0, v2
.line 386
goto :goto_2c
.line 404
:cond_85
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-direct {p0, p2, p3, v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->encryptNonLeaf(Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/wallet/DeterministicKeyChain;Lorg/bitcoinj/crypto/DeterministicKey;Lcom/google/common/collect/ImmutableList;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
.line 405
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
sget-object v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->EXTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
invoke-static {v1, v3}, Lorg/bitcoinj/crypto/HDUtils;->concat(Ljava/util/List;Ljava/util/List;)Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-direct {p0, p2, p3, v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->encryptNonLeaf(Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/wallet/DeterministicKeyChain;Lorg/bitcoinj/crypto/DeterministicKey;Lcom/google/common/collect/ImmutableList;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
iput-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 406
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
sget-object v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->INTERNAL_SUBPATH:Lcom/google/common/collect/ImmutableList;
invoke-static {v1, v3}, Lorg/bitcoinj/crypto/HDUtils;->concat(Ljava/util/List;Ljava/util/List;)Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-direct {p0, p2, p3, v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->encryptNonLeaf(Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/wallet/DeterministicKeyChain;Lorg/bitcoinj/crypto/DeterministicKey;Lcom/google/common/collect/ImmutableList;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 410
iget-object v0, p3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->getKeys()Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v3
:cond_b9
:goto_b9
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_103
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/core/ECKey;
.line 411
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
.line 412
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-virtual {v1}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v1
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v4
invoke-virtual {v4}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v4
add-int/lit8 v4, v4, 0x2
if-ne v1, v4, :cond_b9
.line 413
iget-object v4, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
invoke-static {v1}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-virtual {v4, v1, v2, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->get(Ljava/util/List;ZZ)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
.line 415
new-instance v4, Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->dropPrivateBytes()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
invoke-direct {v4, v0, v1}, Lorg/bitcoinj/crypto/DeterministicKey;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 416
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v0, v4}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->putKey(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 417
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, v4}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKey(Lorg/bitcoinj/core/ECKey;)V
goto :goto_b9
.line 419
:cond_103
return-void
.end method
.method protected constructor <init>(Lorg/bitcoinj/wallet/DeterministicSeed;)V
.registers 3
.prologue
.line 309
const/4 v0, 0x0
invoke-direct {p0, p1, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/wallet/DeterministicSeed;Lorg/bitcoinj/crypto/KeyCrypter;)V
.line 310
return-void
.end method
.method protected constructor <init>(Lorg/bitcoinj/wallet/DeterministicSeed;Lorg/bitcoinj/crypto/KeyCrypter;)V
.registers 8
.prologue
const/4 v4, 0x0
const/4 v1, 0x1
.line 357
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 102
const-string v0, "DeterministicKeyChain"
invoke-static {v0}, Lorg/bitcoinj/utils/Threading;->lock(Ljava/lang/String;)Ljava/util/concurrent/locks/ReentrantLock;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
.line 128
const/16 v0, 0x64
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
.line 132
invoke-direct {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->calcDefaultLookaheadThreshold()I
move-result v0
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
.line 160
iput v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->sigsRequiredToSpend:I
.line 358
iput-object p1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
.line 359
new-instance v0, Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-direct {v0, p2}, Lorg/bitcoinj/wallet/BasicKeyChain;-><init>(Lorg/bitcoinj/crypto/KeyCrypter;)V
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
.line 360
invoke-virtual {p1}, Lorg/bitcoinj/wallet/DeterministicSeed;->isEncrypted()Z
move-result v0
if-nez v0, :cond_73
.line 361
invoke-virtual {p1}, Lorg/bitcoinj/wallet/DeterministicSeed;->getSeedBytes()[B
move-result-object v0
invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, [B
invoke-static {v0}, Lorg/bitcoinj/crypto/HDKeyDerivation;->createMasterPrivateKey([B)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 362
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {p1}, Lorg/bitcoinj/wallet/DeterministicSeed;->getCreationTimeSeconds()J
move-result-wide v2
invoke-virtual {v0, v2, v3}, Lorg/bitcoinj/crypto/DeterministicKey;->setCreationTimeSeconds(J)V
.line 363
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-direct {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->addToBasicChain(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 364
new-instance v0, Lorg/bitcoinj/crypto/DeterministicHierarchy;
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-direct {v0, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;)V
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
move v0, v1
.line 365
:goto_50
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v2
invoke-virtual {v2}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v2
if-gt v0, v2, :cond_6e
.line 366
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v3
invoke-virtual {v3, v4, v0}, Lcom/google/common/collect/ImmutableList;->subList(II)Lcom/google/common/collect/ImmutableList;
move-result-object v3
invoke-virtual {v2, v3, v4, v1}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->get(Ljava/util/List;ZZ)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v2
invoke-direct {p0, v2}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->addToBasicChain(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 365
add-int/lit8 v0, v0, 0x1
goto :goto_50
.line 368
:cond_6e
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-direct {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->initializeHierarchyUnencrypted(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 373
:cond_73
return-void
.end method
.method public constructor <init>([BLjava/lang/String;J)V
.registers 6
.prologue
.line 301
new-instance v0, Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-direct {v0, p1, p2, p3, p4}, Lorg/bitcoinj/wallet/DeterministicSeed;-><init>([BLjava/lang/String;J)V
invoke-direct {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/wallet/DeterministicSeed;)V
.line 302
return-void
.end method
.method private addToBasicChain(Lorg/bitcoinj/crypto/DeterministicKey;)V
.registers 4
.prologue
.line 518
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-static {p1}, Lcom/google/common/collect/ImmutableList;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-virtual {v0, v1}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKeys(Ljava/util/List;)I
.line 519
return-void
.end method
.method public static builder()Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;
.registers 1
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder",
"<*>;"
}
.end annotation
.prologue
.line 267
new-instance v0, Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;
invoke-direct {v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;-><init>()V
return-object v0
.end method
.method private calcDefaultLookaheadThreshold()I
.registers 2
.prologue
.line 135
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
div-int/lit8 v0, v0, 0x3
return v0
.end method
.method private checkForBitFlip(Lorg/bitcoinj/crypto/DeterministicKey;)V
.registers 9
.prologue
.line 510
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
.line 511
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getChildNumber()Lorg/bitcoinj/crypto/ChildNumber;
move-result-object v1
sget-object v2, Lorg/bitcoinj/crypto/HDKeyDerivation$PublicDeriveMode;->WITH_INVERSION:Lorg/bitcoinj/crypto/HDKeyDerivation$PublicDeriveMode;
invoke-static {v0, v1, v2}, Lorg/bitcoinj/crypto/HDKeyDerivation;->deriveChildKeyBytesFromPublic(Lorg/bitcoinj/crypto/DeterministicKey;Lorg/bitcoinj/crypto/ChildNumber;Lorg/bitcoinj/crypto/HDKeyDerivation$PublicDeriveMode;)Lorg/bitcoinj/crypto/HDKeyDerivation$RawKeyBytes;
move-result-object v0
iget-object v0, v0, Lorg/bitcoinj/crypto/HDKeyDerivation$RawKeyBytes;->keyBytes:[B
.line 512
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPubKey()[B
move-result-object v1
.line 513
invoke-static {v0, v1}, Ljava/util/Arrays;->equals([B[B)Z
move-result v2
if-nez v2, :cond_3f
.line 514
new-instance v2, Ljava/lang/IllegalStateException;
sget-object v3, Ljava/util/Locale;->US:Ljava/util/Locale;
const-string v4, "Bit-flip check failed: %s vs %s"
const/4 v5, 0x2
new-array v5, v5, [Ljava/lang/Object;
const/4 v6, 0x0
invoke-static {v0}, Ljava/util/Arrays;->toString([B)Ljava/lang/String;
move-result-object v0
aput-object v0, v5, v6
const/4 v0, 0x1
invoke-static {v1}, Ljava/util/Arrays;->toString([B)Ljava/lang/String;
move-result-object v1
aput-object v1, v5, v0
invoke-static {v3, v4, v5}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-direct {v2, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v2
.line 515
:cond_3f
return-void
.end method
.method private encryptNonLeaf(Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/wallet/DeterministicKeyChain;Lorg/bitcoinj/crypto/DeterministicKey;Lcom/google/common/collect/ImmutableList;)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lorg/spongycastle/crypto/params/KeyParameter;",
"Lorg/bitcoinj/wallet/DeterministicKeyChain;",
"Lorg/bitcoinj/crypto/DeterministicKey;",
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;)",
"Lorg/bitcoinj/crypto/DeterministicKey;"
}
.end annotation
.prologue
const/4 v1, 0x0
.line 428
iget-object v0, p2, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v0, p4, v1, v1}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->get(Ljava/util/List;ZZ)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
.line 429
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v0
invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/KeyCrypter;
invoke-virtual {v1, v0, p1, p3}, Lorg/bitcoinj/crypto/DeterministicKey;->encrypt(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
.line 430
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v1, v0}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->putKey(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 431
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v1, v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKey(Lorg/bitcoinj/core/ECKey;)V
.line 432
return-object v0
.end method
.method static fromProtobuf(Ljava/util/List;Lorg/bitcoinj/crypto/KeyCrypter;)Ljava/util/List;
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/wallet/Protos$Key;",
">;",
"Lorg/bitcoinj/crypto/KeyCrypter;",
")",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/wallet/DeterministicKeyChain;",
">;"
}
.end annotation
.prologue
.line 769
new-instance v0, Lorg/bitcoinj/wallet/DefaultKeyChainFactory;
invoke-direct {v0}, Lorg/bitcoinj/wallet/DefaultKeyChainFactory;-><init>()V
invoke-static {p0, p1, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->fromProtobuf(Ljava/util/List;Lorg/bitcoinj/crypto/KeyCrypter;Lorg/bitcoinj/wallet/KeyChainFactory;)Ljava/util/List;
move-result-object v0
return-object v0
.end method
.method public static fromProtobuf(Ljava/util/List;Lorg/bitcoinj/crypto/KeyCrypter;Lorg/bitcoinj/wallet/KeyChainFactory;)Ljava/util/List;
.registers 27
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/wallet/Protos$Key;",
">;",
"Lorg/bitcoinj/crypto/KeyCrypter;",
"Lorg/bitcoinj/wallet/KeyChainFactory;",
")",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/wallet/DeterministicKeyChain;",
">;"
}
.end annotation
.prologue
.line 3232
new-instance v21, Ljava/util/LinkedList;
invoke-direct/range {v21 .. v21}, Ljava/util/LinkedList;-><init>()V
.line 778
const/4 v6, 0x0
.line 779
const/16 v17, 0x0
.line 781
const/16 v19, -0x1
.line 782
const/16 v18, 0x1
.line 784
invoke-interface/range {p0 .. p0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
invoke-static {v2}, Lcom/google/common/collect/az;->k(Ljava/util/Iterator;)Lcom/google/common/collect/cu;
move-result-object v22
.line 785
:cond_14
:goto_14
invoke-interface/range {v22 .. v22}, Lcom/google/common/collect/cu;->hasNext()Z
move-result v2
if-eqz v2, :cond_35c
.line 786
invoke-interface/range {v22 .. v22}, Lcom/google/common/collect/cu;->next()Ljava/lang/Object;
move-result-object v2
move-object v15, v2
check-cast v15, Lorg/bitcoinj/wallet/Protos$Key;
.line 787
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getType()Lorg/bitcoinj/wallet/Protos$Key$Type;
move-result-object v2
.line 788
sget-object v3, Lorg/bitcoinj/wallet/Protos$Key$Type;->DETERMINISTIC_MNEMONIC:Lorg/bitcoinj/wallet/Protos$Key$Type;
if-ne v2, v3, :cond_128
.line 789
if-eqz v17, :cond_47
.line 790
if-ltz v19, :cond_76
const/4 v2, 0x1
:goto_2e
invoke-static {v2}, Lcom/google/common/base/n;->checkState(Z)V
.line 791
move-object/from16 v0, v17
move/from16 v1, v19
invoke-virtual {v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->setLookaheadSize(I)V
.line 792
invoke-virtual/range {v17 .. v18}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->setSigsRequiredToSpend(I)V
.line 793
invoke-virtual/range {v17 .. v17}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead()V
.line 794
move-object/from16 v0, v21
move-object/from16 v1, v17
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 795
const/16 v17, 0x0
.line 797
:cond_47
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getCreationTimestamp()J
move-result-wide v2
const-wide/16 v4, 0x3e8
div-long v6, v2, v4
.line 798
const-string v5, ""
.line 799
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasSecretBytes()Z
move-result v2
if-eqz v2, :cond_a6
.line 800
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasEncryptedDeterministicSeed()Z
move-result v2
if-eqz v2, :cond_78
.line 801
new-instance v2, Lorg/bitcoinj/wallet/UnreadableWalletException;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Malformed key proto: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v3}, Lorg/bitcoinj/wallet/UnreadableWalletException;-><init>(Ljava/lang/String;)V
throw v2
.line 790
:cond_76
const/4 v2, 0x0
goto :goto_2e
.line 802
:cond_78
const/4 v4, 0x0
.line 803
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasDeterministicSeed()Z
move-result v2
if-eqz v2, :cond_87
.line 804
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicSeed()Lcom/google/protobuf/ByteString;
move-result-object v2
invoke-virtual {v2}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v4
.line 806
:cond_87
new-instance v2, Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getSecretBytes()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v3}, Lcom/google/protobuf/ByteString;->toStringUtf8()Ljava/lang/String;
move-result-object v3
invoke-direct/range {v2 .. v7}, Lorg/bitcoinj/wallet/DeterministicSeed;-><init>(Ljava/lang/String;[BLjava/lang/String;J)V
move-object v6, v2
.line 822
:goto_95
sget-object v2, Lorg/bitcoinj/wallet/DeterministicKeyChain;->log:Lorg/slf4j/Logger;
invoke-interface {v2}, Lorg/slf4j/Logger;->isDebugEnabled()Z
move-result v2
if-eqz v2, :cond_14
.line 823
sget-object v2, Lorg/bitcoinj/wallet/DeterministicKeyChain;->log:Lorg/slf4j/Logger;
const-string v3, "Deserializing: DETERMINISTIC_MNEMONIC: {}"
invoke-interface {v2, v3, v6}, Lorg/slf4j/Logger;->debug(Ljava/lang/String;Ljava/lang/Object;)V
goto/16 :goto_14
.line 807
:cond_a6
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasEncryptedData()Z
move-result v2
if-eqz v2, :cond_10f
.line 808
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasDeterministicSeed()Z
move-result v2
if-eqz v2, :cond_cb
.line 809
new-instance v2, Lorg/bitcoinj/wallet/UnreadableWalletException;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Malformed key proto: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v3}, Lorg/bitcoinj/wallet/UnreadableWalletException;-><init>(Ljava/lang/String;)V
throw v2
.line 810
:cond_cb
new-instance v4, Lorg/bitcoinj/crypto/EncryptedData;
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getEncryptedData()Lorg/bitcoinj/wallet/Protos$EncryptedData;
move-result-object v2
invoke-virtual {v2}, Lorg/bitcoinj/wallet/Protos$EncryptedData;->getInitialisationVector()Lcom/google/protobuf/ByteString;
move-result-object v2
invoke-virtual {v2}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v2
.line 811
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getEncryptedData()Lorg/bitcoinj/wallet/Protos$EncryptedData;
move-result-object v3
invoke-virtual {v3}, Lorg/bitcoinj/wallet/Protos$EncryptedData;->getEncryptedPrivateKey()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v3}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v3
invoke-direct {v4, v2, v3}, Lorg/bitcoinj/crypto/EncryptedData;-><init>([B[B)V
.line 812
const/4 v2, 0x0
.line 813
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasEncryptedDeterministicSeed()Z
move-result v3
if-eqz v3, :cond_108
.line 814
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getEncryptedDeterministicSeed()Lorg/bitcoinj/wallet/Protos$EncryptedData;
move-result-object v3
.line 815
new-instance v2, Lorg/bitcoinj/crypto/EncryptedData;
invoke-virtual {v3}, Lorg/bitcoinj/wallet/Protos$EncryptedData;->getInitialisationVector()Lcom/google/protobuf/ByteString;
move-result-object v5
invoke-virtual {v5}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v5
.line 816
invoke-virtual {v3}, Lorg/bitcoinj/wallet/Protos$EncryptedData;->getEncryptedPrivateKey()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v3}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v3
invoke-direct {v2, v5, v3}, Lorg/bitcoinj/crypto/EncryptedData;-><init>([B[B)V
.line 818
:cond_108
new-instance v3, Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-direct {v3, v4, v2, v6, v7}, Lorg/bitcoinj/wallet/DeterministicSeed;-><init>(Lorg/bitcoinj/crypto/EncryptedData;Lorg/bitcoinj/crypto/EncryptedData;J)V
move-object v6, v3
.line 819
goto :goto_95
.line 820
:cond_10f
new-instance v2, Lorg/bitcoinj/wallet/UnreadableWalletException;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Malformed key proto: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v3}, Lorg/bitcoinj/wallet/UnreadableWalletException;-><init>(Ljava/lang/String;)V
throw v2
.line 824
:cond_128
sget-object v3, Lorg/bitcoinj/wallet/Protos$Key$Type;->DETERMINISTIC_KEY:Lorg/bitcoinj/wallet/Protos$Key$Type;
if-ne v2, v3, :cond_381
.line 825
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasDeterministicKey()Z
move-result v2
if-nez v2, :cond_14b
.line 826
new-instance v2, Lorg/bitcoinj/wallet/UnreadableWalletException;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Deterministic key missing extra data: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v3}, Lorg/bitcoinj/wallet/UnreadableWalletException;-><init>(Ljava/lang/String;)V
throw v2
.line 827
:cond_14b
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicKey()Lorg/bitcoinj/wallet/Protos$DeterministicKey;
move-result-object v2
invoke-virtual {v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey;->getChainCode()Lcom/google/protobuf/ByteString;
move-result-object v2
invoke-virtual {v2}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v4
.line 4232
new-instance v23, Ljava/util/LinkedList;
invoke-direct/range {v23 .. v23}, Ljava/util/LinkedList;-><init>()V
.line 830
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicKey()Lorg/bitcoinj/wallet/Protos$DeterministicKey;
move-result-object v2
invoke-virtual {v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey;->getPathList()Ljava/util/List;
move-result-object v2
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_168
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_183
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/Integer;
invoke-virtual {v2}, Ljava/lang/Integer;->intValue()I
move-result v2
.line 831
new-instance v5, Lorg/bitcoinj/crypto/ChildNumber;
invoke-direct {v5, v2}, Lorg/bitcoinj/crypto/ChildNumber;-><init>(I)V
move-object/from16 v0, v23
invoke-virtual {v0, v5}, Ljava/util/LinkedList;->add(Ljava/lang/Object;)Z
goto :goto_168
.line 833
:cond_183
new-instance v5, Lorg/bitcoinj/crypto/LazyECPoint;
sget-object v2, Lorg/bitcoinj/core/ECKey;->CURVE:Lorg/spongycastle/crypto/params/ECDomainParameters;
invoke-virtual {v2}, Lorg/spongycastle/crypto/params/ECDomainParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v2
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getPublicKey()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v3}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v3
invoke-direct {v5, v2, v3}, Lorg/bitcoinj/crypto/LazyECPoint;-><init>(Lorg/spongycastle/math/ec/ECCurve;[B)V
.line 834
invoke-static/range {v23 .. v23}, Lcom/google/common/collect/ImmutableList;->copyOf(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableList;
move-result-object v3
.line 836
const/4 v12, 0x0
.line 837
const/4 v10, 0x0
.line 840
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicKey()Lorg/bitcoinj/wallet/Protos$DeterministicKey;
move-result-object v2
invoke-virtual {v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey;->getIsFollowing()Z
move-result v2
if-eqz v2, :cond_37b
.line 841
if-eqz v17, :cond_1c5
.line 842
if-ltz v19, :cond_29d
const/4 v2, 0x1
:goto_1ab
invoke-static {v2}, Lcom/google/common/base/n;->checkState(Z)V
.line 843
move-object/from16 v0, v17
move/from16 v1, v19
invoke-virtual {v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->setLookaheadSize(I)V
.line 844
invoke-virtual/range {v17 .. v18}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->setSigsRequiredToSpend(I)V
.line 845
invoke-virtual/range {v17 .. v17}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead()V
.line 846
move-object/from16 v0, v21
move-object/from16 v1, v17
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 847
const/16 v17, 0x0
.line 848
const/4 v6, 0x0
.line 850
:cond_1c5
const/4 v10, 0x1
move-object/from16 v2, v17
move-object/from16 v20, v6
.line 852
:goto_1ca
if-nez v2, :cond_2b7
.line 854
if-nez v10, :cond_2a0
invoke-interface/range {v21 .. v21}, Ljava/util/List;->isEmpty()Z
move-result v2
if-nez v2, :cond_2a0
invoke-interface/range {v21 .. v21}, Ljava/util/List;->size()I
move-result v2
add-int/lit8 v2, v2, -0x1
move-object/from16 v0, v21
invoke-interface {v0, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lorg/bitcoinj/wallet/DeterministicKeyChain;
invoke-virtual {v2}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->isFollowing()Z
move-result v2
if-eqz v2, :cond_2a0
const/4 v11, 0x1
.line 855
:goto_1e9
if-nez v20, :cond_2a3
.line 856
new-instance v2, Lorg/bitcoinj/crypto/DeterministicKey;
const/4 v6, 0x0
const/4 v7, 0x0
invoke-direct/range {v2 .. v7}, Lorg/bitcoinj/crypto/DeterministicKey;-><init>(Lcom/google/common/collect/ImmutableList;[BLorg/bitcoinj/crypto/LazyECPoint;Ljava/math/BigInteger;Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 857
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getCreationTimestamp()J
move-result-wide v6
const-wide/16 v8, 0x3e8
div-long/2addr v6, v8
invoke-virtual {v2, v6, v7}, Lorg/bitcoinj/crypto/DeterministicKey;->setCreationTimeSeconds(J)V
.line 858
invoke-interface/range {v22 .. v22}, Lcom/google/common/collect/cu;->peek()Ljava/lang/Object;
move-result-object v8
check-cast v8, Lorg/bitcoinj/wallet/Protos$Key;
move-object/from16 v6, p2
move-object v7, v15
move-object v9, v2
invoke-interface/range {v6 .. v11}, Lorg/bitcoinj/wallet/KeyChainFactory;->makeWatchingKeyChain(Lorg/bitcoinj/wallet/Protos$Key;Lorg/bitcoinj/wallet/Protos$Key;Lorg/bitcoinj/crypto/DeterministicKey;ZZ)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v6
.line 859
const/4 v2, 0x1
move/from16 v16, v2
move-object/from16 v17, v6
.line 869
:goto_20f
const/4 v7, 0x0
.line 870
invoke-virtual/range {v23 .. v23}, Ljava/util/LinkedList;->isEmpty()Z
move-result v2
if-nez v2, :cond_22f
if-nez v16, :cond_22f
.line 871
invoke-virtual/range {v23 .. v23}, Ljava/util/LinkedList;->removeLast()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lorg/bitcoinj/crypto/ChildNumber;
.line 872
move-object/from16 v0, v17
iget-object v6, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
const/4 v7, 0x0
const/4 v8, 0x0
move-object/from16 v0, v23
invoke-virtual {v6, v0, v7, v8}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->get(Ljava/util/List;ZZ)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v7
.line 873
move-object/from16 v0, v23
invoke-virtual {v0, v2}, Ljava/util/LinkedList;->add(Ljava/lang/Object;)Z
.line 876
:cond_22f
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasSecretBytes()Z
move-result v2
if-eqz v2, :cond_2bd
.line 878
new-instance v6, Ljava/math/BigInteger;
const/4 v2, 0x1
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getSecretBytes()Lcom/google/protobuf/ByteString;
move-result-object v8
invoke-virtual {v8}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v8
invoke-direct {v6, v2, v8}, Ljava/math/BigInteger;-><init>(I[B)V
.line 879
new-instance v2, Lorg/bitcoinj/crypto/DeterministicKey;
invoke-direct/range {v2 .. v7}, Lorg/bitcoinj/crypto/DeterministicKey;-><init>(Lcom/google/common/collect/ImmutableList;[BLorg/bitcoinj/crypto/LazyECPoint;Ljava/math/BigInteger;Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 893
:goto_248
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasCreationTimestamp()Z
move-result v3
if-eqz v3, :cond_258
.line 894
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getCreationTimestamp()J
move-result-wide v4
const-wide/16 v6, 0x3e8
div-long/2addr v4, v6
invoke-virtual {v2, v4, v5}, Lorg/bitcoinj/crypto/DeterministicKey;->setCreationTimeSeconds(J)V
.line 895
:cond_258
sget-object v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->log:Lorg/slf4j/Logger;
invoke-interface {v3}, Lorg/slf4j/Logger;->isDebugEnabled()Z
move-result v3
if-eqz v3, :cond_267
.line 896
sget-object v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->log:Lorg/slf4j/Logger;
const-string v4, "Deserializing: DETERMINISTIC_KEY: {}"
invoke-interface {v3, v4, v2}, Lorg/slf4j/Logger;->debug(Ljava/lang/String;Ljava/lang/Object;)V
.line 897
:cond_267
if-nez v16, :cond_356
.line 902
invoke-virtual/range {v23 .. v23}, Ljava/util/LinkedList;->size()I
move-result v3
if-nez v3, :cond_2f9
.line 904
move-object/from16 v0, v17
iget-object v3, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
if-nez v3, :cond_356
.line 905
move-object/from16 v0, v17
iput-object v2, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 906
new-instance v3, Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-direct {v3, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;)V
move-object/from16 v0, v17
iput-object v3, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
move/from16 v3, v18
move/from16 v4, v19
.line 920
:goto_286
move-object/from16 v0, v17
iget-object v5, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v5, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->putKey(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 921
move-object/from16 v0, v17
iget-object v5, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKey(Lorg/bitcoinj/core/ECKey;)V
move-object/from16 v2, v20
:goto_296
move/from16 v18, v3
move/from16 v19, v4
move-object v6, v2
.line 923
goto/16 :goto_14
.line 842
:cond_29d
const/4 v2, 0x0
goto/16 :goto_1ab
.line 854
:cond_2a0
const/4 v11, 0x0
goto/16 :goto_1e9
.line 861
:cond_2a3
invoke-interface/range {v22 .. v22}, Lcom/google/common/collect/cu;->peek()Ljava/lang/Object;
move-result-object v8
check-cast v8, Lorg/bitcoinj/wallet/Protos$Key;
move-object/from16 v6, p2
move-object v7, v15
move-object/from16 v9, v20
move-object/from16 v10, p1
invoke-interface/range {v6 .. v11}, Lorg/bitcoinj/wallet/KeyChainFactory;->makeKeyChain(Lorg/bitcoinj/wallet/Protos$Key;Lorg/bitcoinj/wallet/Protos$Key;Lorg/bitcoinj/wallet/DeterministicSeed;Lorg/bitcoinj/crypto/KeyCrypter;Z)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v2
.line 862
const/4 v6, -0x1
iput v6, v2, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
:cond_2b7
move/from16 v16, v12
move-object/from16 v17, v2
goto/16 :goto_20f
.line 881
:cond_2bd
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->hasEncryptedData()Z
move-result v2
if-eqz v2, :cond_2f1
.line 882
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getEncryptedData()Lorg/bitcoinj/wallet/Protos$EncryptedData;
move-result-object v2
.line 883
new-instance v13, Lorg/bitcoinj/crypto/EncryptedData;
invoke-virtual {v2}, Lorg/bitcoinj/wallet/Protos$EncryptedData;->getInitialisationVector()Lcom/google/protobuf/ByteString;
move-result-object v6
invoke-virtual {v6}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v6
.line 884
invoke-virtual {v2}, Lorg/bitcoinj/wallet/Protos$EncryptedData;->getEncryptedPrivateKey()Lcom/google/protobuf/ByteString;
move-result-object v2
invoke-virtual {v2}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v2
invoke-direct {v13, v6, v2}, Lorg/bitcoinj/crypto/EncryptedData;-><init>([B[B)V
.line 885
const-string v2, "Encountered an encrypted key but no key crypter provided"
move-object/from16 v0, p1
invoke-static {v0, v2}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 886
new-instance v8, Lorg/bitcoinj/crypto/DeterministicKey;
move-object v9, v3
move-object v10, v4
move-object/from16 v11, p1
move-object v12, v5
move-object v14, v7
invoke-direct/range {v8 .. v14}, Lorg/bitcoinj/crypto/DeterministicKey;-><init>(Lcom/google/common/collect/ImmutableList;[BLorg/bitcoinj/crypto/KeyCrypter;Lorg/bitcoinj/crypto/LazyECPoint;Lorg/bitcoinj/crypto/EncryptedData;Lorg/bitcoinj/crypto/DeterministicKey;)V
move-object v2, v8
.line 887
goto/16 :goto_248
.line 890
:cond_2f1
new-instance v2, Lorg/bitcoinj/crypto/DeterministicKey;
const/4 v6, 0x0
invoke-direct/range {v2 .. v7}, Lorg/bitcoinj/crypto/DeterministicKey;-><init>(Lcom/google/common/collect/ImmutableList;[BLorg/bitcoinj/crypto/LazyECPoint;Ljava/math/BigInteger;Lorg/bitcoinj/crypto/DeterministicKey;)V
goto/16 :goto_248
.line 908
:cond_2f9
invoke-virtual/range {v23 .. v23}, Ljava/util/LinkedList;->size()I
move-result v3
invoke-virtual/range {v17 .. v17}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v4
invoke-virtual {v4}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v4
add-int/lit8 v4, v4, 0x1
if-ne v3, v4, :cond_356
.line 909
invoke-virtual {v2}, Lorg/bitcoinj/crypto/DeterministicKey;->getChildNumber()Lorg/bitcoinj/crypto/ChildNumber;
move-result-object v3
invoke-virtual {v3}, Lorg/bitcoinj/crypto/ChildNumber;->num()I
move-result v3
if-nez v3, :cond_33b
.line 910
move-object/from16 v0, v17
iput-object v2, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 911
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicKey()Lorg/bitcoinj/wallet/Protos$DeterministicKey;
move-result-object v3
invoke-virtual {v3}, Lorg/bitcoinj/wallet/Protos$DeterministicKey;->getIssuedSubkeys()I
move-result v3
move-object/from16 v0, v17
iput v3, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
.line 912
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicKey()Lorg/bitcoinj/wallet/Protos$DeterministicKey;
move-result-object v3
invoke-virtual {v3}, Lorg/bitcoinj/wallet/Protos$DeterministicKey;->getLookaheadSize()I
move-result v3
move/from16 v0, v19
invoke-static {v0, v3}, Ljava/lang/Math;->max(II)I
move-result v4
.line 913
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicKey()Lorg/bitcoinj/wallet/Protos$DeterministicKey;
move-result-object v3
invoke-virtual {v3}, Lorg/bitcoinj/wallet/Protos$DeterministicKey;->getSigsRequiredToSpend()I
move-result v3
goto/16 :goto_286
.line 914
:cond_33b
invoke-virtual {v2}, Lorg/bitcoinj/crypto/DeterministicKey;->getChildNumber()Lorg/bitcoinj/crypto/ChildNumber;
move-result-object v3
invoke-virtual {v3}, Lorg/bitcoinj/crypto/ChildNumber;->num()I
move-result v3
const/4 v4, 0x1
if-ne v3, v4, :cond_356
.line 915
move-object/from16 v0, v17
iput-object v2, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 916
invoke-virtual {v15}, Lorg/bitcoinj/wallet/Protos$Key;->getDeterministicKey()Lorg/bitcoinj/wallet/Protos$DeterministicKey;
move-result-object v3
invoke-virtual {v3}, Lorg/bitcoinj/wallet/Protos$DeterministicKey;->getIssuedSubkeys()I
move-result v3
move-object/from16 v0, v17
iput v3, v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
:cond_356
move/from16 v3, v18
move/from16 v4, v19
goto/16 :goto_286
.line 924
:cond_35c
if-eqz v17, :cond_378
.line 925
if-ltz v19, :cond_379
const/4 v2, 0x1
:goto_361
invoke-static {v2}, Lcom/google/common/base/n;->checkState(Z)V
.line 926
move-object/from16 v0, v17
move/from16 v1, v19
invoke-virtual {v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->setLookaheadSize(I)V
.line 927
invoke-virtual/range {v17 .. v18}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->setSigsRequiredToSpend(I)V
.line 928
invoke-virtual/range {v17 .. v17}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead()V
.line 929
move-object/from16 v0, v21
move-object/from16 v1, v17
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 931
:cond_378
return-object v21
.line 925
:cond_379
const/4 v2, 0x0
goto :goto_361
:cond_37b
move-object/from16 v2, v17
move-object/from16 v20, v6
goto/16 :goto_1ca
:cond_381
move/from16 v3, v18
move/from16 v4, v19
move-object v2, v6
goto/16 :goto_296
.end method
.method private initializeHierarchyUnencrypted(Lorg/bitcoinj/crypto/DeterministicKey;)V
.registers 6
.prologue
const/4 v3, 0x0
.line 438
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
sget-object v2, Lorg/bitcoinj/crypto/ChildNumber;->ZERO:Lorg/bitcoinj/crypto/ChildNumber;
invoke-virtual {v0, v1, v3, v3, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->deriveChild(Ljava/util/List;ZZLorg/bitcoinj/crypto/ChildNumber;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 439
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
sget-object v2, Lorg/bitcoinj/crypto/ChildNumber;->ONE:Lorg/bitcoinj/crypto/ChildNumber;
invoke-virtual {v0, v1, v3, v3, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->deriveChild(Ljava/util/List;ZZLorg/bitcoinj/crypto/ChildNumber;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
iput-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 440
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-direct {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->addToBasicChain(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 441
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-direct {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->addToBasicChain(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 442
return-void
.end method
.method private maybeLookAhead(Lorg/bitcoinj/crypto/DeterministicKey;I)Ljava/util/List;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lorg/bitcoinj/crypto/DeterministicKey;",
"I)",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/crypto/DeterministicKey;",
">;"
}
.end annotation
.prologue
.line 1143
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->isHeldByCurrentThread()Z
move-result v0
invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V
.line 1144
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getLookaheadSize()I
move-result v0
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getLookaheadThreshold()I
move-result v1
invoke-direct {p0, p1, p2, v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead(Lorg/bitcoinj/crypto/DeterministicKey;III)Ljava/util/List;
move-result-object v0
return-object v0
.end method
.method private maybeLookAhead(Lorg/bitcoinj/crypto/DeterministicKey;III)Ljava/util/List;
.registers 13
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lorg/bitcoinj/crypto/DeterministicKey;",
"III)",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/crypto/DeterministicKey;",
">;"
}
.end annotation
.prologue
const/4 v1, 0x0
.line 1154
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->isHeldByCurrentThread()Z
move-result v0
invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V
.line 1155
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v2
invoke-virtual {v0, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->getNumChildren(Lcom/google/common/collect/ImmutableList;)I
move-result v2
.line 1156
add-int v0, p2, p3
add-int/2addr v0, p4
sub-int v3, v0, v2
.line 1158
if-gt v3, p4, :cond_21
.line 1159
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 1176
:goto_20
return-object v0
.line 1161
:cond_21
sget-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->log:Lorg/slf4j/Logger;
const-string v4, "{} keys needed for {} = {} issued + {} lookahead size + {} lookahead threshold - {} num children"
const/4 v5, 0x6
new-array v5, v5, [Ljava/lang/Object;
.line 1162
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v6
aput-object v6, v5, v1
const/4 v6, 0x1
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPathAsString()Ljava/lang/String;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x2
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x3
invoke-static {p3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x4
invoke-static {p4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x5
invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v5, v6
.line 1161
invoke-interface {v0, v4, v5}, Lorg/slf4j/Logger;->info(Ljava/lang/String;[Ljava/lang/Object;)V
.line 1164
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0, v3}, Ljava/util/ArrayList;-><init>(I)V
.line 1165
invoke-static {}, Lcom/google/common/base/s;->wT()Lcom/google/common/base/s;
move-result-object v4
.line 1167
:goto_5d
if-ge v1, v3, :cond_7c
.line 1168
invoke-static {p1, v2}, Lorg/bitcoinj/crypto/HDKeyDerivation;->deriveThisOrNextChildKey(Lorg/bitcoinj/crypto/DeterministicKey;I)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v2
.line 1169
invoke-virtual {v2}, Lorg/bitcoinj/crypto/DeterministicKey;->dropPrivateBytes()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v2
.line 1170
iget-object v5, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v5, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->putKey(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 1171
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 1172
invoke-virtual {v2}, Lorg/bitcoinj/crypto/DeterministicKey;->getChildNumber()Lorg/bitcoinj/crypto/ChildNumber;
move-result-object v2
invoke-virtual {v2}, Lorg/bitcoinj/crypto/ChildNumber;->num()I
move-result v2
add-int/lit8 v2, v2, 0x1
.line 1167
add-int/lit8 v1, v1, 0x1
goto :goto_5d
.line 1174
:cond_7c
invoke-virtual {v4}, Lcom/google/common/base/s;->wU()Lcom/google/common/base/s;
.line 1175
sget-object v1, Lorg/bitcoinj/wallet/DeterministicKeyChain;->log:Lorg/slf4j/Logger;
const-string v2, "Took {}"
invoke-interface {v1, v2, v4}, Lorg/slf4j/Logger;->info(Ljava/lang/String;Ljava/lang/Object;)V
goto :goto_20
.end method
.method static serializeSeedEncryptableItem(Lorg/bitcoinj/wallet/DeterministicSeed;Lorg/bitcoinj/wallet/Protos$Key$Builder;)V
.registers 5
.prologue
.line 1271
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicSeed;->isEncrypted()Z
move-result v0
if-eqz v0, :cond_36
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicSeed;->getEncryptedSeedData()Lorg/bitcoinj/crypto/EncryptedData;
move-result-object v0
if-eqz v0, :cond_36
.line 1272
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicSeed;->getEncryptedSeedData()Lorg/bitcoinj/crypto/EncryptedData;
move-result-object v0
.line 1273
invoke-virtual {p1}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->getEncryptedDeterministicSeedBuilder()Lorg/bitcoinj/wallet/Protos$EncryptedData$Builder;
move-result-object v1
iget-object v2, v0, Lorg/bitcoinj/crypto/EncryptedData;->encryptedBytes:[B
.line 1274
invoke-static {v2}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v2
invoke-virtual {v1, v2}, Lorg/bitcoinj/wallet/Protos$EncryptedData$Builder;->setEncryptedPrivateKey(Lcom/google/protobuf/ByteString;)Lorg/bitcoinj/wallet/Protos$EncryptedData$Builder;
move-result-object v1
iget-object v0, v0, Lorg/bitcoinj/crypto/EncryptedData;->initialisationVector:[B
.line 1275
invoke-static {v0}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-virtual {v1, v0}, Lorg/bitcoinj/wallet/Protos$EncryptedData$Builder;->setInitialisationVector(Lcom/google/protobuf/ByteString;)Lorg/bitcoinj/wallet/Protos$EncryptedData$Builder;
.line 1277
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicSeed;->getEncryptionType()Lorg/bitcoinj/wallet/Protos$Wallet$EncryptionType;
move-result-object v0
sget-object v1, Lorg/bitcoinj/wallet/Protos$Wallet$EncryptionType;->ENCRYPTED_SCRYPT_AES:Lorg/bitcoinj/wallet/Protos$Wallet$EncryptionType;
if-ne v0, v1, :cond_34
const/4 v0, 0x1
:goto_30
invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V
.line 1283
:cond_33
:goto_33
return-void
.line 1277
:cond_34
const/4 v0, 0x0
goto :goto_30
.line 1279
:cond_36
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicSeed;->getSeedBytes()[B
move-result-object v0
.line 1280
if-eqz v0, :cond_33
.line 1281
invoke-static {v0}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-virtual {p1, v0}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->setDeterministicSeed(Lcom/google/protobuf/ByteString;)Lorg/bitcoinj/wallet/Protos$Key$Builder;
goto :goto_33
.end method
.method public static watch(Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
.registers 2
.prologue
.line 351
new-instance v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;
invoke-direct {v0, p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;)V
return-object v0
.end method
.method public static watchAndFollow(Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
.registers 3
.prologue
.line 344
new-instance v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;
const/4 v1, 0x1
invoke-direct {v0, p0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;Z)V
return-object v0
.end method
# virtual methods
.method public addEventListener(Lorg/bitcoinj/wallet/listeners/KeyChainEventListener;)V
.registers 3
.prologue
.line 676
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;->addEventListener(Lorg/bitcoinj/wallet/listeners/KeyChainEventListener;)V
.line 677
return-void
.end method
.method public addEventListener(Lorg/bitcoinj/wallet/listeners/KeyChainEventListener;Ljava/util/concurrent/Executor;)V
.registers 4
.prologue
.line 681
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1, p2}, Lorg/bitcoinj/wallet/BasicKeyChain;->addEventListener(Lorg/bitcoinj/wallet/listeners/KeyChainEventListener;Ljava/util/concurrent/Executor;)V
.line 682
return-void
.end method
.method public checkAESKey(Lorg/spongycastle/crypto/params/KeyParameter;)Z
.registers 6
.prologue
const/4 v1, 0x1
const/4 v2, 0x0
.line 1013
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
if-eqz v0, :cond_2f
move v0, v1
:goto_7
const-string v3, "Can\'t check password for a watching chain"
invoke-static {v0, v3}, Lcom/google/common/base/n;->checkState(ZLjava/lang/Object;)V
.line 1014
invoke-static {p1}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 1015
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v0
if-eqz v0, :cond_31
:goto_15
const-string v0, "Key chain not encrypted"
invoke-static {v1, v0}, Lcom/google/common/base/n;->checkState(ZLjava/lang/Object;)V
.line 1017
:try_start_1a
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v0, p1}, Lorg/bitcoinj/crypto/DeterministicKey;->decrypt(Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPubKeyPoint()Lorg/spongycastle/math/ec/ECPoint;
move-result-object v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->rootKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPubKeyPoint()Lorg/spongycastle/math/ec/ECPoint;
move-result-object v1
invoke-virtual {v0, v1}, Lorg/spongycastle/math/ec/ECPoint;->equals(Lorg/spongycastle/math/ec/ECPoint;)Z
:try_end_2d
.catch Lorg/bitcoinj/crypto/KeyCrypterException; {:try_start_1a .. :try_end_2d} :catch_33
move-result v2
.line 1019
:goto_2e
return v2
:cond_2f
move v0, v2
.line 1013
goto :goto_7
:cond_31
move v1, v2
.line 1015
goto :goto_15
.line 1019
:catch_33
move-exception v0
goto :goto_2e
.end method
.method public checkPassword(Ljava/lang/CharSequence;)Z
.registers 4
.prologue
.line 1006
invoke-static {p1}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 1007
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v0
if-eqz v0, :cond_1c
const/4 v0, 0x1
:goto_a
const-string v1, "Key chain not encrypted"
invoke-static {v0, v1}, Lcom/google/common/base/n;->checkState(ZLjava/lang/Object;)V
.line 1008
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v0
invoke-interface {v0, p1}, Lorg/bitcoinj/crypto/KeyCrypter;->deriveKey(Ljava/lang/CharSequence;)Lorg/spongycastle/crypto/params/KeyParameter;
move-result-object v0
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->checkAESKey(Lorg/spongycastle/crypto/params/KeyParameter;)Z
move-result v0
return v0
.line 1007
:cond_1c
const/4 v0, 0x0
goto :goto_a
.end method
.method public findKeyFromPubHash([B)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 4
.prologue
.line 544
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 546
:try_start_5
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;->findKeyFromPubHash([B)Lorg/bitcoinj/core/ECKey;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
:try_end_d
.catchall {:try_start_5 .. :try_end_d} :catchall_13
.line 548
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 546
return-object v0
.line 548
:catchall_13
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public findKeyFromPubKey([B)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 4
.prologue
.line 553
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 555
:try_start_5
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;->findKeyFromPubKey([B)Lorg/bitcoinj/core/ECKey;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
:try_end_d
.catchall {:try_start_5 .. :try_end_d} :catchall_13
.line 557
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 555
return-object v0
.line 557
:catchall_13
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public findRedeemDataByScriptHash(Lcom/google/protobuf/ByteString;)Lorg/bitcoinj/wallet/RedeemData;
.registers 3
.prologue
.line 1360
const/4 v0, 0x0
return-object v0
.end method
.method protected formatAddresses(ZLorg/bitcoinj/core/NetworkParameters;Ljava/lang/StringBuilder;)V
.registers 6
.prologue
.line 1340
const/4 v0, 0x0
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeys(Z)Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_9
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_19
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/core/ECKey;
.line 1341
invoke-virtual {v0, p1, p3, p2}, Lorg/bitcoinj/core/ECKey;->formatKeyWithAddress(ZLjava/lang/StringBuilder;Lorg/bitcoinj/core/NetworkParameters;)V
goto :goto_9
.line 1342
:cond_19
return-void
.end method
.method public freshOutputScript(Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;)Lorg/bitcoinj/script/Script;
.registers 3
.prologue
.line 1314
new-instance v0, Ljava/lang/UnsupportedOperationException;
invoke-direct {v0}, Ljava/lang/UnsupportedOperationException;-><init>()V
throw v0
.end method
.method protected getAccountPath()Lcom/google/common/collect/ImmutableList;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Lcom/google/common/collect/ImmutableList",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;"
}
.end annotation
.prologue
.line 423
sget-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->ACCOUNT_ZERO_PATH:Lcom/google/common/collect/ImmutableList;
return-object v0
.end method
.method public getEarliestKeyCreationTime()J
.registers 3
.prologue
.line 668
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
if-eqz v0, :cond_b
.line 669
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/DeterministicSeed;->getCreationTimeSeconds()J
move-result-wide v0
.line 671
:goto_a
return-wide v0
:cond_b
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getWatchingKey()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getCreationTimeSeconds()J
move-result-wide v0
goto :goto_a
.end method
.method public getFilter(IDJ)Lorg/bitcoinj/core/BloomFilter;
.registers 12
.prologue
.line 1043
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1045
:try_start_5
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->numBloomFilterEntries()I
move-result v0
if-lt p1, v0, :cond_21
const/4 v0, 0x1
:goto_c
invoke-static {v0}, Lcom/google/common/base/n;->checkArgument(Z)V
.line 1046
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead()V
.line 1047
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
move v1, p1
move-wide v2, p2
move-wide v4, p4
invoke-virtual/range {v0 .. v5}, Lorg/bitcoinj/wallet/BasicKeyChain;->getFilter(IDJ)Lorg/bitcoinj/core/BloomFilter;
:try_end_1a
.catchall {:try_start_5 .. :try_end_1a} :catchall_23
move-result-object v0
.line 1049
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1047
return-object v0
.line 1045
:cond_21
const/4 v0, 0x0
goto :goto_c
.line 1049
:catchall_23
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getIssuedExternalKeys()I
.registers 3
.prologue
.line 1188
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1190
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
:try_end_7
.catchall {:try_start_5 .. :try_end_7} :catchall_d
.line 1192
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1190
return v0
.line 1192
:catchall_d
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getIssuedInternalKeys()I
.registers 3
.prologue
.line 1201
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1203
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
:try_end_7
.catchall {:try_start_5 .. :try_end_7} :catchall_d
.line 1205
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1203
return v0
.line 1205
:catchall_d
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getIssuedReceiveKeys()Ljava/util/List;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/core/ECKey;",
">;"
}
.end annotation
.prologue
.line 1244
new-instance v1, Ljava/util/ArrayList;
const/4 v0, 0x0
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeys(Z)Ljava/util/List;
move-result-object v0
invoke-direct {v1, v0}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V
.line 1245
invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:cond_e
:goto_e
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2c
.line 1246
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
.line 1247
if-eqz v0, :cond_28
iget-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v3, v0}, Lorg/bitcoinj/crypto/DeterministicKey;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_e
.line 1248
:cond_28
invoke-interface {v2}, Ljava/util/Iterator;->remove()V
goto :goto_e
.line 1250
:cond_2c
return-object v1
.end method
.method public bridge synthetic getKey(Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;)Lorg/bitcoinj/core/ECKey;
.registers 3
.prologue
.line 97
invoke-virtual {p0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKey(Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
return-object v0
.end method
.method public getKey(Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 4
.prologue
.line 447
const/4 v0, 0x1
invoke-virtual {p0, p1, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeys(Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;I)Ljava/util/List;
move-result-object v0
const/4 v1, 0x0
invoke-interface {v0, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
return-object v0
.end method
.method protected getKeyByPath(Ljava/util/List;)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;)",
"Lorg/bitcoinj/crypto/DeterministicKey;"
}
.end annotation
.prologue
.line 612
const/4 v0, 0x0
invoke-virtual {p0, p1, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyByPath(Ljava/util/List;Z)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
return-object v0
.end method
.method public getKeyByPath(Ljava/util/List;Z)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/crypto/ChildNumber;",
">;Z)",
"Lorg/bitcoinj/crypto/DeterministicKey;"
}
.end annotation
.prologue
.line 617
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
const/4 v1, 0x0
invoke-virtual {v0, p1, v1, p2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->get(Ljava/util/List;ZZ)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
return-object v0
.end method
.method protected varargs getKeyByPath([Lorg/bitcoinj/crypto/ChildNumber;)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 3
.prologue
.line 607
invoke-static {p1}, Lcom/google/common/collect/ImmutableList;->copyOf([Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyByPath(Ljava/util/List;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
return-object v0
.end method
.method public getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
.registers 2
.prologue
.line 1026
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v0
return-object v0
.end method
.method public getKeyLookaheadEpoch()I
.registers 3
.prologue
.line 1290
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1292
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->keyLookaheadEpoch:I
:try_end_7
.catchall {:try_start_5 .. :try_end_7} :catchall_d
.line 1294
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1292
return v0
.line 1294
:catchall_d
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getKeys(Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;I)Ljava/util/List;
.registers 11
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;",
"I)",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/crypto/DeterministicKey;",
">;"
}
.end annotation
.prologue
const/4 v1, 0x0
.line 453
if-lez p2, :cond_24
const/4 v0, 0x1
:goto_4
invoke-static {v0}, Lcom/google/common/base/n;->checkArgument(Z)V
.line 454
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 458
:try_start_c
sget-object v0, Lorg/bitcoinj/wallet/DeterministicKeyChain$1;->$SwitchMap$org$bitcoinj$wallet$KeyChain$KeyPurpose:[I
invoke-virtual {p1}, Lorg/bitcoinj/wallet/KeyChain$KeyPurpose;->ordinal()I
move-result v2
aget v0, v0, v2
packed-switch v0, :pswitch_data_74
.line 476
new-instance v0, Ljava/lang/UnsupportedOperationException;
invoke-direct {v0}, Ljava/lang/UnsupportedOperationException;-><init>()V
throw v0
:try_end_1d
.catchall {:try_start_c .. :try_end_1d} :catchall_1d
.line 505
:catchall_1d
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
:cond_24
move v0, v1
.line 453
goto :goto_4
.line 465
:pswitch_26
:try_start_26
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
add-int/2addr v0, p2
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
.line 466
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
.line 467
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
.line 489
:goto_2f
const/4 v3, 0x0
const/4 v4, 0x0
invoke-direct {p0, v2, v0, v3, v4}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead(Lorg/bitcoinj/crypto/DeterministicKey;III)Ljava/util/List;
move-result-object v3
.line 490
iget-object v4, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v4, v3}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKeys(Ljava/util/List;)I
.line 491
new-instance v3, Ljava/util/ArrayList;
invoke-direct {v3, p2}, Ljava/util/ArrayList;-><init>(I)V
.line 492
:goto_3f
if-ge v1, p2, :cond_6d
.line 493
invoke-virtual {v2}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v4
new-instance v5, Lorg/bitcoinj/crypto/ChildNumber;
sub-int v6, v0, p2
add-int/2addr v6, v1
const/4 v7, 0x0
invoke-direct {v5, v6, v7}, Lorg/bitcoinj/crypto/ChildNumber;-><init>(IZ)V
invoke-static {v4, v5}, Lorg/bitcoinj/crypto/HDUtils;->append(Ljava/util/List;Lorg/bitcoinj/crypto/ChildNumber;)Lcom/google/common/collect/ImmutableList;
move-result-object v4
.line 494
iget-object v5, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
const/4 v6, 0x0
const/4 v7, 0x0
invoke-virtual {v5, v4, v6, v7}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->get(Ljava/util/List;ZZ)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v4
.line 500
invoke-direct {p0, v4}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->checkForBitFlip(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 501
invoke-interface {v3, v4}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 492
add-int/lit8 v1, v1, 0x1
goto :goto_3f
.line 471
:pswitch_63
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
add-int/2addr v0, p2
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
.line 472
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
.line 473
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
:try_end_6c
.catchall {:try_start_26 .. :try_end_6c} :catchall_1d
goto :goto_2f
.line 505
:cond_6d
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 503
return-object v3
.line 458
nop
:pswitch_data_74
.packed-switch 0x1
:pswitch_26
:pswitch_26
:pswitch_63
:pswitch_63
.end packed-switch
.end method
.method getKeys(Z)Ljava/util/List;
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(Z)",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/core/ECKey;",
">;"
}
.end annotation
.prologue
.line 1222
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->getKeys()Ljava/util/List;
move-result-object v0
.line 1223
if-nez p1, :cond_66
.line 1224
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-virtual {v1}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v2
.line 1225
new-instance v1, Ljava/util/LinkedList;
invoke-direct {v1}, Ljava/util/LinkedList;-><init>()V
.line 1226
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v3
:cond_1b
:goto_1b
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_65
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/core/ECKey;
.line 1227
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
.line 1228
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v4
.line 1229
if-eqz v4, :cond_1b
.line 1230
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v5
invoke-virtual {v5}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v5
if-le v5, v2, :cond_1b
.line 1231
iget-object v5, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v4, v5}, Lorg/bitcoinj/crypto/DeterministicKey;->equals(Ljava/lang/Object;)Z
move-result v5
if-eqz v5, :cond_4d
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getChildNumber()Lorg/bitcoinj/crypto/ChildNumber;
move-result-object v5
invoke-virtual {v5}, Lorg/bitcoinj/crypto/ChildNumber;->i()I
move-result v5
iget v6, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
if-ge v5, v6, :cond_1b
.line 1232
:cond_4d
iget-object v5, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v4, v5}, Lorg/bitcoinj/crypto/DeterministicKey;->equals(Ljava/lang/Object;)Z
move-result v4
if-eqz v4, :cond_61
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getChildNumber()Lorg/bitcoinj/crypto/ChildNumber;
move-result-object v4
invoke-virtual {v4}, Lorg/bitcoinj/crypto/ChildNumber;->i()I
move-result v4
iget v5, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
if-ge v4, v5, :cond_1b
.line 1233
:cond_61
invoke-interface {v1, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_1b
:cond_65
move-object v0, v1
.line 1237
:cond_66
return-object v0
.end method
.method public getLeafKeys()Ljava/util/List;
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/crypto/DeterministicKey;",
">;"
}
.end annotation
.prologue
.line 1257
invoke-static {}, Lcom/google/common/collect/ImmutableList;->builder()Lcom/google/common/collect/an;
move-result-object v1
.line 1258
const/4 v0, 0x1
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeys(Z)Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:cond_d
:goto_d
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_33
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/core/ECKey;
.line 1259
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
.line 1260
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v3
invoke-virtual {v3}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v3
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v4
invoke-virtual {v4}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v4
add-int/lit8 v4, v4, 0x2
if-ne v3, v4, :cond_d
.line 1261
invoke-virtual {v1, v0}, Lcom/google/common/collect/an;->Z(Ljava/lang/Object;)Lcom/google/common/collect/an;
goto :goto_d
.line 1264
:cond_33
invoke-virtual {v1}, Lcom/google/common/collect/an;->xm()Lcom/google/common/collect/ImmutableList;
move-result-object v0
return-object v0
.end method
.method public getLookaheadSize()I
.registers 3
.prologue
.line 1062
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1064
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
:try_end_7
.catchall {:try_start_5 .. :try_end_7} :catchall_d
.line 1066
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1064
return v0
.line 1066
:catchall_d
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getLookaheadThreshold()I
.registers 3
.prologue
.line 1111
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1113
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
iget v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
:try_end_9
.catchall {:try_start_5 .. :try_end_9} :catchall_1a
if-lt v0, v1, :cond_12
.line 1117
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1114
const/4 v0, 0x0
.line 1115
:goto_11
return v0
:cond_12
:try_start_12
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
:try_end_14
.catchall {:try_start_12 .. :try_end_14} :catchall_1a
.line 1117
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
goto :goto_11
:catchall_1a
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getMnemonicCode()Ljava/util/List;
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List",
"<",
"Ljava/lang/String;",
">;"
}
.end annotation
.prologue
.line 692
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
if-nez v0, :cond_6
const/4 v0, 0x0
.line 696
:goto_5
return-object v0
.line 694
:cond_6
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 696
:try_start_b
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/DeterministicSeed;->getMnemonicCode()Ljava/util/List;
:try_end_10
.catchall {:try_start_b .. :try_end_10} :catchall_17
move-result-object v0
.line 698
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
goto :goto_5
:catchall_17
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getRedeemData(Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/wallet/RedeemData;
.registers 3
.prologue
.line 1309
new-instance v0, Ljava/lang/UnsupportedOperationException;
invoke-direct {v0}, Ljava/lang/UnsupportedOperationException;-><init>()V
throw v0
.end method
.method public getSeed()Lorg/bitcoinj/wallet/DeterministicSeed;
.registers 3
.prologue
.line 1212
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1214
:try_start_5
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
:try_end_7
.catchall {:try_start_5 .. :try_end_7} :catchall_d
.line 1216
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1214
return-object v0
.line 1216
:catchall_d
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public getSigsRequiredToSpend()I
.registers 2
.prologue
.line 1354
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->sigsRequiredToSpend:I
return v0
.end method
.method public getWatchingKey()Lorg/bitcoinj/crypto/DeterministicKey;
.registers 2
.prologue
.line 631
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v0
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyByPath(Ljava/util/List;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
return-object v0
.end method
.method public hasKey(Lorg/bitcoinj/core/ECKey;)Z
.registers 4
.prologue
.line 597
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 599
:try_start_5
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;->hasKey(Lorg/bitcoinj/core/ECKey;)Z
:try_end_a
.catchall {:try_start_5 .. :try_end_a} :catchall_11
move-result v0
.line 601
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 599
return v0
.line 601
:catchall_11
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public isFollowing()Z
.registers 2
.prologue
.line 706
iget-boolean v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->isFollowing:Z
return v0
.end method
.method public isMarried()Z
.registers 2
.prologue
.line 1304
const/4 v0, 0x0
return v0
.end method
.method public isWatching()Z
.registers 2
.prologue
.line 636
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getWatchingKey()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->isWatching()Z
move-result v0
return v0
.end method
.method protected makeKeyChainFromSeed(Lorg/bitcoinj/wallet/DeterministicSeed;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
.registers 3
.prologue
.line 1001
new-instance v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;
invoke-direct {v0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/wallet/DeterministicSeed;)V
return-object v0
.end method
.method public markKeyAsUsed(Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 5
.prologue
.line 527
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getChildNumber()Lorg/bitcoinj/crypto/ChildNumber;
move-result-object v0
invoke-virtual {v0}, Lorg/bitcoinj/crypto/ChildNumber;->i()I
move-result v0
add-int/lit8 v0, v0, 0x1
.line 529
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
if-ne v1, v2, :cond_1c
.line 530
iget v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
if-ge v1, v0, :cond_1b
.line 531
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
.line 532
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead()V
.line 540
:cond_1b
:goto_1b
return-object p1
.line 534
:cond_1c
invoke-virtual {p1}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
if-ne v1, v2, :cond_1b
.line 535
iget v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
if-ge v1, v0, :cond_1b
.line 536
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
.line 537
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead()V
goto :goto_1b
.end method
.method public markPubHashAsUsed([B)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 4
.prologue
.line 567
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 569
:try_start_5
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;->findKeyFromPubHash([B)Lorg/bitcoinj/core/ECKey;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
.line 570
if-eqz v0, :cond_12
.line 571
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->markKeyAsUsed(Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/crypto/DeterministicKey;
:try_end_12
.catchall {:try_start_5 .. :try_end_12} :catchall_18
.line 574
:cond_12
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 572
return-object v0
.line 574
:catchall_18
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public markPubKeyAsUsed([B)Lorg/bitcoinj/crypto/DeterministicKey;
.registers 4
.prologue
.line 584
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 586
:try_start_5
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;->findKeyFromPubKey([B)Lorg/bitcoinj/core/ECKey;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
.line 587
if-eqz v0, :cond_12
.line 588
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->markKeyAsUsed(Lorg/bitcoinj/crypto/DeterministicKey;)Lorg/bitcoinj/crypto/DeterministicKey;
:try_end_12
.catchall {:try_start_5 .. :try_end_12} :catchall_18
.line 591
:cond_12
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 589
return-object v0
.line 591
:catchall_18
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public maybeLookAhead()V
.registers 4
.prologue
.line 1126
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1128
:try_start_5
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
iget v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
invoke-direct {p0, v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead(Lorg/bitcoinj/crypto/DeterministicKey;I)Ljava/util/List;
move-result-object v0
.line 1129
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
iget v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
invoke-direct {p0, v1, v2}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead(Lorg/bitcoinj/crypto/DeterministicKey;I)Ljava/util/List;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
.line 1130
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
:try_end_1b
.catchall {:try_start_5 .. :try_end_1b} :catchall_35
move-result v1
if-eqz v1, :cond_24
.line 1138
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1139
:goto_23
return-void
.line 1132
:cond_24
:try_start_24
iget v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->keyLookaheadEpoch:I
add-int/lit8 v1, v1, 0x1
iput v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->keyLookaheadEpoch:I
.line 1136
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v1, v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKeys(Ljava/util/List;)I
:try_end_2f
.catchall {:try_start_24 .. :try_end_2f} :catchall_35
.line 1138
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
goto :goto_23
:catchall_35
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public maybeLookAheadScripts()V
.registers 1
.prologue
.line 1181
return-void
.end method
.method public numBloomFilterEntries()I
.registers 2
.prologue
.line 1038
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->numKeys()I
move-result v0
shl-int/lit8 v0, v0, 0x1
return v0
.end method
.method public numKeys()I
.registers 3
.prologue
.line 643
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 645
:try_start_5
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->maybeLookAhead()V
.line 646
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->numKeys()I
:try_end_d
.catchall {:try_start_5 .. :try_end_d} :catchall_14
move-result v0
.line 648
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 646
return v0
.line 648
:catchall_14
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public numLeafKeysIssued()I
.registers 3
.prologue
.line 658
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 660
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
iget v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
:try_end_9
.catchall {:try_start_5 .. :try_end_9} :catchall_10
add-int/2addr v0, v1
.line 662
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 660
return v0
.line 662
:catchall_10
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public removeEventListener(Lorg/bitcoinj/wallet/listeners/KeyChainEventListener;)Z
.registers 3
.prologue
.line 686
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, p1}, Lorg/bitcoinj/wallet/BasicKeyChain;->removeEventListener(Lorg/bitcoinj/wallet/listeners/KeyChainEventListener;)Z
move-result v0
return v0
.end method
.method protected serializeMyselfToProtobuf()Ljava/util/List;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/wallet/Protos$Key;",
">;"
}
.end annotation
.prologue
.line 2232
new-instance v3, Ljava/util/LinkedList;
invoke-direct {v3}, Ljava/util/LinkedList;-><init>()V
.line 731
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
if-eqz v0, :cond_20
.line 732
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-static {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->serializeEncryptableItem(Lorg/bitcoinj/crypto/EncryptableItem;)Lorg/bitcoinj/wallet/Protos$Key$Builder;
move-result-object v0
.line 733
sget-object v1, Lorg/bitcoinj/wallet/Protos$Key$Type;->DETERMINISTIC_MNEMONIC:Lorg/bitcoinj/wallet/Protos$Key$Type;
invoke-virtual {v0, v1}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->setType(Lorg/bitcoinj/wallet/Protos$Key$Type;)Lorg/bitcoinj/wallet/Protos$Key$Builder;
.line 734
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-static {v1, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->serializeSeedEncryptableItem(Lorg/bitcoinj/wallet/DeterministicSeed;Lorg/bitcoinj/wallet/Protos$Key$Builder;)V
.line 735
invoke-virtual {v0}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->build()Lorg/bitcoinj/wallet/Protos$Key;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/util/LinkedList;->add(Ljava/lang/Object;)Z
.line 737
:cond_20
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->serializeToEditableProtobufs()Ljava/util/Map;
move-result-object v0
.line 738
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v4
:goto_2e
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_cb
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/Map$Entry;
.line 739
invoke-interface {v0}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lorg/bitcoinj/crypto/DeterministicKey;
.line 740
invoke-interface {v0}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/wallet/Protos$Key$Builder;
.line 741
sget-object v2, Lorg/bitcoinj/wallet/Protos$Key$Type;->DETERMINISTIC_KEY:Lorg/bitcoinj/wallet/Protos$Key$Type;
invoke-virtual {v0, v2}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->setType(Lorg/bitcoinj/wallet/Protos$Key$Type;)Lorg/bitcoinj/wallet/Protos$Key$Builder;
.line 742
invoke-virtual {v0}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->getDeterministicKeyBuilder()Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
move-result-object v5
.line 743
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getChainCode()[B
move-result-object v2
invoke-static {v2}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v2
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setChainCode(Lcom/google/protobuf/ByteString;)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
.line 744
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v2
invoke-virtual {v2}, Lcom/google/common/collect/ImmutableList;->iterator()Lcom/google/common/collect/dd;
move-result-object v6
:goto_62
invoke-interface {v6}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_76
invoke-interface {v6}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lorg/bitcoinj/crypto/ChildNumber;
.line 745
invoke-virtual {v2}, Lorg/bitcoinj/crypto/ChildNumber;->i()I
move-result v2
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->addPath(I)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
goto :goto_62
.line 746
:cond_76
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->externalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v1, v2}, Lorg/bitcoinj/crypto/DeterministicKey;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_b1
.line 747
iget v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setIssuedSubkeys(I)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
.line 748
iget v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setLookaheadSize(I)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
.line 749
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getSigsRequiredToSpend()I
move-result v2
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setSigsRequiredToSpend(I)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
.line 756
:cond_8f
:goto_8f
invoke-virtual {v3}, Ljava/util/LinkedList;->isEmpty()Z
move-result v2
if-eqz v2, :cond_9f
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->isFollowing()Z
move-result v2
if-eqz v2, :cond_9f
.line 757
const/4 v2, 0x1
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setIsFollowing(Z)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
.line 759
:cond_9f
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
if-eqz v1, :cond_a8
.line 761
invoke-virtual {v0}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->clearCreationTimestamp()Lorg/bitcoinj/wallet/Protos$Key$Builder;
.line 763
:cond_a8
invoke-virtual {v0}, Lorg/bitcoinj/wallet/Protos$Key$Builder;->build()Lorg/bitcoinj/wallet/Protos$Key;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/util/LinkedList;->add(Ljava/lang/Object;)Z
goto/16 :goto_2e
.line 750
:cond_b1
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->internalParentKey:Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v1, v2}, Lorg/bitcoinj/crypto/DeterministicKey;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_8f
.line 751
iget v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setIssuedSubkeys(I)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
.line 752
iget v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setLookaheadSize(I)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
.line 753
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getSigsRequiredToSpend()I
move-result v2
invoke-virtual {v5, v2}, Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;->setSigsRequiredToSpend(I)Lorg/bitcoinj/wallet/Protos$DeterministicKey$Builder;
goto :goto_8f
.line 765
:cond_cb
return-object v3
.end method
.method public serializeToProtobuf()Ljava/util/List;
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/wallet/Protos$Key;",
">;"
}
.end annotation
.prologue
.line 2088
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 718
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 720
:try_start_a
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->serializeMyselfToProtobuf()Ljava/util/List;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
:try_end_11
.catchall {:try_start_a .. :try_end_11} :catchall_17
.line 722
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 724
return-object v0
.line 722
:catchall_17
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public setLookaheadSize(I)V
.registers 4
.prologue
.line 1078
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1080
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
invoke-direct {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->calcDefaultLookaheadThreshold()I
move-result v1
if-ne v0, v1, :cond_1e
const/4 v0, 0x1
.line 1081
:goto_e
iput p1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
.line 1082
if-eqz v0, :cond_18
.line 1083
invoke-direct {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->calcDefaultLookaheadThreshold()I
move-result v0
iput v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
:try_end_18
.catchall {:try_start_5 .. :try_end_18} :catchall_20
.line 1085
:cond_18
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1086
return-void
.line 1080
:cond_1e
const/4 v0, 0x0
goto :goto_e
.line 1085
:catchall_20
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.end method
.method public setLookaheadThreshold(I)V
.registers 4
.prologue
.line 1095
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->lock()V
.line 1097
:try_start_5
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
if-lt p1, v0, :cond_18
.line 1098
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Threshold larger or equal to the lookaheadSize"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_11
.catchall {:try_start_5 .. :try_end_11} :catchall_11
.line 1101
:catchall_11
move-exception v0
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v1}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
throw v0
.line 1099
:cond_18
:try_start_18
iput p1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadThreshold:I
:try_end_1a
.catchall {:try_start_18 .. :try_end_1a} :catchall_11
.line 1101
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lock:Ljava/util/concurrent/locks/ReentrantLock;
invoke-virtual {v0}, Ljava/util/concurrent/locks/ReentrantLock;->unlock()V
.line 1102
return-void
.end method
.method public setSigsRequiredToSpend(I)V
.registers 2
.prologue
.line 1346
iput p1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->sigsRequiredToSpend:I
.line 1347
return-void
.end method
.method public toDecrypted(Ljava/lang/CharSequence;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
.registers 5
.prologue
const/4 v1, 0x1
const/4 v2, 0x0
.line 958
invoke-static {p1}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 959
invoke-interface {p1}, Ljava/lang/CharSequence;->length()I
move-result v0
if-lez v0, :cond_23
move v0, v1
:goto_c
invoke-static {v0}, Lcom/google/common/base/n;->checkArgument(Z)V
.line 960
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v0
.line 961
if-eqz v0, :cond_25
:goto_15
const-string v2, "Chain not encrypted"
invoke-static {v1, v2}, Lcom/google/common/base/n;->checkState(ZLjava/lang/Object;)V
.line 962
invoke-interface {v0, p1}, Lorg/bitcoinj/crypto/KeyCrypter;->deriveKey(Ljava/lang/CharSequence;)Lorg/spongycastle/crypto/params/KeyParameter;
move-result-object v0
.line 963
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->toDecrypted(Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v0
return-object v0
:cond_23
move v0, v2
.line 959
goto :goto_c
:cond_25
move v1, v2
.line 961
goto :goto_15
.end method
.method public toDecrypted(Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
.registers 8
.prologue
const/4 v1, 0x1
const/4 v2, 0x0
.line 968
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v0
if-eqz v0, :cond_4e
move v0, v1
:goto_9
const-string v3, "Key chain not encrypted"
invoke-static {v0, v3}, Lcom/google/common/base/n;->checkState(ZLjava/lang/Object;)V
.line 969
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
if-eqz v0, :cond_50
:goto_12
const-string v0, "Can\'t decrypt a watching chain"
invoke-static {v1, v0}, Lcom/google/common/base/n;->checkState(ZLjava/lang/Object;)V
.line 970
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/DeterministicSeed;->isEncrypted()Z
move-result v0
invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V
.line 971
const-string v0, ""
.line 972
iget-object v1, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyCrypter()Lorg/bitcoinj/crypto/KeyCrypter;
move-result-object v3
invoke-virtual {v1, v3, v0, p1}, Lorg/bitcoinj/wallet/DeterministicSeed;->decrypt(Lorg/bitcoinj/crypto/KeyCrypter;Ljava/lang/String;Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicSeed;
move-result-object v0
.line 973
invoke-virtual {p0, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->makeKeyChainFromSeed(Lorg/bitcoinj/wallet/DeterministicSeed;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v3
.line 975
invoke-virtual {v3}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getWatchingKey()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPubKeyPoint()Lorg/spongycastle/math/ec/ECPoint;
move-result-object v0
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getWatchingKey()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPubKeyPoint()Lorg/spongycastle/math/ec/ECPoint;
move-result-object v1
invoke-virtual {v0, v1}, Lorg/spongycastle/math/ec/ECPoint;->equals(Lorg/spongycastle/math/ec/ECPoint;)Z
move-result v0
if-nez v0, :cond_52
.line 976
new-instance v0, Lorg/bitcoinj/crypto/KeyCrypterException;
const-string v1, "Provided AES key is wrong"
invoke-direct {v0, v1}, Lorg/bitcoinj/crypto/KeyCrypterException;-><init>(Ljava/lang/String;)V
throw v0
:cond_4e
move v0, v2
.line 968
goto :goto_9
:cond_50
move v1, v2
.line 969
goto :goto_12
.line 977
:cond_52
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
iput v0, v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->lookaheadSize:I
.line 980
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/BasicKeyChain;->getKeys()Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v4
:cond_60
:goto_60
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_b1
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/core/ECKey;
.line 981
check-cast v0, Lorg/bitcoinj/crypto/DeterministicKey;
.line 982
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-virtual {v1}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v1
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getAccountPath()Lcom/google/common/collect/ImmutableList;
move-result-object v5
invoke-virtual {v5}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v5
add-int/lit8 v5, v5, 0x2
if-ne v1, v5, :cond_60
.line 983
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->isEncrypted()Z
move-result v1
invoke-static {v1}, Lcom/google/common/base/n;->checkState(Z)V
.line 984
iget-object v5, v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getParent()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
invoke-static {v1}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v1}, Lorg/bitcoinj/crypto/DeterministicKey;->getPath()Lcom/google/common/collect/ImmutableList;
move-result-object v1
invoke-virtual {v5, v1, v2, v2}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->get(Ljava/util/List;ZZ)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v1
.line 986
new-instance v5, Lorg/bitcoinj/crypto/DeterministicKey;
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->dropPrivateBytes()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
invoke-direct {v5, v0, v1}, Lorg/bitcoinj/crypto/DeterministicKey;-><init>(Lorg/bitcoinj/crypto/DeterministicKey;Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 987
iget-object v0, v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->hierarchy:Lorg/bitcoinj/crypto/DeterministicHierarchy;
invoke-virtual {v0, v5}, Lorg/bitcoinj/crypto/DeterministicHierarchy;->putKey(Lorg/bitcoinj/crypto/DeterministicKey;)V
.line 988
iget-object v0, v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->basicKeyChain:Lorg/bitcoinj/wallet/BasicKeyChain;
invoke-virtual {v0, v5}, Lorg/bitcoinj/wallet/BasicKeyChain;->importKey(Lorg/bitcoinj/core/ECKey;)V
goto :goto_60
.line 990
:cond_b1
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
iput v0, v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedExternalKeys:I
.line 991
iget v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
iput v0, v3, Lorg/bitcoinj/wallet/DeterministicKeyChain;->issuedInternalKeys:I
.line 992
return-object v3
.end method
.method public bridge synthetic toDecrypted(Ljava/lang/CharSequence;)Lorg/bitcoinj/wallet/EncryptableKeyChain;
.registers 3
.prologue
.line 97
invoke-virtual {p0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->toDecrypted(Ljava/lang/CharSequence;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v0
return-object v0
.end method
.method public bridge synthetic toDecrypted(Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/EncryptableKeyChain;
.registers 3
.prologue
.line 97
invoke-virtual {p0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->toDecrypted(Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v0
return-object v0
.end method
.method public toEncrypted(Ljava/lang/CharSequence;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
.registers 6
.prologue
const/4 v1, 0x1
const/4 v2, 0x0
.line 942
invoke-static {p1}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 943
invoke-interface {p1}, Ljava/lang/CharSequence;->length()I
move-result v0
if-lez v0, :cond_32
move v0, v1
:goto_c
invoke-static {v0}, Lcom/google/common/base/n;->checkArgument(Z)V
.line 944
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
if-eqz v0, :cond_34
move v0, v1
:goto_14
const-string v3, "Attempt to encrypt a watching chain."
invoke-static {v0, v3}, Lcom/google/common/base/n;->checkState(ZLjava/lang/Object;)V
.line 945
iget-object v0, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v0}, Lorg/bitcoinj/wallet/DeterministicSeed;->isEncrypted()Z
move-result v0
if-nez v0, :cond_36
:goto_21
invoke-static {v1}, Lcom/google/common/base/n;->checkState(Z)V
.line 946
new-instance v0, Lorg/bitcoinj/crypto/KeyCrypterScrypt;
invoke-direct {v0}, Lorg/bitcoinj/crypto/KeyCrypterScrypt;-><init>()V
.line 947
invoke-interface {v0, p1}, Lorg/bitcoinj/crypto/KeyCrypter;->deriveKey(Ljava/lang/CharSequence;)Lorg/spongycastle/crypto/params/KeyParameter;
move-result-object v1
.line 948
invoke-virtual {p0, v0, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->toEncrypted(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v0
return-object v0
:cond_32
move v0, v2
.line 943
goto :goto_c
:cond_34
move v0, v2
.line 944
goto :goto_14
:cond_36
move v1, v2
.line 945
goto :goto_21
.end method
.method public toEncrypted(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
.registers 4
.prologue
.line 953
new-instance v0, Lorg/bitcoinj/wallet/DeterministicKeyChain;
invoke-direct {v0, p1, p2, p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;-><init>(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;Lorg/bitcoinj/wallet/DeterministicKeyChain;)V
return-object v0
.end method
.method public bridge synthetic toEncrypted(Ljava/lang/CharSequence;)Lorg/bitcoinj/wallet/EncryptableKeyChain;
.registers 3
.prologue
.line 97
invoke-virtual {p0, p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->toEncrypted(Ljava/lang/CharSequence;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v0
return-object v0
.end method
.method public bridge synthetic toEncrypted(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/EncryptableKeyChain;
.registers 4
.prologue
.line 97
invoke-virtual {p0, p1, p2}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->toEncrypted(Lorg/bitcoinj/crypto/KeyCrypter;Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/wallet/DeterministicKeyChain;
move-result-object v0
return-object v0
.end method
.method public toString(ZLorg/bitcoinj/core/NetworkParameters;)Ljava/lang/String;
.registers 13
.prologue
const-wide/16 v8, 0x3e8
const/16 v6, 0xa
.line 1318
invoke-virtual {p0}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getWatchingKey()Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
.line 1319
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
.line 1320
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
if-eqz v2, :cond_8e
.line 1321
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v2}, Lorg/bitcoinj/wallet/DeterministicSeed;->isEncrypted()Z
move-result v2
if-eqz v2, :cond_61
.line 1322
const-string v2, "Seed is encrypted\n"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 1328
:cond_1e
:goto_1e
const-string v2, "Seed birthday: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
iget-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v3}, Lorg/bitcoinj/wallet/DeterministicSeed;->getCreationTimeSeconds()J
move-result-wide v4
invoke-virtual {v2, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, " ["
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
iget-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
.line 1329
invoke-virtual {v3}, Lorg/bitcoinj/wallet/DeterministicSeed;->getCreationTimeSeconds()J
move-result-wide v4
mul-long/2addr v4, v8
invoke-static {v4, v5}, Lorg/bitcoinj/core/Utils;->dateTimeFormat(J)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "]\n"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 1334
:goto_48
const-string v2, "Key to watch: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v0, p2}, Lorg/bitcoinj/crypto/DeterministicKey;->serializePubB58(Lorg/bitcoinj/core/NetworkParameters;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
.line 1335
invoke-virtual {p0, p1, p2, v1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->formatAddresses(ZLorg/bitcoinj/core/NetworkParameters;Ljava/lang/StringBuilder;)V
.line 1336
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.line 1323
:cond_61
if-eqz p1, :cond_1e
.line 1324
iget-object v2, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v2}, Lorg/bitcoinj/wallet/DeterministicSeed;->getMnemonicCode()Ljava/util/List;
move-result-object v2
.line 1325
const-string v3, "Seed as words: "
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-static {v2}, Lorg/bitcoinj/core/Utils;->join(Ljava/lang/Iterable;)Ljava/lang/String;
move-result-object v2
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
.line 1326
const-string v2, "Seed as hex: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
iget-object v3, p0, Lorg/bitcoinj/wallet/DeterministicKeyChain;->seed:Lorg/bitcoinj/wallet/DeterministicSeed;
invoke-virtual {v3}, Lorg/bitcoinj/wallet/DeterministicSeed;->toHexString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
goto :goto_1e
.line 1331
:cond_8e
const-string v2, "Key birthday: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getCreationTimeSeconds()J
move-result-wide v4
invoke-virtual {v2, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, " ["
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
.line 1332
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getCreationTimeSeconds()J
move-result-wide v4
mul-long/2addr v4, v8
invoke-static {v4, v5}, Lorg/bitcoinj/core/Utils;->dateTimeFormat(J)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "]\n"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
goto :goto_48
.end method