final class sun.security.ssl.X509TrustManagerImpl extends javax.net.ssl.X509ExtendedTrustManager implements javax.net.ssl.X509TrustManager
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.X509TrustManagerImpl
  super_class: javax.net.ssl.X509ExtendedTrustManager
{
  private final java.lang.String validatorType;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  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;>;

  private final java.security.cert.PKIXBuilderParameters pkixParams;
    descriptor: Ljava/security/cert/PKIXBuilderParameters;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile sun.security.validator.Validator clientValidator;
    descriptor: Lsun/security/validator/Validator;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile sun.security.validator.Validator serverValidator;
    descriptor: Lsun/security/validator/Validator;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private static final sun.security.ssl.Debug debug;
    descriptor: Lsun/security/ssl/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 71
            ldc "ssl"
            invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
            putstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.lang.String, java.security.KeyStore);
    descriptor: (Ljava/lang/String;Ljava/security/KeyStore;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.lang.String validatorType
        start local 2 // java.security.KeyStore ks
         0: .line 73
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedTrustManager.<init>:()V
         1: .line 75
            aload 0 /* this */
            aload 1 /* validatorType */
            putfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
         2: .line 76
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
         3: .line 77
            aload 2 /* ks */
            ifnonnull 6
         4: .line 78
            aload 0 /* this */
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            putfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
         5: .line 79
            goto 7
         6: .line 80
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.lang.String java.security.KeyStore
      StackMap stack:
            aload 0 /* this */
            aload 2 /* ks */
            invokestatic sun.security.validator.KeyStores.getTrustedCerts:(Ljava/security/KeyStore;)Ljava/util/Set;
            putfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
         7: .line 82
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.X509TrustManagerImpl.showTrustedCerts:()V
         8: .line 83
            return
        end local 2 // java.security.KeyStore ks
        end local 1 // java.lang.String validatorType
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/ssl/X509TrustManagerImpl;
            0    9     1  validatorType  Ljava/lang/String;
            0    9     2             ks  Ljava/security/KeyStore;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
               Name  Flags
      validatorType  
      ks             

  void <init>(java.lang.String, java.security.cert.PKIXBuilderParameters);
    descriptor: (Ljava/lang/String;Ljava/security/cert/PKIXBuilderParameters;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.lang.String validatorType
        start local 2 // java.security.cert.PKIXBuilderParameters params
         0: .line 85
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedTrustManager.<init>:()V
         1: .line 86
            aload 0 /* this */
            aload 1 /* validatorType */
            putfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
         2: .line 87
            aload 0 /* this */
            aload 2 /* params */
            putfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
         3: .line 92
            aload 0 /* this */
            ldc "tls server"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 3 /* v */
        start local 3 // sun.security.validator.Validator v
         4: .line 93
            aload 0 /* this */
            aload 3 /* v */
            invokevirtual sun.security.validator.Validator.getTrustedCertificates:()Ljava/util/Collection;
            putfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
         5: .line 94
            aload 0 /* this */
            aload 3 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
         6: .line 95
            aload 0 /* this */
            invokevirtual sun.security.ssl.X509TrustManagerImpl.showTrustedCerts:()V
         7: .line 96
            return
        end local 3 // sun.security.validator.Validator v
        end local 2 // java.security.cert.PKIXBuilderParameters params
        end local 1 // java.lang.String validatorType
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    8     0           this  Lsun/security/ssl/X509TrustManagerImpl;
            0    8     1  validatorType  Ljava/lang/String;
            0    8     2         params  Ljava/security/cert/PKIXBuilderParameters;
            4    8     3              v  Lsun/security/validator/Validator;
    MethodParameters:
               Name  Flags
      validatorType  
      params         

  public void checkClientTrusted(java.security.cert.X509Certificate[], java.lang.String);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
         0: .line 101
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            aconst_null
            iconst_1
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrusted:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/net/Socket;Z)V
         1: .line 102
            return
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  

  public void checkServerTrusted(java.security.cert.X509Certificate[], java.lang.String);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
         0: .line 107
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            aconst_null
            iconst_0
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrusted:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/net/Socket;Z)V
         1: .line 108
            return
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  

  public java.security.cert.X509Certificate[] getAcceptedIssuers();
    descriptor: ()[Ljava/security/cert/X509Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
         0: .line 112
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
            invokeinterface java.util.Collection.size:()I
            anewarray java.security.cert.X509Certificate
            astore 1 /* certsArray */
        start local 1 // java.security.cert.X509Certificate[] certsArray
         1: .line 113
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
            aload 1 /* certsArray */
            invokeinterface java.util.Collection.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            pop
         2: .line 114
            aload 1 /* certsArray */
            areturn
        end local 1 // java.security.cert.X509Certificate[] certsArray
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lsun/security/ssl/X509TrustManagerImpl;
            1    3     1  certsArray  [Ljava/security/cert/X509Certificate;

  public void checkClientTrusted(java.security.cert.X509Certificate[], java.lang.String, java.net.Socket);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/net/Socket;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
        start local 3 // java.net.Socket socket
         0: .line 120
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            aload 3 /* socket */
            iconst_1
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrusted:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/net/Socket;Z)V
         1: .line 121
            return
        end local 3 // java.net.Socket socket
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
            0    2     3    socket  Ljava/net/Socket;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      socket    

  public void checkServerTrusted(java.security.cert.X509Certificate[], java.lang.String, java.net.Socket);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/net/Socket;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
        start local 3 // java.net.Socket socket
         0: .line 126
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            aload 3 /* socket */
            iconst_0
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrusted:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/net/Socket;Z)V
         1: .line 127
            return
        end local 3 // java.net.Socket socket
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
            0    2     3    socket  Ljava/net/Socket;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      socket    

  public void checkClientTrusted(java.security.cert.X509Certificate[], java.lang.String, javax.net.ssl.SSLEngine);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljavax/net/ssl/SSLEngine;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
        start local 3 // javax.net.ssl.SSLEngine engine
         0: .line 132
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            aload 3 /* engine */
            iconst_1
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrusted:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljavax/net/ssl/SSLEngine;Z)V
         1: .line 133
            return
        end local 3 // javax.net.ssl.SSLEngine engine
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
            0    2     3    engine  Ljavax/net/ssl/SSLEngine;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      engine    

  public void checkServerTrusted(java.security.cert.X509Certificate[], java.lang.String, javax.net.ssl.SSLEngine);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljavax/net/ssl/SSLEngine;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
        start local 3 // javax.net.ssl.SSLEngine engine
         0: .line 138
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            aload 3 /* engine */
            iconst_0
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrusted:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljavax/net/ssl/SSLEngine;Z)V
         1: .line 139
            return
        end local 3 // javax.net.ssl.SSLEngine engine
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
            0    2     3    engine  Ljavax/net/ssl/SSLEngine;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      engine    

  private sun.security.validator.Validator checkTrustedInit(java.security.cert.X509Certificate[], java.lang.String, boolean);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)Lsun/security/validator/Validator;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=4
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
        start local 3 // boolean isClient
         0: .line 143
            aload 1 /* chain */
            ifnull 1
            aload 1 /* chain */
            arraylength
            ifne 4
         1: .line 144
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         2: .line 145
            ldc "null or zero-length certificate chain"
         3: .line 144
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 148
      StackMap locals:
      StackMap stack:
            aload 2 /* authType */
            ifnull 5
            aload 2 /* authType */
            invokevirtual java.lang.String.length:()I
            ifne 8
         5: .line 149
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         6: .line 150
            ldc "null or zero-length authentication type"
         7: .line 149
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 153
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* v */
        start local 4 // sun.security.validator.Validator v
         9: .line 154
            iload 3 /* isClient */
            ifeq 21
        10: .line 155
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        11: .line 156
            aload 4 /* v */
            ifnonnull 32
        12: .line 157
            aload 0 /* this */
            dup
            astore 5
            monitorenter
        13: .line 158
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        14: .line 159
            aload 4 /* v */
            ifnonnull 17
        15: .line 160
            aload 0 /* this */
            ldc "tls client"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 4 /* v */
        16: .line 161
            aload 0 /* this */
            aload 4 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
        17: .line 157
      StackMap locals: sun.security.validator.Validator sun.security.ssl.X509TrustManagerImpl
      StackMap stack:
            aload 5
            monitorexit
        18: goto 32
      StackMap locals:
      StackMap stack: java.lang.Throwable
        19: aload 5
            monitorexit
        20: athrow
        21: .line 168
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        22: .line 169
            aload 4 /* v */
            ifnonnull 32
        23: .line 170
            aload 0 /* this */
            dup
            astore 5
            monitorenter
        24: .line 171
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        25: .line 172
            aload 4 /* v */
            ifnonnull 28
        26: .line 173
            aload 0 /* this */
            ldc "tls server"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 4 /* v */
        27: .line 174
            aload 0 /* this */
            aload 4 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
        28: .line 170
      StackMap locals: sun.security.ssl.X509TrustManagerImpl
      StackMap stack:
            aload 5
            monitorexit
        29: goto 32
      StackMap locals:
      StackMap stack: java.lang.Throwable
        30: aload 5
            monitorexit
        31: athrow
        32: .line 180
      StackMap locals:
      StackMap stack:
            aload 4 /* v */
            areturn
        end local 4 // sun.security.validator.Validator v
        end local 3 // boolean isClient
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   33     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0   33     1     chain  [Ljava/security/cert/X509Certificate;
            0   33     2  authType  Ljava/lang/String;
            0   33     3  isClient  Z
            9   33     4         v  Lsun/security/validator/Validator;
      Exception table:
        from    to  target  type
          13    18      19  any
          19    20      19  any
          24    29      30  any
          30    31      30  any
    MethodParameters:
          Name  Flags
      chain     
      authType  
      isClient  

  private void checkTrusted(java.security.cert.X509Certificate[], java.lang.String, java.net.Socket, boolean);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/net/Socket;Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=13, args_size=5
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
        start local 3 // java.net.Socket socket
        start local 4 // boolean isClient
         0: .line 186
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            iload 4 /* isClient */
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrustedInit:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)Lsun/security/validator/Validator;
            astore 5 /* v */
        start local 5 // sun.security.validator.Validator v
         1: .line 188
            aconst_null
            astore 6 /* constraints */
        start local 6 // java.security.AlgorithmConstraints constraints
         2: .line 189
            aload 3 /* socket */
            ifnull 30
            aload 3 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 30
         3: .line 190
            aload 3 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 30
         4: .line 192
            aload 3 /* socket */
            checkcast javax.net.ssl.SSLSocket
            astore 7 /* sslSocket */
        start local 7 // javax.net.ssl.SSLSocket sslSocket
         5: .line 193
            aload 7 /* sslSocket */
            invokevirtual javax.net.ssl.SSLSocket.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
            astore 8 /* session */
        start local 8 // javax.net.ssl.SSLSession session
         6: .line 194
            aload 8 /* session */
            ifnonnull 8
         7: .line 195
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 199
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.AlgorithmConstraints javax.net.ssl.SSLSocket javax.net.ssl.SSLSession
      StackMap stack:
            aload 7 /* sslSocket */
            invokevirtual javax.net.ssl.SSLSocket.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
         9: .line 200
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
        10: .line 199
            astore 9 /* identityAlg */
        start local 9 // java.lang.String identityAlg
        11: .line 201
            aload 9 /* identityAlg */
            ifnull 14
            aload 9 /* identityAlg */
            invokevirtual java.lang.String.length:()I
            ifeq 14
        12: .line 202
            aload 8 /* session */
            invokeinterface javax.net.ssl.SSLSession.getPeerHost:()Ljava/lang/String;
            astore 10 /* hostname */
        start local 10 // java.lang.String hostname
        13: .line 203
            aload 10 /* hostname */
            aload 1 /* chain */
            iconst_0
            aaload
            aload 9 /* identityAlg */
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
        end local 10 // java.lang.String hostname
        14: .line 208
      StackMap locals: java.lang.String
      StackMap stack:
            aload 8 /* session */
            invokeinterface javax.net.ssl.SSLSession.getProtocol:()Ljava/lang/String;
            invokestatic sun.security.ssl.ProtocolVersion.valueOf:(Ljava/lang/String;)Lsun/security/ssl/ProtocolVersion;
        15: .line 207
            astore 10 /* protocolVersion */
        start local 10 // sun.security.ssl.ProtocolVersion protocolVersion
        16: .line 209
            aload 10 /* protocolVersion */
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmplt 29
        17: .line 210
            aload 8 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 26
        18: .line 212
            aload 8 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
        19: .line 211
            astore 11 /* extSession */
        start local 11 // javax.net.ssl.ExtendedSSLSession extSession
        20: .line 214
            aload 11 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        21: .line 213
            astore 12 /* localSupportedSignAlgs */
        start local 12 // java.lang.String[] localSupportedSignAlgs
        22: .line 216
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        23: .line 217
            aload 7 /* sslSocket */
            aload 12 /* localSupportedSignAlgs */
            iconst_0
        24: .line 216
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;[Ljava/lang/String;Z)V
            astore 6 /* constraints */
        end local 12 // java.lang.String[] localSupportedSignAlgs
        end local 11 // javax.net.ssl.ExtendedSSLSession extSession
        25: .line 218
            goto 30
        26: .line 220
      StackMap locals: sun.security.ssl.ProtocolVersion
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 7 /* sslSocket */
            iconst_0
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;Z)V
        27: .line 219
            astore 6 /* constraints */
        28: .line 222
            goto 30
        29: .line 223
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 7 /* sslSocket */
            iconst_0
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;Z)V
            astore 6 /* constraints */
        end local 10 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 9 // java.lang.String identityAlg
        end local 8 // javax.net.ssl.SSLSession session
        end local 7 // javax.net.ssl.SSLSocket sslSocket
        30: .line 227
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.AlgorithmConstraints
      StackMap stack:
            aconst_null
            astore 7 /* trustedChain */
        start local 7 // java.security.cert.X509Certificate[] trustedChain
        31: .line 228
            iload 4 /* isClient */
            ifeq 34
        32: .line 229
            aload 5 /* v */
            aload 1 /* chain */
            aload 6 /* constraints */
            aconst_null
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 7 /* trustedChain */
        33: .line 230
            goto 35
        34: .line 231
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aload 6 /* constraints */
            aload 2 /* authType */
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 7 /* trustedChain */
        35: .line 233
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 38
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 38
        36: .line 234
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Found trusted certificate:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        37: .line 235
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 7 /* trustedChain */
            aload 7 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            invokevirtual java.io.PrintStream.println:(Ljava/lang/Object;)V
        38: .line 237
      StackMap locals:
      StackMap stack:
            return
        end local 7 // java.security.cert.X509Certificate[] trustedChain
        end local 6 // java.security.AlgorithmConstraints constraints
        end local 5 // sun.security.validator.Validator v
        end local 4 // boolean isClient
        end local 3 // java.net.Socket socket
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0   39     0                    this  Lsun/security/ssl/X509TrustManagerImpl;
            0   39     1                   chain  [Ljava/security/cert/X509Certificate;
            0   39     2                authType  Ljava/lang/String;
            0   39     3                  socket  Ljava/net/Socket;
            0   39     4                isClient  Z
            1   39     5                       v  Lsun/security/validator/Validator;
            2   39     6             constraints  Ljava/security/AlgorithmConstraints;
            5   30     7               sslSocket  Ljavax/net/ssl/SSLSocket;
            6   30     8                 session  Ljavax/net/ssl/SSLSession;
           11   30     9             identityAlg  Ljava/lang/String;
           13   14    10                hostname  Ljava/lang/String;
           16   30    10         protocolVersion  Lsun/security/ssl/ProtocolVersion;
           20   25    11              extSession  Ljavax/net/ssl/ExtendedSSLSession;
           22   25    12  localSupportedSignAlgs  [Ljava/lang/String;
           31   39     7            trustedChain  [Ljava/security/cert/X509Certificate;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      socket    
      isClient  

  private void checkTrusted(java.security.cert.X509Certificate[], java.lang.String, javax.net.ssl.SSLEngine, boolean);
    descriptor: ([Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljavax/net/ssl/SSLEngine;Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=12, args_size=5
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.lang.String authType
        start local 3 // javax.net.ssl.SSLEngine engine
        start local 4 // boolean isClient
         0: .line 241
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            iload 4 /* isClient */
            invokevirtual sun.security.ssl.X509TrustManagerImpl.checkTrustedInit:([Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)Lsun/security/validator/Validator;
            astore 5 /* v */
        start local 5 // sun.security.validator.Validator v
         1: .line 243
            aconst_null
            astore 6 /* constraints */
        start local 6 // java.security.AlgorithmConstraints constraints
         2: .line 244
            aload 3 /* engine */
            ifnull 28
         3: .line 245
            aload 3 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
            astore 7 /* session */
        start local 7 // javax.net.ssl.SSLSession session
         4: .line 246
            aload 7 /* session */
            ifnonnull 6
         5: .line 247
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 251
      StackMap locals: sun.security.validator.Validator java.security.AlgorithmConstraints javax.net.ssl.SSLSession
      StackMap stack:
            aload 3 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
         7: .line 252
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
         8: .line 251
            astore 8 /* identityAlg */
        start local 8 // java.lang.String identityAlg
         9: .line 253
            aload 8 /* identityAlg */
            ifnull 12
            aload 8 /* identityAlg */
            invokevirtual java.lang.String.length:()I
            ifeq 12
        10: .line 254
            aload 7 /* session */
            invokeinterface javax.net.ssl.SSLSession.getPeerHost:()Ljava/lang/String;
            astore 9 /* hostname */
        start local 9 // java.lang.String hostname
        11: .line 255
            aload 9 /* hostname */
            aload 1 /* chain */
            iconst_0
            aaload
            aload 8 /* identityAlg */
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
        end local 9 // java.lang.String hostname
        12: .line 260
      StackMap locals: java.lang.String
      StackMap stack:
            aload 7 /* session */
            invokeinterface javax.net.ssl.SSLSession.getProtocol:()Ljava/lang/String;
            invokestatic sun.security.ssl.ProtocolVersion.valueOf:(Ljava/lang/String;)Lsun/security/ssl/ProtocolVersion;
        13: .line 259
            astore 9 /* protocolVersion */
        start local 9 // sun.security.ssl.ProtocolVersion protocolVersion
        14: .line 261
            aload 9 /* protocolVersion */
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmplt 27
        15: .line 262
            aload 7 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 24
        16: .line 264
            aload 7 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
        17: .line 263
            astore 10 /* extSession */
        start local 10 // javax.net.ssl.ExtendedSSLSession extSession
        18: .line 266
            aload 10 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        19: .line 265
            astore 11 /* localSupportedSignAlgs */
        start local 11 // java.lang.String[] localSupportedSignAlgs
        20: .line 268
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        21: .line 269
            aload 3 /* engine */
            aload 11 /* localSupportedSignAlgs */
            iconst_0
        22: .line 268
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;[Ljava/lang/String;Z)V
            astore 6 /* constraints */
        end local 11 // java.lang.String[] localSupportedSignAlgs
        end local 10 // javax.net.ssl.ExtendedSSLSession extSession
        23: .line 270
            goto 28
        24: .line 272
      StackMap locals: sun.security.ssl.ProtocolVersion
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 3 /* engine */
            iconst_0
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;Z)V
        25: .line 271
            astore 6 /* constraints */
        26: .line 274
            goto 28
        27: .line 275
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 3 /* engine */
            iconst_0
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;Z)V
            astore 6 /* constraints */
        end local 9 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 8 // java.lang.String identityAlg
        end local 7 // javax.net.ssl.SSLSession session
        28: .line 279
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 7 /* trustedChain */
        start local 7 // java.security.cert.X509Certificate[] trustedChain
        29: .line 280
            iload 4 /* isClient */
            ifeq 32
        30: .line 281
            aload 5 /* v */
            aload 1 /* chain */
            aload 6 /* constraints */
            aconst_null
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 7 /* trustedChain */
        31: .line 282
            goto 33
        32: .line 283
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aload 6 /* constraints */
            aload 2 /* authType */
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 7 /* trustedChain */
        33: .line 285
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 36
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 36
        34: .line 286
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Found trusted certificate:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        35: .line 287
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 7 /* trustedChain */
            aload 7 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            invokevirtual java.io.PrintStream.println:(Ljava/lang/Object;)V
        36: .line 289
      StackMap locals:
      StackMap stack:
            return
        end local 7 // java.security.cert.X509Certificate[] trustedChain
        end local 6 // java.security.AlgorithmConstraints constraints
        end local 5 // sun.security.validator.Validator v
        end local 4 // boolean isClient
        end local 3 // javax.net.ssl.SSLEngine engine
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0   37     0                    this  Lsun/security/ssl/X509TrustManagerImpl;
            0   37     1                   chain  [Ljava/security/cert/X509Certificate;
            0   37     2                authType  Ljava/lang/String;
            0   37     3                  engine  Ljavax/net/ssl/SSLEngine;
            0   37     4                isClient  Z
            1   37     5                       v  Lsun/security/validator/Validator;
            2   37     6             constraints  Ljava/security/AlgorithmConstraints;
            4   28     7                 session  Ljavax/net/ssl/SSLSession;
            9   28     8             identityAlg  Ljava/lang/String;
           11   12     9                hostname  Ljava/lang/String;
           14   28     9         protocolVersion  Lsun/security/ssl/ProtocolVersion;
           18   23    10              extSession  Ljavax/net/ssl/ExtendedSSLSession;
           20   23    11  localSupportedSignAlgs  [Ljava/lang/String;
           29   37     7            trustedChain  [Ljava/security/cert/X509Certificate;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      engine    
      isClient  

  private void showTrustedCerts();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
         0: .line 292
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 21
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 21
         1: .line 293
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 20
      StackMap locals: sun.security.ssl.X509TrustManagerImpl top java.util.Iterator
      StackMap stack:
         2: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 1 /* cert */
        start local 1 // java.security.cert.X509Certificate cert
         3: .line 294
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "adding as trusted cert:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         4: .line 295
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "  Subject: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         5: .line 296
            aload 1 /* 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;
         6: .line 295
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         7: .line 297
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "  Issuer:  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 298
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 297
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        10: .line 299
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "  Algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 300
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        12: .line 301
            ldc "; Serial number: 0x"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        13: .line 302
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSerialNumber:()Ljava/math/BigInteger;
            bipush 16
            invokevirtual java.math.BigInteger.toString:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 299
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        15: .line 303
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "  Valid from "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        16: .line 304
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getNotBefore:()Ljava/util/Date;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " until "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        17: .line 305
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getNotAfter:()Ljava/util/Date;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 303
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        19: .line 306
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
        end local 1 // java.security.cert.X509Certificate cert
        20: .line 293
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        21: .line 309
      StackMap locals: sun.security.ssl.X509TrustManagerImpl
      StackMap stack:
            return
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   22     0  this  Lsun/security/ssl/X509TrustManagerImpl;
            3   20     1  cert  Ljava/security/cert/X509Certificate;

  private sun.security.validator.Validator getValidator(java.lang.String);
    descriptor: (Ljava/lang/String;)Lsun/security/validator/Validator;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.ssl.X509TrustManagerImpl this
        start local 1 // java.lang.String variant
         0: .line 313
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
            ifnonnull 3
         1: .line 314
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
            aload 1 /* variant */
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
            invokestatic sun.security.validator.Validator.getInstance:(Ljava/lang/String;Ljava/lang/String;Ljava/util/Collection;)Lsun/security/validator/Validator;
            astore 2 /* v */
        start local 2 // sun.security.validator.Validator v
         2: .line 315
            goto 4
        end local 2 // sun.security.validator.Validator v
         3: .line 316
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
            aload 1 /* variant */
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
            invokestatic sun.security.validator.Validator.getInstance:(Ljava/lang/String;Ljava/lang/String;Ljava/security/cert/PKIXBuilderParameters;)Lsun/security/validator/Validator;
            astore 2 /* v */
        start local 2 // sun.security.validator.Validator v
         4: .line 318
      StackMap locals: sun.security.validator.Validator
      StackMap stack:
            aload 2 /* v */
            areturn
        end local 2 // sun.security.validator.Validator v
        end local 1 // java.lang.String variant
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lsun/security/ssl/X509TrustManagerImpl;
            0    5     1  variant  Ljava/lang/String;
            2    3     2        v  Lsun/security/validator/Validator;
            4    5     2        v  Lsun/security/validator/Validator;
    MethodParameters:
         Name  Flags
      variant  

  private static java.security.cert.X509Certificate[] validate(sun.security.validator.Validator, java.security.cert.X509Certificate[], java.security.AlgorithmConstraints, java.lang.String);
    descriptor: (Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=7, args_size=4
        start local 0 // sun.security.validator.Validator v
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.security.AlgorithmConstraints constraints
        start local 3 // java.lang.String authType
         0: .line 324
            invokestatic sun.security.ssl.JsseJce.beginFipsProvider:()Ljava/lang/Object;
            astore 4 /* o */
        start local 4 // java.lang.Object o
         1: .line 326
            aload 0 /* v */
            aload 1 /* chain */
            aconst_null
            aload 2 /* constraints */
            aload 3 /* authType */
            invokevirtual sun.security.validator.Validator.validate:([Ljava/security/cert/X509Certificate;Ljava/util/Collection;Ljava/security/AlgorithmConstraints;Ljava/lang/Object;)[Ljava/security/cert/X509Certificate;
            astore 6
         2: .line 328
            aload 4 /* o */
            invokestatic sun.security.ssl.JsseJce.endFipsProvider:(Ljava/lang/Object;)V
         3: .line 326
            aload 6
            areturn
         4: .line 327
      StackMap locals: sun.security.validator.Validator java.security.cert.X509Certificate[] java.security.AlgorithmConstraints java.lang.String java.lang.Object
      StackMap stack: java.lang.Throwable
            astore 5
         5: .line 328
            aload 4 /* o */
            invokestatic sun.security.ssl.JsseJce.endFipsProvider:(Ljava/lang/Object;)V
         6: .line 329
            aload 5
            athrow
        end local 4 // java.lang.Object o
        end local 3 // java.lang.String authType
        end local 2 // java.security.AlgorithmConstraints constraints
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.validator.Validator v
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0            v  Lsun/security/validator/Validator;
            0    7     1        chain  [Ljava/security/cert/X509Certificate;
            0    7     2  constraints  Ljava/security/AlgorithmConstraints;
            0    7     3     authType  Ljava/lang/String;
            1    7     4            o  Ljava/lang/Object;
      Exception table:
        from    to  target  type
           1     2       4  any
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
             Name  Flags
      v            
      chain        
      constraints  
      authType     

  static void checkIdentity(java.lang.String, java.security.cert.X509Certificate, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // java.lang.String hostname
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.lang.String algorithm
         0: .line 339
            aload 2 /* algorithm */
            ifnull 18
            aload 2 /* algorithm */
            invokevirtual java.lang.String.length:()I
            ifeq 18
         1: .line 341
            aload 0 /* hostname */
            ifnull 4
            aload 0 /* hostname */
            ldc "["
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 4
         2: .line 342
            aload 0 /* hostname */
            ldc "]"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 343
            aload 0 /* hostname */
            iconst_1
            aload 0 /* hostname */
            invokevirtual java.lang.String.length:()I
            iconst_1
            isub
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 0 /* hostname */
         4: .line 346
      StackMap locals:
      StackMap stack:
            aload 2 /* algorithm */
            ldc "HTTPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 9
         5: .line 347
            iconst_1
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
         6: .line 348
            aload 0 /* hostname */
            aload 1 /* cert */
         7: .line 347
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;)V
         8: .line 349
            goto 18
      StackMap locals:
      StackMap stack:
         9: aload 2 /* algorithm */
            ldc "LDAP"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 11
        10: .line 350
            aload 2 /* algorithm */
            ldc "LDAPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 15
        11: .line 351
      StackMap locals:
      StackMap stack:
            iconst_2
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
        12: .line 352
            aload 0 /* hostname */
            aload 1 /* cert */
        13: .line 351
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;)V
        14: .line 353
            goto 18
        15: .line 354
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateException
            dup
        16: .line 355
            new java.lang.StringBuilder
            dup
            ldc "Unknown identification algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 354
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 358
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String algorithm
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // java.lang.String hostname
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   19     0   hostname  Ljava/lang/String;
            0   19     1       cert  Ljava/security/cert/X509Certificate;
            0   19     2  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
           Name  Flags
      hostname   
      cert       
      algorithm  
}
SourceFile: "X509TrustManagerImpl.java"