OpenSSLKey.smali
.class final Lorg/conscrypt/OpenSSLKey;
.super Ljava/lang/Object;
.source ""
# instance fields
.field private final ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
.field private final hardwareBacked:Z
.field private final wrapped:Z
# direct methods
.method constructor <init>(J)V
.registers 4
const/4 v0, 0x0
invoke-direct {p0, p1, p2, v0}, Lorg/conscrypt/OpenSSLKey;-><init>(JZ)V
return-void
.end method
.method constructor <init>(JZ)V
.registers 5
const/4 v0, 0x0
invoke-direct {p0, p1, p2, p3, v0}, Lorg/conscrypt/OpenSSLKey;-><init>(JZZ)V
return-void
.end method
.method constructor <init>(JZZ)V
.registers 6
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v0, Lorg/conscrypt/NativeRef$EVP_PKEY;
invoke-direct {v0, p1, p2}, Lorg/conscrypt/NativeRef$EVP_PKEY;-><init>(J)V
iput-object v0, p0, Lorg/conscrypt/OpenSSLKey;->ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
iput-boolean p3, p0, Lorg/conscrypt/OpenSSLKey;->wrapped:Z
iput-boolean p4, p0, Lorg/conscrypt/OpenSSLKey;->hardwareBacked:Z
return-void
.end method
.method static fromECPrivateKeyForTLSStackOnly(Ljava/security/PrivateKey;Ljava/security/spec/ECParameterSpec;)Lorg/conscrypt/OpenSSLKey;
.registers 3
invoke-static {p0}, Lorg/conscrypt/OpenSSLKey;->getOpenSSLKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object v0
if-eqz v0, :cond_7
return-object v0
:cond_7
invoke-static {p0}, Lorg/conscrypt/OpenSSLKey;->fromKeyMaterial(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object v0
if-eqz v0, :cond_e
return-object v0
:cond_e
invoke-static {p0, p1}, Lorg/conscrypt/OpenSSLECPrivateKey;->wrapJCAPrivateKeyForTLSStackOnly(Ljava/security/PrivateKey;Ljava/security/spec/ECParameterSpec;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
.end method
.method private static fromKeyMaterial(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
.registers 4
invoke-interface {p0}, Ljava/security/PrivateKey;->getFormat()Ljava/lang/String;
move-result-object v0
const-string v1, "PKCS#8"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_e
return-object v1
:cond_e
invoke-interface {p0}, Ljava/security/PrivateKey;->getEncoded()[B
move-result-object p0
if-nez p0, :cond_15
return-object v1
:cond_15
:try_start_15
new-instance v0, Lorg/conscrypt/OpenSSLKey;
invoke-static {p0}, Lorg/conscrypt/NativeCrypto;->EVP_parse_private_key([B)J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lorg/conscrypt/OpenSSLKey;-><init>(J)V
:try_end_1e
.catch Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException; {:try_start_15 .. :try_end_1e} :catch_1f
return-object v0
:catch_1f
move-exception p0
new-instance v0, Ljava/security/InvalidKeyException;
invoke-direct {v0, p0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/Throwable;)V
throw v0
.end method
.method static fromPrivateKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
.registers 4
instance-of v0, p0, Lorg/conscrypt/OpenSSLKeyHolder;
if-eqz v0, :cond_b
check-cast p0, Lorg/conscrypt/OpenSSLKeyHolder;
invoke-interface {p0}, Lorg/conscrypt/OpenSSLKeyHolder;->getOpenSSLKey()Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_b
invoke-interface {p0}, Ljava/security/PrivateKey;->getFormat()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_16
invoke-static {p0}, Lorg/conscrypt/OpenSSLKey;->wrapPrivateKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_16
invoke-interface {p0}, Ljava/security/PrivateKey;->getFormat()Ljava/lang/String;
move-result-object v1
const-string v2, "PKCS#8"
invoke-virtual {v2, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_45
invoke-interface {p0}, Ljava/security/PrivateKey;->getEncoded()[B
move-result-object v0
if-eqz v0, :cond_3d
:try_start_28
new-instance v0, Lorg/conscrypt/OpenSSLKey;
invoke-interface {p0}, Ljava/security/PrivateKey;->getEncoded()[B
move-result-object p0
invoke-static {p0}, Lorg/conscrypt/NativeCrypto;->EVP_parse_private_key([B)J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lorg/conscrypt/OpenSSLKey;-><init>(J)V
:try_end_35
.catch Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException; {:try_start_28 .. :try_end_35} :catch_36
return-object v0
:catch_36
move-exception p0
new-instance v0, Ljava/security/InvalidKeyException;
invoke-direct {v0, p0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/Throwable;)V
throw v0
:cond_3d
new-instance p0, Ljava/security/InvalidKeyException;
const-string v0, "Key encoding is null"
invoke-direct {p0, v0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p0
:cond_45
new-instance p0, Ljava/security/InvalidKeyException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Unknown key format "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p0
.end method
.method static fromPrivateKeyForTLSStackOnly(Ljava/security/PrivateKey;Ljava/security/PublicKey;)Lorg/conscrypt/OpenSSLKey;
.registers 3
invoke-static {p0}, Lorg/conscrypt/OpenSSLKey;->getOpenSSLKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object v0
if-eqz v0, :cond_7
return-object v0
:cond_7
invoke-static {p0}, Lorg/conscrypt/OpenSSLKey;->fromKeyMaterial(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object v0
if-eqz v0, :cond_e
return-object v0
:cond_e
invoke-static {p0, p1}, Lorg/conscrypt/OpenSSLKey;->wrapJCAPrivateKeyForTLSStackOnly(Ljava/security/PrivateKey;Ljava/security/PublicKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
.end method
.method static fromPrivateKeyPemInputStream(Ljava/io/InputStream;)Lorg/conscrypt/OpenSSLKey;
.registers 6
new-instance v0, Lorg/conscrypt/OpenSSLBIOInputStream;
const/4 v1, 0x1
invoke-direct {v0, p0, v1}, Lorg/conscrypt/OpenSSLBIOInputStream;-><init>(Ljava/io/InputStream;Z)V
:try_start_6
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->getBioContext()J
move-result-wide v1
invoke-static {v1, v2}, Lorg/conscrypt/NativeCrypto;->PEM_read_bio_PrivateKey(J)J
move-result-wide v1
:try_end_e
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_e} :catch_24
.catchall {:try_start_6 .. :try_end_e} :catchall_22
const-wide/16 v3, 0x0
cmp-long p0, v1, v3
if-nez p0, :cond_19
const/4 p0, 0x0
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
return-object p0
:cond_19
:try_start_19
new-instance p0, Lorg/conscrypt/OpenSSLKey;
invoke-direct {p0, v1, v2}, Lorg/conscrypt/OpenSSLKey;-><init>(J)V
:try_end_1e
.catch Ljava/lang/Exception; {:try_start_19 .. :try_end_1e} :catch_24
.catchall {:try_start_19 .. :try_end_1e} :catchall_22
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
return-object p0
:catchall_22
move-exception p0
goto :goto_2b
:catch_24
move-exception p0
:try_start_25
new-instance v1, Ljava/security/InvalidKeyException;
invoke-direct {v1, p0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/Throwable;)V
throw v1
:try_end_2b
.catchall {:try_start_25 .. :try_end_2b} :catchall_22
:goto_2b
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
throw p0
.end method
.method static fromPublicKey(Ljava/security/PublicKey;)Lorg/conscrypt/OpenSSLKey;
.registers 4
instance-of v0, p0, Lorg/conscrypt/OpenSSLKeyHolder;
if-eqz v0, :cond_b
check-cast p0, Lorg/conscrypt/OpenSSLKeyHolder;
invoke-interface {p0}, Lorg/conscrypt/OpenSSLKeyHolder;->getOpenSSLKey()Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_b
invoke-interface {p0}, Ljava/security/PublicKey;->getFormat()Ljava/lang/String;
move-result-object v0
const-string v1, "X.509"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_3a
invoke-interface {p0}, Ljava/security/PublicKey;->getEncoded()[B
move-result-object v0
if-eqz v0, :cond_32
:try_start_1d
new-instance v0, Lorg/conscrypt/OpenSSLKey;
invoke-interface {p0}, Ljava/security/PublicKey;->getEncoded()[B
move-result-object p0
invoke-static {p0}, Lorg/conscrypt/NativeCrypto;->EVP_parse_public_key([B)J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lorg/conscrypt/OpenSSLKey;-><init>(J)V
:try_end_2a
.catch Ljava/lang/Exception; {:try_start_1d .. :try_end_2a} :catch_2b
return-object v0
:catch_2b
move-exception p0
new-instance v0, Ljava/security/InvalidKeyException;
invoke-direct {v0, p0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/Throwable;)V
throw v0
:cond_32
new-instance p0, Ljava/security/InvalidKeyException;
const-string v0, "Key encoding is null"
invoke-direct {p0, v0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p0
:cond_3a
new-instance v0, Ljava/security/InvalidKeyException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Unknown key format "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-interface {p0}, Ljava/security/PublicKey;->getFormat()Ljava/lang/String;
move-result-object p0
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-direct {v0, p0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method static fromPublicKeyPemInputStream(Ljava/io/InputStream;)Lorg/conscrypt/OpenSSLKey;
.registers 6
new-instance v0, Lorg/conscrypt/OpenSSLBIOInputStream;
const/4 v1, 0x1
invoke-direct {v0, p0, v1}, Lorg/conscrypt/OpenSSLBIOInputStream;-><init>(Ljava/io/InputStream;Z)V
:try_start_6
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->getBioContext()J
move-result-wide v1
invoke-static {v1, v2}, Lorg/conscrypt/NativeCrypto;->PEM_read_bio_PUBKEY(J)J
move-result-wide v1
:try_end_e
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_e} :catch_24
.catchall {:try_start_6 .. :try_end_e} :catchall_22
const-wide/16 v3, 0x0
cmp-long p0, v1, v3
if-nez p0, :cond_19
const/4 p0, 0x0
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
return-object p0
:cond_19
:try_start_19
new-instance p0, Lorg/conscrypt/OpenSSLKey;
invoke-direct {p0, v1, v2}, Lorg/conscrypt/OpenSSLKey;-><init>(J)V
:try_end_1e
.catch Ljava/lang/Exception; {:try_start_19 .. :try_end_1e} :catch_24
.catchall {:try_start_19 .. :try_end_1e} :catchall_22
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
return-object p0
:catchall_22
move-exception p0
goto :goto_2b
:catch_24
move-exception p0
:try_start_25
new-instance v1, Ljava/security/InvalidKeyException;
invoke-direct {v1, p0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/Throwable;)V
throw v1
:try_end_2b
.catchall {:try_start_25 .. :try_end_2b} :catchall_22
:goto_2b
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
throw p0
.end method
.method private static getOpenSSLKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
.registers 3
instance-of v0, p0, Lorg/conscrypt/OpenSSLKeyHolder;
if-eqz v0, :cond_b
check-cast p0, Lorg/conscrypt/OpenSSLKeyHolder;
invoke-interface {p0}, Lorg/conscrypt/OpenSSLKeyHolder;->getOpenSSLKey()Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_b
invoke-interface {p0}, Ljava/security/PrivateKey;->getAlgorithm()Ljava/lang/String;
move-result-object v0
const-string v1, "RSA"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1c
invoke-static {p0}, Lorg/conscrypt/Platform;->wrapRsaKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_1c
const/4 p0, 0x0
return-object p0
.end method
.method static getPrivateKey(Ljava/security/spec/PKCS8EncodedKeySpec;I)Ljava/security/PrivateKey;
.registers 5
:try_start_0
new-instance v0, Lorg/conscrypt/OpenSSLKey;
invoke-virtual {p0}, Ljava/security/spec/PKCS8EncodedKeySpec;->getEncoded()[B
move-result-object p0
invoke-static {p0}, Lorg/conscrypt/NativeCrypto;->EVP_parse_private_key([B)J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lorg/conscrypt/OpenSSLKey;-><init>(J)V
:try_end_d
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_d} :catch_2b
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object p0
invoke-static {p0}, Lorg/conscrypt/NativeCrypto;->EVP_PKEY_type(Lorg/conscrypt/NativeRef$EVP_PKEY;)I
move-result p0
if-ne p0, p1, :cond_23
:try_start_17
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLKey;->getPrivateKey()Ljava/security/PrivateKey;
move-result-object p0
:try_end_1b
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_17 .. :try_end_1b} :catch_1c
return-object p0
:catch_1c
move-exception p0
new-instance p1, Ljava/security/spec/InvalidKeySpecException;
invoke-direct {p1, p0}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/Throwable;)V
throw p1
:cond_23
new-instance p0, Ljava/security/spec/InvalidKeySpecException;
const-string p1, "Unexpected key type"
invoke-direct {p0, p1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw p0
:catch_2b
move-exception p0
new-instance p1, Ljava/security/spec/InvalidKeySpecException;
invoke-direct {p1, p0}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/Throwable;)V
throw p1
.end method
.method static getPublicKey(Ljava/security/spec/X509EncodedKeySpec;I)Ljava/security/PublicKey;
.registers 5
:try_start_0
new-instance v0, Lorg/conscrypt/OpenSSLKey;
invoke-virtual {p0}, Ljava/security/spec/X509EncodedKeySpec;->getEncoded()[B
move-result-object p0
invoke-static {p0}, Lorg/conscrypt/NativeCrypto;->EVP_parse_public_key([B)J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lorg/conscrypt/OpenSSLKey;-><init>(J)V
:try_end_d
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_d} :catch_2b
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object p0
invoke-static {p0}, Lorg/conscrypt/NativeCrypto;->EVP_PKEY_type(Lorg/conscrypt/NativeRef$EVP_PKEY;)I
move-result p0
if-ne p0, p1, :cond_23
:try_start_17
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLKey;->getPublicKey()Ljava/security/PublicKey;
move-result-object p0
:try_end_1b
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_17 .. :try_end_1b} :catch_1c
return-object p0
:catch_1c
move-exception p0
new-instance p1, Ljava/security/spec/InvalidKeySpecException;
invoke-direct {p1, p0}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/Throwable;)V
throw p1
:cond_23
new-instance p0, Ljava/security/spec/InvalidKeySpecException;
const-string p1, "Unexpected key type"
invoke-direct {p0, p1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw p0
:catch_2b
move-exception p0
new-instance p1, Ljava/security/spec/InvalidKeySpecException;
invoke-direct {p1, p0}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/Throwable;)V
throw p1
.end method
.method private static wrapJCAPrivateKeyForTLSStackOnly(Ljava/security/PrivateKey;Ljava/security/PublicKey;)Lorg/conscrypt/OpenSSLKey;
.registers 4
invoke-interface {p0}, Ljava/security/PrivateKey;->getAlgorithm()Ljava/lang/String;
move-result-object v0
const-string v1, "RSA"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_11
invoke-static {p0, p1}, Lorg/conscrypt/OpenSSLRSAPrivateKey;->wrapJCAPrivateKeyForTLSStackOnly(Ljava/security/PrivateKey;Ljava/security/PublicKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_11
const-string v1, "EC"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_1e
invoke-static {p0, p1}, Lorg/conscrypt/OpenSSLECPrivateKey;->wrapJCAPrivateKeyForTLSStackOnly(Ljava/security/PrivateKey;Ljava/security/PublicKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_1e
new-instance p0, Ljava/security/InvalidKeyException;
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Unsupported key algorithm: "
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p0, p1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw p0
.end method
.method private static wrapPrivateKey(Ljava/security/PrivateKey;)Lorg/conscrypt/OpenSSLKey;
.registers 4
instance-of v0, p0, Ljava/security/interfaces/RSAPrivateKey;
if-eqz v0, :cond_b
check-cast p0, Ljava/security/interfaces/RSAPrivateKey;
invoke-static {p0}, Lorg/conscrypt/OpenSSLRSAPrivateKey;->wrapPlatformKey(Ljava/security/interfaces/RSAPrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_b
instance-of v0, p0, Ljava/security/interfaces/ECPrivateKey;
if-eqz v0, :cond_16
check-cast p0, Ljava/security/interfaces/ECPrivateKey;
invoke-static {p0}, Lorg/conscrypt/OpenSSLECPrivateKey;->wrapPlatformKey(Ljava/security/interfaces/ECPrivateKey;)Lorg/conscrypt/OpenSSLKey;
move-result-object p0
return-object p0
:cond_16
new-instance v0, Ljava/security/InvalidKeyException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Unknown key type: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p0}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p0
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-direct {v0, p0}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.end method
# virtual methods
.method public equals(Ljava/lang/Object;)Z
.registers 6
const/4 v0, 0x1
if-ne p1, p0, :cond_4
return v0
:cond_4
instance-of v1, p1, Lorg/conscrypt/OpenSSLKey;
const/4 v2, 0x0
if-nez v1, :cond_a
return v2
:cond_a
check-cast p1, Lorg/conscrypt/OpenSSLKey;
iget-object v1, p0, Lorg/conscrypt/OpenSSLKey;->ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
invoke-virtual {p1}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object v3
invoke-virtual {v1, v3}, Lorg/conscrypt/NativeRef;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_19
return v0
:cond_19
iget-object v1, p0, Lorg/conscrypt/OpenSSLKey;->ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
invoke-virtual {p1}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object p1
invoke-static {v1, p1}, Lorg/conscrypt/NativeCrypto;->EVP_PKEY_cmp(Lorg/conscrypt/NativeRef$EVP_PKEY;Lorg/conscrypt/NativeRef$EVP_PKEY;)I
move-result p1
if-ne p1, v0, :cond_26
goto :goto_27
:cond_26
const/4 v0, 0x0
:goto_27
return v0
.end method
.method getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
.registers 2
iget-object v0, p0, Lorg/conscrypt/OpenSSLKey;->ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
return-object v0
.end method
.method getPrivateKey()Ljava/security/PrivateKey;
.registers 3
iget-object v0, p0, Lorg/conscrypt/OpenSSLKey;->ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
invoke-static {v0}, Lorg/conscrypt/NativeCrypto;->EVP_PKEY_type(Lorg/conscrypt/NativeRef$EVP_PKEY;)I
move-result v0
const/4 v1, 0x6
if-eq v0, v1, :cond_1b
const/16 v1, 0x198
if-ne v0, v1, :cond_13
new-instance v0, Lorg/conscrypt/OpenSSLECPrivateKey;
invoke-direct {v0, p0}, Lorg/conscrypt/OpenSSLECPrivateKey;-><init>(Lorg/conscrypt/OpenSSLKey;)V
return-object v0
:cond_13
new-instance v0, Ljava/security/NoSuchAlgorithmException;
const-string v1, "unknown PKEY type"
invoke-direct {v0, v1}, Ljava/security/NoSuchAlgorithmException;-><init>(Ljava/lang/String;)V
throw v0
:cond_1b
new-instance v0, Lorg/conscrypt/OpenSSLRSAPrivateKey;
invoke-direct {v0, p0}, Lorg/conscrypt/OpenSSLRSAPrivateKey;-><init>(Lorg/conscrypt/OpenSSLKey;)V
return-object v0
.end method
.method getPublicKey()Ljava/security/PublicKey;
.registers 3
iget-object v0, p0, Lorg/conscrypt/OpenSSLKey;->ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
invoke-static {v0}, Lorg/conscrypt/NativeCrypto;->EVP_PKEY_type(Lorg/conscrypt/NativeRef$EVP_PKEY;)I
move-result v0
const/4 v1, 0x6
if-eq v0, v1, :cond_1b
const/16 v1, 0x198
if-ne v0, v1, :cond_13
new-instance v0, Lorg/conscrypt/OpenSSLECPublicKey;
invoke-direct {v0, p0}, Lorg/conscrypt/OpenSSLECPublicKey;-><init>(Lorg/conscrypt/OpenSSLKey;)V
return-object v0
:cond_13
new-instance v0, Ljava/security/NoSuchAlgorithmException;
const-string v1, "unknown PKEY type"
invoke-direct {v0, v1}, Ljava/security/NoSuchAlgorithmException;-><init>(Ljava/lang/String;)V
throw v0
:cond_1b
new-instance v0, Lorg/conscrypt/OpenSSLRSAPublicKey;
invoke-direct {v0, p0}, Lorg/conscrypt/OpenSSLRSAPublicKey;-><init>(Lorg/conscrypt/OpenSSLKey;)V
return-object v0
.end method
.method public hashCode()I
.registers 2
iget-object v0, p0, Lorg/conscrypt/OpenSSLKey;->ctx:Lorg/conscrypt/NativeRef$EVP_PKEY;
invoke-virtual {v0}, Lorg/conscrypt/NativeRef;->hashCode()I
move-result v0
return v0
.end method
.method isHardwareBacked()Z
.registers 2
iget-boolean v0, p0, Lorg/conscrypt/OpenSSLKey;->hardwareBacked:Z
return v0
.end method
.method isWrapped()Z
.registers 2
iget-boolean v0, p0, Lorg/conscrypt/OpenSSLKey;->wrapped:Z
return v0
.end method