Hkdf.smali
.class public final Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;
.super Ljava/lang/Object;
.source "Hkdf.java"
# static fields
.field private static final EMPTY_ARRAY:[B
.field private static final MAX_KEY_SIZE:I = 0xff
# instance fields
.field private final algorithm:Ljava/lang/String;
.field private prk:Ljavax/crypto/SecretKey;
# direct methods
.method static constructor <clinit>()V
.registers 1
const/4 v0, 0x0
.line 1
new-array v0, v0, [B
sput-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->EMPTY_ARRAY:[B
return-void
.end method
.method private constructor <init>(Ljava/lang/String;)V
.registers 5
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
.line 2
iput-object v0, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->prk:Ljavax/crypto/SecretKey;
const-string v0, "Hmac"
.line 3
invoke-virtual {p1, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_11
.line 4
iput-object p1, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->algorithm:Ljava/lang/String;
return-void
.line 5
:cond_11
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Invalid algorithm "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, ". Hkdf may only be used with Hmac algorithms."
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private assertInitialized()V
.registers 3
.line 1
iget-object v0, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->prk:Ljavax/crypto/SecretKey;
if-eqz v0, :cond_5
return-void
.line 2
:cond_5
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Hkdf has not been initialized"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private createMac()Ljavax/crypto/Mac;
.registers 3
.line 1
:try_start_0
iget-object v0, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->algorithm:Ljava/lang/String;
invoke-static {v0}, Ljavax/crypto/Mac;->getInstance(Ljava/lang/String;)Ljavax/crypto/Mac;
move-result-object v0
.line 2
iget-object v1, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->prk:Ljavax/crypto/SecretKey;
invoke-virtual {v0, v1}, Ljavax/crypto/Mac;->init(Ljava/security/Key;)V
:try_end_b
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_0 .. :try_end_b} :catch_13
.catch Ljava/security/InvalidKeyException; {:try_start_0 .. :try_end_b} :catch_c
return-object v0
:catch_c
move-exception v0
.line 3
new-instance v1, Ljava/lang/RuntimeException;
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw v1
:catch_13
move-exception v0
.line 4
new-instance v1, Ljava/lang/RuntimeException;
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw v1
.end method
.method public static getInstance(Ljava/lang/String;)Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/security/NoSuchAlgorithmException;
}
.end annotation
.line 1
invoke-static {p0}, Ljavax/crypto/Mac;->getInstance(Ljava/lang/String;)Ljavax/crypto/Mac;
.line 2
new-instance v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;
invoke-direct {v0, p0}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;-><init>(Ljava/lang/String;)V
return-object v0
.end method
# virtual methods
.method public deriveKey([BI[BI)V
.registers 11
.annotation system Ldalvik/annotation/Throws;
value = {
Ljavax/crypto/ShortBufferException;
}
.end annotation
.line 5
invoke-direct {p0}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->assertInitialized()V
if-ltz p2, :cond_57
.line 6
array-length v0, p3
add-int/2addr p4, p2
if-lt v0, p4, :cond_51
.line 7
invoke-direct {p0}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->createMac()Ljavax/crypto/Mac;
move-result-object p4
.line 8
invoke-virtual {p4}, Ljavax/crypto/Mac;->getMacLength()I
move-result v0
mul-int/lit16 v0, v0, 0xff
if-gt p2, v0, :cond_49
.line 9
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->EMPTY_ARRAY:[B
const/4 v1, 0x1
const/4 v2, 0x0
move-object v1, v0
const/4 v0, 0x0
const/4 v3, 0x1
:goto_1c
if-ge v0, p2, :cond_45
.line 10
:try_start_1e
invoke-virtual {p4, v1}, Ljavax/crypto/Mac;->update([B)V
.line 11
invoke-virtual {p4, p1}, Ljavax/crypto/Mac;->update([B)V
.line 12
invoke-virtual {p4, v3}, Ljavax/crypto/Mac;->update(B)V
.line 13
invoke-virtual {p4}, Ljavax/crypto/Mac;->doFinal()[B
move-result-object v1
move v4, v0
const/4 v0, 0x0
.line 14
:goto_2d
array-length v5, v1
if-ge v0, v5, :cond_3b
if-ge v4, p2, :cond_3b
.line 15
aget-byte v5, v1, v0
aput-byte v5, p3, v4
:try_end_36
.catchall {:try_start_1e .. :try_end_36} :catchall_40
add-int/lit8 v0, v0, 0x1
add-int/lit8 v4, v4, 0x1
goto :goto_2d
:cond_3b
add-int/lit8 v3, v3, 0x1
int-to-byte v3, v3
move v0, v4
goto :goto_1c
:catchall_40
move-exception p1
.line 16
invoke-static {v1, v2}, Ljava/util/Arrays;->fill([BB)V
.line 17
throw p1
.line 18
:cond_45
invoke-static {v1, v2}, Ljava/util/Arrays;->fill([BB)V
return-void
.line 19
:cond_49
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Requested keys may not be longer than 255 times the underlying HMAC length."
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 20
:cond_51
new-instance p1, Ljavax/crypto/ShortBufferException;
invoke-direct {p1}, Ljavax/crypto/ShortBufferException;-><init>()V
throw p1
.line 21
:cond_57
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Length must be a non-negative value."
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
goto :goto_60
:goto_5f
throw p1
:goto_60
goto :goto_5f
.end method
.method public deriveKey(Ljava/lang/String;I)[B
.registers 4
if-eqz p1, :cond_9
.line 1
sget-object v0, Lcom/amazonaws/util/StringUtils;->UTF8:Ljava/nio/charset/Charset;
invoke-virtual {p1, v0}, Ljava/lang/String;->getBytes(Ljava/nio/charset/Charset;)[B
move-result-object p1
goto :goto_a
:cond_9
const/4 p1, 0x0
:goto_a
invoke-virtual {p0, p1, p2}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->deriveKey([BI)[B
move-result-object p1
return-object p1
.end method
.method public deriveKey([BI)[B
.registers 5
.line 2
new-array v0, p2, [B
const/4 v1, 0x0
.line 3
:try_start_3
invoke-virtual {p0, p1, p2, v0, v1}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->deriveKey([BI[BI)V
:try_end_6
.catch Ljavax/crypto/ShortBufferException; {:try_start_3 .. :try_end_6} :catch_7
return-object v0
:catch_7
move-exception p1
.line 4
new-instance p2, Ljava/lang/RuntimeException;
invoke-direct {p2, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw p2
.end method
.method public init([B)V
.registers 3
const/4 v0, 0x0
.line 1
invoke-virtual {p0, p1, v0}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->init([B[B)V
return-void
.end method
.method public init([B[B)V
.registers 8
if-nez p2, :cond_5
.line 2
sget-object p2, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->EMPTY_ARRAY:[B
goto :goto_b
:cond_5
invoke-virtual {p2}, [B->clone()Ljava/lang/Object;
move-result-object p2
check-cast p2, [B
.line 3
:goto_b
sget-object v0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->EMPTY_ARRAY:[B
const/4 v1, 0x0
.line 4
:try_start_e
iget-object v2, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->algorithm:Ljava/lang/String;
invoke-static {v2}, Ljavax/crypto/Mac;->getInstance(Ljava/lang/String;)Ljavax/crypto/Mac;
move-result-object v2
.line 5
array-length v3, p2
if-nez v3, :cond_20
.line 6
invoke-virtual {v2}, Ljavax/crypto/Mac;->getMacLength()I
move-result p2
new-array p2, p2, [B
.line 7
invoke-static {p2, v1}, Ljava/util/Arrays;->fill([BB)V
.line 8
:cond_20
new-instance v3, Ljavax/crypto/spec/SecretKeySpec;
iget-object v4, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->algorithm:Ljava/lang/String;
invoke-direct {v3, p2, v4}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
invoke-virtual {v2, v3}, Ljavax/crypto/Mac;->init(Ljava/security/Key;)V
.line 9
invoke-virtual {v2, p1}, Ljavax/crypto/Mac;->doFinal([B)[B
move-result-object v0
.line 10
new-instance p1, Ljavax/crypto/spec/SecretKeySpec;
iget-object p2, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->algorithm:Ljava/lang/String;
invoke-direct {p1, v0, p2}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
.line 11
invoke-static {v0, v1}, Ljava/util/Arrays;->fill([BB)V
.line 12
invoke-virtual {p0, p1}, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->unsafeInitWithoutKeyExtraction(Ljavax/crypto/SecretKey;)V
:try_end_3b
.catch Ljava/security/GeneralSecurityException; {:try_start_e .. :try_end_3b} :catch_41
.catchall {:try_start_e .. :try_end_3b} :catchall_3f
.line 13
invoke-static {v0, v1}, Ljava/util/Arrays;->fill([BB)V
return-void
:catchall_3f
move-exception p1
goto :goto_4a
:catch_41
move-exception p1
.line 14
:try_start_42
new-instance p2, Ljava/lang/RuntimeException;
const-string v2, "Unexpected exception"
invoke-direct {p2, v2, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p2
:try_end_4a
.catchall {:try_start_42 .. :try_end_4a} :catchall_3f
.line 15
:goto_4a
invoke-static {v0, v1}, Ljava/util/Arrays;->fill([BB)V
.line 16
throw p1
.end method
.method public unsafeInitWithoutKeyExtraction(Ljavax/crypto/SecretKey;)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/security/InvalidKeyException;
}
.end annotation
.line 1
invoke-interface {p1}, Ljavax/crypto/SecretKey;->getAlgorithm()Ljava/lang/String;
move-result-object v0
iget-object v1, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->algorithm:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_f
.line 2
iput-object p1, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->prk:Ljavax/crypto/SecretKey;
return-void
.line 3
:cond_f
new-instance v0, Ljava/security/InvalidKeyException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Algorithm for the provided key must match the algorithm for this Hkdf. Expected "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/amazonaws/mobileconnectors/cognitoidentityprovider/util/Hkdf;->algorithm:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " but found "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 4
invoke-interface {p1}, Ljavax/crypto/SecretKey;->getAlgorithm()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.end method