OpenSSLSignature.smali
.class public Lorg/conscrypt/OpenSSLSignature;
.super Ljava/security/SignatureSpi;
.source ""
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/conscrypt/OpenSSLSignature$SHA512RSAPSS;,
Lorg/conscrypt/OpenSSLSignature$SHA384RSAPSS;,
Lorg/conscrypt/OpenSSLSignature$SHA256RSAPSS;,
Lorg/conscrypt/OpenSSLSignature$SHA224RSAPSS;,
Lorg/conscrypt/OpenSSLSignature$SHA1RSAPSS;,
Lorg/conscrypt/OpenSSLSignature$RSAPSSPadding;,
Lorg/conscrypt/OpenSSLSignature$SHA512ECDSA;,
Lorg/conscrypt/OpenSSLSignature$SHA384ECDSA;,
Lorg/conscrypt/OpenSSLSignature$SHA256ECDSA;,
Lorg/conscrypt/OpenSSLSignature$SHA224ECDSA;,
Lorg/conscrypt/OpenSSLSignature$SHA1ECDSA;,
Lorg/conscrypt/OpenSSLSignature$SHA512RSA;,
Lorg/conscrypt/OpenSSLSignature$SHA384RSA;,
Lorg/conscrypt/OpenSSLSignature$SHA256RSA;,
Lorg/conscrypt/OpenSSLSignature$SHA224RSA;,
Lorg/conscrypt/OpenSSLSignature$SHA1RSA;,
Lorg/conscrypt/OpenSSLSignature$MD5RSA;,
Lorg/conscrypt/OpenSSLSignature$RSAPKCS1Padding;,
Lorg/conscrypt/OpenSSLSignature$EngineType;
}
.end annotation
# instance fields
.field private ctx:Lorg/conscrypt/NativeRef$EVP_MD_CTX;
.field private final engineType:Lorg/conscrypt/OpenSSLSignature$EngineType;
.field private final evpMdRef:J
.field private evpPkeyCtx:J
.field private key:Lorg/conscrypt/OpenSSLKey;
.field private signing:Z
.field private final singleByte:[B
# direct methods
.method private constructor <init>(JLorg/conscrypt/OpenSSLSignature$EngineType;)V
.registers 5
invoke-direct {p0}, Ljava/security/SignatureSpi;-><init>()V
const/4 v0, 0x1
new-array v0, v0, [B
iput-object v0, p0, Lorg/conscrypt/OpenSSLSignature;->singleByte:[B
iput-object p3, p0, Lorg/conscrypt/OpenSSLSignature;->engineType:Lorg/conscrypt/OpenSSLSignature$EngineType;
iput-wide p1, p0, Lorg/conscrypt/OpenSSLSignature;->evpMdRef:J
return-void
.end method
.method synthetic constructor <init>(JLorg/conscrypt/OpenSSLSignature$EngineType;Lorg/conscrypt/OpenSSLSignature$1;)V
.registers 5
invoke-direct {p0, p1, p2, p3}, Lorg/conscrypt/OpenSSLSignature;-><init>(JLorg/conscrypt/OpenSSLSignature$EngineType;)V
return-void
.end method
.method private checkEngineType(Lorg/conscrypt/OpenSSLKey;)V
.registers 5
invoke-virtual {p1}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object p1
invoke-static {p1}, Lorg/conscrypt/NativeCrypto;->EVP_PKEY_type(Lorg/conscrypt/NativeRef$EVP_PKEY;)I
move-result p1
sget-object v0, Lorg/conscrypt/OpenSSLSignature$1;->$SwitchMap$org$conscrypt$OpenSSLSignature$EngineType:[I
iget-object v1, p0, Lorg/conscrypt/OpenSSLSignature;->engineType:Lorg/conscrypt/OpenSSLSignature$EngineType;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
aget v0, v0, v1
const/4 v1, 0x1
const-string v2, "Signature initialized as "
if-eq v0, v1, :cond_54
const/4 v1, 0x2
if-ne v0, v1, :cond_3b
const/16 v0, 0x198
if-ne p1, v0, :cond_1f
goto :goto_57
:cond_1f
new-instance p1, Ljava/security/InvalidKeyException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/conscrypt/OpenSSLSignature;->engineType:Lorg/conscrypt/OpenSSLSignature$EngineType;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v1, " (not EC)"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p1, v0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p1
:cond_3b
new-instance p1, Ljava/security/InvalidKeyException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Key must be of type "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/conscrypt/OpenSSLSignature;->engineType:Lorg/conscrypt/OpenSSLSignature$EngineType;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p1, v0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p1
:cond_54
const/4 v0, 0x6
if-ne p1, v0, :cond_58
:goto_57
return-void
:cond_58
new-instance p1, Ljava/security/InvalidKeyException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/conscrypt/OpenSSLSignature;->engineType:Lorg/conscrypt/OpenSSLSignature$EngineType;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v1, " (not RSA)"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p1, v0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private initInternal(Lorg/conscrypt/OpenSSLKey;Z)V
.registers 3
invoke-direct {p0, p1}, Lorg/conscrypt/OpenSSLSignature;->checkEngineType(Lorg/conscrypt/OpenSSLKey;)V
iput-object p1, p0, Lorg/conscrypt/OpenSSLSignature;->key:Lorg/conscrypt/OpenSSLKey;
iput-boolean p2, p0, Lorg/conscrypt/OpenSSLSignature;->signing:Z
:try_start_7
invoke-direct {p0}, Lorg/conscrypt/OpenSSLSignature;->resetContext()V
:try_end_a
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_7 .. :try_end_a} :catch_b
return-void
:catch_b
move-exception p1
new-instance p2, Ljava/security/InvalidKeyException;
invoke-direct {p2, p1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/Throwable;)V
throw p2
.end method
.method private resetContext()V
.registers 5
new-instance v0, Lorg/conscrypt/NativeRef$EVP_MD_CTX;
invoke-static {}, Lorg/conscrypt/NativeCrypto;->EVP_MD_CTX_create()J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lorg/conscrypt/NativeRef$EVP_MD_CTX;-><init>(J)V
iget-boolean v1, p0, Lorg/conscrypt/OpenSSLSignature;->signing:Z
if-eqz v1, :cond_1a
iget-wide v1, p0, Lorg/conscrypt/OpenSSLSignature;->evpMdRef:J
iget-object v3, p0, Lorg/conscrypt/OpenSSLSignature;->key:Lorg/conscrypt/OpenSSLKey;
invoke-virtual {v3}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object v3
invoke-static {v0, v1, v2, v3}, Lorg/conscrypt/NativeCrypto;->EVP_DigestSignInit(Lorg/conscrypt/NativeRef$EVP_MD_CTX;JLorg/conscrypt/NativeRef$EVP_PKEY;)J
move-result-wide v1
goto :goto_26
:cond_1a
iget-wide v1, p0, Lorg/conscrypt/OpenSSLSignature;->evpMdRef:J
iget-object v3, p0, Lorg/conscrypt/OpenSSLSignature;->key:Lorg/conscrypt/OpenSSLKey;
invoke-virtual {v3}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object v3
invoke-static {v0, v1, v2, v3}, Lorg/conscrypt/NativeCrypto;->EVP_DigestVerifyInit(Lorg/conscrypt/NativeRef$EVP_MD_CTX;JLorg/conscrypt/NativeRef$EVP_PKEY;)J
move-result-wide v1
:goto_26
iput-wide v1, p0, Lorg/conscrypt/OpenSSLSignature;->evpPkeyCtx:J
iget-wide v1, p0, Lorg/conscrypt/OpenSSLSignature;->evpPkeyCtx:J
invoke-virtual {p0, v1, v2}, Lorg/conscrypt/OpenSSLSignature;->configureEVP_PKEY_CTX(J)V
iput-object v0, p0, Lorg/conscrypt/OpenSSLSignature;->ctx:Lorg/conscrypt/NativeRef$EVP_MD_CTX;
return-void
.end method
# virtual methods
.method protected configureEVP_PKEY_CTX(J)V
.registers 3
return-void
.end method
.method protected engineGetParameter(Ljava/lang/String;)Ljava/lang/Object;
.registers 2
.annotation runtime Ljava/lang/Deprecated;
.end annotation
const/4 p1, 0x0
return-object p1
.end method
.method protected engineInitSign(Ljava/security/PrivateKey;)V
.registers 3
invoke-static {p1}, Lorg/conscrypt/OpenSSLKey;->fromPrivateKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p1
const/4 v0, 0x1
invoke-direct {p0, p1, v0}, Lorg/conscrypt/OpenSSLSignature;->initInternal(Lorg/conscrypt/OpenSSLKey;Z)V
return-void
.end method
.method protected engineInitVerify(Ljava/security/PublicKey;)V
.registers 3
invoke-static {p1}, Lorg/conscrypt/OpenSSLKey;->fromPublicKey(Ljava/security/PublicKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p1
const/4 v0, 0x0
invoke-direct {p0, p1, v0}, Lorg/conscrypt/OpenSSLSignature;->initInternal(Lorg/conscrypt/OpenSSLKey;Z)V
return-void
.end method
.method protected engineSetParameter(Ljava/lang/String;Ljava/lang/Object;)V
.registers 3
.annotation runtime Ljava/lang/Deprecated;
.end annotation
return-void
.end method
.method protected engineSign()[B
.registers 4
const-string v0, "Reset of context failed after it was successful once"
iget-object v1, p0, Lorg/conscrypt/OpenSSLSignature;->ctx:Lorg/conscrypt/NativeRef$EVP_MD_CTX;
:try_start_4
invoke-static {v1}, Lorg/conscrypt/NativeCrypto;->EVP_DigestSignFinal(Lorg/conscrypt/NativeRef$EVP_MD_CTX;)[B
move-result-object v1
:try_end_8
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_8} :catch_14
.catchall {:try_start_4 .. :try_end_8} :catchall_12
:try_start_8
invoke-direct {p0}, Lorg/conscrypt/OpenSSLSignature;->resetContext()V
:try_end_b
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_8 .. :try_end_b} :catch_c
return-object v1
:catch_c
new-instance v1, Ljava/lang/AssertionError;
invoke-direct {v1, v0}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
throw v1
:catchall_12
move-exception v1
goto :goto_1b
:catch_14
move-exception v1
:try_start_15
new-instance v2, Ljava/security/SignatureException;
invoke-direct {v2, v1}, Ljava/security/SignatureException;-><init>(Ljava/lang/Throwable;)V
throw v2
:try_end_1b
.catchall {:try_start_15 .. :try_end_1b} :catchall_12
:goto_1b
:try_start_1b
invoke-direct {p0}, Lorg/conscrypt/OpenSSLSignature;->resetContext()V
:try_end_1e
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_1b .. :try_end_1e} :catch_1f
throw v1
:catch_1f
new-instance v1, Ljava/lang/AssertionError;
invoke-direct {v1, v0}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
throw v1
.end method
.method protected engineUpdate(B)V
.registers 4
iget-object v0, p0, Lorg/conscrypt/OpenSSLSignature;->singleByte:[B
const/4 v1, 0x0
aput-byte p1, v0, v1
const/4 p1, 0x1
invoke-virtual {p0, v0, v1, p1}, Lorg/conscrypt/OpenSSLSignature;->engineUpdate([BII)V
return-void
.end method
.method protected engineUpdate(Ljava/nio/ByteBuffer;)V
.registers 8
invoke-virtual {p1}, Ljava/nio/ByteBuffer;->hasRemaining()Z
move-result v0
if-nez v0, :cond_7
return-void
:cond_7
invoke-virtual {p1}, Ljava/nio/ByteBuffer;->isDirect()Z
move-result v0
if-nez v0, :cond_11
invoke-super {p0, p1}, Ljava/security/SignatureSpi;->engineUpdate(Ljava/nio/ByteBuffer;)V
return-void
:cond_11
invoke-static {p1}, Lorg/conscrypt/NativeCrypto;->getDirectBufferAddress(Ljava/nio/Buffer;)J
move-result-wide v0
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-nez v4, :cond_1f
invoke-super {p0, p1}, Ljava/security/SignatureSpi;->engineUpdate(Ljava/nio/ByteBuffer;)V
return-void
:cond_1f
invoke-virtual {p1}, Ljava/nio/ByteBuffer;->position()I
move-result v2
if-ltz v2, :cond_47
int-to-long v3, v2
add-long/2addr v0, v3
invoke-virtual {p1}, Ljava/nio/ByteBuffer;->remaining()I
move-result v3
if-ltz v3, :cond_3f
iget-object v4, p0, Lorg/conscrypt/OpenSSLSignature;->ctx:Lorg/conscrypt/NativeRef$EVP_MD_CTX;
iget-boolean v5, p0, Lorg/conscrypt/OpenSSLSignature;->signing:Z
if-eqz v5, :cond_37
invoke-static {v4, v0, v1, v3}, Lorg/conscrypt/NativeCrypto;->EVP_DigestSignUpdateDirect(Lorg/conscrypt/NativeRef$EVP_MD_CTX;JI)V
goto :goto_3a
:cond_37
invoke-static {v4, v0, v1, v3}, Lorg/conscrypt/NativeCrypto;->EVP_DigestVerifyUpdateDirect(Lorg/conscrypt/NativeRef$EVP_MD_CTX;JI)V
:goto_3a
add-int/2addr v2, v3
invoke-virtual {p1, v2}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
return-void
:cond_3f
new-instance p1, Ljava/lang/RuntimeException;
const-string v0, "Negative remaining amount"
invoke-direct {p1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
:cond_47
new-instance p1, Ljava/lang/RuntimeException;
const-string v0, "Negative position"
invoke-direct {p1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method protected engineUpdate([BII)V
.registers 6
iget-object v0, p0, Lorg/conscrypt/OpenSSLSignature;->ctx:Lorg/conscrypt/NativeRef$EVP_MD_CTX;
iget-boolean v1, p0, Lorg/conscrypt/OpenSSLSignature;->signing:Z
if-eqz v1, :cond_a
invoke-static {v0, p1, p2, p3}, Lorg/conscrypt/NativeCrypto;->EVP_DigestSignUpdate(Lorg/conscrypt/NativeRef$EVP_MD_CTX;[BII)V
goto :goto_d
:cond_a
invoke-static {v0, p1, p2, p3}, Lorg/conscrypt/NativeCrypto;->EVP_DigestVerifyUpdate(Lorg/conscrypt/NativeRef$EVP_MD_CTX;[BII)V
:goto_d
return-void
.end method
.method protected engineVerify([B)Z
.registers 6
const-string v0, "Reset of context failed after it was successful once"
iget-object v1, p0, Lorg/conscrypt/OpenSSLSignature;->ctx:Lorg/conscrypt/NativeRef$EVP_MD_CTX;
const/4 v2, 0x0
:try_start_5
array-length v3, p1
invoke-static {v1, p1, v2, v3}, Lorg/conscrypt/NativeCrypto;->EVP_DigestVerifyFinal(Lorg/conscrypt/NativeRef$EVP_MD_CTX;[BII)Z
move-result p1
:try_end_a
.catch Ljava/lang/Exception; {:try_start_5 .. :try_end_a} :catch_16
.catchall {:try_start_5 .. :try_end_a} :catchall_14
:try_start_a
invoke-direct {p0}, Lorg/conscrypt/OpenSSLSignature;->resetContext()V
:try_end_d
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_a .. :try_end_d} :catch_e
return p1
:catch_e
new-instance p1, Ljava/lang/AssertionError;
invoke-direct {p1, v0}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
throw p1
:catchall_14
move-exception p1
goto :goto_1d
:catch_16
move-exception p1
:try_start_17
new-instance v1, Ljava/security/SignatureException;
invoke-direct {v1, p1}, Ljava/security/SignatureException;-><init>(Ljava/lang/Throwable;)V
throw v1
:try_end_1d
.catchall {:try_start_17 .. :try_end_1d} :catchall_14
:goto_1d
:try_start_1d
invoke-direct {p0}, Lorg/conscrypt/OpenSSLSignature;->resetContext()V
:try_end_20
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_1d .. :try_end_20} :catch_21
throw p1
:catch_21
new-instance p1, Ljava/lang/AssertionError;
invoke-direct {p1, v0}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
throw p1
.end method
.method protected final getEVP_PKEY_CTX()J
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLSignature;->evpPkeyCtx:J
return-wide v0
.end method