OpenSSLX509CRL.smali
.class final Lorg/conscrypt/OpenSSLX509CRL;
.super Ljava/security/cert/X509CRL;
.source ""
# instance fields
.field private final mContext:J
.field private final nextUpdate:Ljava/util/Date;
.field private final thisUpdate:Ljava/util/Date;
# direct methods
.method private constructor <init>(J)V
.registers 5
invoke-direct {p0}, Ljava/security/cert/X509CRL;-><init>()V
iput-wide p1, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {p1, p2, p0}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get_lastUpdate(JLorg/conscrypt/OpenSSLX509CRL;)J
move-result-wide v0
invoke-static {v0, v1}, Lorg/conscrypt/OpenSSLX509CRL;->toDate(J)Ljava/util/Date;
move-result-object v0
iput-object v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->thisUpdate:Ljava/util/Date;
invoke-static {p1, p2, p0}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get_nextUpdate(JLorg/conscrypt/OpenSSLX509CRL;)J
move-result-wide p1
invoke-static {p1, p2}, Lorg/conscrypt/OpenSSLX509CRL;->toDate(J)Ljava/util/Date;
move-result-object p1
iput-object p1, p0, Lorg/conscrypt/OpenSSLX509CRL;->nextUpdate:Ljava/util/Date;
return-void
.end method
.method static fromPkcs7DerInputStream(Ljava/io/InputStream;)Ljava/util/List;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/InputStream;",
")",
"Ljava/util/List<",
"Lorg/conscrypt/OpenSSLX509CRL;",
">;"
}
.end annotation
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
const/4 p0, 0x2
invoke-static {v1, v2, p0}, Lorg/conscrypt/NativeCrypto;->d2i_PKCS7_bio(JI)[J
move-result-object p0
:try_end_f
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_f} :catch_35
.catchall {:try_start_6 .. :try_end_f} :catchall_33
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
new-instance v0, Ljava/util/ArrayList;
array-length v1, p0
invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(I)V
const/4 v1, 0x0
:goto_19
array-length v2, p0
if-ge v1, v2, :cond_32
aget-wide v2, p0, v1
const-wide/16 v4, 0x0
cmp-long v6, v2, v4
if-nez v6, :cond_25
goto :goto_2f
:cond_25
new-instance v2, Lorg/conscrypt/OpenSSLX509CRL;
aget-wide v3, p0, v1
invoke-direct {v2, v3, v4}, Lorg/conscrypt/OpenSSLX509CRL;-><init>(J)V
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:goto_2f
add-int/lit8 v1, v1, 0x1
goto :goto_19
:cond_32
return-object v0
:catchall_33
move-exception p0
goto :goto_3c
:catch_35
move-exception p0
:try_start_36
new-instance v1, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;
invoke-direct {v1, p0}, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;-><init>(Ljava/lang/Exception;)V
throw v1
:try_end_3c
.catchall {:try_start_36 .. :try_end_3c} :catchall_33
:goto_3c
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
goto :goto_41
:goto_40
throw p0
:goto_41
goto :goto_40
.end method
.method static fromPkcs7PemInputStream(Ljava/io/InputStream;)Ljava/util/List;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/InputStream;",
")",
"Ljava/util/List<",
"Lorg/conscrypt/OpenSSLX509CRL;",
">;"
}
.end annotation
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
const/4 p0, 0x2
invoke-static {v1, v2, p0}, Lorg/conscrypt/NativeCrypto;->PEM_read_bio_PKCS7(JI)[J
move-result-object p0
:try_end_f
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_f} :catch_35
.catchall {:try_start_6 .. :try_end_f} :catchall_33
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
new-instance v0, Ljava/util/ArrayList;
array-length v1, p0
invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(I)V
const/4 v1, 0x0
:goto_19
array-length v2, p0
if-ge v1, v2, :cond_32
aget-wide v2, p0, v1
const-wide/16 v4, 0x0
cmp-long v6, v2, v4
if-nez v6, :cond_25
goto :goto_2f
:cond_25
new-instance v2, Lorg/conscrypt/OpenSSLX509CRL;
aget-wide v3, p0, v1
invoke-direct {v2, v3, v4}, Lorg/conscrypt/OpenSSLX509CRL;-><init>(J)V
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:goto_2f
add-int/lit8 v1, v1, 0x1
goto :goto_19
:cond_32
return-object v0
:catchall_33
move-exception p0
goto :goto_3c
:catch_35
move-exception p0
:try_start_36
new-instance v1, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;
invoke-direct {v1, p0}, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;-><init>(Ljava/lang/Exception;)V
throw v1
:try_end_3c
.catchall {:try_start_36 .. :try_end_3c} :catchall_33
:goto_3c
invoke-virtual {v0}, Lorg/conscrypt/OpenSSLBIOInputStream;->release()V
goto :goto_41
:goto_40
throw p0
:goto_41
goto :goto_40
.end method
.method static fromX509DerInputStream(Ljava/io/InputStream;)Lorg/conscrypt/OpenSSLX509CRL;
.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;->d2i_X509_CRL_bio(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/OpenSSLX509CRL;
invoke-direct {p0, v1, v2}, Lorg/conscrypt/OpenSSLX509CRL;-><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, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;
invoke-direct {v1, p0}, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;-><init>(Ljava/lang/Exception;)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 fromX509PemInputStream(Ljava/io/InputStream;)Lorg/conscrypt/OpenSSLX509CRL;
.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_X509_CRL(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/OpenSSLX509CRL;
invoke-direct {p0, v1, v2}, Lorg/conscrypt/OpenSSLX509CRL;-><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, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;
invoke-direct {v1, p0}, Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException;-><init>(Ljava/lang/Exception;)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 toDate(J)Ljava/util/Date;
.registers 5
const-string v0, "UTC"
invoke-static {v0}, Ljava/util/TimeZone;->getTimeZone(Ljava/lang/String;)Ljava/util/TimeZone;
move-result-object v0
invoke-static {v0}, Ljava/util/Calendar;->getInstance(Ljava/util/TimeZone;)Ljava/util/Calendar;
move-result-object v0
const/16 v1, 0xe
const/4 v2, 0x0
invoke-virtual {v0, v1, v2}, Ljava/util/Calendar;->set(II)V
invoke-static {p0, p1, v0}, Lorg/conscrypt/NativeCrypto;->ASN1_TIME_to_Calendar(JLjava/util/Calendar;)V
invoke-virtual {v0}, Ljava/util/Calendar;->getTime()Ljava/util/Date;
move-result-object p0
return-object p0
.end method
.method private verifyInternal(Ljava/security/PublicKey;Ljava/lang/String;)V
.registers 4
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLX509CRL;->getSigAlgName()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_a
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLX509CRL;->getSigAlgOID()Ljava/lang/String;
move-result-object v0
:cond_a
if-nez p2, :cond_11
invoke-static {v0}, Ljava/security/Signature;->getInstance(Ljava/lang/String;)Ljava/security/Signature;
move-result-object p2
goto :goto_15
:cond_11
invoke-static {v0, p2}, Ljava/security/Signature;->getInstance(Ljava/lang/String;Ljava/lang/String;)Ljava/security/Signature;
move-result-object p2
:goto_15
invoke-virtual {p2, p1}, Ljava/security/Signature;->initVerify(Ljava/security/PublicKey;)V
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLX509CRL;->getTBSCertList()[B
move-result-object p1
invoke-virtual {p2, p1}, Ljava/security/Signature;->update([B)V
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLX509CRL;->getSignature()[B
move-result-object p1
invoke-virtual {p2, p1}, Ljava/security/Signature;->verify([B)Z
move-result p1
if-eqz p1, :cond_2a
return-void
:cond_2a
new-instance p1, Ljava/security/SignatureException;
const-string p2, "signature did not verify"
invoke-direct {p1, p2}, Ljava/security/SignatureException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private verifyOpenSSL(Lorg/conscrypt/OpenSSLKey;)V
.registers 4
:try_start_0
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-virtual {p1}, Lorg/conscrypt/OpenSSLKey;->getNativeRef()Lorg/conscrypt/NativeRef$EVP_PKEY;
move-result-object p1
invoke-static {v0, v1, p0, p1}, Lorg/conscrypt/NativeCrypto;->X509_CRL_verify(JLorg/conscrypt/OpenSSLX509CRL;Lorg/conscrypt/NativeRef$EVP_PKEY;)V
:try_end_9
.catch Ljavax/crypto/BadPaddingException; {:try_start_0 .. :try_end_9} :catch_c
.catch Ljavax/crypto/IllegalBlockSizeException; {:try_start_0 .. :try_end_9} :catch_a
return-void
:catch_a
move-exception p1
goto :goto_d
:catch_c
move-exception p1
:goto_d
new-instance v0, Ljava/security/SignatureException;
invoke-direct {v0, p1}, Ljava/security/SignatureException;-><init>(Ljava/lang/Throwable;)V
throw v0
.end method
# virtual methods
.method protected finalize()V
.registers 6
:try_start_0
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-eqz v4, :cond_b
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->X509_CRL_free(JLorg/conscrypt/OpenSSLX509CRL;)V
:try_end_b
.catchall {:try_start_0 .. :try_end_b} :catchall_f
:cond_b
invoke-super {p0}, Ljava/lang/Object;->finalize()V
return-void
:catchall_f
move-exception v0
invoke-super {p0}, Ljava/lang/Object;->finalize()V
throw v0
.end method
.method public getCriticalExtensionOIDs()Ljava/util/Set;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
const/4 v2, 0x1
invoke-static {v0, v1, p0, v2}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_ext_oids(JLorg/conscrypt/OpenSSLX509CRL;I)[Ljava/lang/String;
move-result-object v0
array-length v1, v0
if-nez v1, :cond_16
iget-wide v1, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
const/4 v3, 0x0
invoke-static {v1, v2, p0, v3}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_ext_oids(JLorg/conscrypt/OpenSSLX509CRL;I)[Ljava/lang/String;
move-result-object v1
array-length v1, v1
if-nez v1, :cond_16
const/4 v0, 0x0
return-object v0
:cond_16
new-instance v1, Ljava/util/HashSet;
invoke-static {v0}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v0
invoke-direct {v1, v0}, Ljava/util/HashSet;-><init>(Ljava/util/Collection;)V
return-object v1
.end method
.method public getEncoded()[B
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->i2d_X509_CRL(JLorg/conscrypt/OpenSSLX509CRL;)[B
move-result-object v0
return-object v0
.end method
.method public getExtensionValue(Ljava/lang/String;)[B
.registers 4
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0, p1}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get_ext_oid(JLorg/conscrypt/OpenSSLX509CRL;Ljava/lang/String;)[B
move-result-object p1
return-object p1
.end method
.method public getIssuerDN()Ljava/security/Principal;
.registers 2
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLX509CRL;->getIssuerX500Principal()Ljavax/security/auth/x500/X500Principal;
move-result-object v0
return-object v0
.end method
.method public getIssuerX500Principal()Ljavax/security/auth/x500/X500Principal;
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get_issuer_name(JLorg/conscrypt/OpenSSLX509CRL;)[B
move-result-object v0
new-instance v1, Ljavax/security/auth/x500/X500Principal;
invoke-direct {v1, v0}, Ljavax/security/auth/x500/X500Principal;-><init>([B)V
return-object v1
.end method
.method public getNextUpdate()Ljava/util/Date;
.registers 2
iget-object v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->nextUpdate:Ljava/util/Date;
invoke-virtual {v0}, Ljava/util/Date;->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/Date;
return-object v0
.end method
.method public getNonCriticalExtensionOIDs()Ljava/util/Set;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
const/4 v2, 0x0
invoke-static {v0, v1, p0, v2}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_ext_oids(JLorg/conscrypt/OpenSSLX509CRL;I)[Ljava/lang/String;
move-result-object v0
array-length v1, v0
if-nez v1, :cond_16
iget-wide v1, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
const/4 v3, 0x1
invoke-static {v1, v2, p0, v3}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_ext_oids(JLorg/conscrypt/OpenSSLX509CRL;I)[Ljava/lang/String;
move-result-object v1
array-length v1, v1
if-nez v1, :cond_16
const/4 v0, 0x0
return-object v0
:cond_16
new-instance v1, Ljava/util/HashSet;
invoke-static {v0}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v0
invoke-direct {v1, v0}, Ljava/util/HashSet;-><init>(Ljava/util/Collection;)V
return-object v1
.end method
.method public getRevokedCertificate(Ljava/math/BigInteger;)Ljava/security/cert/X509CRLEntry;
.registers 7
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-virtual {p1}, Ljava/math/BigInteger;->toByteArray()[B
move-result-object p1
invoke-static {v0, v1, p0, p1}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get0_by_serial(JLorg/conscrypt/OpenSSLX509CRL;[B)J
move-result-wide v0
const/4 p1, 0x0
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-nez v4, :cond_12
return-object p1
:cond_12
:try_start_12
new-instance v2, Lorg/conscrypt/OpenSSLX509CRLEntry;
invoke-static {v0, v1}, Lorg/conscrypt/NativeCrypto;->X509_REVOKED_dup(J)J
move-result-wide v0
invoke-direct {v2, v0, v1}, Lorg/conscrypt/OpenSSLX509CRLEntry;-><init>(J)V
:try_end_1b
.catch Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException; {:try_start_12 .. :try_end_1b} :catch_1c
return-object v2
:catch_1c
return-object p1
.end method
.method public getRevokedCertificate(Ljava/security/cert/X509Certificate;)Ljava/security/cert/X509CRLEntry;
.registers 9
instance-of v0, p1, Lorg/conscrypt/OpenSSLX509Certificate;
if-eqz v0, :cond_25
move-object v6, p1
check-cast v6, Lorg/conscrypt/OpenSSLX509Certificate;
iget-wide v1, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-virtual {v6}, Lorg/conscrypt/OpenSSLX509Certificate;->getContext()J
move-result-wide v4
move-object v3, p0
invoke-static/range {v1 .. v6}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get0_by_cert(JLorg/conscrypt/OpenSSLX509CRL;JLorg/conscrypt/OpenSSLX509Certificate;)J
move-result-wide v0
const-wide/16 v2, 0x0
const/4 p1, 0x0
cmp-long v4, v0, v2
if-nez v4, :cond_1a
return-object p1
:cond_1a
:try_start_1a
new-instance v2, Lorg/conscrypt/OpenSSLX509CRLEntry;
invoke-static {v0, v1}, Lorg/conscrypt/NativeCrypto;->X509_REVOKED_dup(J)J
move-result-wide v0
invoke-direct {v2, v0, v1}, Lorg/conscrypt/OpenSSLX509CRLEntry;-><init>(J)V
:try_end_23
.catch Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException; {:try_start_1a .. :try_end_23} :catch_24
return-object v2
:catch_24
return-object p1
:cond_25
invoke-virtual {p1}, Ljava/security/cert/X509Certificate;->getSerialNumber()Ljava/math/BigInteger;
move-result-object p1
invoke-virtual {p0, p1}, Lorg/conscrypt/OpenSSLX509CRL;->getRevokedCertificate(Ljava/math/BigInteger;)Ljava/security/cert/X509CRLEntry;
move-result-object p1
return-object p1
.end method
.method public getRevokedCertificates()Ljava/util/Set;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set<",
"+",
"Ljava/security/cert/X509CRLEntry;",
">;"
}
.end annotation
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get_REVOKED(JLorg/conscrypt/OpenSSLX509CRL;)[J
move-result-object v0
if-eqz v0, :cond_23
array-length v1, v0
if-nez v1, :cond_c
goto :goto_23
:cond_c
new-instance v1, Ljava/util/HashSet;
invoke-direct {v1}, Ljava/util/HashSet;-><init>()V
array-length v2, v0
const/4 v3, 0x0
:goto_13
if-ge v3, v2, :cond_22
aget-wide v4, v0, v3
:try_start_17
new-instance v6, Lorg/conscrypt/OpenSSLX509CRLEntry;
invoke-direct {v6, v4, v5}, Lorg/conscrypt/OpenSSLX509CRLEntry;-><init>(J)V
invoke-interface {v1, v6}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_1f
.catch Lorg/conscrypt/OpenSSLX509CertificateFactory$ParsingException; {:try_start_17 .. :try_end_1f} :catch_1f
:catch_1f
add-int/lit8 v3, v3, 0x1
goto :goto_13
:cond_22
return-object v1
:cond_23
:goto_23
const/4 v0, 0x0
return-object v0
.end method
.method public getSigAlgName()Ljava/lang/String;
.registers 3
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLX509CRL;->getSigAlgOID()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lorg/conscrypt/OidData;->oidToAlgorithmName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
if-eqz v1, :cond_b
return-object v1
:cond_b
invoke-static {v0}, Lorg/conscrypt/Platform;->oidToAlgorithmName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
if-eqz v1, :cond_12
return-object v1
:cond_12
return-object v0
.end method
.method public getSigAlgOID()Ljava/lang/String;
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_sig_alg_oid(JLorg/conscrypt/OpenSSLX509CRL;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getSigAlgParams()[B
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_sig_alg_parameter(JLorg/conscrypt/OpenSSLX509CRL;)[B
move-result-object v0
return-object v0
.end method
.method public getSignature()[B
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_signature(JLorg/conscrypt/OpenSSLX509CRL;)[B
move-result-object v0
return-object v0
.end method
.method public getTBSCertList()[B
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_crl_enc(JLorg/conscrypt/OpenSSLX509CRL;)[B
move-result-object v0
return-object v0
.end method
.method public getThisUpdate()Ljava/util/Date;
.registers 2
iget-object v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->thisUpdate:Ljava/util/Date;
invoke-virtual {v0}, Ljava/util/Date;->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/Date;
return-object v0
.end method
.method public getVersion()I
.registers 3
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v0, v1, p0}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get_version(JLorg/conscrypt/OpenSSLX509CRL;)J
move-result-wide v0
long-to-int v1, v0
add-int/lit8 v1, v1, 0x1
return v1
.end method
.method public hasUnsupportedCriticalExtension()Z
.registers 9
iget-wide v0, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
const/4 v2, 0x1
invoke-static {v0, v1, p0, v2}, Lorg/conscrypt/NativeCrypto;->get_X509_CRL_ext_oids(JLorg/conscrypt/OpenSSLX509CRL;I)[Ljava/lang/String;
move-result-object v0
array-length v1, v0
const/4 v3, 0x0
const/4 v4, 0x0
:goto_a
if-ge v4, v1, :cond_1e
aget-object v5, v0, v4
iget-wide v6, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v6, v7, p0, v5}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get_ext(JLorg/conscrypt/OpenSSLX509CRL;Ljava/lang/String;)J
move-result-wide v5
invoke-static {v5, v6}, Lorg/conscrypt/NativeCrypto;->X509_supported_extension(J)I
move-result v5
if-eq v5, v2, :cond_1b
return v2
:cond_1b
add-int/lit8 v4, v4, 0x1
goto :goto_a
:cond_1e
return v3
.end method
.method public isRevoked(Ljava/security/cert/Certificate;)Z
.registers 10
instance-of v0, p1, Ljava/security/cert/X509Certificate;
const/4 v1, 0x0
if-nez v0, :cond_6
return v1
:cond_6
instance-of v0, p1, Lorg/conscrypt/OpenSSLX509Certificate;
if-eqz v0, :cond_e
check-cast p1, Lorg/conscrypt/OpenSSLX509Certificate;
:goto_c
move-object v7, p1
goto :goto_1c
:cond_e
:try_start_e
new-instance v0, Ljava/io/ByteArrayInputStream;
invoke-virtual {p1}, Ljava/security/cert/Certificate;->getEncoded()[B
move-result-object p1
invoke-direct {v0, p1}, Ljava/io/ByteArrayInputStream;-><init>([B)V
invoke-static {v0}, Lorg/conscrypt/OpenSSLX509Certificate;->fromX509DerInputStream(Ljava/io/InputStream;)Lorg/conscrypt/OpenSSLX509Certificate;
move-result-object p1
:try_end_1b
.catch Ljava/lang/Exception; {:try_start_e .. :try_end_1b} :catch_2f
goto :goto_c
:goto_1c
iget-wide v2, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-virtual {v7}, Lorg/conscrypt/OpenSSLX509Certificate;->getContext()J
move-result-wide v5
move-object v4, p0
invoke-static/range {v2 .. v7}, Lorg/conscrypt/NativeCrypto;->X509_CRL_get0_by_cert(JLorg/conscrypt/OpenSSLX509CRL;JLorg/conscrypt/OpenSSLX509Certificate;)J
move-result-wide v2
const-wide/16 v4, 0x0
cmp-long p1, v2, v4
if-eqz p1, :cond_2e
const/4 v1, 0x1
:cond_2e
return v1
:catch_2f
move-exception p1
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "cannot convert certificate"
invoke-direct {v0, v1, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_39
:goto_38
throw v0
:goto_39
goto :goto_38
.end method
.method public toString()Ljava/lang/String;
.registers 6
new-instance v0, Ljava/io/ByteArrayOutputStream;
invoke-direct {v0}, Ljava/io/ByteArrayOutputStream;-><init>()V
invoke-static {v0}, Lorg/conscrypt/NativeCrypto;->create_BIO_OutputStream(Ljava/io/OutputStream;)J
move-result-wide v1
:try_start_9
iget-wide v3, p0, Lorg/conscrypt/OpenSSLX509CRL;->mContext:J
invoke-static {v1, v2, v3, v4, p0}, Lorg/conscrypt/NativeCrypto;->X509_CRL_print(JJLorg/conscrypt/OpenSSLX509CRL;)V
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toString()Ljava/lang/String;
move-result-object v0
:try_end_12
.catchall {:try_start_9 .. :try_end_12} :catchall_16
invoke-static {v1, v2}, Lorg/conscrypt/NativeCrypto;->BIO_free_all(J)V
return-object v0
:catchall_16
move-exception v0
invoke-static {v1, v2}, Lorg/conscrypt/NativeCrypto;->BIO_free_all(J)V
throw v0
.end method
.method public verify(Ljava/security/PublicKey;)V
.registers 3
instance-of v0, p1, Lorg/conscrypt/OpenSSLKeyHolder;
if-eqz v0, :cond_e
check-cast p1, Lorg/conscrypt/OpenSSLKeyHolder;
invoke-interface {p1}, Lorg/conscrypt/OpenSSLKeyHolder;->getOpenSSLKey()Lorg/conscrypt/OpenSSLKey;
move-result-object p1
invoke-direct {p0, p1}, Lorg/conscrypt/OpenSSLX509CRL;->verifyOpenSSL(Lorg/conscrypt/OpenSSLKey;)V
return-void
:cond_e
const/4 v0, 0x0
invoke-direct {p0, p1, v0}, Lorg/conscrypt/OpenSSLX509CRL;->verifyInternal(Ljava/security/PublicKey;Ljava/lang/String;)V
return-void
.end method
.method public verify(Ljava/security/PublicKey;Ljava/lang/String;)V
.registers 3
invoke-direct {p0, p1, p2}, Lorg/conscrypt/OpenSSLX509CRL;->verifyInternal(Ljava/security/PublicKey;Ljava/lang/String;)V
return-void
.end method