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