b.smali
.class public final Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;
.super Ljava/lang/Object;
.source "PrivateKeyCheck.java"
# static fields
.field private static SL:I
.field private static SM:I
.field private static SO:I
.field private static SP:I
.field private static SQ:I
.field private static SR:I
.field private static SS:I
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 50
const/4 v0, -0x1
sput v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SL:I
.line 51
const/4 v0, -0x2
sput v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SM:I
.line 54
const/4 v0, -0x5
sput v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SO:I
.line 55
const/4 v0, -0x6
sput v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SP:I
.line 56
const/4 v0, -0x7
sput v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SQ:I
.line 57
const/4 v0, -0x8
sput v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SR:I
.line 58
const/16 v0, -0x9
sput v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SS:I
return-void
.end method
.method public static a(Ljava/lang/String;Landroid/content/Context;Ljava/lang/String;)Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;
.registers 4
.prologue
.line 247
const-string v0, ""
invoke-static {p0, p1, p2, v0}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->a(Ljava/lang/String;Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;
move-result-object v0
return-object v0
.end method
.method private static a(Ljava/lang/String;Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;
.registers 12
.prologue
.line 252
if-nez p1, :cond_4
.line 253
const/4 v0, 0x0
.line 292
:goto_3
return-object v0
.line 254
:cond_4
invoke-virtual {p1}, Landroid/content/Context;->getAssets()Landroid/content/res/AssetManager;
move-result-object v0
.line 255
new-instance v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;
invoke-direct {v6}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;-><init>()V
.line 256
const-string v1, "\\s+"
invoke-virtual {p0, v1}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v2
.line 257
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v1
rem-int/lit8 v1, v1, 0x3
if-lez v1, :cond_25
.line 258
sget v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SR:I
iput v0, v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
move-object v0, v6
.line 259
goto :goto_3
.line 262
:cond_25
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v1
const/16 v3, 0xc
if-ge v1, v3, :cond_33
.line 263
sget v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SQ:I
iput v0, v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
move-object v0, v6
.line 264
goto :goto_3
.line 267
:cond_33
invoke-static {p0, v0}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/a;->a(Ljava/lang/String;Landroid/content/res/AssetManager;)I
move-result v1
.line 268
const/4 v3, -0x1
if-ne v1, v3, :cond_3e
.line 270
sget v3, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SP:I
iput v3, v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
.line 274
:cond_3e
:try_start_3e
invoke-static {v1, v0}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/a;->a(ILandroid/content/res/AssetManager;)Lcom/cmcm/safewallet/data/coinprovider/btc/cm/a;
.line 275
invoke-static {}, Lorg/bitcoinj/wallet/DeterministicKeyChain;->builder()Lorg/bitcoinj/wallet/DeterministicKeyChain$Builder;
move-result-object v7
new-instance v0, Lorg/bitcoinj/wallet/DeterministicSeed;
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
invoke-static {v2}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/a;->i(Ljava/util/List;)[B
move-result-object v2
const-wide/16 v4, 0x0
move-object v3, p3
invoke-direct/range {v0 .. v5}, Lorg/bitcoinj/wallet/DeterministicSeed;-><init>(Ljava/util/List;[BLjava/lang/String;J)V
invoke-virtual {v7, 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 276
invoke-static {p2}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->ax(Ljava/lang/String;)Lcom/google/common/collect/ImmutableList;
move-result-object v1
.line 277
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 v2
.line 278
invoke-virtual {v2}, Lorg/bitcoinj/crypto/DeterministicKey;->isCompressed()Z
move-result v0
iput-boolean v0, v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SV:Z
.line 279
invoke-virtual {v1}, Lcom/google/common/collect/ImmutableList;->size()I
move-result v0
const/4 v3, 0x2
if-le v0, v3, :cond_88
.line 281
const/4 v0, 0x1
invoke-virtual {v1, v0}, Lcom/google/common/collect/ImmutableList;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/crypto/ChildNumber;
.line 282
invoke-virtual {v0}, Lorg/bitcoinj/crypto/ChildNumber;->getI()I
move-result v0
and-int/lit16 v0, v0, 0xff
.line 283
const/16 v1, 0x3c
if-ne v0, v1, :cond_88
.line 284
const/4 v0, 0x0
iput-boolean v0, v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SV:Z
.line 286
:cond_88
invoke-virtual {v2}, Lorg/bitcoinj/crypto/DeterministicKey;->getPrivKey()Ljava/math/BigInteger;
move-result-object v0
iput-object v0, v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
:try_end_8e
.catch Ljava/lang/Exception; {:try_start_3e .. :try_end_8e} :catch_91
:goto_8e
move-object v0, v6
.line 292
goto/16 :goto_3
.line 289
:catch_91
move-exception v0
sget v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SO:I
iput v0, v6, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
goto :goto_8e
.end method
.method public static aw(Ljava/lang/String;)Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;
.registers 9
.prologue
const/16 v7, 0x40
const/4 v6, 0x2
const/16 v3, 0x10
const/4 v5, 0x0
const/4 v4, 0x1
.line 85
new-instance v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;
invoke-direct {v1}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;-><init>()V
.line 86
iput-boolean v4, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SV:Z
.line 87
new-array v0, v5, [B
.line 90
:try_start_10
invoke-static {p0}, Lorg/bitcoinj/core/Base58;->decodeChecked(Ljava/lang/String;)[B
:try_end_13
.catch Ljava/lang/Exception; {:try_start_10 .. :try_end_13} :catch_155
move-result-object v0
.line 93
:goto_14
array-length v2, v0
if-nez v2, :cond_7e
.line 95
const-string v0, "0x"
invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_23
.line 96
invoke-virtual {p0, v6}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object p0
.line 97
:cond_23
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v0
if-ne v0, v7, :cond_31
.line 99
new-instance v0, Ljava/math/BigInteger;
invoke-direct {v0, p0, v3}, Ljava/math/BigInteger;-><init>(Ljava/lang/String;I)V
iput-object v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
.line 174
:cond_30
:goto_30
return-object v1
.line 101
:cond_31
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v0
const/16 v2, 0x42
if-ne v0, v2, :cond_4d
const-string v0, "00"
invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_4d
.line 103
new-instance v0, Ljava/math/BigInteger;
invoke-virtual {p0, v6}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v2
invoke-direct {v0, v2, v3}, Ljava/math/BigInteger;-><init>(Ljava/lang/String;I)V
iput-object v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
goto :goto_30
.line 105
:cond_4d
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v0
const/16 v2, 0x42
if-ne v0, v2, :cond_6b
const-string v0, "01"
invoke-virtual {p0, v0}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_6b
.line 107
new-instance v0, Ljava/math/BigInteger;
invoke-virtual {p0, v5, v7}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v2
invoke-direct {v0, v2, v3}, Ljava/math/BigInteger;-><init>(Ljava/lang/String;I)V
iput-object v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
.line 108
iput-boolean v4, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SV:Z
goto :goto_30
.line 110
:cond_6b
invoke-static {p0}, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->isNumeric(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_79
.line 112
new-instance v0, Ljava/math/BigInteger;
invoke-direct {v0, p0}, Ljava/math/BigInteger;-><init>(Ljava/lang/String;)V
iput-object v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
goto :goto_30
.line 115
:cond_79
sget v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SL:I
iput v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
goto :goto_30
.line 119
:cond_7e
aget-byte v2, v0, v5
and-int/lit16 v2, v2, 0xff
.line 121
const/16 v3, 0x80
if-ne v2, v3, :cond_cc
.line 123
const-string v2, "5"
invoke-virtual {p0, v2}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_9f
.line 125
array-length v2, v0
invoke-static {v0, v4, v2}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v0
.line 126
new-instance v2, Ljava/math/BigInteger;
invoke-static {v0, v5}, Lorg/spongycastle/util/Arrays;->prepend([BB)[B
move-result-object v0
invoke-direct {v2, v0}, Ljava/math/BigInteger;-><init>([B)V
iput-object v2, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
goto :goto_30
.line 129
:cond_9f
const-string v2, "K"
invoke-virtual {p0, v2}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v2
if-nez v2, :cond_b6
const-string v2, "L"
invoke-virtual {p0, v2}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_30
array-length v2, v0
add-int/lit8 v2, v2, -0x1
aget-byte v2, v0, v2
if-ne v2, v4, :cond_30
.line 131
:cond_b6
array-length v2, v0
add-int/lit8 v2, v2, -0x1
invoke-static {v0, v4, v2}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v0
.line 132
new-instance v2, Ljava/math/BigInteger;
invoke-static {v0, v5}, Lorg/spongycastle/util/Arrays;->prepend([BB)[B
move-result-object v0
invoke-direct {v2, v0}, Ljava/math/BigInteger;-><init>([B)V
iput-object v2, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
.line 133
iput-boolean v4, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SV:Z
goto/16 :goto_30
.line 138
:cond_cc
const/16 v3, 0xef
if-eq v2, v3, :cond_d4
const/16 v3, 0xb0
if-ne v2, v3, :cond_10d
.line 141
:cond_d4
array-length v2, v0
const/16 v3, 0x22
if-ne v2, v3, :cond_f6
array-length v2, v0
add-int/lit8 v2, v2, -0x1
aget-byte v2, v0, v2
if-ne v2, v4, :cond_f6
.line 143
array-length v2, v0
add-int/lit8 v2, v2, -0x1
invoke-static {v0, v4, v2}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v0
.line 144
new-instance v2, Ljava/math/BigInteger;
invoke-static {v0, v5}, Lorg/spongycastle/util/Arrays;->prepend([BB)[B
move-result-object v0
invoke-direct {v2, v0}, Ljava/math/BigInteger;-><init>([B)V
iput-object v2, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
.line 145
iput-boolean v4, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SV:Z
goto/16 :goto_30
.line 147
:cond_f6
array-length v2, v0
const/16 v3, 0x21
if-ne v2, v3, :cond_30
.line 149
array-length v2, v0
invoke-static {v0, v4, v2}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v0
.line 150
new-instance v2, Ljava/math/BigInteger;
invoke-static {v0, v5}, Lorg/spongycastle/util/Arrays;->prepend([BB)[B
move-result-object v0
invoke-direct {v2, v0}, Ljava/math/BigInteger;-><init>([B)V
iput-object v2, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
goto/16 :goto_30
.line 153
:cond_10d
const-string v0, "6P"
invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_11b
.line 155
sget v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SM:I
iput v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
goto/16 :goto_30
.line 160
:cond_11b
const-string v0, "xprv"
invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_12b
const-string v0, "tprv"
invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_14f
.line 162
:cond_12b
const-string v0, "tprv"
invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
.line 164
const-string v0, "org.bitcoin.production"
invoke-static {v0}, Lorg/bitcoinj/core/NetworkParameters;->fromID(Ljava/lang/String;)Lorg/bitcoinj/core/NetworkParameters;
move-result-object v0
invoke-static {p0, v0}, Lorg/bitcoinj/crypto/DeterministicKey;->deserializeB58(Ljava/lang/String;Lorg/bitcoinj/core/NetworkParameters;)Lorg/bitcoinj/crypto/DeterministicKey;
move-result-object v0
.line 165
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getDepth()I
.line 166
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->isCompressed()Z
move-result v2
iput-boolean v2, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SV:Z
.line 167
invoke-virtual {v0}, Lorg/bitcoinj/crypto/DeterministicKey;->getPrivKey()Ljava/math/BigInteger;
move-result-object v0
iput-object v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->SU:Ljava/math/BigInteger;
.line 168
sget v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SS:I
iput v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
goto/16 :goto_30
.line 171
:cond_14f
sget v0, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/b;->SL:I
iput v0, v1, Lcom/cmcm/safewallet/data/coinprovider/btc/cm/c;->errorCode:I
goto/16 :goto_30
:catch_155
move-exception v2
goto/16 :goto_14
.end method
.method private static ax(Ljava/lang/String;)Lcom/google/common/collect/ImmutableList;
.registers 9
.prologue
const/4 v1, 0x0
.line 205
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
.line 206
const-string v0, "/"
invoke-virtual {p0, v0}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v3
.line 207
array-length v4, v3
move v0, v1
.line 208
:goto_e
if-ge v0, v4, :cond_4f
.line 209
aget-object v5, v3, v0
.line 210
const-string v6, "m"
invoke-virtual {v6, v5}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v6
if-nez v6, :cond_3f
.line 211
invoke-virtual {v5}, Ljava/lang/String;->length()I
move-result v6
add-int/lit8 v6, v6, -0x1
invoke-virtual {v5, v6}, Ljava/lang/String;->charAt(I)C
move-result v6
const/16 v7, 0x27
if-ne v6, v7, :cond_42
.line 212
new-instance v6, Lorg/bitcoinj/crypto/ChildNumber;
invoke-virtual {v5}, Ljava/lang/String;->length()I
move-result v7
add-int/lit8 v7, v7, -0x1
invoke-virtual {v5, v1, v7}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v5
invoke-static {v5}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result v5
const/4 v7, 0x1
invoke-direct {v6, v5, v7}, Lorg/bitcoinj/crypto/ChildNumber;-><init>(IZ)V
invoke-interface {v2, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 208
:cond_3f
:goto_3f
add-int/lit8 v0, v0, 0x1
goto :goto_e
.line 215
:cond_42
new-instance v6, Lorg/bitcoinj/crypto/ChildNumber;
invoke-static {v5}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result v5
invoke-direct {v6, v5, v1}, Lorg/bitcoinj/crypto/ChildNumber;-><init>(IZ)V
invoke-interface {v2, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_3f
.line 220
:cond_4f
invoke-static {}, Lcom/google/common/collect/ImmutableList;->builder()Lcom/google/common/collect/an;
move-result-object v0
invoke-virtual {v0, v2}, Lcom/google/common/collect/an;->c(Ljava/lang/Iterable;)Lcom/google/common/collect/an;
move-result-object v0
invoke-virtual {v0}, Lcom/google/common/collect/an;->xm()Lcom/google/common/collect/ImmutableList;
move-result-object v0
return-object v0
.end method
.method public static isNumeric(Ljava/lang/String;)Z
.registers 2
.prologue
.line 67
const-string v0, "[0-9]*"
invoke-static {v0}, Ljava/util/regex/Pattern;->compile(Ljava/lang/String;)Ljava/util/regex/Pattern;
move-result-object v0
.line 68
invoke-virtual {v0, p0}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
move-result-object v0
.line 69
invoke-virtual {v0}, Ljava/util/regex/Matcher;->matches()Z
move-result v0
if-nez v0, :cond_12
.line 70
const/4 v0, 0x0
.line 72
:goto_11
return v0
:cond_12
const/4 v0, 0x1
goto :goto_11
.end method