n.smali

.class public final Lcom/cmcm/safewallet/data/keystore/n;
.super Lcom/cmcm/safewallet/data/keystore/ai;
.source "HDKeyStore.java"


# instance fields
.field private WR:Ljava/lang/String;

.field private WS:Ljava/lang/String;

.field private mac:Ljava/lang/String;


# direct methods
.method public constructor <init>()V
    .registers 1

    .prologue
    .line 37
    invoke-direct {p0}, Lcom/cmcm/safewallet/data/keystore/ai;-><init>()V

    .line 38
    return-void
.end method

.method static a([BLjava/lang/String;)Ljava/lang/String;
    .registers 9

    .prologue
    .line 144
    invoke-static {}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->builder()Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;

    move-result-object v6

    new-instance v0, Lorg/bitcoinj/wallet/DeterministicSeed;

    new-instance v1, Ljava/util/ArrayList;

    invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V

    const-string v3, ""

    const-wide/16 v4, 0x0

    move-object v2, p0

    invoke-direct/range {v0 .. v5}, Lorg/bitcoinj/wallet/DeterministicSeed;-><init>(Ljava/util/List;[BLjava/lang/String;J)V

    invoke-virtual {v6, v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;->seed(Lorg/bitcoinj/wallet/DeterministicSeed;)Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;

    move-result-object v0

    invoke-virtual {v0}, Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;->build()Lorg/bitcoinj/wallet/DeterministicKeyChain;

    move-result-object v0

    .line 145
    invoke-static {p1}, Lcom/cmcm/safewallet/data/keystore/a;->bk(Ljava/lang/String;)Ljava/util/List;

    move-result-object v1

    .line 146
    if-nez v1, :cond_23

    .line 147
    const/4 v0, 0x0

    .line 151
    :goto_22
    return-object v0

    .line 149
    :cond_23
    const/4 v2, 0x1

    invoke-virtual {v0, v1, v2}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getKeyByPath(Ljava/util/List;Z)Lorg/bitcoinj/crypto/DeterministicKey;

    move-result-object v0

    invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPrivKeyBytes33()[B

    move-result-object v0

    .line 150
    sget-object v1, Lorg/bitcoinj/core/Utils;->HEX:Lcom/google/common/io/BaseEncoding;

    invoke-virtual {v1, v0}, Lcom/google/common/io/BaseEncoding;->encode([B)Ljava/lang/String;

    move-result-object v0

    goto :goto_22
.end method


# virtual methods
.method public final a(Landroid/content/Context;[BLjava/lang/String;)Ljava/lang/String;
    .registers 6

    .prologue
    .line 131
    sget-object v0, Lorg/bitcoinj/core/Utils;->HEX:Lcom/google/common/io/BaseEncoding;

    invoke-virtual {p0, p1, p2}, Lcom/cmcm/safewallet/data/keystore/n;->c(Landroid/content/Context;[B)Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Lcom/google/common/io/BaseEncoding;->m(Ljava/lang/CharSequence;)[B

    move-result-object v0

    .line 132
    invoke-static {v0, p3}, Lcom/cmcm/safewallet/data/keystore/n;->a([BLjava/lang/String;)Ljava/lang/String;

    move-result-object v0

    return-object v0
.end method

.method public final a(Ljava/lang/String;[BLcom/cmcm/safewallet/data/keystore/ak;)V
    .registers 5

    .prologue
    .line 81
    iput-object p3, p0, Lcom/cmcm/safewallet/data/keystore/n;->Xe:Lcom/cmcm/safewallet/data/keystore/ak;

    .line 82
    sget-object v0, Lorg/bitcoinj/core/Utils;->HEX:Lcom/google/common/io/BaseEncoding;

    invoke-virtual {v0, p1}, Lcom/google/common/io/BaseEncoding;->m(Ljava/lang/CharSequence;)[B

    move-result-object v0

    invoke-virtual {p0, v0, p2}, Lcom/cmcm/safewallet/data/keystore/n;->d([B[B)Lcom/cmcm/safewallet/data/keystore/ai;

    .line 83
    return-void
.end method

.method public final a(Lorg/bitcoinj/wallet/DeterministicKeyChain;Ljava/lang/String;[BLjava/lang/String;Lcom/cmcm/safewallet/data/keystore/ak;)V
    .registers 12

    .prologue
    .line 87
    iput-object p5, p0, Lcom/cmcm/safewallet/data/keystore/n;->Xe:Lcom/cmcm/safewallet/data/keystore/ak;

    .line 88
    iput-object p2, p0, Lcom/cmcm/safewallet/data/keystore/n;->WS:Ljava/lang/String;

    .line 1054
    const-string v0, "@@@"

    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "HDKeystore build defaultCoinName : "

    invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-virtual {v1, p4}, 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 2052
    invoke-static {v0, v1}, Lcom/cmcm/safewallet/a/e;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 1055
    sget-object v0, Lcom/cmcm/safewallet/data/keystore/m;->WJ:Ljava/lang/String;

    .line 1057
    invoke-virtual {p1}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->getSeed()Lorg/bitcoinj/wallet/DeterministicSeed;

    move-result-object v1

    invoke-virtual {v1}, Lorg/bitcoinj/wallet/DeterministicSeed;->getSeedBytes()[B

    move-result-object v1

    .line 1058
    invoke-virtual {p0, v1, p3}, Lcom/cmcm/safewallet/data/keystore/n;->d([B[B)Lcom/cmcm/safewallet/data/keystore/ai;

    .line 2088
    const v1, 0x800001

    iput v1, p0, Lcom/cmcm/safewallet/data/keystore/q;->version:I

    .line 1065
    invoke-virtual {p0, p3}, Lcom/cmcm/safewallet/data/keystore/n;->L([B)[B

    move-result-object v1

    .line 1068
    iget-object v2, p0, Lcom/cmcm/safewallet/data/keystore/n;->WS:Ljava/lang/String;

    if-eqz v2, :cond_7d

    .line 1069
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "HDKeystore build encrypt start : "

    invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v4

    invoke-virtual {v2, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    .line 1070
    sget-object v2, Lorg/bitcoinj/core/Utils;->HEX:Lcom/google/common/io/BaseEncoding;

    iget-object v3, p0, Lcom/cmcm/safewallet/data/keystore/n;->Xy:Lcom/cmcm/safewallet/data/keystore/m;

    .line 3057
    iget-object v3, v3, Lcom/cmcm/safewallet/data/keystore/m;->WN:Lcom/cmcm/safewallet/data/keystore/j;

    .line 4018
    iget-object v3, v3, Lcom/cmcm/safewallet/data/keystore/j;->WB:Ljava/lang/String;

    .line 1070
    invoke-virtual {v2, v3}, Lcom/google/common/io/BaseEncoding;->m(Ljava/lang/CharSequence;)[B

    move-result-object v2

    invoke-virtual {p0, p3}, Lcom/cmcm/safewallet/data/keystore/n;->L([B)[B

    move-result-object v3

    const/4 v4, 0x0

    const/16 v5, 0x10

    invoke-static {v3, v4, v5}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B

    move-result-object v3

    iget-object v4, p0, Lcom/cmcm/safewallet/data/keystore/n;->WS:Ljava/lang/String;

    invoke-virtual {v4}, Ljava/lang/String;->getBytes()[B

    move-result-object v4

    invoke-static {v2, v3, v4, v0}, Lcom/cmcm/safewallet/data/keystore/al;->b([B[B[BLjava/lang/String;)[B

    move-result-object v0

    .line 1071
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "HDKeystore build encrypt end : "

    invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v4

    invoke-virtual {v2, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    .line 1073
    invoke-static {v1, v0}, Lcom/cmcm/safewallet/data/keystore/al;->e([B[B)Ljava/lang/String;

    move-result-object v1

    iput-object v1, p0, Lcom/cmcm/safewallet/data/keystore/n;->mac:Ljava/lang/String;

    .line 1074
    sget-object v1, Lorg/bitcoinj/core/Utils;->HEX:Lcom/google/common/io/BaseEncoding;

    invoke-virtual {v1, v0}, Lcom/google/common/io/BaseEncoding;->encode([B)Ljava/lang/String;

    move-result-object v0

    iput-object v0, p0, Lcom/cmcm/safewallet/data/keystore/n;->WR:Ljava/lang/String;

    .line 1076
    :cond_7d
    const-string v0, "@@@"

    const-string v1, "HDKeystore build finish"

    .line 4052
    invoke-static {v0, v1}, Lcom/cmcm/safewallet/a/e;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 90
    return-void
.end method

.method public final a(Lorg/json/JSONObject;)Z
    .registers 5

    .prologue
    const/4 v0, 0x0

    .line 193
    :try_start_1
    invoke-super {p0, p1}, Lcom/cmcm/safewallet/data/keystore/ai;->a(Lorg/json/JSONObject;)Z

    move-result v1

    if-nez v1, :cond_8

    .line 214
    :cond_7
    :goto_7
    return v0

    .line 198
    :cond_8
    if-eqz p1, :cond_7

    .line 201
    const-string v1, "mnemonic"

    invoke-virtual {p1, v1}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z

    move-result v1

    if-eqz v1, :cond_38

    .line 202
    const-string v1, "mnemonic"

    invoke-virtual {p1, v1}, Lorg/json/JSONObject;->getJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;

    move-result-object v1

    .line 203
    const-string v2, "encode"

    invoke-virtual {v1, v2}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z

    move-result v2

    if-eqz v2, :cond_28

    .line 204
    const-string v2, "encode"

    invoke-virtual {v1, v2}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v2

    iput-object v2, p0, Lcom/cmcm/safewallet/data/keystore/n;->WR:Ljava/lang/String;

    .line 206
    :cond_28
    const-string v2, "mac"

    invoke-virtual {v1, v2}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z

    move-result v2

    if-eqz v2, :cond_38

    .line 207
    const-string v2, "mac"

    invoke-virtual {v1, v2}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    iput-object v1, p0, Lcom/cmcm/safewallet/data/keystore/n;->mac:Ljava/lang/String;
    :try_end_38
    .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_38} :catch_3a

    .line 214
    :cond_38
    const/4 v0, 0x1

    goto :goto_7

    .line 211
    :catch_3a
    move-exception v1

    invoke-virtual {v1}, Ljava/lang/Exception;->printStackTrace()V

    goto :goto_7
.end method

.method public final toJSON()Lorg/json/JSONObject;
    .registers 5

    .prologue
    .line 174
    invoke-super {p0}, Lcom/cmcm/safewallet/data/keystore/ai;->toJSON()Lorg/json/JSONObject;

    move-result-object v0

    .line 176
    :try_start_4
    iget-object v1, p0, Lcom/cmcm/safewallet/data/keystore/n;->WR:Ljava/lang/String;

    if-eqz v1, :cond_20

    .line 177
    new-instance v1, Lorg/json/JSONObject;

    invoke-direct {v1}, Lorg/json/JSONObject;-><init>()V

    .line 178
    const-string v2, "mac"

    iget-object v3, p0, Lcom/cmcm/safewallet/data/keystore/n;->mac:Ljava/lang/String;

    invoke-virtual {v1, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;

    .line 179
    const-string v2, "encode"

    iget-object v3, p0, Lcom/cmcm/safewallet/data/keystore/n;->WR:Ljava/lang/String;

    invoke-virtual {v1, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;

    .line 180
    const-string v2, "mnemonic"

    invoke-virtual {v0, v2, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
    :try_end_20
    .catch Ljava/lang/Exception; {:try_start_4 .. :try_end_20} :catch_21

    .line 187
    :cond_20
    :goto_20
    return-object v0

    .line 183
    :catch_21
    move-exception v0

    invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V

    .line 184
    const/4 v0, 0x0

    goto :goto_20
.end method