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

  void <init>(java.lang.String, java.util.Collection<java.security.cert.X509Certificate>);
    descriptor: (Ljava/lang/String;Ljava/util/Collection;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=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 66
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedTrustManager.<init>:()V
         1: .line 69
            aload 0 /* this */
            aload 1 /* validatorType */
            putfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
         2: .line 70
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
         3: .line 72
            aload 2 /* trustedCerts */
            ifnonnull 5
         4: .line 73
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 2 /* trustedCerts */
         5: .line 76
      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 78
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 10
            ldc "ssl,trustmanager"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 10
         7: .line 79
            ldc "adding as trusted certificates"
         8: .line 80
            aload 2 /* trustedCerts */
            iconst_0
            anewarray java.security.cert.X509Certificate
            invokeinterface java.util.Collection.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
         9: .line 79
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        10: .line 82
      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   11     0           this  Lsun/security/ssl/X509TrustManagerImpl;
            0   11     1  validatorType  Ljava/lang/String;
            0   11     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=3, 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 84
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedTrustManager.<init>:()V
         1: .line 85
            aload 0 /* this */
            aload 1 /* validatorType */
            putfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
         2: .line 86
            aload 0 /* this */
            aload 2 /* params */
            putfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
         3: .line 91
            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 92
            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 93
            aload 0 /* this */
            aload 3 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
         6: .line 95
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 10
            ldc "ssl,trustmanager"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 10
         7: .line 96
            ldc "adding as trusted certificates"
         8: .line 97
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
            iconst_0
            anewarray java.security.cert.X509Certificate
            invokeinterface java.util.Collection.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
         9: .line 96
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        10: .line 99
      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   11     0           this  Lsun/security/ssl/X509TrustManagerImpl;
            0   11     1  validatorType  Ljava/lang/String;
            0   11     2         params  Ljava/security/cert/PKIXBuilderParameters;
            4   11     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 104
            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 105
            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 110
            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 111
            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 115
            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 116
            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 117
            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 123
            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 124
            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 129
            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 130
            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 135
            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 136
            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 141
            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 142
            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 checkClientTrusted
         0: .line 146
            aload 1 /* chain */
            ifnull 1
            aload 1 /* chain */
            arraylength
            ifne 4
         1: .line 147
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         2: .line 148
            ldc "null or zero-length certificate chain"
         3: .line 147
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 151
      StackMap locals:
      StackMap stack:
            aload 2 /* authType */
            ifnull 5
            aload 2 /* authType */
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 8
         5: .line 152
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         6: .line 153
            ldc "null or zero-length authentication type"
         7: .line 152
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 156
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* v */
        start local 4 // sun.security.validator.Validator v
         9: .line 157
            iload 3 /* checkClientTrusted */
            ifeq 21
        10: .line 158
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        11: .line 159
            aload 4 /* v */
            ifnonnull 32
        12: .line 160
            aload 0 /* this */
            dup
            astore 5
            monitorenter
        13: .line 161
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        14: .line 162
            aload 4 /* v */
            ifnonnull 17
        15: .line 163
            aload 0 /* this */
            ldc "tls client"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 4 /* v */
        16: .line 164
            aload 0 /* this */
            aload 4 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
        17: .line 160
      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 171
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        22: .line 172
            aload 4 /* v */
            ifnonnull 32
        23: .line 173
            aload 0 /* this */
            dup
            astore 5
            monitorenter
        24: .line 174
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        25: .line 175
            aload 4 /* v */
            ifnonnull 28
        26: .line 176
            aload 0 /* this */
            ldc "tls server"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 4 /* v */
        27: .line 177
            aload 0 /* this */
            aload 4 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
        28: .line 173
      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 183
      StackMap locals:
      StackMap stack:
            aload 4 /* v */
            areturn
        end local 4 // sun.security.validator.Validator v
        end local 3 // boolean checkClientTrusted
        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  checkClientTrusted  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            
      checkClientTrusted  

  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=7, 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 checkClientTrusted
         0: .line 189
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            iload 4 /* checkClientTrusted */
            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 191
            aconst_null
            astore 6 /* trustedChain */
        start local 6 // java.security.cert.X509Certificate[] trustedChain
         2: .line 192
            aload 3 /* socket */
            ifnull 35
            aload 3 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 35
         3: .line 193
            aload 3 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 35
         4: .line 195
            aload 3 /* socket */
            checkcast javax.net.ssl.SSLSocket
            astore 7 /* sslSocket */
        start local 7 // javax.net.ssl.SSLSocket sslSocket
         5: .line 196
            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 197
            aload 8 /* session */
            ifnonnull 8
         7: .line 198
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 202
      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 */
            instanceof javax.net.ssl.ExtendedSSLSession
            istore 9 /* isExtSession */
        start local 9 // boolean isExtSession
         9: .line 204
            iload 9 /* isExtSession */
            ifeq 18
        10: .line 205
            aload 8 /* session */
            invokeinterface javax.net.ssl.SSLSession.getProtocol:()Ljava/lang/String;
            invokestatic sun.security.ssl.ProtocolVersion.useTLS12PlusSpec:(Ljava/lang/String;)Z
            ifeq 18
        11: .line 206
            aload 8 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 11 /* extSession */
        start local 11 // javax.net.ssl.ExtendedSSLSession extSession
        12: .line 208
            aload 11 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        13: .line 207
            astore 12 /* localSupportedSignAlgs */
        start local 12 // java.lang.String[] localSupportedSignAlgs
        14: .line 210
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        15: .line 211
            aload 7 /* sslSocket */
            aload 12 /* localSupportedSignAlgs */
            iconst_0
        16: .line 210
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;[Ljava/lang/String;Z)V
            astore 10 /* constraints */
        end local 12 // java.lang.String[] localSupportedSignAlgs
        end local 11 // javax.net.ssl.ExtendedSSLSession extSession
        start local 10 // java.security.AlgorithmConstraints constraints
        17: .line 212
            goto 19
        end local 10 // java.security.AlgorithmConstraints constraints
        18: .line 213
      StackMap locals: int
      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 10 /* constraints */
        start local 10 // java.security.AlgorithmConstraints constraints
        19: .line 217
      StackMap locals: java.security.AlgorithmConstraints
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            astore 11 /* responseList */
        start local 11 // java.util.List responseList
        20: .line 218
            iload 4 /* checkClientTrusted */
            ifne 23
            iload 9 /* isExtSession */
            ifeq 23
        21: .line 220
            aload 8 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getStatusResponses:()Ljava/util/List;
        22: .line 219
            astore 11 /* responseList */
        23: .line 222
      StackMap locals: java.util.List
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aload 11 /* responseList */
        24: .line 223
            aload 10 /* constraints */
            iload 4 /* checkClientTrusted */
            ifeq 25
            aconst_null
            goto 26
      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 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 222
      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 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 226
            aload 7 /* sslSocket */
            invokevirtual javax.net.ssl.SSLSocket.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
        28: .line 227
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
        29: .line 226
            astore 12 /* identityAlg */
        start local 12 // java.lang.String identityAlg
        30: .line 228
            aload 12 /* identityAlg */
            ifnull 39
            aload 12 /* identityAlg */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 39
        31: .line 229
            aload 8 /* session */
        32: .line 230
            aload 6 /* trustedChain */
            aload 12 /* identityAlg */
            iload 4 /* checkClientTrusted */
        33: .line 229
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljavax/net/ssl/SSLSession;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
        end local 12 // java.lang.String identityAlg
        end local 11 // java.util.List responseList
        end local 10 // java.security.AlgorithmConstraints constraints
        end local 9 // boolean isExtSession
        end local 8 // javax.net.ssl.SSLSession session
        end local 7 // javax.net.ssl.SSLSocket sslSocket
        34: .line 232
            goto 39
        35: .line 233
      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;
        36: .line 234
            aconst_null
            iload 4 /* checkClientTrusted */
            ifeq 37
            aconst_null
            goto 38
      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
        37: aload 2 /* authType */
        38: .line 233
      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 */
        39: .line 237
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 43
            ldc "ssl,trustmanager"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 43
        40: .line 238
            ldc "Found trusted certificate"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        41: .line 239
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            aastore
        42: .line 238
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        43: .line 241
      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 checkClientTrusted
        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   44     0                    this  Lsun/security/ssl/X509TrustManagerImpl;
            0   44     1                   chain  [Ljava/security/cert/X509Certificate;
            0   44     2                authType  Ljava/lang/String;
            0   44     3                  socket  Ljava/net/Socket;
            0   44     4      checkClientTrusted  Z
            1   44     5                       v  Lsun/security/validator/Validator;
            2   44     6            trustedChain  [Ljava/security/cert/X509Certificate;
            5   34     7               sslSocket  Ljavax/net/ssl/SSLSocket;
            6   34     8                 session  Ljavax/net/ssl/SSLSession;
            9   34     9            isExtSession  Z
           17   18    10             constraints  Ljava/security/AlgorithmConstraints;
           19   34    10             constraints  Ljava/security/AlgorithmConstraints;
           12   17    11              extSession  Ljavax/net/ssl/ExtendedSSLSession;
           14   17    12  localSupportedSignAlgs  [Ljava/lang/String;
           20   34    11            responseList  Ljava/util/List<[B>;
           30   34    12             identityAlg  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
                    Name  Flags
      chain               
      authType            
      socket              
      checkClientTrusted  

  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=7, 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 checkClientTrusted
         0: .line 246
            aload 0 /* this */
            aload 1 /* chain */
            aload 2 /* authType */
            iload 4 /* checkClientTrusted */
            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 248
            aconst_null
            astore 6 /* trustedChain */
        start local 6 // java.security.cert.X509Certificate[] trustedChain
         2: .line 249
            aload 3 /* engine */
            ifnull 33
         3: .line 250
            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 251
            aload 7 /* session */
            ifnonnull 6
         5: .line 252
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 256
      StackMap locals: sun.security.validator.Validator java.security.cert.X509Certificate[] javax.net.ssl.SSLSession
      StackMap stack:
            aload 7 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            istore 8 /* isExtSession */
        start local 8 // boolean isExtSession
         7: .line 258
            iload 8 /* isExtSession */
            ifeq 16
         8: .line 259
            aload 7 /* session */
            invokeinterface javax.net.ssl.SSLSession.getProtocol:()Ljava/lang/String;
            invokestatic sun.security.ssl.ProtocolVersion.useTLS12PlusSpec:(Ljava/lang/String;)Z
            ifeq 16
         9: .line 260
            aload 7 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 10 /* extSession */
        start local 10 // javax.net.ssl.ExtendedSSLSession extSession
        10: .line 262
            aload 10 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        11: .line 261
            astore 11 /* localSupportedSignAlgs */
        start local 11 // java.lang.String[] localSupportedSignAlgs
        12: .line 264
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        13: .line 265
            aload 3 /* engine */
            aload 11 /* localSupportedSignAlgs */
            iconst_0
        14: .line 264
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;[Ljava/lang/String;Z)V
            astore 9 /* constraints */
        end local 11 // java.lang.String[] localSupportedSignAlgs
        end local 10 // javax.net.ssl.ExtendedSSLSession extSession
        start local 9 // java.security.AlgorithmConstraints constraints
        15: .line 266
            goto 17
        end local 9 // java.security.AlgorithmConstraints constraints
        16: .line 267
      StackMap locals: int
      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 9 /* constraints */
        start local 9 // java.security.AlgorithmConstraints constraints
        17: .line 271
      StackMap locals: java.security.AlgorithmConstraints
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            astore 10 /* responseList */
        start local 10 // java.util.List responseList
        18: .line 272
            iload 4 /* checkClientTrusted */
            ifne 21
            iload 8 /* isExtSession */
            ifeq 21
        19: .line 274
            aload 7 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getStatusResponses:()Ljava/util/List;
        20: .line 273
            astore 10 /* responseList */
        21: .line 276
      StackMap locals: java.util.List
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aload 10 /* responseList */
        22: .line 277
            aload 9 /* constraints */
            iload 4 /* checkClientTrusted */
            ifeq 23
            aconst_null
            goto 24
      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 int java.security.AlgorithmConstraints java.util.List
      StackMap stack: sun.security.validator.Validator java.security.cert.X509Certificate[] java.util.List java.security.AlgorithmConstraints
        23: aload 2 /* authType */
        24: .line 276
      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 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 */
        25: .line 280
            aload 3 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
        26: .line 281
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
        27: .line 280
            astore 11 /* identityAlg */
        start local 11 // java.lang.String identityAlg
        28: .line 282
            aload 11 /* identityAlg */
            ifnull 37
            aload 11 /* identityAlg */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 37
        29: .line 283
            aload 7 /* session */
            aload 6 /* trustedChain */
        30: .line 284
            aload 11 /* identityAlg */
            iload 4 /* checkClientTrusted */
        31: .line 283
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljavax/net/ssl/SSLSession;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
        end local 11 // java.lang.String identityAlg
        end local 10 // java.util.List responseList
        end local 9 // java.security.AlgorithmConstraints constraints
        end local 8 // boolean isExtSession
        end local 7 // javax.net.ssl.SSLSession session
        32: .line 286
            goto 37
        33: .line 287
      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;
        34: .line 288
            aconst_null
            iload 4 /* checkClientTrusted */
            ifeq 35
            aconst_null
            goto 36
      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
        35: aload 2 /* authType */
        36: .line 287
      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 */
        37: .line 291
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 41
            ldc "ssl,trustmanager"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 41
        38: .line 292
            ldc "Found trusted certificate"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        39: .line 293
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            aastore
        40: .line 292
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        41: .line 295
      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 checkClientTrusted
        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   42     0                    this  Lsun/security/ssl/X509TrustManagerImpl;
            0   42     1                   chain  [Ljava/security/cert/X509Certificate;
            0   42     2                authType  Ljava/lang/String;
            0   42     3                  engine  Ljavax/net/ssl/SSLEngine;
            0   42     4      checkClientTrusted  Z
            1   42     5                       v  Lsun/security/validator/Validator;
            2   42     6            trustedChain  [Ljava/security/cert/X509Certificate;
            4   32     7                 session  Ljavax/net/ssl/SSLSession;
            7   32     8            isExtSession  Z
           15   16     9             constraints  Ljava/security/AlgorithmConstraints;
           17   32     9             constraints  Ljava/security/AlgorithmConstraints;
           10   15    10              extSession  Ljavax/net/ssl/ExtendedSSLSession;
           12   15    11  localSupportedSignAlgs  [Ljava/lang/String;
           18   32    10            responseList  Ljava/util/List<[B>;
           28   32    11             identityAlg  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
                    Name  Flags
      chain               
      authType            
      engine              
      checkClientTrusted  

  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 299
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
            ifnonnull 3
         1: .line 300
            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 301
            goto 4
        end local 2 // sun.security.validator.Validator v
         3: .line 302
      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 304
      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 311
            invokestatic sun.security.ssl.JsseJce.beginFipsProvider:()Ljava/lang/Object;
            astore 5 /* o */
        start local 5 // java.lang.Object o
         1: .line 313
            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 315
            aload 5 /* o */
            invokestatic sun.security.ssl.JsseJce.endFipsProvider:(Ljava/lang/Object;)V
         3: .line 313
            aload 7
            areturn
         4: .line 314
      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 315
            aload 5 /* o */
            invokestatic sun.security.ssl.JsseJce.endFipsProvider:(Ljava/lang/Object;)V
         6: .line 316
            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=3, locals=4, args_size=1
        start local 0 // java.util.List sniNames
         0: .line 324
            aconst_null
            astore 1 /* hostname */
        start local 1 // javax.net.ssl.SNIHostName hostname
         1: .line 325
            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 326
            aload 2 /* sniName */
            invokevirtual javax.net.ssl.SNIServerName.getType:()I
            ifeq 5
         4: .line 327
            goto 14
         5: .line 330
      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 331
            aload 2 /* sniName */
            checkcast javax.net.ssl.SNIHostName
            astore 1 /* hostname */
         7: .line 332
            goto 15
         8: .line 334
      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 335
            goto 15
      StackMap locals:
      StackMap stack: java.lang.IllegalArgumentException
        10: pop
        11: .line 337
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 15
            ldc "ssl,trustmanager"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 15
        12: .line 338
            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;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        13: .line 344
            goto 15
        end local 2 // javax.net.ssl.SNIServerName sniName
        14: .line 325
      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 347
      StackMap locals: java.util.List javax.net.ssl.SNIHostName
      StackMap stack:
            aload 1 /* hostname */
            ifnull 17
        16: .line 348
            aload 1 /* hostname */
            invokevirtual javax.net.ssl.SNIHostName.getAsciiName:()Ljava/lang/String;
            areturn
        17: .line 351
      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=1, args_size=1
        start local 0 // java.net.Socket socket
         0: .line 356
            aload 0 /* socket */
            ifnull 4
            aload 0 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 4
         1: .line 357
            aload 0 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 4
         2: .line 359
            aload 0 /* socket */
            checkcast javax.net.ssl.SSLSocket
            invokevirtual javax.net.ssl.SSLSocket.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
         3: .line 358
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljavax/net/ssl/SSLSession;)Ljava/util/List;
            areturn
         4: .line 362
      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    5     0  socket  Ljava/net/Socket;
    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=1, args_size=1
        start local 0 // javax.net.ssl.SSLEngine engine
         0: .line 367
            aload 0 /* engine */
            ifnull 2
         1: .line 368
            aload 0 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljavax/net/ssl/SSLSession;)Ljava/util/List;
            areturn
         2: .line 371
      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    3     0  engine  Ljavax/net/ssl/SSLEngine;
    Signature: (Ljavax/net/ssl/SSLEngine;)Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
    MethodParameters:
        Name  Flags
      engine  

  private static java.util.List<javax.net.ssl.SNIServerName> getRequestedServerNames(javax.net.ssl.SSLSession);
    descriptor: (Ljavax/net/ssl/SSLSession;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.net.ssl.SSLSession session
         0: .line 376
            aload 0 /* session */
            ifnull 2
            aload 0 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 2
         1: .line 377
            aload 0 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getRequestedServerNames:()Ljava/util/List;
            areturn
         2: .line 380
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
        end local 0 // javax.net.ssl.SSLSession session
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0  session  Ljavax/net/ssl/SSLSession;
    Signature: (Ljavax/net/ssl/SSLSession;)Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
    MethodParameters:
         Name  Flags
      session  

  static void checkIdentity(javax.net.ssl.SSLSession, java.security.cert.X509Certificate[], java.lang.String, boolean);
    descriptor: (Ljavax/net/ssl/SSLSession;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=10, args_size=4
        start local 0 // javax.net.ssl.SSLSession session
        start local 1 // java.security.cert.X509Certificate[] trustedChain
        start local 2 // java.lang.String algorithm
        start local 3 // boolean checkClientTrusted
         0: .line 406
            aload 1 /* trustedChain */
            aload 1 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
         1: .line 405
            invokestatic sun.security.util.AnchorCertificates.contains:(Ljava/security/cert/X509Certificate;)Z
            istore 4 /* chainsToPublicCA */
        start local 4 // boolean chainsToPublicCA
         2: .line 408
            iconst_0
            istore 5 /* identifiable */
        start local 5 // boolean identifiable
         3: .line 409
            aload 0 /* session */
            invokeinterface javax.net.ssl.SSLSession.getPeerHost:()Ljava/lang/String;
            astore 6 /* peerHost */
        start local 6 // java.lang.String peerHost
         4: .line 410
            iload 3 /* checkClientTrusted */
            ifne 16
         5: .line 411
            aload 0 /* session */
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljavax/net/ssl/SSLSession;)Ljava/util/List;
            astore 7 /* sniNames */
        start local 7 // java.util.List sniNames
         6: .line 412
            aload 7 /* sniNames */
            invokestatic sun.security.ssl.X509TrustManagerImpl.getHostNameInSNI:(Ljava/util/List;)Ljava/lang/String;
            astore 8 /* sniHostName */
        start local 8 // java.lang.String sniHostName
         7: .line 413
            aload 8 /* sniHostName */
            ifnull 16
         8: .line 415
            aload 8 /* sniHostName */
         9: .line 416
            aload 1 /* trustedChain */
            iconst_0
            aaload
            aload 2 /* algorithm */
            iload 4 /* chainsToPublicCA */
        10: .line 415
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
        11: .line 417
            iconst_1
            istore 5 /* identifiable */
        12: .line 418
            goto 16
      StackMap locals: javax.net.ssl.SSLSession java.security.cert.X509Certificate[] java.lang.String int int int java.lang.String java.util.List java.lang.String
      StackMap stack: java.security.cert.CertificateException
        13: astore 9 /* ce */
        start local 9 // java.security.cert.CertificateException ce
        14: .line 419
            aload 8 /* sniHostName */
            aload 6 /* peerHost */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 16
        15: .line 420
            aload 9 /* ce */
            athrow
        end local 9 // java.security.cert.CertificateException ce
        end local 8 // java.lang.String sniHostName
        end local 7 // java.util.List sniNames
        16: .line 428
      StackMap locals:
      StackMap stack:
            iload 5 /* identifiable */
            ifne 20
        17: .line 429
            aload 6 /* peerHost */
        18: .line 430
            aload 1 /* trustedChain */
            iconst_0
            aaload
            aload 2 /* algorithm */
            iload 4 /* chainsToPublicCA */
        19: .line 429
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
        20: .line 432
      StackMap locals:
      StackMap stack:
            return
        end local 6 // java.lang.String peerHost
        end local 5 // boolean identifiable
        end local 4 // boolean chainsToPublicCA
        end local 3 // boolean checkClientTrusted
        end local 2 // java.lang.String algorithm
        end local 1 // java.security.cert.X509Certificate[] trustedChain
        end local 0 // javax.net.ssl.SSLSession session
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   21     0             session  Ljavax/net/ssl/SSLSession;
            0   21     1        trustedChain  [Ljava/security/cert/X509Certificate;
            0   21     2           algorithm  Ljava/lang/String;
            0   21     3  checkClientTrusted  Z
            2   21     4    chainsToPublicCA  Z
            3   21     5        identifiable  Z
            4   21     6            peerHost  Ljava/lang/String;
            6   16     7            sniNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
            7   16     8         sniHostName  Ljava/lang/String;
           14   16     9                  ce  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
           8    12      13  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
                    Name  Flags
      session             
      trustedChain        
      algorithm           
      checkClientTrusted  

  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 441
            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 442
            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 447
            aload 2 /* algorithm */
            ifnull 18
            aload 2 /* algorithm */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 18
         1: .line 449
            aload 0 /* hostname */
            ifnull 4
            aload 0 /* hostname */
            ldc "["
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 4
         2: .line 450
            aload 0 /* hostname */
            ldc "]"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 451
            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 454
      StackMap locals:
      StackMap stack:
            aload 2 /* algorithm */
            ldc "HTTPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 9
         5: .line 455
            iconst_1
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
         6: .line 456
            aload 0 /* hostname */
            aload 1 /* cert */
            iload 3 /* chainsToPublicCA */
         7: .line 455
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Z)V
         8: .line 457
            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 458
            aload 2 /* algorithm */
            ldc "LDAPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 15
        11: .line 459
      StackMap locals:
      StackMap stack:
            iconst_2
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
        12: .line 460
            aload 0 /* hostname */
            aload 1 /* cert */
            iload 3 /* chainsToPublicCA */
        13: .line 459
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Z)V
        14: .line 461
            goto 18
        15: .line 462
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateException
            dup
        16: .line 463
            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 462
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 466
      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"