public final class sun.security.validator.SimpleValidator extends sun.security.validator.Validator
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.validator.SimpleValidator
  super_class: sun.security.validator.Validator
{
  static final java.lang.String OID_BASIC_CONSTRAINTS;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "2.5.29.19"

  static final java.lang.String OID_NETSCAPE_CERT_TYPE;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "2.16.840.1.113730.1.1"

  static final java.lang.String OID_KEY_USAGE;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "2.5.29.15"

  static final java.lang.String OID_EXTENDED_KEY_USAGE;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "2.5.29.37"

  static final java.lang.String OID_EKU_ANY_USAGE;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "2.5.29.37.0"

  static final sun.security.util.ObjectIdentifier OBJID_NETSCAPE_CERT_TYPE;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  private static final java.lang.String NSCT_SSL_CA;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "ssl_ca"

  private static final java.lang.String NSCT_CODE_SIGNING_CA;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "object_signing_ca"

  private final java.util.Map<javax.security.auth.x500.X500Principal, java.util.List<java.security.cert.X509Certificate>> trustedX500Principals;
    descriptor: Ljava/util/Map;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Map<Ljavax/security/auth/x500/X500Principal;Ljava/util/List<Ljava/security/cert/X509Certificate;>;>;

  private final java.util.Collection<java.security.cert.X509Certificate> trustedCerts;
    descriptor: Ljava/util/Collection;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 74
            getstatic sun.security.x509.NetscapeCertTypeExtension.NetscapeCertType_Id:Lsun/security/util/ObjectIdentifier;
         1: .line 73
            putstatic sun.security.validator.SimpleValidator.OBJID_NETSCAPE_CERT_TYPE:Lsun/security/util/ObjectIdentifier;
         2: .line 80
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.lang.String, java.util.Collection<java.security.cert.X509Certificate>);
    descriptor: (Ljava/lang/String;Ljava/util/Collection;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=7, args_size=3
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.lang.String variant
        start local 2 // java.util.Collection trustedCerts
         0: .line 98
            aload 0 /* this */
            ldc "Simple"
            aload 1 /* variant */
            invokespecial sun.security.validator.Validator.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         1: .line 99
            aload 0 /* this */
            aload 2 /* trustedCerts */
            putfield sun.security.validator.SimpleValidator.trustedCerts:Ljava/util/Collection;
         2: .line 100
            aload 0 /* this */
         3: .line 101
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
         4: .line 100
            putfield sun.security.validator.SimpleValidator.trustedX500Principals:Ljava/util/Map;
         5: .line 102
            aload 2 /* trustedCerts */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 13
      StackMap locals: sun.security.validator.SimpleValidator java.lang.String java.util.Collection top java.util.Iterator
      StackMap stack:
         6: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 3 /* cert */
        start local 3 // java.security.cert.X509Certificate cert
         7: .line 103
            aload 3 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 5 /* principal */
        start local 5 // javax.security.auth.x500.X500Principal principal
         8: .line 104
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.trustedX500Principals:Ljava/util/Map;
            aload 5 /* principal */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.List
            astore 6 /* list */
        start local 6 // java.util.List list
         9: .line 105
            aload 6 /* list */
            ifnonnull 12
        10: .line 108
            new java.util.ArrayList
            dup
            iconst_2
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 6 /* list */
        11: .line 109
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.trustedX500Principals:Ljava/util/Map;
            aload 5 /* principal */
            aload 6 /* list */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        12: .line 111
      StackMap locals: sun.security.validator.SimpleValidator java.lang.String java.util.Collection java.security.cert.X509Certificate java.util.Iterator javax.security.auth.x500.X500Principal java.util.List
      StackMap stack:
            aload 6 /* list */
            aload 3 /* cert */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 6 // java.util.List list
        end local 5 // javax.security.auth.x500.X500Principal principal
        end local 3 // java.security.cert.X509Certificate cert
        13: .line 102
      StackMap locals: sun.security.validator.SimpleValidator java.lang.String java.util.Collection top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        14: .line 113
            return
        end local 2 // java.util.Collection trustedCerts
        end local 1 // java.lang.String variant
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   15     0          this  Lsun/security/validator/SimpleValidator;
            0   15     1       variant  Ljava/lang/String;
            0   15     2  trustedCerts  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            7   13     3          cert  Ljava/security/cert/X509Certificate;
            8   13     5     principal  Ljavax/security/auth/x500/X500Principal;
            9   13     6          list  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
    Signature: (Ljava/lang/String;Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      variant       
      trustedCerts  

  public java.util.Collection<java.security.cert.X509Certificate> getTrustedCertificates();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.validator.SimpleValidator this
         0: .line 116
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.trustedCerts:Ljava/util/Collection;
            areturn
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/validator/SimpleValidator;
    Signature: ()Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;

  java.security.cert.X509Certificate[] engineValidate(java.security.cert.X509Certificate[], java.util.Collection<java.security.cert.X509Certificate>, java.util.List<byte[]>, java.security.AlgorithmConstraints, );
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/util/Collection;Ljava/util/List;Ljava/security/AlgorithmConstraints;Ljava/lang/Object;)[Ljava/security/cert/X509Certificate;
    flags: (0x0000) 
    Code:
      stack=7, locals=17, args_size=6
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.util.Collection otherCerts
        start local 3 // java.util.List responseList
        start local 4 // java.security.AlgorithmConstraints constraints
        start local 5 // java.lang.Object parameter
         0: .line 129
            aload 1 /* chain */
            ifnull 1
            aload 1 /* chain */
            arraylength
            ifne 4
         1: .line 130
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateException
            dup
         2: .line 131
            ldc "null or zero-length certificate chain"
         3: .line 130
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 135
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* chain */
            invokevirtual sun.security.validator.SimpleValidator.buildTrustedChain:([Ljava/security/cert/X509Certificate;)[Ljava/security/cert/X509Certificate;
            astore 1 /* chain */
         5: .line 138
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.validationDate:Ljava/util/Date;
            astore 6 /* date */
        start local 6 // java.util.Date date
         6: .line 139
            aload 6 /* date */
            ifnonnull 8
         7: .line 140
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 6 /* date */
         8: .line 144
      StackMap locals: java.util.Date
      StackMap stack:
            new sun.security.provider.certpath.UntrustedChecker
            dup
            invokespecial sun.security.provider.certpath.UntrustedChecker.<init>:()V
            astore 7 /* untrustedChecker */
        start local 7 // sun.security.provider.certpath.UntrustedChecker untrustedChecker
         9: .line 147
            aload 1 /* chain */
            aload 1 /* chain */
            arraylength
            iconst_1
            isub
            aaload
            astore 8 /* anchorCert */
        start local 8 // java.security.cert.X509Certificate anchorCert
        10: .line 149
            aload 7 /* untrustedChecker */
            aload 8 /* anchorCert */
            invokevirtual sun.security.provider.certpath.UntrustedChecker.check:(Ljava/security/cert/Certificate;)V
        11: .line 150
            goto 17
      StackMap locals: sun.security.validator.SimpleValidator java.security.cert.X509Certificate[] java.util.Collection java.util.List java.security.AlgorithmConstraints java.lang.Object java.util.Date sun.security.provider.certpath.UntrustedChecker java.security.cert.X509Certificate
      StackMap stack: java.security.cert.CertPathValidatorException
        12: astore 9 /* cpve */
        start local 9 // java.security.cert.CertPathValidatorException cpve
        13: .line 151
            new sun.security.validator.ValidatorException
            dup
        14: .line 152
            new java.lang.StringBuilder
            dup
            ldc "Untrusted certificate: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* anchorCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 153
            getstatic sun.security.validator.ValidatorException.T_UNTRUSTED_CERT:Ljava/lang/Object;
            aload 8 /* anchorCert */
            aload 9 /* cpve */
        16: .line 151
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;Ljava/lang/Throwable;)V
            athrow
        end local 9 // java.security.cert.CertPathValidatorException cpve
        17: .line 157
      StackMap locals:
      StackMap stack:
            new java.security.cert.TrustAnchor
            dup
            aload 8 /* anchorCert */
            aconst_null
            invokespecial java.security.cert.TrustAnchor.<init>:(Ljava/security/cert/X509Certificate;[B)V
            astore 9 /* anchor */
        start local 9 // java.security.cert.TrustAnchor anchor
        18: .line 159
            new sun.security.provider.certpath.AlgorithmChecker
            dup
            aload 9 /* anchor */
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            invokespecial sun.security.provider.certpath.AlgorithmChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/lang/String;)V
        19: .line 158
            astore 10 /* defaultAlgChecker */
        start local 10 // sun.security.provider.certpath.AlgorithmChecker defaultAlgChecker
        20: .line 162
            aconst_null
            astore 11 /* appAlgChecker */
        start local 11 // sun.security.provider.certpath.AlgorithmChecker appAlgChecker
        21: .line 163
            aload 4 /* constraints */
            ifnull 25
        22: .line 164
            new sun.security.provider.certpath.AlgorithmChecker
            dup
            aload 9 /* anchor */
            aload 4 /* constraints */
            aconst_null
        23: .line 165
            aconst_null
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
        24: .line 164
            invokespecial sun.security.provider.certpath.AlgorithmChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/security/AlgorithmConstraints;Ljava/util/Date;Ljava/security/Timestamp;Ljava/lang/String;)V
            astore 11 /* appAlgChecker */
        25: .line 170
      StackMap locals: java.security.cert.TrustAnchor sun.security.provider.certpath.AlgorithmChecker sun.security.provider.certpath.AlgorithmChecker
      StackMap stack:
            aload 1 /* chain */
            arraylength
            iconst_1
            isub
            istore 12 /* maxPathLength */
        start local 12 // int maxPathLength
        26: .line 171
            aload 1 /* chain */
            arraylength
            iconst_2
            isub
            istore 13 /* i */
        start local 13 // int i
        27: goto 64
        28: .line 172
      StackMap locals: int int
      StackMap stack:
            aload 1 /* chain */
            iload 13 /* i */
            iconst_1
            iadd
            aaload
            astore 14 /* issuerCert */
        start local 14 // java.security.cert.X509Certificate issuerCert
        29: .line 173
            aload 1 /* chain */
            iload 13 /* i */
            aaload
            astore 15 /* cert */
        start local 15 // java.security.cert.X509Certificate cert
        30: .line 179
            aload 7 /* untrustedChecker */
            aload 15 /* cert */
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            invokevirtual sun.security.provider.certpath.UntrustedChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
        31: .line 180
            goto 37
      StackMap locals: sun.security.validator.SimpleValidator java.security.cert.X509Certificate[] java.util.Collection java.util.List java.security.AlgorithmConstraints java.lang.Object java.util.Date sun.security.provider.certpath.UntrustedChecker java.security.cert.X509Certificate java.security.cert.TrustAnchor sun.security.provider.certpath.AlgorithmChecker sun.security.provider.certpath.AlgorithmChecker int int java.security.cert.X509Certificate java.security.cert.X509Certificate
      StackMap stack: java.security.cert.CertPathValidatorException
        32: astore 16 /* cpve */
        start local 16 // java.security.cert.CertPathValidatorException cpve
        33: .line 181
            new sun.security.validator.ValidatorException
            dup
        34: .line 182
            new java.lang.StringBuilder
            dup
            ldc "Untrusted certificate: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        35: .line 183
            getstatic sun.security.validator.ValidatorException.T_UNTRUSTED_CERT:Ljava/lang/Object;
            aload 15 /* cert */
            aload 16 /* cpve */
        36: .line 181
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;Ljava/lang/Throwable;)V
            athrow
        end local 16 // java.security.cert.CertPathValidatorException cpve
        37: .line 190
      StackMap locals:
      StackMap stack:
            aload 10 /* defaultAlgChecker */
            aload 15 /* cert */
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            invokevirtual sun.security.provider.certpath.AlgorithmChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
        38: .line 191
            aload 11 /* appAlgChecker */
            ifnull 45
        39: .line 192
            aload 11 /* appAlgChecker */
            aload 15 /* cert */
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            invokevirtual sun.security.provider.certpath.AlgorithmChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
        40: .line 194
            goto 45
      StackMap locals:
      StackMap stack: java.security.cert.CertPathValidatorException
        41: astore 16 /* cpve */
        start local 16 // java.security.cert.CertPathValidatorException cpve
        42: .line 195
            new sun.security.validator.ValidatorException
            dup
        43: .line 196
            getstatic sun.security.validator.ValidatorException.T_ALGORITHM_DISABLED:Ljava/lang/Object;
            aload 15 /* cert */
            aload 16 /* cpve */
        44: .line 195
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/Object;Ljava/security/cert/X509Certificate;Ljava/lang/Throwable;)V
            athrow
        end local 16 // java.security.cert.CertPathValidatorException cpve
        45: .line 200
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            ldc "code signing"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 48
        46: .line 201
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            ldc "jce signing"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 48
        47: .line 202
            aload 15 /* cert */
            aload 6 /* date */
            invokevirtual java.security.cert.X509Certificate.checkValidity:(Ljava/util/Date;)V
        48: .line 206
      StackMap locals:
      StackMap stack:
            aload 15 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
        49: .line 207
            aload 14 /* issuerCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
        50: .line 206
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
        51: .line 207
            ifne 55
        52: .line 208
            new sun.security.validator.ValidatorException
            dup
        53: .line 209
            getstatic sun.security.validator.ValidatorException.T_NAME_CHAINING:Ljava/lang/Object;
            aload 15 /* cert */
        54: .line 208
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/Object;Ljava/security/cert/X509Certificate;)V
            athrow
        55: .line 214
      StackMap locals:
      StackMap stack:
            aload 15 /* cert */
            aload 14 /* issuerCert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            invokevirtual java.security.cert.X509Certificate.verify:(Ljava/security/PublicKey;)V
        56: .line 215
            goto 61
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
        57: astore 16 /* e */
        start local 16 // java.security.GeneralSecurityException e
        58: .line 216
            new sun.security.validator.ValidatorException
            dup
        59: .line 217
            getstatic sun.security.validator.ValidatorException.T_SIGNATURE_ERROR:Ljava/lang/Object;
            aload 15 /* cert */
            aload 16 /* e */
        60: .line 216
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/Object;Ljava/security/cert/X509Certificate;Ljava/lang/Throwable;)V
            athrow
        end local 16 // java.security.GeneralSecurityException e
        61: .line 221
      StackMap locals:
      StackMap stack:
            iload 13 /* i */
            ifeq 63
        62: .line 222
            aload 0 /* this */
            aload 15 /* cert */
            iload 12 /* maxPathLength */
            invokevirtual sun.security.validator.SimpleValidator.checkExtensions:(Ljava/security/cert/X509Certificate;I)I
            istore 12 /* maxPathLength */
        end local 15 // java.security.cert.X509Certificate cert
        end local 14 // java.security.cert.X509Certificate issuerCert
        63: .line 171
      StackMap locals:
      StackMap stack:
            iinc 13 /* i */ -1
      StackMap locals:
      StackMap stack:
        64: iload 13 /* i */
            ifge 28
        end local 13 // int i
        65: .line 226
            aload 1 /* chain */
            areturn
        end local 12 // int maxPathLength
        end local 11 // sun.security.provider.certpath.AlgorithmChecker appAlgChecker
        end local 10 // sun.security.provider.certpath.AlgorithmChecker defaultAlgChecker
        end local 9 // java.security.cert.TrustAnchor anchor
        end local 8 // java.security.cert.X509Certificate anchorCert
        end local 7 // sun.security.provider.certpath.UntrustedChecker untrustedChecker
        end local 6 // java.util.Date date
        end local 5 // java.lang.Object parameter
        end local 4 // java.security.AlgorithmConstraints constraints
        end local 3 // java.util.List responseList
        end local 2 // java.util.Collection otherCerts
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   66     0               this  Lsun/security/validator/SimpleValidator;
            0   66     1              chain  [Ljava/security/cert/X509Certificate;
            0   66     2         otherCerts  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            0   66     3       responseList  Ljava/util/List<[B>;
            0   66     4        constraints  Ljava/security/AlgorithmConstraints;
            0   66     5          parameter  Ljava/lang/Object;
            6   66     6               date  Ljava/util/Date;
            9   66     7   untrustedChecker  Lsun/security/provider/certpath/UntrustedChecker;
           10   66     8         anchorCert  Ljava/security/cert/X509Certificate;
           13   17     9               cpve  Ljava/security/cert/CertPathValidatorException;
           18   66     9             anchor  Ljava/security/cert/TrustAnchor;
           20   66    10  defaultAlgChecker  Lsun/security/provider/certpath/AlgorithmChecker;
           21   66    11      appAlgChecker  Lsun/security/provider/certpath/AlgorithmChecker;
           26   66    12      maxPathLength  I
           27   65    13                  i  I
           29   63    14         issuerCert  Ljava/security/cert/X509Certificate;
           30   63    15               cert  Ljava/security/cert/X509Certificate;
           33   37    16               cpve  Ljava/security/cert/CertPathValidatorException;
           42   45    16               cpve  Ljava/security/cert/CertPathValidatorException;
           58   61    16                  e  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
          10    11      12  Class java.security.cert.CertPathValidatorException
          30    31      32  Class java.security.cert.CertPathValidatorException
          37    40      41  Class java.security.cert.CertPathValidatorException
          55    56      57  Class java.security.GeneralSecurityException
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: ([Ljava/security/cert/X509Certificate;Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;Ljava/util/List<[B>;Ljava/security/AlgorithmConstraints;Ljava/lang/Object;)[Ljava/security/cert/X509Certificate;
    MethodParameters:
              Name  Flags
      chain         
      otherCerts    
      responseList  
      constraints   
      parameter     

  private int checkExtensions(java.security.cert.X509Certificate, int);
    descriptor: (Ljava/security/cert/X509Certificate;I)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // int maxPathLen
         0: .line 231
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getCriticalExtensionOIDs:()Ljava/util/Set;
            astore 3 /* critSet */
        start local 3 // java.util.Set critSet
         1: .line 232
            aload 3 /* critSet */
            ifnonnull 3
         2: .line 233
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 3 /* critSet */
         3: .line 238
      StackMap locals: java.util.Set
      StackMap stack:
            aload 0 /* this */
            aload 1 /* cert */
            aload 3 /* critSet */
            iload 2 /* maxPathLen */
            invokevirtual sun.security.validator.SimpleValidator.checkBasicConstraints:(Ljava/security/cert/X509Certificate;Ljava/util/Set;I)I
         4: .line 237
            istore 4 /* pathLenConstraint */
        start local 4 // int pathLenConstraint
         5: .line 241
            aload 0 /* this */
            aload 1 /* cert */
            aload 3 /* critSet */
            invokevirtual sun.security.validator.SimpleValidator.checkKeyUsage:(Ljava/security/cert/X509Certificate;Ljava/util/Set;)V
         6: .line 244
            aload 0 /* this */
            aload 1 /* cert */
            aload 3 /* critSet */
            invokevirtual sun.security.validator.SimpleValidator.checkNetscapeCertType:(Ljava/security/cert/X509Certificate;Ljava/util/Set;)V
         7: .line 246
            aload 3 /* critSet */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 12
         8: .line 247
            new sun.security.validator.ValidatorException
            dup
         9: .line 248
            new java.lang.StringBuilder
            dup
            ldc "Certificate contains unknown critical extensions: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* critSet */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 249
            getstatic sun.security.validator.ValidatorException.T_CA_EXTENSIONS:Ljava/lang/Object;
            aload 1 /* cert */
        11: .line 247
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;)V
            athrow
        12: .line 252
      StackMap locals: int
      StackMap stack:
            iload 4 /* pathLenConstraint */
            ireturn
        end local 4 // int pathLenConstraint
        end local 3 // java.util.Set critSet
        end local 2 // int maxPathLen
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   13     0               this  Lsun/security/validator/SimpleValidator;
            0   13     1               cert  Ljava/security/cert/X509Certificate;
            0   13     2         maxPathLen  I
            1   13     3            critSet  Ljava/util/Set<Ljava/lang/String;>;
            5   13     4  pathLenConstraint  I
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
            Name  Flags
      cert        
      maxPathLen  

  private void checkNetscapeCertType(java.security.cert.X509Certificate, java.util.Set<java.lang.String>);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.util.Set critSet
         0: .line 257
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            ldc "generic"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 20
         1: .line 259
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            ldc "tls client"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 3
         2: .line 260
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            ldc "tls server"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 10
         3: .line 261
      StackMap locals:
      StackMap stack:
            aload 1 /* cert */
            ldc "ssl_ca"
            invokestatic sun.security.validator.SimpleValidator.getNetscapeCertTypeBit:(Ljava/security/cert/X509Certificate;Ljava/lang/String;)Z
            ifne 8
         4: .line 262
            new sun.security.validator.ValidatorException
            dup
         5: .line 263
            ldc "Invalid Netscape CertType extension for SSL CA certificate"
         6: .line 265
            getstatic sun.security.validator.ValidatorException.T_CA_EXTENSIONS:Ljava/lang/Object;
            aload 1 /* cert */
         7: .line 262
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;)V
            athrow
         8: .line 267
      StackMap locals:
      StackMap stack:
            aload 2 /* critSet */
            ldc "2.16.840.1.113730.1.1"
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         9: .line 268
            goto 20
      StackMap locals:
      StackMap stack:
        10: aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            ldc "code signing"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 12
        11: .line 269
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            ldc "jce signing"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 19
        12: .line 270
      StackMap locals:
      StackMap stack:
            aload 1 /* cert */
            ldc "object_signing_ca"
            invokestatic sun.security.validator.SimpleValidator.getNetscapeCertTypeBit:(Ljava/security/cert/X509Certificate;Ljava/lang/String;)Z
            ifne 17
        13: .line 271
            new sun.security.validator.ValidatorException
            dup
        14: .line 272
            ldc "Invalid Netscape CertType extension for code signing CA certificate"
        15: .line 274
            getstatic sun.security.validator.ValidatorException.T_CA_EXTENSIONS:Ljava/lang/Object;
            aload 1 /* cert */
        16: .line 271
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;)V
            athrow
        17: .line 276
      StackMap locals:
      StackMap stack:
            aload 2 /* critSet */
            ldc "2.16.840.1.113730.1.1"
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        18: .line 277
            goto 20
        19: .line 278
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown variant "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.variant:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 280
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.Set critSet
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   21     0     this  Lsun/security/validator/SimpleValidator;
            0   21     1     cert  Ljava/security/cert/X509Certificate;
            0   21     2  critSet  Ljava/util/Set<Ljava/lang/String;>;
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Ljava/security/cert/X509Certificate;Ljava/util/Set<Ljava/lang/String;>;)V
    MethodParameters:
         Name  Flags
      cert     
      critSet  

  static boolean getNetscapeCertTypeBit(java.security.cert.X509Certificate, java.lang.String);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/lang/String;)Z
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // java.security.cert.X509Certificate cert
        start local 1 // java.lang.String type
         0: .line 289
            aload 0 /* cert */
            instanceof sun.security.x509.X509CertImpl
            ifeq 6
         1: .line 290
            aload 0 /* cert */
            checkcast sun.security.x509.X509CertImpl
            astore 3 /* certImpl */
        start local 3 // sun.security.x509.X509CertImpl certImpl
         2: .line 291
            getstatic sun.security.validator.SimpleValidator.OBJID_NETSCAPE_CERT_TYPE:Lsun/security/util/ObjectIdentifier;
            astore 4 /* oid */
        start local 4 // sun.security.util.ObjectIdentifier oid
         3: .line 292
            aload 3 /* certImpl */
            aload 4 /* oid */
            invokevirtual sun.security.x509.X509CertImpl.getExtension:(Lsun/security/util/ObjectIdentifier;)Lsun/security/x509/Extension;
            checkcast sun.security.x509.NetscapeCertTypeExtension
            astore 2 /* ext */
        start local 2 // sun.security.x509.NetscapeCertTypeExtension ext
         4: .line 293
            aload 2 /* ext */
            ifnonnull 15
         5: .line 294
            iconst_1
            ireturn
        end local 4 // sun.security.util.ObjectIdentifier oid
        end local 3 // sun.security.x509.X509CertImpl certImpl
        end local 2 // sun.security.x509.NetscapeCertTypeExtension ext
         6: .line 297
      StackMap locals:
      StackMap stack:
            aload 0 /* cert */
            ldc "2.16.840.1.113730.1.1"
            invokevirtual java.security.cert.X509Certificate.getExtensionValue:(Ljava/lang/String;)[B
            astore 3 /* extVal */
        start local 3 // byte[] extVal
         7: .line 298
            aload 3 /* extVal */
            ifnonnull 9
         8: .line 299
            iconst_1
            ireturn
         9: .line 301
      StackMap locals: java.security.cert.X509Certificate java.lang.String top byte[]
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 3 /* extVal */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 4 /* in */
        start local 4 // sun.security.util.DerInputStream in
        10: .line 302
            aload 4 /* in */
            invokevirtual sun.security.util.DerInputStream.getOctetString:()[B
            astore 5 /* encoded */
        start local 5 // byte[] encoded
        11: .line 303
            new sun.security.util.DerValue
            dup
            aload 5 /* encoded */
            invokespecial sun.security.util.DerValue.<init>:([B)V
            invokevirtual sun.security.util.DerValue.getUnalignedBitString:()Lsun/security/util/BitArray;
        12: .line 304
            invokevirtual sun.security.util.BitArray.toByteArray:()[B
        13: .line 303
            astore 5 /* encoded */
        14: .line 305
            new sun.security.x509.NetscapeCertTypeExtension
            dup
            aload 5 /* encoded */
            invokespecial sun.security.x509.NetscapeCertTypeExtension.<init>:([B)V
            astore 2 /* ext */
        end local 5 // byte[] encoded
        end local 4 // sun.security.util.DerInputStream in
        end local 3 // byte[] extVal
        start local 2 // sun.security.x509.NetscapeCertTypeExtension ext
        15: .line 307
      StackMap locals: java.security.cert.X509Certificate java.lang.String sun.security.x509.NetscapeCertTypeExtension
      StackMap stack:
            aload 2 /* ext */
            aload 1 /* type */
            invokevirtual sun.security.x509.NetscapeCertTypeExtension.get:(Ljava/lang/String;)Ljava/lang/Boolean;
            astore 3 /* val */
        start local 3 // java.lang.Boolean val
        16: .line 308
            aload 3 /* val */
            invokevirtual java.lang.Boolean.booleanValue:()Z
        17: ireturn
        end local 3 // java.lang.Boolean val
        end local 2 // sun.security.x509.NetscapeCertTypeExtension ext
        18: .line 309
      StackMap locals: java.security.cert.X509Certificate java.lang.String
      StackMap stack: java.io.IOException
            pop
        19: .line 310
            iconst_0
            ireturn
        end local 1 // java.lang.String type
        end local 0 // java.security.cert.X509Certificate cert
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   20     0      cert  Ljava/security/cert/X509Certificate;
            0   20     1      type  Ljava/lang/String;
            4    6     2       ext  Lsun/security/x509/NetscapeCertTypeExtension;
           15   18     2       ext  Lsun/security/x509/NetscapeCertTypeExtension;
            2    6     3  certImpl  Lsun/security/x509/X509CertImpl;
            3    6     4       oid  Lsun/security/util/ObjectIdentifier;
            7   15     3    extVal  [B
           10   15     4        in  Lsun/security/util/DerInputStream;
           11   15     5   encoded  [B
           16   18     3       val  Ljava/lang/Boolean;
      Exception table:
        from    to  target  type
           0     5      18  Class java.io.IOException
           6     8      18  Class java.io.IOException
           9    17      18  Class java.io.IOException
    MethodParameters:
      Name  Flags
      cert  
      type  

  private int checkBasicConstraints(java.security.cert.X509Certificate, java.util.Set<java.lang.String>, );
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/util/Set;I)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.util.Set critSet
        start local 3 // int maxPathLen
         0: .line 317
            aload 2 /* critSet */
            ldc "2.5.29.19"
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         1: .line 318
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getBasicConstraints:()I
            istore 4 /* constraints */
        start local 4 // int constraints
         2: .line 320
            iload 4 /* constraints */
            ifge 6
         3: .line 321
            new sun.security.validator.ValidatorException
            dup
            ldc "End user tried to act as a CA"
         4: .line 322
            getstatic sun.security.validator.ValidatorException.T_CA_EXTENSIONS:Ljava/lang/Object;
            aload 1 /* cert */
         5: .line 321
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;)V
            athrow
         6: .line 327
      StackMap locals: int
      StackMap stack:
            aload 1 /* cert */
            invokestatic sun.security.x509.X509CertImpl.isSelfIssued:(Ljava/security/cert/X509Certificate;)Z
            ifne 12
         7: .line 328
            iload 3 /* maxPathLen */
            ifgt 11
         8: .line 329
            new sun.security.validator.ValidatorException
            dup
            ldc "Violated path length constraints"
         9: .line 330
            getstatic sun.security.validator.ValidatorException.T_CA_EXTENSIONS:Ljava/lang/Object;
            aload 1 /* cert */
        10: .line 329
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;)V
            athrow
        11: .line 333
      StackMap locals:
      StackMap stack:
            iinc 3 /* maxPathLen */ -1
        12: .line 336
      StackMap locals:
      StackMap stack:
            iload 3 /* maxPathLen */
            iload 4 /* constraints */
            if_icmple 14
        13: .line 337
            iload 4 /* constraints */
            istore 3 /* maxPathLen */
        14: .line 340
      StackMap locals:
      StackMap stack:
            iload 3 /* maxPathLen */
            ireturn
        end local 4 // int constraints
        end local 3 // int maxPathLen
        end local 2 // java.util.Set critSet
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   15     0         this  Lsun/security/validator/SimpleValidator;
            0   15     1         cert  Ljava/security/cert/X509Certificate;
            0   15     2      critSet  Ljava/util/Set<Ljava/lang/String;>;
            0   15     3   maxPathLen  I
            2   15     4  constraints  I
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Ljava/security/cert/X509Certificate;Ljava/util/Set<Ljava/lang/String;>;I)I
    MethodParameters:
            Name  Flags
      cert        
      critSet     
      maxPathLen  

  private void checkKeyUsage(java.security.cert.X509Certificate, java.util.Set<java.lang.String>);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.util.Set critSet
         0: .line 350
            aload 2 /* critSet */
            ldc "2.5.29.15"
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         1: .line 352
            aload 2 /* critSet */
            ldc "2.5.29.37"
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         2: .line 355
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getKeyUsage:()[Z
            astore 3 /* keyUsageInfo */
        start local 3 // boolean[] keyUsageInfo
         3: .line 356
            aload 3 /* keyUsageInfo */
            ifnull 9
         4: .line 358
            aload 3 /* keyUsageInfo */
            arraylength
            bipush 6
            if_icmplt 5
            aload 3 /* keyUsageInfo */
            iconst_5
            baload
            ifne 9
         5: .line 359
      StackMap locals: boolean[]
      StackMap stack:
            new sun.security.validator.ValidatorException
            dup
         6: .line 360
            ldc "Wrong key usage: expected keyCertSign"
         7: .line 361
            getstatic sun.security.validator.ValidatorException.T_CA_EXTENSIONS:Ljava/lang/Object;
            aload 1 /* cert */
         8: .line 359
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/security/cert/X509Certificate;)V
            athrow
         9: .line 364
      StackMap locals:
      StackMap stack:
            return
        end local 3 // boolean[] keyUsageInfo
        end local 2 // java.util.Set critSet
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   10     0          this  Lsun/security/validator/SimpleValidator;
            0   10     1          cert  Ljava/security/cert/X509Certificate;
            0   10     2       critSet  Ljava/util/Set<Ljava/lang/String;>;
            3   10     3  keyUsageInfo  [Z
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Ljava/security/cert/X509Certificate;Ljava/util/Set<Ljava/lang/String;>;)V
    MethodParameters:
         Name  Flags
      cert     
      critSet  

  private java.security.cert.X509Certificate[] buildTrustedChain(java.security.cert.X509Certificate[]);
    descriptor: ([Ljava/security/cert/X509Certificate;)[Ljava/security/cert/X509Certificate;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=12, args_size=2
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.security.cert.X509Certificate[] chain
         0: .line 373
            new java.util.ArrayList
            dup
            aload 1 /* chain */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 2 /* c */
        start local 2 // java.util.List c
         1: .line 376
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         2: goto 10
         3: .line 377
      StackMap locals: java.util.List int
      StackMap stack:
            aload 1 /* chain */
            iload 3 /* i */
            aaload
            astore 4 /* cert */
        start local 4 // java.security.cert.X509Certificate cert
         4: .line 378
            aload 0 /* this */
            aload 4 /* cert */
            invokevirtual sun.security.validator.SimpleValidator.getTrustedCertificate:(Ljava/security/cert/X509Certificate;)Ljava/security/cert/X509Certificate;
            astore 5 /* trustedCert */
        start local 5 // java.security.cert.X509Certificate trustedCert
         5: .line 379
            aload 5 /* trustedCert */
            ifnull 8
         6: .line 380
            aload 2 /* c */
            aload 5 /* trustedCert */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         7: .line 381
            aload 2 /* c */
            getstatic sun.security.validator.SimpleValidator.CHAIN0:[Ljava/security/cert/X509Certificate;
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate[]
            areturn
         8: .line 383
      StackMap locals: java.security.cert.X509Certificate java.security.cert.X509Certificate
      StackMap stack:
            aload 2 /* c */
            aload 4 /* cert */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 5 // java.security.cert.X509Certificate trustedCert
        end local 4 // java.security.cert.X509Certificate cert
         9: .line 376
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        10: iload 3 /* i */
            aload 1 /* chain */
            arraylength
            if_icmplt 3
        end local 3 // int i
        11: .line 387
            aload 1 /* chain */
            aload 1 /* chain */
            arraylength
            iconst_1
            isub
            aaload
            astore 3 /* cert */
        start local 3 // java.security.cert.X509Certificate cert
        12: .line 388
            aload 3 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            pop
        13: .line 389
            aload 3 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 4 /* issuer */
        start local 4 // javax.security.auth.x500.X500Principal issuer
        14: .line 390
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.trustedX500Principals:Ljava/util/Map;
            aload 4 /* issuer */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.List
            astore 5 /* list */
        start local 5 // java.util.List list
        15: .line 391
            aload 5 /* list */
            ifnull 29
        16: .line 392
            aload 5 /* list */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 6 /* matchedCert */
        start local 6 // java.security.cert.X509Certificate matchedCert
        17: .line 393
            aload 3 /* cert */
            invokestatic sun.security.x509.X509CertImpl.toImpl:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            astore 7 /* certImpl */
        start local 7 // sun.security.x509.X509CertImpl certImpl
        18: .line 394
            aload 7 /* certImpl */
            invokevirtual sun.security.x509.X509CertImpl.getAuthKeyId:()Lsun/security/x509/KeyIdentifier;
            astore 8 /* akid */
        start local 8 // sun.security.x509.KeyIdentifier akid
        19: .line 395
            aload 8 /* akid */
            ifnull 27
        20: .line 396
            aload 5 /* list */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 10
            goto 26
      StackMap locals: sun.security.validator.SimpleValidator java.security.cert.X509Certificate[] java.util.List java.security.cert.X509Certificate javax.security.auth.x500.X500Principal java.util.List java.security.cert.X509Certificate sun.security.x509.X509CertImpl sun.security.x509.KeyIdentifier top java.util.Iterator
      StackMap stack:
        21: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 9 /* sup */
        start local 9 // java.security.cert.X509Certificate sup
        22: .line 398
            aload 9 /* sup */
            invokestatic sun.security.x509.X509CertImpl.toImpl:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            astore 11 /* supCert */
        start local 11 // sun.security.x509.X509CertImpl supCert
        23: .line 399
            aload 8 /* akid */
            aload 11 /* supCert */
            invokevirtual sun.security.x509.X509CertImpl.getSubjectKeyId:()Lsun/security/x509/KeyIdentifier;
            invokevirtual sun.security.x509.KeyIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 26
        24: .line 400
            aload 9 /* sup */
            astore 6 /* matchedCert */
        25: .line 401
            goto 27
        end local 11 // sun.security.x509.X509CertImpl supCert
        end local 9 // java.security.cert.X509Certificate sup
        26: .line 396
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 21
        27: .line 406
      StackMap locals: sun.security.validator.SimpleValidator java.security.cert.X509Certificate[] java.util.List java.security.cert.X509Certificate javax.security.auth.x500.X500Principal java.util.List java.security.cert.X509Certificate sun.security.x509.X509CertImpl sun.security.x509.KeyIdentifier
      StackMap stack:
            aload 2 /* c */
            aload 6 /* matchedCert */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        28: .line 407
            aload 2 /* c */
            getstatic sun.security.validator.SimpleValidator.CHAIN0:[Ljava/security/cert/X509Certificate;
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate[]
            areturn
        end local 8 // sun.security.x509.KeyIdentifier akid
        end local 7 // sun.security.x509.X509CertImpl certImpl
        end local 6 // java.security.cert.X509Certificate matchedCert
        29: .line 411
      StackMap locals:
      StackMap stack:
            new sun.security.validator.ValidatorException
            dup
            getstatic sun.security.validator.ValidatorException.T_NO_TRUST_ANCHOR:Ljava/lang/Object;
            invokespecial sun.security.validator.ValidatorException.<init>:(Ljava/lang/Object;)V
            athrow
        end local 5 // java.util.List list
        end local 4 // javax.security.auth.x500.X500Principal issuer
        end local 3 // java.security.cert.X509Certificate cert
        end local 2 // java.util.List c
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   30     0         this  Lsun/security/validator/SimpleValidator;
            0   30     1        chain  [Ljava/security/cert/X509Certificate;
            1   30     2            c  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
            2   11     3            i  I
            4    9     4         cert  Ljava/security/cert/X509Certificate;
            5    9     5  trustedCert  Ljava/security/cert/X509Certificate;
           12   30     3         cert  Ljava/security/cert/X509Certificate;
           14   30     4       issuer  Ljavax/security/auth/x500/X500Principal;
           15   30     5         list  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
           17   29     6  matchedCert  Ljava/security/cert/X509Certificate;
           18   29     7     certImpl  Lsun/security/x509/X509CertImpl;
           19   29     8         akid  Lsun/security/x509/KeyIdentifier;
           22   26     9          sup  Ljava/security/cert/X509Certificate;
           23   26    11      supCert  Lsun/security/x509/X509CertImpl;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
       Name  Flags
      chain  

  private java.security.cert.X509Certificate getTrustedCertificate(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)Ljava/security/cert/X509Certificate;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=8, args_size=2
        start local 0 // sun.security.validator.SimpleValidator this
        start local 1 // java.security.cert.X509Certificate cert
         0: .line 421
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 2 /* certSubjectName */
        start local 2 // java.security.Principal certSubjectName
         1: .line 422
            aload 0 /* this */
            getfield sun.security.validator.SimpleValidator.trustedX500Principals:Ljava/util/Map;
            aload 2 /* certSubjectName */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.List
            astore 3 /* list */
        start local 3 // java.util.List list
         2: .line 423
            aload 3 /* list */
            ifnonnull 4
         3: .line 424
            aconst_null
            areturn
         4: .line 427
      StackMap locals: java.security.Principal java.util.List
      StackMap stack:
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 4 /* certIssuerName */
        start local 4 // java.security.Principal certIssuerName
         5: .line 428
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 5 /* certPublicKey */
        start local 5 // java.security.PublicKey certPublicKey
         6: .line 430
            aload 3 /* list */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 15
      StackMap locals: sun.security.validator.SimpleValidator java.security.cert.X509Certificate java.security.Principal java.util.List java.security.Principal java.security.PublicKey top java.util.Iterator
      StackMap stack:
         7: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 6 /* mycert */
        start local 6 // java.security.cert.X509Certificate mycert
         8: .line 431
            aload 6 /* mycert */
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 10
         9: .line 432
            aload 1 /* cert */
            areturn
        10: .line 434
      StackMap locals: sun.security.validator.SimpleValidator java.security.cert.X509Certificate java.security.Principal java.util.List java.security.Principal java.security.PublicKey java.security.cert.X509Certificate java.util.Iterator
      StackMap stack:
            aload 6 /* mycert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            aload 4 /* certIssuerName */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 12
        11: .line 435
            goto 15
        12: .line 437
      StackMap locals:
      StackMap stack:
            aload 6 /* mycert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            aload 5 /* certPublicKey */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifne 14
        13: .line 438
            goto 15
        14: .line 442
      StackMap locals:
      StackMap stack:
            aload 6 /* mycert */
            areturn
        end local 6 // java.security.cert.X509Certificate mycert
        15: .line 430
      StackMap locals: sun.security.validator.SimpleValidator java.security.cert.X509Certificate java.security.Principal java.util.List java.security.Principal java.security.PublicKey top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        16: .line 444
            aconst_null
            areturn
        end local 5 // java.security.PublicKey certPublicKey
        end local 4 // java.security.Principal certIssuerName
        end local 3 // java.util.List list
        end local 2 // java.security.Principal certSubjectName
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.validator.SimpleValidator this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   17     0             this  Lsun/security/validator/SimpleValidator;
            0   17     1             cert  Ljava/security/cert/X509Certificate;
            1   17     2  certSubjectName  Ljava/security/Principal;
            2   17     3             list  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
            5   17     4   certIssuerName  Ljava/security/Principal;
            6   17     5    certPublicKey  Ljava/security/PublicKey;
            8   15     6           mycert  Ljava/security/cert/X509Certificate;
    MethodParameters:
      Name  Flags
      cert  
}
SourceFile: "SimpleValidator.java"