CognitoDeviceHelper$deviceSRP.smali
.class public Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;
.super Ljava/lang/Object;
.source "CognitoDeviceHelper.java"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x9
name = "deviceSRP"
.end annotation
# static fields
.field private static final GG:Ljava/math/BigInteger;
.field private static final HASH_ALGORITHM:Ljava/lang/String; = "SHA-256"
.field private static final HEX_N:Ljava/lang/String; = "FFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD129024E088A67CC74020BBEA63B139B22514A08798E3404DDEF9519B3CD3A431B302B0A6DF25F14374FE1356D6D51C245E485B576625E7EC6F44C42E9A637ED6B0BFF5CB6F406B7EDEE386BFB5A899FA5AE9F24117C4B1FE649286651ECE45B3DC2007CB8A163BF0598DA48361C55D39A69163FA8FD24CF5F83655D23DCA3AD961C62F356208552BB9ED529077096966D670C354E4ABC9804F1746C08CA18217C32905E462E36CE3BE39E772C180E86039B2783A2EC07A28FB5C55DF06F4C52C9DE2BCBF6955817183995497CEA956AE515D2261898FA051015728E5A8AAAC42DAD33170D04507A33A85521ABDF1CBA64ECFB850458DBEF0A8AEA71575D060C7DB3970F85A6E1E4C7ABF5AE8CDB0933D71E8C94E04A25619DCEE3D2261AD2EE6BF12FFA06D98A0864D87602733EC86A64521F2B18177B200CBBE117577A615D6C770988C0BAD946E208E24FA074E5AB3143DB5BFCE0FD108E4B82D120A93AD2CAFFFFFFFFFFFFFFFF"
.field private static final N:Ljava/math/BigInteger;
.field private static final SALT_LENGTH_BITS:I = 0x80
.field private static final SECURE_RANDOM:Ljava/security/SecureRandom;
.field private static final THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/ThreadLocal<",
"Ljava/security/MessageDigest;",
">;"
}
.end annotation
.end field
# instance fields
.field private final salt:Ljava/math/BigInteger;
.field private final verifier:Ljava/math/BigInteger;
# direct methods
.method static constructor <clinit>()V
.registers 3
.line 1
new-instance v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP$1;
invoke-direct {v0}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP$1;-><init>()V
sput-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
.line 2
new-instance v0, Ljava/math/BigInteger;
const-string v1, "FFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD129024E088A67CC74020BBEA63B139B22514A08798E3404DDEF9519B3CD3A431B302B0A6DF25F14374FE1356D6D51C245E485B576625E7EC6F44C42E9A637ED6B0BFF5CB6F406B7EDEE386BFB5A899FA5AE9F24117C4B1FE649286651ECE45B3DC2007CB8A163BF0598DA48361C55D39A69163FA8FD24CF5F83655D23DCA3AD961C62F356208552BB9ED529077096966D670C354E4ABC9804F1746C08CA18217C32905E462E36CE3BE39E772C180E86039B2783A2EC07A28FB5C55DF06F4C52C9DE2BCBF6955817183995497CEA956AE515D2261898FA051015728E5A8AAAC42DAD33170D04507A33A85521ABDF1CBA64ECFB850458DBEF0A8AEA71575D060C7DB3970F85A6E1E4C7ABF5AE8CDB0933D71E8C94E04A25619DCEE3D2261AD2EE6BF12FFA06D98A0864D87602733EC86A64521F2B18177B200CBBE117577A615D6C770988C0BAD946E208E24FA074E5AB3143DB5BFCE0FD108E4B82D120A93AD2CAFFFFFFFFFFFFFFFF"
const/16 v2, 0x10
invoke-direct {v0, v1, v2}, Ljava/math/BigInteger;-><init>(Ljava/lang/String;I)V
sput-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->N:Ljava/math/BigInteger;
const-wide/16 v0, 0x2
.line 3
invoke-static {v0, v1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v0
sput-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->GG:Ljava/math/BigInteger;
:try_start_1a
const-string v0, "SHA1PRNG"
.line 4
invoke-static {v0}, Ljava/security/SecureRandom;->getInstance(Ljava/lang/String;)Ljava/security/SecureRandom;
move-result-object v0
sput-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->SECURE_RANDOM:Ljava/security/SecureRandom;
:try_end_22
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_1a .. :try_end_22} :catch_23
return-void
:catch_23
move-exception v0
.line 5
new-instance v1, Ljava/lang/ExceptionInInitializerError;
invoke-direct {v1, v0}, Ljava/lang/ExceptionInInitializerError;-><init>(Ljava/lang/Throwable;)V
throw v1
.end method
.method public constructor <init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.registers 5
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
invoke-direct {p0, p1, p2, p3}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->getUserIdHash(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)[B
move-result-object p1
.line 3
new-instance p2, Ljava/math/BigInteger;
sget-object p3, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->SECURE_RANDOM:Ljava/security/SecureRandom;
const/16 v0, 0x80
invoke-direct {p2, v0, p3}, Ljava/math/BigInteger;-><init>(ILjava/util/Random;)V
iput-object p2, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->salt:Ljava/math/BigInteger;
.line 4
iget-object p2, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->salt:Ljava/math/BigInteger;
invoke-static {p2, p1}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->calcVerifier(Ljava/math/BigInteger;[B)Ljava/math/BigInteger;
move-result-object p1
iput-object p1, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->verifier:Ljava/math/BigInteger;
return-void
.end method
.method public static begin()V
.registers 1
.line 1
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
.line 2
invoke-virtual {v0}, Ljava/security/MessageDigest;->reset()V
return-void
.end method
.method private static calcVerifier(Ljava/math/BigInteger;[B)Ljava/math/BigInteger;
.registers 3
.line 1
invoke-static {}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->begin()V
.line 2
invoke-static {p0}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->update(Ljava/math/BigInteger;)V
.line 3
invoke-static {p1}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->update([B)V
.line 4
invoke-static {}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->end()[B
move-result-object p0
.line 5
new-instance p1, Ljava/math/BigInteger;
const/4 v0, 0x1
invoke-direct {p1, v0, p0}, Ljava/math/BigInteger;-><init>(I[B)V
.line 6
sget-object p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->GG:Ljava/math/BigInteger;
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->N:Ljava/math/BigInteger;
invoke-virtual {p0, p1, v0}, Ljava/math/BigInteger;->modPow(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.end method
.method public static end()[B
.registers 1
.line 1
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
.line 2
invoke-virtual {v0}, Ljava/security/MessageDigest;->digest()[B
move-result-object v0
return-object v0
.end method
.method private getUserIdHash(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)[B
.registers 6
.line 1
invoke-static {}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->begin()V
const/4 v0, 0x4
.line 2
new-array v0, v0, [Ljava/lang/String;
const/4 v1, 0x0
aput-object p1, v0, v1
const/4 p1, 0x1
aput-object p2, v0, p1
const/4 p1, 0x2
const-string p2, ":"
aput-object p2, v0, p1
const/4 p1, 0x3
aput-object p3, v0, p1
invoke-static {v0}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->update([Ljava/lang/String;)V
.line 3
invoke-static {}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->end()[B
move-result-object p1
return-object p1
.end method
.method public static update(Ljava/lang/String;)V
.registers 3
.line 4
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
if-eqz p0, :cond_13
.line 5
sget-object v1, Lcom/amazonaws/util/StringUtils;->UTF8:Ljava/nio/charset/Charset;
invoke-virtual {p0, v1}, Ljava/lang/String;->getBytes(Ljava/nio/charset/Charset;)[B
move-result-object p0
invoke-virtual {v0, p0}, Ljava/security/MessageDigest;->update([B)V
:cond_13
return-void
.end method
.method public static update(Ljava/math/BigInteger;)V
.registers 2
.line 9
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
if-eqz p0, :cond_11
.line 10
invoke-virtual {p0}, Ljava/math/BigInteger;->toByteArray()[B
move-result-object p0
invoke-virtual {v0, p0}, Ljava/security/MessageDigest;->update([B)V
:cond_11
return-void
.end method
.method public static update(Ljava/nio/ByteBuffer;)V
.registers 2
.line 11
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
if-eqz p0, :cond_11
.line 12
invoke-virtual {p0}, Ljava/nio/ByteBuffer;->array()[B
move-result-object p0
invoke-virtual {v0, p0}, Ljava/security/MessageDigest;->update([B)V
:cond_11
return-void
.end method
.method public static update([B)V
.registers 2
.line 13
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
if-eqz p0, :cond_d
.line 14
invoke-virtual {v0, p0}, Ljava/security/MessageDigest;->update([B)V
:cond_d
return-void
.end method
.method public static varargs update([Ljava/lang/String;)V
.registers 6
.line 1
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
.line 2
array-length v1, p0
const/4 v2, 0x0
:goto_a
if-ge v2, v1, :cond_1c
aget-object v3, p0, v2
if-eqz v3, :cond_19
.line 3
sget-object v4, Lcom/amazonaws/util/StringUtils;->UTF8:Ljava/nio/charset/Charset;
invoke-virtual {v3, v4}, Ljava/lang/String;->getBytes(Ljava/nio/charset/Charset;)[B
move-result-object v3
invoke-virtual {v0, v3}, Ljava/security/MessageDigest;->update([B)V
:cond_19
add-int/lit8 v2, v2, 0x1
goto :goto_a
:cond_1c
return-void
.end method
.method public static varargs update([Ljava/math/BigInteger;)V
.registers 5
.line 6
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->THREAD_MESSAGE_DIGEST:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/security/MessageDigest;
.line 7
array-length v1, p0
const/4 v2, 0x0
:goto_a
if-ge v2, v1, :cond_1a
aget-object v3, p0, v2
if-eqz v3, :cond_17
.line 8
invoke-virtual {v3}, Ljava/math/BigInteger;->toByteArray()[B
move-result-object v3
invoke-virtual {v0, v3}, Ljava/security/MessageDigest;->update([B)V
:cond_17
add-int/lit8 v2, v2, 0x1
goto :goto_a
:cond_1a
return-void
.end method
# virtual methods
.method public getSalt()Ljava/math/BigInteger;
.registers 2
.line 1
iget-object v0, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->salt:Ljava/math/BigInteger;
return-object v0
.end method
.method public getVerifier()Ljava/math/BigInteger;
.registers 2
.line 1
iget-object v0, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/CognitoDeviceHelper$deviceSRP;->verifier:Ljava/math/BigInteger;
return-object v0
.end method