X509LDAPCertStoreSpi.smali
.class public Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;
.super Ljava/security/cert/CertStoreSpi;
.source "X509LDAPCertStoreSpi.java"
# static fields
.field private static LDAP_PROVIDER:Ljava/lang/String; = null
.field private static REFERRALS_IGNORE:Ljava/lang/String; = null
.field private static final SEARCH_SECURITY_LEVEL:Ljava/lang/String; = "none"
.field private static final URL_CONTEXT_PREFIX:Ljava/lang/String; = "com.sun.jndi.url"
# instance fields
.field private params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 73
const-string v0, "com.sun.jndi.ldap.LdapCtxFactory"
sput-object v0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->LDAP_PROVIDER:Ljava/lang/String;
.line 78
const-string v0, "ignore"
sput-object v0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->REFERRALS_IGNORE:Ljava/lang/String;
return-void
.end method
.method public constructor <init>(Ljava/security/cert/CertStoreParameters;)V
.registers 5
.prologue
.line 58
invoke-direct {p0, p1}, Ljava/security/cert/CertStoreSpi;-><init>(Ljava/security/cert/CertStoreParameters;)V
.line 60
instance-of v0, p1, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
if-nez v0, :cond_3e
.line 62
new-instance v0, Ljava/security/InvalidAlgorithmParameterException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-class v2, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;
.line 63
invoke-virtual {v2}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ": parameter must be a "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-class v2, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v2}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, " object\n"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 64
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw v0
.line 67
:cond_3e
check-cast p1, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
iput-object p1, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
.line 68
return-void
.end method
.method private certSubjectSerialSearch(Ljava/security/cert/X509CertSelector;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/util/Set;
.registers 10
.prologue
.line 232
new-instance v2, Ljava/util/HashSet;
invoke-direct {v2}, Ljava/util/HashSet;-><init>()V
.line 235
:try_start_5
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getSubjectAsBytes()[B
move-result-object v0
if-nez v0, :cond_17
.line 236
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getSubjectAsString()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_17
.line 237
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getCertificate()Ljava/security/cert/X509Certificate;
move-result-object v0
if-eqz v0, :cond_a0
.line 240
:cond_17
const/4 v0, 0x0
.line 241
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getCertificate()Ljava/security/cert/X509Certificate;
move-result-object v1
if-eqz v1, :cond_85
.line 243
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getCertificate()Ljava/security/cert/X509Certificate;
move-result-object v0
.line 244
invoke-virtual {v0}, Ljava/security/cert/X509Certificate;->getSubjectX500Principal()Ljavax/security/auth/x500/X500Principal;
move-result-object v0
const-string v1, "RFC1779"
invoke-virtual {v0, v1}, Ljavax/security/auth/x500/X500Principal;->getName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
.line 245
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getCertificate()Ljava/security/cert/X509Certificate;
move-result-object v0
invoke-virtual {v0}, Ljava/security/cert/X509Certificate;->getSerialNumber()Ljava/math/BigInteger;
move-result-object v0
.line 246
invoke-virtual {v0}, Ljava/math/BigInteger;->toString()Ljava/lang/String;
move-result-object v0
.line 260
:goto_38
invoke-direct {p0, v1, p4}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->parseDN(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
.line 261
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "*"
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v3, "*"
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {p0, p3, v1, p2}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v1
invoke-interface {v2, v1}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 262
if-eqz v0, :cond_84
iget-object v1, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
.line 263
invoke-virtual {v1}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getSearchForSerialNumberIn()Ljava/lang/String;
move-result-object v1
if-eqz v1, :cond_84
.line 266
iget-object v1, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v1}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getSearchForSerialNumberIn()Ljava/lang/String;
move-result-object v1
.line 267
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "*"
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v3, "*"
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v1, v0, p2}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
invoke-interface {v2, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 280
:cond_84
:goto_84
return-object v2
.line 250
:cond_85
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getSubjectAsBytes()[B
move-result-object v1
if-eqz v1, :cond_9b
.line 252
new-instance v1, Ljavax/security/auth/x500/X500Principal;
.line 253
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getSubjectAsBytes()[B
move-result-object v3
invoke-direct {v1, v3}, Ljavax/security/auth/x500/X500Principal;-><init>([B)V
const-string v3, "RFC1779"
invoke-virtual {v1, v3}, Ljavax/security/auth/x500/X500Principal;->getName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
goto :goto_38
.line 257
:cond_9b
invoke-virtual {p1}, Ljava/security/cert/X509CertSelector;->getSubjectAsString()Ljava/lang/String;
move-result-object v1
goto :goto_38
.line 272
:cond_a0
const-string v0, "*"
invoke-direct {p0, p3, v0, p2}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
invoke-interface {v2, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
:try_end_a9
.catch Ljava/io/IOException; {:try_start_5 .. :try_end_a9} :catch_aa
goto :goto_84
.line 275
:catch_aa
move-exception v0
.line 277
new-instance v1, Ljava/security/cert/CertStoreException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "exception processing selector: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/security/cert/CertStoreException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method private connectLDAP()Ljavax/naming/directory/DirContext;
.registers 4
.prologue
.line 92
new-instance v0, Ljava/util/Properties;
invoke-direct {v0}, Ljava/util/Properties;-><init>()V
.line 93
const-string v1, "java.naming.factory.initial"
sget-object v2, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->LDAP_PROVIDER:Ljava/lang/String;
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
.line 94
const-string v1, "java.naming.batchsize"
const-string v2, "0"
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
.line 96
const-string v1, "java.naming.provider.url"
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getLdapURL()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
.line 97
const-string v1, "java.naming.factory.url.pkgs"
const-string v2, "com.sun.jndi.url"
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
.line 98
const-string v1, "java.naming.referral"
sget-object v2, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->REFERRALS_IGNORE:Ljava/lang/String;
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
.line 99
const-string v1, "java.naming.security.authentication"
const-string v2, "none"
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
.line 102
new-instance v1, Ljavax/naming/directory/InitialDirContext;
invoke-direct {v1, v0}, Ljavax/naming/directory/InitialDirContext;-><init>(Ljava/util/Hashtable;)V
.line 103
return-object v1
.end method
.method private getCACertificates(Ljava/security/cert/X509CertSelector;)Ljava/util/Set;
.registers 6
.prologue
.line 298
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/String;
const/4 v1, 0x0
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getCACertificateAttribute()Ljava/lang/String;
move-result-object v2
aput-object v2, v0, v1
.line 299
iget-object v1, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v1}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getLdapCACertificateAttributeName()Ljava/lang/String;
move-result-object v1
.line 300
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
.line 301
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getCACertificateSubjectAttributeName()Ljava/lang/String;
move-result-object v2
.line 302
invoke-direct {p0, p1, v0, v1, v2}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->certSubjectSerialSearch(Ljava/security/cert/X509CertSelector;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/util/Set;
move-result-object v1
.line 305
invoke-interface {v1}, Ljava/util/Set;->isEmpty()Z
move-result v2
if-eqz v2, :cond_2c
.line 307
const/4 v2, 0x0
const-string v3, "*"
invoke-direct {p0, v2, v3, v0}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
invoke-interface {v1, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 310
:cond_2c
return-object v1
.end method
.method private getCrossCertificates(Ljava/security/cert/X509CertSelector;)Ljava/util/Set;
.registers 6
.prologue
.line 316
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/String;
const/4 v1, 0x0
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getCrossCertificateAttribute()Ljava/lang/String;
move-result-object v2
aput-object v2, v0, v1
.line 317
iget-object v1, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v1}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getLdapCrossCertificateAttributeName()Ljava/lang/String;
move-result-object v1
.line 318
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
.line 319
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getCrossCertificateSubjectAttributeName()Ljava/lang/String;
move-result-object v2
.line 320
invoke-direct {p0, p1, v0, v1, v2}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->certSubjectSerialSearch(Ljava/security/cert/X509CertSelector;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/util/Set;
move-result-object v1
.line 323
invoke-interface {v1}, Ljava/util/Set;->isEmpty()Z
move-result v2
if-eqz v2, :cond_2c
.line 325
const/4 v2, 0x0
const-string v3, "*"
invoke-direct {p0, v2, v3, v0}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
invoke-interface {v1, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 328
:cond_2c
return-object v1
.end method
.method private getEndCertificates(Ljava/security/cert/X509CertSelector;)Ljava/util/Set;
.registers 5
.prologue
.line 286
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/String;
const/4 v1, 0x0
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getUserCertificateAttribute()Ljava/lang/String;
move-result-object v2
aput-object v2, v0, v1
.line 287
iget-object v1, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v1}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getLdapUserCertificateAttributeName()Ljava/lang/String;
move-result-object v1
.line 288
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getUserCertificateSubjectAttributeName()Ljava/lang/String;
move-result-object v2
.line 290
invoke-direct {p0, p1, v0, v1, v2}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->certSubjectSerialSearch(Ljava/security/cert/X509CertSelector;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
.line 292
return-object v0
.end method
.method private parseDN(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 11
.prologue
const/16 v7, 0x2c
const/4 v6, 0x1
const/4 v5, -0x1
const/4 v4, 0x0
.line 108
.line 109
invoke-virtual {p1}, Ljava/lang/String;->toLowerCase()Ljava/lang/String;
move-result-object v0
.line 110
invoke-virtual {p2}, Ljava/lang/String;->toLowerCase()Ljava/lang/String;
move-result-object v1
.line 109
invoke-virtual {v0, v1}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I
move-result v0
.line 111
invoke-virtual {p2}, Ljava/lang/String;->length()I
move-result v1
add-int/2addr v0, v1
invoke-virtual {p1, v0}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v1
.line 112
invoke-virtual {v1, v7}, Ljava/lang/String;->indexOf(I)I
move-result v0
.line 113
if-ne v0, v5, :cond_24
.line 115
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v0
.line 117
:cond_24
:goto_24
add-int/lit8 v2, v0, -0x1
invoke-virtual {v1, v2}, Ljava/lang/String;->charAt(I)C
move-result v2
const/16 v3, 0x5c
if-ne v2, v3, :cond_3b
.line 119
add-int/lit8 v0, v0, 0x1
invoke-virtual {v1, v7, v0}, Ljava/lang/String;->indexOf(II)I
move-result v0
.line 120
if-ne v0, v5, :cond_24
.line 122
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v0
goto :goto_24
.line 125
:cond_3b
invoke-virtual {v1, v4, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v0
.line 126
const/16 v1, 0x3d
invoke-virtual {v0, v1}, Ljava/lang/String;->indexOf(I)I
move-result v1
.line 127
add-int/lit8 v1, v1, 0x1
invoke-virtual {v0, v1}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v0
.line 128
invoke-virtual {v0, v4}, Ljava/lang/String;->charAt(I)C
move-result v1
const/16 v2, 0x20
if-ne v1, v2, :cond_57
.line 130
invoke-virtual {v0, v6}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v0
.line 132
:cond_57
const-string v1, "\""
invoke-virtual {v0, v1}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_63
.line 134
invoke-virtual {v0, v6}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v0
.line 136
:cond_63
const-string v1, "\""
invoke-virtual {v0, v1}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_75
.line 138
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v1
add-int/lit8 v1, v1, -0x1
invoke-virtual {v0, v4, v1}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v0
.line 140
:cond_75
return-object v0
.end method
.method private search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
.registers 13
.prologue
const/4 v0, 0x0
const/4 v3, 0x0
.line 411
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, "="
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 412
if-nez p1, :cond_1c
move-object v1, v0
.line 417
:cond_1c
new-instance v4, Ljava/util/HashSet;
invoke-direct {v4}, Ljava/util/HashSet;-><init>()V
.line 421
:try_start_21
invoke-direct {p0}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->connectLDAP()Ljavax/naming/directory/DirContext;
:try_end_24
.catch Ljava/lang/Exception; {:try_start_21 .. :try_end_24} :catch_e7
.catchall {:try_start_21 .. :try_end_24} :catchall_e1
move-result-object v2
.line 423
:try_start_25
new-instance v5, Ljavax/naming/directory/SearchControls;
invoke-direct {v5}, Ljavax/naming/directory/SearchControls;-><init>()V
.line 424
const/4 v0, 0x2
invoke-virtual {v5, v0}, Ljavax/naming/directory/SearchControls;->setSearchScope(I)V
.line 425
const-wide/16 v6, 0x0
invoke-virtual {v5, v6, v7}, Ljavax/naming/directory/SearchControls;->setCountLimit(J)V
.line 426
:goto_33
array-length v0, p3
if-ge v3, v0, :cond_d7
.line 428
const/4 v0, 0x1
new-array v6, v0, [Ljava/lang/String;
.line 429
const/4 v0, 0x0
aget-object v7, p3, v3
aput-object v7, v6, v0
.line 430
invoke-virtual {v5, v6}, Ljavax/naming/directory/SearchControls;->setReturningAttributes([Ljava/lang/String;)V
.line 432
new-instance v0, Ljava/lang/StringBuilder;
const-string v7, "(&("
invoke-direct {v0, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v7, ")("
invoke-virtual {v0, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const/4 v7, 0x0
aget-object v7, v6, v7
invoke-virtual {v0, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v7, "=*))"
invoke-virtual {v0, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 433
if-nez v1, :cond_7d
.line 435
new-instance v0, Ljava/lang/StringBuilder;
const-string v7, "("
invoke-direct {v0, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
const/4 v7, 0x0
aget-object v6, v6, v7
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v6, "=*)"
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 437
:cond_7d
iget-object v6, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v6}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getBaseDN()Ljava/lang/String;
move-result-object v6
invoke-interface {v2, v6, v0, v5}, Ljavax/naming/directory/DirContext;->search(Ljava/lang/String;Ljava/lang/String;Ljavax/naming/directory/SearchControls;)Ljavax/naming/NamingEnumeration;
move-result-object v6
.line 439
:cond_87
invoke-interface {v6}, Ljavax/naming/NamingEnumeration;->hasMoreElements()Z
move-result v0
if-eqz v0, :cond_d2
.line 441
invoke-interface {v6}, Ljavax/naming/NamingEnumeration;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljavax/naming/directory/SearchResult;
.line 446
invoke-virtual {v0}, Ljavax/naming/directory/SearchResult;->getAttributes()Ljavax/naming/directory/Attributes;
move-result-object v0
invoke-interface {v0}, Ljavax/naming/directory/Attributes;->getAll()Ljavax/naming/NamingEnumeration;
move-result-object v0
invoke-interface {v0}, Ljavax/naming/NamingEnumeration;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljavax/naming/directory/Attribute;
invoke-interface {v0}, Ljavax/naming/directory/Attribute;->getAll()Ljavax/naming/NamingEnumeration;
move-result-object v0
.line 447
:goto_a5
invoke-interface {v0}, Ljavax/naming/NamingEnumeration;->hasMore()Z
move-result v7
if-eqz v7, :cond_87
.line 449
invoke-interface {v0}, Ljavax/naming/NamingEnumeration;->next()Ljava/lang/Object;
move-result-object v7
.line 450
invoke-interface {v4, v7}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_b2
.catch Ljava/lang/Exception; {:try_start_25 .. :try_end_b2} :catch_b3
.catchall {:try_start_25 .. :try_end_b2} :catchall_e5
goto :goto_a5
.line 455
:catch_b3
move-exception v0
move-object v1, v2
.line 457
:goto_b5
:try_start_b5
new-instance v2, Ljava/security/cert/CertStoreException;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Error getting results from LDAP directory "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v2, v0}, Ljava/security/cert/CertStoreException;-><init>(Ljava/lang/String;)V
throw v2
:try_end_ca
.catchall {:try_start_b5 .. :try_end_ca} :catchall_ca
.line 463
:catchall_ca
move-exception v0
move-object v2, v1
.line 465
:goto_cc
if-eqz v2, :cond_d1
.line 467
:try_start_ce
invoke-interface {v2}, Ljavax/naming/directory/DirContext;->close()V
:try_end_d1
.catch Ljava/lang/Exception; {:try_start_ce .. :try_end_d1} :catch_df
.line 472
:cond_d1
:goto_d1
throw v0
.line 426
:cond_d2
add-int/lit8 v0, v3, 0x1
move v3, v0
goto/16 :goto_33
.line 465
:cond_d7
if-eqz v2, :cond_dc
.line 467
:try_start_d9
invoke-interface {v2}, Ljavax/naming/directory/DirContext;->close()V
:try_end_dc
.catch Ljava/lang/Exception; {:try_start_d9 .. :try_end_dc} :catch_dd
.line 474
:cond_dc
:goto_dc
return-object v4
.line 473
:catch_dd
move-exception v0
goto :goto_dc
:catch_df
move-exception v1
goto :goto_d1
.line 463
:catchall_e1
move-exception v1
move-object v2, v0
move-object v0, v1
goto :goto_cc
:catchall_e5
move-exception v0
goto :goto_cc
.line 455
:catch_e7
move-exception v1
move-object v8, v1
move-object v1, v0
move-object v0, v8
goto :goto_b5
.end method
# virtual methods
.method public engineGetCRLs(Ljava/security/cert/CRLSelector;)Ljava/util/Collection;
.registers 10
.prologue
.line 334
const/4 v0, 0x1
new-array v1, v0, [Ljava/lang/String;
const/4 v0, 0x0
iget-object v2, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v2}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getCertificateRevocationListAttribute()Ljava/lang/String;
move-result-object v2
aput-object v2, v1, v0
.line 335
instance-of v0, p1, Ljava/security/cert/X509CRLSelector;
if-nez v0, :cond_18
.line 337
new-instance v0, Ljava/security/cert/CertStoreException;
const-string v1, "selector is not a X509CRLSelector"
invoke-direct {v0, v1}, Ljava/security/cert/CertStoreException;-><init>(Ljava/lang/String;)V
throw v0
.line 339
:cond_18
check-cast p1, Ljava/security/cert/X509CRLSelector;
.line 341
new-instance v2, Ljava/util/HashSet;
invoke-direct {v2}, Ljava/util/HashSet;-><init>()V
.line 343
iget-object v0, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
invoke-virtual {v0}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getLdapCertificateRevocationListAttributeName()Ljava/lang/String;
move-result-object v3
.line 344
new-instance v4, Ljava/util/HashSet;
invoke-direct {v4}, Ljava/util/HashSet;-><init>()V
.line 346
invoke-virtual {p1}, Ljava/security/cert/X509CRLSelector;->getIssuerNames()Ljava/util/Collection;
move-result-object v0
if-eqz v0, :cond_87
.line 348
invoke-virtual {p1}, Ljava/security/cert/X509CRLSelector;->getIssuerNames()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v5
.line 349
:goto_38
invoke-interface {v5}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_90
.line 351
invoke-interface {v5}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
.line 353
instance-of v6, v0, Ljava/lang/String;
if-eqz v6, :cond_6f
.line 355
iget-object v6, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
.line 356
invoke-virtual {v6}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getCertificateRevocationListIssuerAttributeName()Ljava/lang/String;
move-result-object v6
.line 357
check-cast v0, Ljava/lang/String;
invoke-direct {p0, v0, v6}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->parseDN(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 366
:goto_52
new-instance v6, Ljava/lang/StringBuilder;
const-string v7, "*"
invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v6, "*"
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v3, v0, v1}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
invoke-interface {v4, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
goto :goto_38
.line 361
:cond_6f
iget-object v6, p0, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->params:Lorg/spongycastle/jce/X509LDAPCertStoreParameters;
.line 362
invoke-virtual {v6}, Lorg/spongycastle/jce/X509LDAPCertStoreParameters;->getCertificateRevocationListIssuerAttributeName()Ljava/lang/String;
move-result-object v6
.line 363
new-instance v7, Ljavax/security/auth/x500/X500Principal;
check-cast v0, [B
invoke-direct {v7, v0}, Ljavax/security/auth/x500/X500Principal;-><init>([B)V
const-string v0, "RFC1779"
.line 364
invoke-virtual {v7, v0}, Ljavax/security/auth/x500/X500Principal;->getName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 363
invoke-direct {p0, v0, v6}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->parseDN(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_52
.line 371
:cond_87
const-string v0, "*"
invoke-direct {p0, v3, v0, v1}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
invoke-interface {v4, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 373
:cond_90
const/4 v0, 0x0
const-string v3, "*"
invoke-direct {p0, v0, v3, v1}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->search(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
invoke-interface {v4, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 374
invoke-interface {v4}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v1
.line 378
:try_start_9e
const-string v0, "X.509"
const-string v3, "SC"
invoke-static {v0, v3}, Ljava/security/cert/CertificateFactory;->getInstance(Ljava/lang/String;Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
move-result-object v3
.line 380
:cond_a6
:goto_a6
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_db
.line 382
new-instance v4, Ljava/io/ByteArrayInputStream;
.line 383
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, [B
invoke-direct {v4, v0}, Ljava/io/ByteArrayInputStream;-><init>([B)V
.line 382
invoke-virtual {v3, v4}, Ljava/security/cert/CertificateFactory;->generateCRL(Ljava/io/InputStream;)Ljava/security/cert/CRL;
move-result-object v0
.line 384
invoke-virtual {p1, v0}, Ljava/security/cert/X509CRLSelector;->match(Ljava/security/cert/CRL;)Z
move-result v4
if-eqz v4, :cond_a6
.line 386
invoke-interface {v2, v0}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_c4
.catch Ljava/lang/Exception; {:try_start_9e .. :try_end_c4} :catch_c5
goto :goto_a6
.line 390
:catch_c5
move-exception v0
.line 392
new-instance v1, Ljava/security/cert/CertStoreException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "CRL cannot be constructed from LDAP result "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/security/cert/CertStoreException;-><init>(Ljava/lang/String;)V
throw v1
.line 396
:cond_db
return-object v2
.end method
.method public engineGetCertificates(Ljava/security/cert/CertSelector;)Ljava/util/Collection;
.registers 8
.prologue
.line 146
instance-of v0, p1, Ljava/security/cert/X509CertSelector;
if-nez v0, :cond_c
.line 148
new-instance v0, Ljava/security/cert/CertStoreException;
const-string v1, "selector is not a X509CertSelector"
invoke-direct {v0, v1}, Ljava/security/cert/CertStoreException;-><init>(Ljava/lang/String;)V
throw v0
.line 150
:cond_c
check-cast p1, Ljava/security/cert/X509CertSelector;
.line 152
new-instance v1, Ljava/util/HashSet;
invoke-direct {v1}, Ljava/util/HashSet;-><init>()V
.line 154
invoke-direct {p0, p1}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->getEndCertificates(Ljava/security/cert/X509CertSelector;)Ljava/util/Set;
move-result-object v0
.line 155
invoke-direct {p0, p1}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->getCACertificates(Ljava/security/cert/X509CertSelector;)Ljava/util/Set;
move-result-object v2
invoke-interface {v0, v2}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 156
invoke-direct {p0, p1}, Lorg/spongycastle/jce/provider/X509LDAPCertStoreSpi;->getCrossCertificates(Ljava/security/cert/X509CertSelector;)Ljava/util/Set;
move-result-object v2
invoke-interface {v0, v2}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 158
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v2
.line 162
:try_start_29
const-string v0, "X.509"
const-string v3, "SC"
invoke-static {v0, v3}, Ljava/security/cert/CertificateFactory;->getInstance(Ljava/lang/String;Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
move-result-object v3
.line 164
:cond_31
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_b7
.line 166
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, [B
.line 167
if-eqz v0, :cond_31
array-length v4, v0
if-eqz v4, :cond_31
.line 172
new-instance v4, Ljava/util/ArrayList;
invoke-direct {v4}, Ljava/util/ArrayList;-><init>()V
.line 173
invoke-interface {v4, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:try_end_4a
.catch Ljava/lang/Exception; {:try_start_29 .. :try_end_4a} :catch_a1
.line 177
:try_start_4a
new-instance v5, Lorg/spongycastle/asn1/ASN1InputStream;
invoke-direct {v5, v0}, Lorg/spongycastle/asn1/ASN1InputStream;-><init>([B)V
.line 179
invoke-virtual {v5}, Lorg/spongycastle/asn1/ASN1InputStream;->readObject()Lorg/spongycastle/asn1/ASN1Primitive;
move-result-object v0
.line 178
invoke-static {v0}, Lorg/spongycastle/asn1/x509/CertificatePair;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/x509/CertificatePair;
move-result-object v0
.line 180
invoke-interface {v4}, Ljava/util/List;->clear()V
.line 181
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/CertificatePair;->getForward()Lorg/spongycastle/asn1/x509/Certificate;
move-result-object v5
if-eqz v5, :cond_6b
.line 183
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/CertificatePair;->getForward()Lorg/spongycastle/asn1/x509/Certificate;
move-result-object v5
invoke-virtual {v5}, Lorg/spongycastle/asn1/x509/Certificate;->getEncoded()[B
move-result-object v5
invoke-interface {v4, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 185
:cond_6b
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/CertificatePair;->getReverse()Lorg/spongycastle/asn1/x509/Certificate;
move-result-object v5
if-eqz v5, :cond_7c
.line 187
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/CertificatePair;->getReverse()Lorg/spongycastle/asn1/x509/Certificate;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/Certificate;->getEncoded()[B
move-result-object v0
invoke-interface {v4, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:try_end_7c
.catch Ljava/io/IOException; {:try_start_4a .. :try_end_7c} :catch_ba
.catch Ljava/lang/IllegalArgumentException; {:try_start_4a .. :try_end_7c} :catch_b8
.catch Ljava/lang/Exception; {:try_start_4a .. :try_end_7c} :catch_a1
.line 198
:cond_7c
:goto_7c
:try_start_7c
invoke-interface {v4}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v4
:cond_80
:goto_80
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_31
.line 200
new-instance v5, Ljava/io/ByteArrayInputStream;
.line 201
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, [B
invoke-direct {v5, v0}, Ljava/io/ByteArrayInputStream;-><init>([B)V
:try_end_91
.catch Ljava/lang/Exception; {:try_start_7c .. :try_end_91} :catch_a1
.line 204
:try_start_91
invoke-virtual {v3, v5}, Ljava/security/cert/CertificateFactory;->generateCertificate(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
move-result-object v0
.line 207
invoke-virtual {p1, v0}, Ljava/security/cert/X509CertSelector;->match(Ljava/security/cert/Certificate;)Z
move-result v5
if-eqz v5, :cond_80
.line 209
invoke-interface {v1, v0}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_9e
.catch Ljava/lang/Exception; {:try_start_91 .. :try_end_9e} :catch_9f
goto :goto_80
.line 216
:catch_9f
move-exception v0
goto :goto_80
.line 219
:catch_a1
move-exception v0
.line 221
new-instance v1, Ljava/security/cert/CertStoreException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "certificate cannot be constructed from LDAP result: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/security/cert/CertStoreException;-><init>(Ljava/lang/String;)V
throw v1
.line 225
:cond_b7
return-object v1
:catch_b8
move-exception v0
goto :goto_7c
.line 197
:catch_ba
move-exception v0
goto :goto_7c
.end method