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 70
            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.util.Collection<java.security.cert.X509Certificate>);
    descriptor: (Ljava/lang/String;Ljava/util/Collection;)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.util.Collection trustedCerts
         0: .line 72
            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 78
            aload 2 /* trustedCerts */
            ifnonnull 5
         4: .line 79
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 2 /* trustedCerts */
         5: .line 82
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.lang.String java.util.Collection
      StackMap stack:
            aload 0 /* this */
            aload 2 /* trustedCerts */
            putfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
         6: .line 84
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 8
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 8
         7: .line 85
            aload 0 /* this */
            invokevirtual sun.security.ssl.X509TrustManagerImpl.showTrustedCerts:()V
         8: .line 87
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.Collection trustedCerts
        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   trustedCerts  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    Signature: (Ljava/lang/String;Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
               Name  Flags
      validatorType  
      trustedCerts   

  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 89
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedTrustManager.<init>:()V
         1: .line 90
            aload 0 /* this */
            aload 1 /* validatorType */
            putfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
         2: .line 91
            aload 0 /* this */
            aload 2 /* params */
            putfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
         3: .line 96
            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 97
            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 98
            aload 0 /* this */
            aload 3 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
         6: .line 100
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 8
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 8
         7: .line 101
            aload 0 /* this */
            invokevirtual sun.security.ssl.X509TrustManagerImpl.showTrustedCerts:()V
         8: .line 103
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.lang.String java.security.cert.PKIXBuilderParameters sun.security.validator.Validator
      StackMap stack:
            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    9     0           this  Lsun/security/ssl/X509TrustManagerImpl;
            0    9     1  validatorType  Ljava/lang/String;
            0    9     2         params  Ljava/security/cert/PKIXBuilderParameters;
            4    9     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 108
            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 109
            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 114
            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 115
            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 119
            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 120
            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 121
            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 127
            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 128
            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 133
            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 134
            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 139
            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 140
            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 145
            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 146
            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 150
            aload 1 /* chain */
            ifnull 1
            aload 1 /* chain */
            arraylength
            ifne 4
         1: .line 151
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         2: .line 152
            ldc "null or zero-length certificate chain"
         3: .line 151
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 155
      StackMap locals:
      StackMap stack:
            aload 2 /* authType */
            ifnull 5
            aload 2 /* authType */
            invokevirtual java.lang.String.length:()I
            ifne 8
         5: .line 156
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         6: .line 157
            ldc "null or zero-length authentication type"
         7: .line 156
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 160
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* v */
        start local 4 // sun.security.validator.Validator v
         9: .line 161
            iload 3 /* isClient */
            ifeq 21
        10: .line 162
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        11: .line 163
            aload 4 /* v */
            ifnonnull 32
        12: .line 164
            aload 0 /* this */
            dup
            astore 5
            monitorenter
        13: .line 165
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        14: .line 166
            aload 4 /* v */
            ifnonnull 17
        15: .line 167
            aload 0 /* this */
            ldc "tls client"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 4 /* v */
        16: .line 168
            aload 0 /* this */
            aload 4 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
        17: .line 164
      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 175
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        22: .line 176
            aload 4 /* v */
            ifnonnull 32
        23: .line 177
            aload 0 /* this */
            dup
            astore 5
            monitorenter
        24: .line 178
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        25: .line 179
            aload 4 /* v */
            ifnonnull 28
        26: .line 180
            aload 0 /* this */
            ldc "tls server"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 4 /* v */
        27: .line 181
            aload 0 /* this */
            aload 4 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
        28: .line 177
      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 187
      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=6, locals=15, 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 192
            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 194
            aconst_null
            astore 6 /* trustedChain */
        start local 6 // java.security.cert.X509Certificate[] trustedChain
         2: .line 195
            aload 3 /* socket */
            ifnull 39
            aload 3 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 39
         3: .line 196
            aload 3 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 39
         4: .line 198
            aload 3 /* socket */
            checkcast javax.net.ssl.SSLSocket
            astore 7 /* sslSocket */
        start local 7 // javax.net.ssl.SSLSocket sslSocket
         5: .line 199
            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 200
            aload 8 /* session */
            ifnonnull 8
         7: .line 201
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 206
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.cert.X509Certificate[] javax.net.ssl.SSLSocket javax.net.ssl.SSLSession
      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;
         9: .line 205
            astore 9 /* protocolVersion */
        start local 9 // sun.security.ssl.ProtocolVersion protocolVersion
        10: .line 207
            aload 8 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            istore 10 /* isExtSession */
        start local 10 // boolean isExtSession
        11: .line 208
            aconst_null
            astore 11 /* constraints */
        start local 11 // java.security.AlgorithmConstraints constraints
        12: .line 209
            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 20
            iload 10 /* isExtSession */
            ifeq 20
        13: .line 210
            aload 8 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 12 /* extSession */
        start local 12 // javax.net.ssl.ExtendedSSLSession extSession
        14: .line 212
            aload 12 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        15: .line 211
            astore 13 /* localSupportedSignAlgs */
        start local 13 // java.lang.String[] localSupportedSignAlgs
        16: .line 214
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        17: .line 215
            aload 7 /* sslSocket */
            aload 13 /* localSupportedSignAlgs */
            iconst_0
        18: .line 214
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;[Ljava/lang/String;Z)V
            astore 11 /* constraints */
        end local 13 // java.lang.String[] localSupportedSignAlgs
        end local 12 // javax.net.ssl.ExtendedSSLSession extSession
        19: .line 216
            goto 21
        20: .line 217
      StackMap locals: sun.security.ssl.ProtocolVersion int java.security.AlgorithmConstraints
      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 11 /* constraints */
        21: .line 221
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            astore 12 /* responseList */
        start local 12 // java.util.List responseList
        22: .line 222
            iload 4 /* isClient */
            ifne 25
            iload 10 /* isExtSession */
            ifeq 25
        23: .line 224
            aload 8 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getStatusResponses:()Ljava/util/List;
        24: .line 223
            astore 12 /* responseList */
        25: .line 226
      StackMap locals: java.util.List
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aload 12 /* responseList */
        26: .line 227
            aload 11 /* constraints */
            iload 4 /* isClient */
            ifeq 27
            aconst_null
            goto 28
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.cert.X509Certificate[] javax.net.ssl.SSLSocket javax.net.ssl.SSLSession sun.security.ssl.ProtocolVersion int java.security.AlgorithmConstraints java.util.List
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List java.security.AlgorithmConstraints
        27: aload 2 /* authType */
        28: .line 226
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.cert.X509Certificate[] javax.net.ssl.SSLSocket javax.net.ssl.SSLSession sun.security.ssl.ProtocolVersion int java.security.AlgorithmConstraints java.util.List
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List java.security.AlgorithmConstraints java.lang.String
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/util/List;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 6 /* trustedChain */
        29: .line 232
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            invokestatic sun.security.util.AnchorCertificates.contains:(Ljava/security/cert/X509Certificate;)Z
        30: .line 231
            istore 13 /* chainsToPublicCA */
        start local 13 // boolean chainsToPublicCA
        31: .line 235
            aload 7 /* sslSocket */
            invokevirtual javax.net.ssl.SSLSocket.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
        32: .line 236
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
        33: .line 235
            astore 14 /* identityAlg */
        start local 14 // java.lang.String identityAlg
        34: .line 237
            aload 14 /* identityAlg */
            ifnull 43
            aload 14 /* identityAlg */
            invokevirtual java.lang.String.length:()I
            ifeq 43
        35: .line 238
            aload 8 /* session */
            aload 6 /* trustedChain */
            iconst_0
            aaload
            aload 14 /* identityAlg */
            iload 4 /* isClient */
        36: .line 239
            aload 3 /* socket */
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljava/net/Socket;)Ljava/util/List;
            iload 13 /* chainsToPublicCA */
        37: .line 238
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljavax/net/ssl/SSLSession;Ljava/security/cert/X509Certificate;Ljava/lang/String;ZLjava/util/List;Z)V
        end local 14 // java.lang.String identityAlg
        end local 13 // boolean chainsToPublicCA
        end local 12 // java.util.List responseList
        end local 11 // java.security.AlgorithmConstraints constraints
        end local 10 // boolean isExtSession
        end local 9 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 8 // javax.net.ssl.SSLSession session
        end local 7 // javax.net.ssl.SSLSocket sslSocket
        38: .line 241
            goto 43
        39: .line 242
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.cert.X509Certificate[]
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
        40: .line 243
            aconst_null
            iload 4 /* isClient */
            ifeq 41
            aconst_null
            goto 42
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.cert.X509Certificate[]
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List null
        41: aload 2 /* authType */
        42: .line 242
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String java.net.Socket int sun.security.validator.Validator java.security.cert.X509Certificate[]
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List null java.lang.String
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/util/List;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 6 /* trustedChain */
        43: .line 245
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 46
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 46
        44: .line 246
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Found trusted certificate:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        45: .line 247
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            invokevirtual java.io.PrintStream.println:(Ljava/lang/Object;)V
        46: .line 249
      StackMap locals:
      StackMap stack:
            return
        end local 6 // java.security.cert.X509Certificate[] trustedChain
        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   47     0                    this  Lsun/security/ssl/X509TrustManagerImpl;
            0   47     1                   chain  [Ljava/security/cert/X509Certificate;
            0   47     2                authType  Ljava/lang/String;
            0   47     3                  socket  Ljava/net/Socket;
            0   47     4                isClient  Z
            1   47     5                       v  Lsun/security/validator/Validator;
            2   47     6            trustedChain  [Ljava/security/cert/X509Certificate;
            5   38     7               sslSocket  Ljavax/net/ssl/SSLSocket;
            6   38     8                 session  Ljavax/net/ssl/SSLSession;
           10   38     9         protocolVersion  Lsun/security/ssl/ProtocolVersion;
           11   38    10            isExtSession  Z
           12   38    11             constraints  Ljava/security/AlgorithmConstraints;
           14   19    12              extSession  Ljavax/net/ssl/ExtendedSSLSession;
           16   19    13  localSupportedSignAlgs  [Ljava/lang/String;
           22   38    12            responseList  Ljava/util/List<[B>;
           31   38    13        chainsToPublicCA  Z
           34   38    14             identityAlg  Ljava/lang/String;
    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=6, locals=14, 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 253
            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 255
            aconst_null
            astore 6 /* trustedChain */
        start local 6 // java.security.cert.X509Certificate[] trustedChain
         2: .line 256
            aload 3 /* engine */
            ifnull 37
         3: .line 257
            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 258
            aload 7 /* session */
            ifnonnull 6
         5: .line 259
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 264
      StackMap locals: sun.security.validator.Validator java.security.cert.X509Certificate[] javax.net.ssl.SSLSession
      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;
         7: .line 263
            astore 8 /* protocolVersion */
        start local 8 // sun.security.ssl.ProtocolVersion protocolVersion
         8: .line 265
            aload 7 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            istore 9 /* isExtSession */
        start local 9 // boolean isExtSession
         9: .line 266
            aconst_null
            astore 10 /* constraints */
        start local 10 // java.security.AlgorithmConstraints constraints
        10: .line 267
            aload 8 /* 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 18
            iload 9 /* isExtSession */
            ifeq 18
        11: .line 268
            aload 7 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 11 /* extSession */
        start local 11 // javax.net.ssl.ExtendedSSLSession extSession
        12: .line 270
            aload 11 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        13: .line 269
            astore 12 /* localSupportedSignAlgs */
        start local 12 // java.lang.String[] localSupportedSignAlgs
        14: .line 272
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        15: .line 273
            aload 3 /* engine */
            aload 12 /* localSupportedSignAlgs */
            iconst_0
        16: .line 272
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;[Ljava/lang/String;Z)V
            astore 10 /* constraints */
        end local 12 // java.lang.String[] localSupportedSignAlgs
        end local 11 // javax.net.ssl.ExtendedSSLSession extSession
        17: .line 274
            goto 19
        18: .line 275
      StackMap locals: sun.security.ssl.ProtocolVersion int java.security.AlgorithmConstraints
      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 10 /* constraints */
        19: .line 279
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            astore 11 /* responseList */
        start local 11 // java.util.List responseList
        20: .line 280
            iload 4 /* isClient */
            ifne 23
            iload 9 /* isExtSession */
            ifeq 23
        21: .line 282
            aload 7 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getStatusResponses:()Ljava/util/List;
        22: .line 281
            astore 11 /* responseList */
        23: .line 284
      StackMap locals: java.util.List
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aload 11 /* responseList */
        24: .line 285
            aload 10 /* constraints */
            iload 4 /* isClient */
            ifeq 25
            aconst_null
            goto 26
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String javax.net.ssl.SSLEngine int sun.security.validator.Validator java.security.cert.X509Certificate[] javax.net.ssl.SSLSession sun.security.ssl.ProtocolVersion int java.security.AlgorithmConstraints java.util.List
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List java.security.AlgorithmConstraints
        25: aload 2 /* authType */
        26: .line 284
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String javax.net.ssl.SSLEngine int sun.security.validator.Validator java.security.cert.X509Certificate[] javax.net.ssl.SSLSession sun.security.ssl.ProtocolVersion int java.security.AlgorithmConstraints java.util.List
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List java.security.AlgorithmConstraints java.lang.String
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/util/List;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 6 /* trustedChain */
        27: .line 290
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            invokestatic sun.security.util.AnchorCertificates.contains:(Ljava/security/cert/X509Certificate;)Z
        28: .line 289
            istore 12 /* chainsToPublicCA */
        start local 12 // boolean chainsToPublicCA
        29: .line 293
            aload 3 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
        30: .line 294
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
        31: .line 293
            astore 13 /* identityAlg */
        start local 13 // java.lang.String identityAlg
        32: .line 295
            aload 13 /* identityAlg */
            ifnull 41
            aload 13 /* identityAlg */
            invokevirtual java.lang.String.length:()I
            ifeq 41
        33: .line 296
            aload 7 /* session */
            aload 6 /* trustedChain */
            iconst_0
            aaload
            aload 13 /* identityAlg */
            iload 4 /* isClient */
        34: .line 297
            aload 3 /* engine */
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljavax/net/ssl/SSLEngine;)Ljava/util/List;
            iload 12 /* chainsToPublicCA */
        35: .line 296
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljavax/net/ssl/SSLSession;Ljava/security/cert/X509Certificate;Ljava/lang/String;ZLjava/util/List;Z)V
        end local 13 // java.lang.String identityAlg
        end local 12 // boolean chainsToPublicCA
        end local 11 // java.util.List responseList
        end local 10 // java.security.AlgorithmConstraints constraints
        end local 9 // boolean isExtSession
        end local 8 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 7 // javax.net.ssl.SSLSession session
        36: .line 299
            goto 41
        37: .line 300
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String javax.net.ssl.SSLEngine int sun.security.validator.Validator java.security.cert.X509Certificate[]
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
        38: .line 301
            aconst_null
            iload 4 /* isClient */
            ifeq 39
            aconst_null
            goto 40
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String javax.net.ssl.SSLEngine int sun.security.validator.Validator java.security.cert.X509Certificate[]
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List null
        39: aload 2 /* authType */
        40: .line 300
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String javax.net.ssl.SSLEngine int sun.security.validator.Validator java.security.cert.X509Certificate[]
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List null java.lang.String
            invokestatic sun.security.ssl.X509TrustManagerImpl.validate:(Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/util/List;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 6 /* trustedChain */
        41: .line 303
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 44
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 44
        42: .line 304
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Found trusted certificate:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        43: .line 305
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            invokevirtual java.io.PrintStream.println:(Ljava/lang/Object;)V
        44: .line 307
      StackMap locals:
      StackMap stack:
            return
        end local 6 // java.security.cert.X509Certificate[] trustedChain
        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   45     0                    this  Lsun/security/ssl/X509TrustManagerImpl;
            0   45     1                   chain  [Ljava/security/cert/X509Certificate;
            0   45     2                authType  Ljava/lang/String;
            0   45     3                  engine  Ljavax/net/ssl/SSLEngine;
            0   45     4                isClient  Z
            1   45     5                       v  Lsun/security/validator/Validator;
            2   45     6            trustedChain  [Ljava/security/cert/X509Certificate;
            4   36     7                 session  Ljavax/net/ssl/SSLSession;
            8   36     8         protocolVersion  Lsun/security/ssl/ProtocolVersion;
            9   36     9            isExtSession  Z
           10   36    10             constraints  Ljava/security/AlgorithmConstraints;
           12   17    11              extSession  Ljavax/net/ssl/ExtendedSSLSession;
           14   17    12  localSupportedSignAlgs  [Ljava/lang/String;
           20   36    11            responseList  Ljava/util/List<[B>;
           29   36    12        chainsToPublicCA  Z
           32   36    13             identityAlg  Ljava/lang/String;
    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 310
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 19
      StackMap locals: sun.security.ssl.X509TrustManagerImpl top java.util.Iterator
      StackMap stack:
         1: 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
         2: .line 311
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "adding as trusted cert:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         3: .line 312
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "  Subject: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         4: .line 313
            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;
         5: .line 312
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 314
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "  Issuer:  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         7: .line 315
            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;
         8: .line 314
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         9: .line 316
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "  Algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        10: .line 317
            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;
        11: .line 318
            ldc "; Serial number: 0x"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        12: .line 319
            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;
        13: .line 316
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        14: .line 320
            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
        15: .line 321
            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;
        16: .line 322
            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;
        17: .line 320
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        18: .line 323
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
        end local 1 // java.security.cert.X509Certificate cert
        19: .line 310
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
        20: .line 325
            return
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   21     0  this  Lsun/security/ssl/X509TrustManagerImpl;
            2   19     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 329
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
            ifnonnull 3
         1: .line 330
            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 331
            goto 4
        end local 2 // sun.security.validator.Validator v
         3: .line 332
      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 334
      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.util.List<byte[]>, java.security.AlgorithmConstraints, java.lang.String);
    descriptor: (Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/util/List;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=8, args_size=5
        start local 0 // sun.security.validator.Validator v
        start local 1 // java.security.cert.X509Certificate[] chain
        start local 2 // java.util.List responseList
        start local 3 // java.security.AlgorithmConstraints constraints
        start local 4 // java.lang.String authType
         0: .line 341
            invokestatic sun.security.ssl.JsseJce.beginFipsProvider:()Ljava/lang/Object;
            astore 5 /* o */
        start local 5 // java.lang.Object o
         1: .line 343
            aload 0 /* v */
            aload 1 /* chain */
            aconst_null
            aload 2 /* responseList */
            aload 3 /* constraints */
            aload 4 /* authType */
            invokevirtual sun.security.validator.Validator.validate:([Ljava/security/cert/X509Certificate;Ljava/util/Collection;Ljava/util/List;Ljava/security/AlgorithmConstraints;Ljava/lang/Object;)[Ljava/security/cert/X509Certificate;
            astore 7
         2: .line 345
            aload 5 /* o */
            invokestatic sun.security.ssl.JsseJce.endFipsProvider:(Ljava/lang/Object;)V
         3: .line 343
            aload 7
            areturn
         4: .line 344
      StackMap locals: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List java.security.AlgorithmConstraints java.lang.String java.lang.Object
      StackMap stack: java.lang.Throwable
            astore 6
         5: .line 345
            aload 5 /* o */
            invokestatic sun.security.ssl.JsseJce.endFipsProvider:(Ljava/lang/Object;)V
         6: .line 346
            aload 6
            athrow
        end local 5 // java.lang.Object o
        end local 4 // java.lang.String authType
        end local 3 // java.security.AlgorithmConstraints constraints
        end local 2 // java.util.List responseList
        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  responseList  Ljava/util/List<[B>;
            0    7     3   constraints  Ljava/security/AlgorithmConstraints;
            0    7     4      authType  Ljava/lang/String;
            1    7     5             o  Ljava/lang/Object;
      Exception table:
        from    to  target  type
           1     2       4  any
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Lsun/security/validator/Validator;[Ljava/security/cert/X509Certificate;Ljava/util/List<[B>;Ljava/security/AlgorithmConstraints;Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
    MethodParameters:
              Name  Flags
      v             
      chain         
      responseList  
      constraints   
      authType      

  private static java.lang.String getHostNameInSNI(java.util.List<javax.net.ssl.SNIServerName>);
    descriptor: (Ljava/util/List;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // java.util.List sniNames
         0: .line 354
            aconst_null
            astore 1 /* hostname */
        start local 1 // javax.net.ssl.SNIHostName hostname
         1: .line 355
            aload 0 /* sniNames */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 14
      StackMap locals: java.util.List javax.net.ssl.SNIHostName top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.net.ssl.SNIServerName
            astore 2 /* sniName */
        start local 2 // javax.net.ssl.SNIServerName sniName
         3: .line 356
            aload 2 /* sniName */
            invokevirtual javax.net.ssl.SNIServerName.getType:()I
            ifeq 5
         4: .line 357
            goto 14
         5: .line 360
      StackMap locals: java.util.List javax.net.ssl.SNIHostName javax.net.ssl.SNIServerName java.util.Iterator
      StackMap stack:
            aload 2 /* sniName */
            instanceof javax.net.ssl.SNIHostName
            ifeq 8
         6: .line 361
            aload 2 /* sniName */
            checkcast javax.net.ssl.SNIHostName
            astore 1 /* hostname */
         7: .line 362
            goto 15
         8: .line 364
      StackMap locals:
      StackMap stack:
            new javax.net.ssl.SNIHostName
            dup
            aload 2 /* sniName */
            invokevirtual javax.net.ssl.SNIServerName.getEncoded:()[B
            invokespecial javax.net.ssl.SNIHostName.<init>:([B)V
            astore 1 /* hostname */
         9: .line 365
            goto 15
      StackMap locals:
      StackMap stack: java.lang.IllegalArgumentException
        10: pop
        11: .line 367
            getstatic sun.security.ssl.X509TrustManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 15
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 15
        12: .line 368
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Illegal server name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* sniName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        13: .line 374
            goto 15
        end local 2 // javax.net.ssl.SNIServerName sniName
        14: .line 355
      StackMap locals: java.util.List javax.net.ssl.SNIHostName top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        15: .line 377
      StackMap locals: java.util.List javax.net.ssl.SNIHostName
      StackMap stack:
            aload 1 /* hostname */
            ifnull 17
        16: .line 378
            aload 1 /* hostname */
            invokevirtual javax.net.ssl.SNIHostName.getAsciiName:()Ljava/lang/String;
            areturn
        17: .line 381
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 1 // javax.net.ssl.SNIHostName hostname
        end local 0 // java.util.List sniNames
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   18     0  sniNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
            1   18     1  hostname  Ljavax/net/ssl/SNIHostName;
            3   14     2   sniName  Ljavax/net/ssl/SNIServerName;
      Exception table:
        from    to  target  type
           8     9      10  Class java.lang.IllegalArgumentException
    Signature: (Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;)Ljava/lang/String;
    MethodParameters:
          Name  Flags
      sniNames  

  static java.util.List<javax.net.ssl.SNIServerName> getRequestedServerNames(java.net.Socket);
    descriptor: (Ljava/net/Socket;)Ljava/util/List;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=4, args_size=1
        start local 0 // java.net.Socket socket
         0: .line 386
            aload 0 /* socket */
            ifnull 7
            aload 0 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 7
         1: .line 387
            aload 0 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 7
         2: .line 389
            aload 0 /* socket */
            checkcast javax.net.ssl.SSLSocket
            astore 1 /* sslSocket */
        start local 1 // javax.net.ssl.SSLSocket sslSocket
         3: .line 390
            aload 1 /* sslSocket */
            invokevirtual javax.net.ssl.SSLSocket.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
            astore 2 /* session */
        start local 2 // javax.net.ssl.SSLSession session
         4: .line 392
            aload 2 /* session */
            ifnull 7
            aload 2 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 7
         5: .line 393
            aload 2 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 3 /* extSession */
        start local 3 // javax.net.ssl.ExtendedSSLSession extSession
         6: .line 394
            aload 3 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getRequestedServerNames:()Ljava/util/List;
            areturn
        end local 3 // javax.net.ssl.ExtendedSSLSession extSession
        end local 2 // javax.net.ssl.SSLSession session
        end local 1 // javax.net.ssl.SSLSocket sslSocket
         7: .line 398
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
        end local 0 // java.net.Socket socket
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    8     0      socket  Ljava/net/Socket;
            3    7     1   sslSocket  Ljavax/net/ssl/SSLSocket;
            4    7     2     session  Ljavax/net/ssl/SSLSession;
            6    7     3  extSession  Ljavax/net/ssl/ExtendedSSLSession;
    Signature: (Ljava/net/Socket;)Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
    MethodParameters:
        Name  Flags
      socket  

  static java.util.List<javax.net.ssl.SNIServerName> getRequestedServerNames(javax.net.ssl.SSLEngine);
    descriptor: (Ljavax/net/ssl/SSLEngine;)Ljava/util/List;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // javax.net.ssl.SSLEngine engine
         0: .line 403
            aload 0 /* engine */
            ifnull 5
         1: .line 404
            aload 0 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
            astore 1 /* session */
        start local 1 // javax.net.ssl.SSLSession session
         2: .line 406
            aload 1 /* session */
            ifnull 5
            aload 1 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 5
         3: .line 407
            aload 1 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 2 /* extSession */
        start local 2 // javax.net.ssl.ExtendedSSLSession extSession
         4: .line 408
            aload 2 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getRequestedServerNames:()Ljava/util/List;
            areturn
        end local 2 // javax.net.ssl.ExtendedSSLSession extSession
        end local 1 // javax.net.ssl.SSLSession session
         5: .line 412
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
        end local 0 // javax.net.ssl.SSLEngine engine
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    6     0      engine  Ljavax/net/ssl/SSLEngine;
            2    5     1     session  Ljavax/net/ssl/SSLSession;
            4    5     2  extSession  Ljavax/net/ssl/ExtendedSSLSession;
    Signature: (Ljavax/net/ssl/SSLEngine;)Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
    MethodParameters:
        Name  Flags
      engine  

  private static void checkIdentity(javax.net.ssl.SSLSession, java.security.cert.X509Certificate, java.lang.String, boolean, java.util.List<javax.net.ssl.SNIServerName>, );
    descriptor: (Ljavax/net/ssl/SSLSession;Ljava/security/cert/X509Certificate;Ljava/lang/String;ZLjava/util/List;Z)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=10, args_size=6
        start local 0 // javax.net.ssl.SSLSession session
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.lang.String algorithm
        start local 3 // boolean isClient
        start local 4 // java.util.List sniNames
        start local 5 // boolean chainsToPublicCA
         0: .line 437
            iconst_0
            istore 6 /* identifiable */
        start local 6 // boolean identifiable
         1: .line 438
            aload 0 /* session */
            invokeinterface javax.net.ssl.SSLSession.getPeerHost:()Ljava/lang/String;
            astore 7 /* peerHost */
        start local 7 // java.lang.String peerHost
         2: .line 439
            iload 3 /* isClient */
            ifeq 11
         3: .line 440
            aload 4 /* sniNames */
            invokestatic sun.security.ssl.X509TrustManagerImpl.getHostNameInSNI:(Ljava/util/List;)Ljava/lang/String;
            astore 8 /* hostname */
        start local 8 // java.lang.String hostname
         4: .line 441
            aload 8 /* hostname */
            ifnull 11
         5: .line 443
            aload 8 /* hostname */
            aload 1 /* cert */
            aload 2 /* algorithm */
            iload 5 /* chainsToPublicCA */
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
         6: .line 444
            iconst_1
            istore 6 /* identifiable */
         7: .line 445
            goto 11
      StackMap locals: javax.net.ssl.SSLSession java.security.cert.X509Certificate java.lang.String int java.util.List int int java.lang.String java.lang.String
      StackMap stack: java.security.cert.CertificateException
         8: astore 9 /* ce */
        start local 9 // java.security.cert.CertificateException ce
         9: .line 446
            aload 8 /* hostname */
            aload 7 /* peerHost */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 11
        10: .line 447
            aload 9 /* ce */
            athrow
        end local 9 // java.security.cert.CertificateException ce
        end local 8 // java.lang.String hostname
        11: .line 455
      StackMap locals:
      StackMap stack:
            iload 6 /* identifiable */
            ifne 13
        12: .line 456
            aload 7 /* peerHost */
            aload 1 /* cert */
            aload 2 /* algorithm */
            iload 5 /* chainsToPublicCA */
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
        13: .line 458
      StackMap locals:
      StackMap stack:
            return
        end local 7 // java.lang.String peerHost
        end local 6 // boolean identifiable
        end local 5 // boolean chainsToPublicCA
        end local 4 // java.util.List sniNames
        end local 3 // boolean isClient
        end local 2 // java.lang.String algorithm
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // javax.net.ssl.SSLSession session
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   14     0           session  Ljavax/net/ssl/SSLSession;
            0   14     1              cert  Ljava/security/cert/X509Certificate;
            0   14     2         algorithm  Ljava/lang/String;
            0   14     3          isClient  Z
            0   14     4          sniNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
            0   14     5  chainsToPublicCA  Z
            1   14     6      identifiable  Z
            2   14     7          peerHost  Ljava/lang/String;
            4   11     8          hostname  Ljava/lang/String;
            9   11     9                ce  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
           5     7       8  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Ljavax/net/ssl/SSLSession;Ljava/security/cert/X509Certificate;Ljava/lang/String;ZLjava/util/List<Ljavax/net/ssl/SNIServerName;>;Z)V
    MethodParameters:
                  Name  Flags
      session           
      cert              
      algorithm         
      isClient          
      sniNames          
      chainsToPublicCA  

  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=4, 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 467
            aload 0 /* hostname */
            aload 1 /* cert */
            aload 2 /* algorithm */
            iconst_0
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
         1: .line 468
            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    2     0   hostname  Ljava/lang/String;
            0    2     1       cert  Ljava/security/cert/X509Certificate;
            0    2     2  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
           Name  Flags
      hostname   
      cert       
      algorithm  

  private static void checkIdentity(java.lang.String, java.security.cert.X509Certificate, java.lang.String, boolean);
    descriptor: (Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // java.lang.String hostname
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.lang.String algorithm
        start local 3 // boolean chainsToPublicCA
         0: .line 473
            aload 2 /* algorithm */
            ifnull 18
            aload 2 /* algorithm */
            invokevirtual java.lang.String.length:()I
            ifeq 18
         1: .line 475
            aload 0 /* hostname */
            ifnull 4
            aload 0 /* hostname */
            ldc "["
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 4
         2: .line 476
            aload 0 /* hostname */
            ldc "]"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 477
            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 480
      StackMap locals:
      StackMap stack:
            aload 2 /* algorithm */
            ldc "HTTPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 9
         5: .line 481
            iconst_1
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
         6: .line 482
            aload 0 /* hostname */
            aload 1 /* cert */
            iload 3 /* chainsToPublicCA */
         7: .line 481
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Z)V
         8: .line 483
            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 484
            aload 2 /* algorithm */
            ldc "LDAPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 15
        11: .line 485
      StackMap locals:
      StackMap stack:
            iconst_2
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
        12: .line 486
            aload 0 /* hostname */
            aload 1 /* cert */
            iload 3 /* chainsToPublicCA */
        13: .line 485
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Z)V
        14: .line 487
            goto 18
        15: .line 488
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateException
            dup
        16: .line 489
            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 488
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 492
      StackMap locals:
      StackMap stack:
            return
        end local 3 // boolean chainsToPublicCA
        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;
            0   19     3  chainsToPublicCA  Z
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
                  Name  Flags
      hostname          
      cert              
      algorithm         
      chainsToPublicCA  
}
SourceFile: "X509TrustManagerImpl.java"