OpenSSLMac.smali
.class public abstract Lorg/conscrypt/OpenSSLMac;
.super Ljavax/crypto/MacSpi;
.source ""
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/conscrypt/OpenSSLMac$HmacSHA512;,
Lorg/conscrypt/OpenSSLMac$HmacSHA384;,
Lorg/conscrypt/OpenSSLMac$HmacSHA256;,
Lorg/conscrypt/OpenSSLMac$HmacSHA224;,
Lorg/conscrypt/OpenSSLMac$HmacSHA1;,
Lorg/conscrypt/OpenSSLMac$HmacMD5;
}
.end annotation
# instance fields
.field private ctx:Lorg/conscrypt/NativeRef$HMAC_CTX;
.field private final evp_md:J
.field private keyBytes:[B
.field private final singleByte:[B
.field private final size:I
# direct methods
.method private constructor <init>(JI)V
.registers 5
invoke-direct {p0}, Ljavax/crypto/MacSpi;-><init>()V
const/4 v0, 0x1
new-array v0, v0, [B
iput-object v0, p0, Lorg/conscrypt/OpenSSLMac;->singleByte:[B
iput-wide p1, p0, Lorg/conscrypt/OpenSSLMac;->evp_md:J
iput p3, p0, Lorg/conscrypt/OpenSSLMac;->size:I
return-void
.end method
.method synthetic constructor <init>(JILorg/conscrypt/OpenSSLMac$1;)V
.registers 5
invoke-direct {p0, p1, p2, p3}, Lorg/conscrypt/OpenSSLMac;-><init>(JI)V
return-void
.end method
.method private final resetContext()V
.registers 5
new-instance v0, Lorg/conscrypt/NativeRef$HMAC_CTX;
invoke-static {}, Lorg/conscrypt/NativeCrypto;->HMAC_CTX_new()J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lorg/conscrypt/NativeRef$HMAC_CTX;-><init>(J)V
iget-object v1, p0, Lorg/conscrypt/OpenSSLMac;->keyBytes:[B
if-eqz v1, :cond_12
iget-wide v2, p0, Lorg/conscrypt/OpenSSLMac;->evp_md:J
invoke-static {v0, v1, v2, v3}, Lorg/conscrypt/NativeCrypto;->HMAC_Init_ex(Lorg/conscrypt/NativeRef$HMAC_CTX;[BJ)V
:cond_12
iput-object v0, p0, Lorg/conscrypt/OpenSSLMac;->ctx:Lorg/conscrypt/NativeRef$HMAC_CTX;
return-void
.end method
# virtual methods
.method protected engineDoFinal()[B
.registers 2
iget-object v0, p0, Lorg/conscrypt/OpenSSLMac;->ctx:Lorg/conscrypt/NativeRef$HMAC_CTX;
invoke-static {v0}, Lorg/conscrypt/NativeCrypto;->HMAC_Final(Lorg/conscrypt/NativeRef$HMAC_CTX;)[B
move-result-object v0
invoke-direct {p0}, Lorg/conscrypt/OpenSSLMac;->resetContext()V
return-object v0
.end method
.method protected engineGetMacLength()I
.registers 2
iget v0, p0, Lorg/conscrypt/OpenSSLMac;->size:I
return v0
.end method
.method protected engineInit(Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
.registers 4
instance-of v0, p1, Ljavax/crypto/SecretKey;
if-eqz v0, :cond_22
if-nez p2, :cond_1a
invoke-interface {p1}, Ljava/security/Key;->getEncoded()[B
move-result-object p1
iput-object p1, p0, Lorg/conscrypt/OpenSSLMac;->keyBytes:[B
if-eqz p1, :cond_12
invoke-direct {p0}, Lorg/conscrypt/OpenSSLMac;->resetContext()V
return-void
:cond_12
new-instance p1, Ljava/security/InvalidKeyException;
const-string p2, "key cannot be encoded"
invoke-direct {p1, p2}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p1
:cond_1a
new-instance p1, Ljava/security/InvalidAlgorithmParameterException;
const-string p2, "unknown parameter type"
invoke-direct {p1, p2}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw p1
:cond_22
new-instance p1, Ljava/security/InvalidKeyException;
const-string p2, "key must be a SecretKey"
invoke-direct {p1, p2}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method protected engineReset()V
.registers 1
invoke-direct {p0}, Lorg/conscrypt/OpenSSLMac;->resetContext()V
return-void
.end method
.method protected engineUpdate(B)V
.registers 4
iget-object v0, p0, Lorg/conscrypt/OpenSSLMac;->singleByte:[B
const/4 v1, 0x0
aput-byte p1, v0, v1
const/4 p1, 0x1
invoke-virtual {p0, v0, v1, p1}, Lorg/conscrypt/OpenSSLMac;->engineUpdate(