h.smali
.class public Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;
.super Ljava/lang/Object;
.source "MnemonicCode.java"
# static fields
.field public static Qz:Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;
.field private static final log:Lorg/slf4j/Logger;
# instance fields
.field private wordList:Ljava/util/ArrayList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayList",
"<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
# direct methods
.method static constructor <clinit>()V
.registers 3
.prologue
.line 46
const-class v0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->getLogger(Ljava/lang/Class;)Lorg/slf4j/Logger;
move-result-object v0
sput-object v0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->log:Lorg/slf4j/Logger;
.line 62
:try_start_8
new-instance v0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;
invoke-direct {v0}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;-><init>()V
sput-object v0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->Qz:Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;
:try_end_f
.catch Ljava/io/FileNotFoundException; {:try_start_8 .. :try_end_f} :catch_10
.catch Ljava/io/IOException; {:try_start_8 .. :try_end_f} :catch_1f
.line 70
:cond_f
:goto_f
return-void
.line 63
:catch_10
move-exception v0
.line 65
invoke-static {}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/core/aq;->isAndroidRuntime()Z
move-result v1
if-nez v1, :cond_f
.line 66
sget-object v1, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->log:Lorg/slf4j/Logger;
const-string v2, "Could not find word list"
invoke-interface {v1, v2, v0}, Lorg/slf4j/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_f
.line 67
:catch_1f
move-exception v0
.line 68
sget-object v1, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->log:Lorg/slf4j/Logger;
const-string v2, "Failed to load word list"
invoke-interface {v1, v2, v0}, Lorg/slf4j/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_f
.end method
.method public constructor <init>()V
.registers 3
.prologue
.line 74
.line 1078
const-class v0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;
const-string v1, "mnemonic/wordlist/english.txt"
invoke-virtual {v0, v1}, Ljava/lang/Class;->getResourceAsStream(Ljava/lang/String;)Ljava/io/InputStream;
move-result-object v0
.line 1079
if-nez v0, :cond_12
.line 1080
new-instance v0, Ljava/io/FileNotFoundException;
const-string v1, "mnemonic/wordlist/english.txt"
invoke-direct {v0, v1}, Ljava/io/FileNotFoundException;-><init>(Ljava/lang/String;)V
throw v0
.line 74
:cond_12
const-string v1, "ad90bf3beb7b0eb7e5acd74727dc0da96e0a280a258354e7293fb7e211ac03db"
invoke-direct {p0, v0, v1}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;-><init>(Ljava/io/InputStream;Ljava/lang/String;)V
.line 75
return-void
.end method
.method private constructor <init>(Ljava/io/InputStream;Ljava/lang/String;)V
.registers 8
.prologue
const/16 v4, 0x800
.line 88
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 89
new-instance v0, Ljava/io/BufferedReader;
new-instance v1, Ljava/io/InputStreamReader;
const-string v2, "UTF-8"
invoke-direct {v1, p1, v2}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;Ljava/lang/String;)V
invoke-direct {v0, v1}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;)V
.line 90
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1, v4}, Ljava/util/ArrayList;-><init>(I)V
iput-object v1, p0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->wordList:Ljava/util/ArrayList;
.line 91
invoke-static {}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/core/Sha256Hash;->newDigest()Ljava/security/MessageDigest;
move-result-object v1
.line 93
:goto_1c
invoke-virtual {v0}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v2
if-eqz v2, :cond_2f
.line 94
invoke-virtual {v2}, Ljava/lang/String;->getBytes()[B
move-result-object v3
invoke-virtual {v1, v3}, Ljava/security/MessageDigest;->update([B)V
.line 95
iget-object v3, p0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->wordList:Ljava/util/ArrayList;
invoke-virtual {v3, v2}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1c
.line 97
:cond_2f
invoke-virtual {v0}, Ljava/io/BufferedReader;->close()V
.line 99
iget-object v0, p0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->wordList:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->size()I
move-result v0
if-eq v0, v4, :cond_42
.line 100
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "input stream did not contain 2048 words"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 104
:cond_42
invoke-virtual {v1}, Ljava/security/MessageDigest;->digest()[B
move-result-object v0
.line 105
sget-object v1, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/core/aq;->HEX:Lcom/google/common/io/BaseEncoding;
invoke-virtual {v1, v0}, Lcom/google/common/io/BaseEncoding;->encode([B)Ljava/lang/String;
move-result-object v0
.line 106
invoke-virtual {v0, p2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_5a
.line 107
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "wordlist digest mismatch"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 109
:cond_5a
return-void
.end method
.method private static bytesToBits([B)[Z
.registers 9
.prologue
const/4 v3, 0x1
const/4 v1, 0x0
.line 242
array-length v0, p0
shl-int/lit8 v0, v0, 0x3
new-array v5, v0, [Z
move v0, v1
.line 243
:goto_8
array-length v2, p0
if-ge v0, v2, :cond_29
move v4, v1
.line 244
:goto_c
const/16 v2, 0x8
if-ge v4, v2, :cond_26
.line 245
shl-int/lit8 v2, v0, 0x3
add-int v6, v2, v4
aget-byte v2, p0, v0
rsub-int/lit8 v7, v4, 0x7
shl-int v7, v3, v7
and-int/2addr v2, v7
if-eqz v2, :cond_24
move v2, v3
:goto_1e
aput-boolean v2, v5, v6
.line 244
add-int/lit8 v2, v4, 0x1
move v4, v2
goto :goto_c
:cond_24
move v2, v1
.line 245
goto :goto_1e
.line 243
:cond_26
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 246
:cond_29
return-object v5
.end method
.method public static toSeed(Ljava/util/List;Ljava/lang/String;)[B
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List",
"<",
"Ljava/lang/String;",
">;",
"Ljava/lang/String;",
")[B"
}
.end annotation
.prologue
.line 130
invoke-static {p0}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/core/aq;->join(Ljava/lang/Iterable;)Ljava/lang/String;
move-result-object v0
.line 131
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "mnemonic"
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 133
invoke-static {}, Lcom/google/common/base/s;->wT()Lcom/google/common/base/s;
move-result-object v2
.line 134
invoke-static {v0, v1}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/i;->q(Ljava/lang/String;Ljava/lang/String;)[B
move-result-object v0
.line 135
invoke-virtual {v2}, Lcom/google/common/base/s;->wU()Lcom/google/common/base/s;
.line 136
sget-object v1, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->log:Lorg/slf4j/Logger;
const-string v3, "PBKDF2 took {}"
invoke-interface {v1, v3, v2}, Lorg/slf4j/Logger;->info(Ljava/lang/String;Ljava/lang/Object;)V
.line 137
return-object v0
.end method
# virtual methods
.method public final toMnemonic([B)Ljava/util/List;
.registers 10
.annotation system Ldalvik/annotation/Signature;
value = {
"([B)",
"Ljava/util/List",
"<",
"Ljava/lang/String;",
">;"
}
.end annotation
.prologue
const/4 v2, 0x0
.line 194
array-length v0, p1
rem-int/lit8 v0, v0, 0x4
if-lez v0, :cond_e
.line 195
new-instance v0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/MnemonicException$MnemonicLengthException;
const-string v1, "Entropy length not multiple of 32 bits."
invoke-direct {v0, v1}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/MnemonicException$MnemonicLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 197
:cond_e
array-length v0, p1
if-nez v0, :cond_19
.line 198
new-instance v0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/MnemonicException$MnemonicLengthException;
const-string v1, "Entropy is empty."
invoke-direct {v0, v1}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/MnemonicException$MnemonicLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 203
:cond_19
invoke-static {p1}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/core/Sha256Hash;->hash([B)[B
move-result-object v0
.line 204
invoke-static {v0}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->bytesToBits([B)[Z
move-result-object v0
.line 206
invoke-static {p1}, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->bytesToBits([B)[Z
move-result-object v1
.line 207
array-length v3, v1
div-int/lit8 v3, v3, 0x20
.line 210
array-length v4, v1
add-int/2addr v4, v3
new-array v4, v4, [Z
.line 211
array-length v5, v1
invoke-static {v1, v2, v4, v2, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 212
array-length v1, v1
invoke-static {v0, v2, v4, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 219
new-instance v5, Ljava/util/ArrayList;
invoke-direct {v5}, Ljava/util/ArrayList;-><init>()V
.line 220
array-length v0, v4
div-int/lit8 v6, v0, 0xb
move v3, v2
.line 221
:goto_3d
if-ge v3, v6, :cond_60
move v1, v2
move v0, v2
.line 223
:goto_41
const/16 v7, 0xb
if-ge v1, v7, :cond_53
.line 224
shl-int/lit8 v0, v0, 0x1
.line 225
mul-int/lit8 v7, v3, 0xb
add-int/2addr v7, v1
aget-boolean v7, v4, v7
if-eqz v7, :cond_50
.line 226
or-int/lit8 v0, v0, 0x1
.line 223
:cond_50
add-int/lit8 v1, v1, 0x1
goto :goto_41
.line 228
:cond_53
iget-object v1, p0, Lcom/cmcm/safewallet/data/coinprovider/bch/bitcoinj/crypto/h;->wordList:Ljava/util/ArrayList;
invoke-virtual {v1, v0}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v0
invoke-virtual {v5, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 221
add-int/lit8 v0, v3, 0x1
move v3, v0
goto :goto_3d
.line 231
:cond_60
return-object v5
.end method