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 final java.util.concurrent.locks.ReentrantLock validatorLock;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  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 69
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedTrustManager.<init>:()V
         1: .line 67
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
         2: .line 72
            aload 0 /* this */
            aload 1 /* validatorType */
            putfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
         3: .line 73
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
         4: .line 75
            aload 2 /* trustedCerts */
            ifnonnull 6
         5: .line 76
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 2 /* trustedCerts */
         6: .line 79
      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;
         7: .line 81
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 11
            ldc "ssl,trustmanager"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 11
         8: .line 82
            ldc "adding as trusted certificates"
         9: .line 83
            aload 2 /* trustedCerts */
            iconst_0
            anewarray java.security.cert.X509Certificate
            invokeinterface java.util.Collection.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
        10: .line 82
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        11: .line 85
      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   12     0           this  Lsun/security/ssl/X509TrustManagerImpl;
            0   12     1  validatorType  Ljava/lang/String;
            0   12     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 87
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedTrustManager.<init>:()V
         1: .line 67
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
         2: .line 88
            aload 0 /* this */
            aload 1 /* validatorType */
            putfield sun.security.ssl.X509TrustManagerImpl.validatorType:Ljava/lang/String;
         3: .line 89
            aload 0 /* this */
            aload 2 /* params */
            putfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
         4: .line 94
            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
         5: .line 95
            aload 0 /* this */
            aload 3 /* v */
            invokevirtual sun.security.validator.Validator.getTrustedCertificates:()Ljava/util/Collection;
            putfield sun.security.ssl.X509TrustManagerImpl.trustedCerts:Ljava/util/Collection;
         6: .line 96
            aload 0 /* this */
            aload 3 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
         7: .line 98
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 11
            ldc "ssl,trustmanager"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 11
         8: .line 99
            ldc "adding as trusted certificates"
         9: .line 100
            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;
        10: .line 99
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        11: .line 102
      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   12     0           this  Lsun/security/ssl/X509TrustManagerImpl;
            0   12     1  validatorType  Ljava/lang/String;
            0   12     2         params  Ljava/security/cert/PKIXBuilderParameters;
            5   12     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 107
            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 108
            return
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  

  public 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 113
            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 114
            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 118
            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 119
            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 120
            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 126
            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 127
            return
        end local 3 // java.net.Socket socket
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
            0    2     3    socket  Ljava/net/Socket;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      socket    

  public void 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 132
            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 133
            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 138
            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 139
            return
        end local 3 // javax.net.ssl.SSLEngine engine
        end local 2 // java.lang.String authType
        end local 1 // java.security.cert.X509Certificate[] chain
        end local 0 // sun.security.ssl.X509TrustManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/X509TrustManagerImpl;
            0    2     1     chain  [Ljava/security/cert/X509Certificate;
            0    2     2  authType  Ljava/lang/String;
            0    2     3    engine  Ljavax/net/ssl/SSLEngine;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      chain     
      authType  
      engine    

  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 144
            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 145
            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 149
            aload 1 /* chain */
            ifnull 1
            aload 1 /* chain */
            arraylength
            ifne 4
         1: .line 150
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         2: .line 151
            ldc "null or zero-length certificate chain"
         3: .line 150
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 154
      StackMap locals:
      StackMap stack:
            aload 2 /* authType */
            ifnull 5
            aload 2 /* authType */
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 8
         5: .line 155
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         6: .line 156
            ldc "null or zero-length authentication type"
         7: .line 155
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 159
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* v */
        start local 4 // sun.security.validator.Validator v
         9: .line 160
            iload 3 /* checkClientTrusted */
            ifeq 23
        10: .line 161
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.clientValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        11: .line 162
            aload 4 /* v */
            ifnonnull 35
        12: .line 163
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
        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 21
        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 170
            goto 21
      StackMap locals: sun.security.ssl.X509TrustManagerImpl java.security.cert.X509Certificate[] java.lang.String int sun.security.validator.Validator
      StackMap stack: java.lang.Throwable
        18: astore 5
        19: .line 171
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        20: .line 172
            aload 5
            athrow
        21: .line 171
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        22: .line 174
            goto 35
        23: .line 177
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        24: .line 178
            aload 4 /* v */
            ifnonnull 35
        25: .line 179
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
        26: .line 181
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
            astore 4 /* v */
        27: .line 182
            aload 4 /* v */
            ifnonnull 34
        28: .line 183
            aload 0 /* this */
            ldc "tls server"
            invokevirtual sun.security.ssl.X509TrustManagerImpl.getValidator:(Ljava/lang/String;)Lsun/security/validator/Validator;
            astore 4 /* v */
        29: .line 184
            aload 0 /* this */
            aload 4 /* v */
            putfield sun.security.ssl.X509TrustManagerImpl.serverValidator:Lsun/security/validator/Validator;
        30: .line 186
            goto 34
      StackMap locals:
      StackMap stack: java.lang.Throwable
        31: astore 5
        32: .line 187
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        33: .line 188
            aload 5
            athrow
        34: .line 187
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.validatorLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        35: .line 192
      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   36     0                this  Lsun/security/ssl/X509TrustManagerImpl;
            0   36     1               chain  [Ljava/security/cert/X509Certificate;
            0   36     2            authType  Ljava/lang/String;
            0   36     3  checkClientTrusted  Z
            9   36     4                   v  Lsun/security/validator/Validator;
      Exception table:
        from    to  target  type
          13    18      18  any
          26    31      31  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 198
            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 200
            aconst_null
            astore 6 /* trustedChain */
        start local 6 // java.security.cert.X509Certificate[] trustedChain
         2: .line 201
            aload 3 /* socket */
            ifnull 35
            aload 3 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 35
         3: .line 202
            aload 3 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 35
         4: .line 204
            aload 3 /* socket */
            checkcast javax.net.ssl.SSLSocket
            astore 7 /* sslSocket */
        start local 7 // javax.net.ssl.SSLSocket sslSocket
         5: .line 205
            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 206
            aload 8 /* session */
            ifnonnull 8
         7: .line 207
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 211
      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 213
            iload 9 /* isExtSession */
            ifeq 18
        10: .line 214
            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 215
            aload 8 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 11 /* extSession */
        start local 11 // javax.net.ssl.ExtendedSSLSession extSession
        12: .line 217
            aload 11 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        13: .line 216
            astore 12 /* localSupportedSignAlgs */
        start local 12 // java.lang.String[] localSupportedSignAlgs
        14: .line 219
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        15: .line 220
            aload 7 /* sslSocket */
            aload 12 /* localSupportedSignAlgs */
            iconst_0
        16: .line 219
            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 221
            goto 19
        end local 10 // java.security.AlgorithmConstraints constraints
        18: .line 222
      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 226
      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 227
            iload 4 /* checkClientTrusted */
            ifne 23
            iload 9 /* isExtSession */
            ifeq 23
        21: .line 229
            aload 8 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getStatusResponses:()Ljava/util/List;
        22: .line 228
            astore 11 /* responseList */
        23: .line 231
      StackMap locals: java.util.List
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aconst_null
            aload 11 /* responseList */
        24: .line 232
            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[] null java.util.List java.security.AlgorithmConstraints
        25: aload 2 /* authType */
        26: .line 231
      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[] null java.util.List java.security.AlgorithmConstraints java.lang.String
            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 6 /* trustedChain */
        27: .line 235
            aload 7 /* sslSocket */
            invokevirtual javax.net.ssl.SSLSocket.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
        28: .line 236
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
        29: .line 235
            astore 12 /* identityAlg */
        start local 12 // java.lang.String identityAlg
        30: .line 237
            aload 12 /* identityAlg */
            ifnull 39
            aload 12 /* identityAlg */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 39
        31: .line 238
            aload 8 /* session */
        32: .line 239
            aload 6 /* trustedChain */
            aload 12 /* identityAlg */
            iload 4 /* checkClientTrusted */
        33: .line 238
            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 241
            goto 39
        35: .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 */
            aconst_null
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
        36: .line 243
            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[] null java.util.List null
        37: aload 2 /* authType */
        38: .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[] null java.util.List null java.lang.String
            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 6 /* trustedChain */
        39: .line 246
      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 247
            ldc "Found trusted certificate"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        41: .line 248
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            aastore
        42: .line 247
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        43: .line 250
      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 255
            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 257
            aconst_null
            astore 6 /* trustedChain */
        start local 6 // java.security.cert.X509Certificate[] trustedChain
         2: .line 258
            aload 3 /* engine */
            ifnull 33
         3: .line 259
            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 260
            aload 7 /* session */
            ifnonnull 6
         5: .line 261
            new java.security.cert.CertificateException
            dup
            ldc "No handshake session"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 265
      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 267
            iload 8 /* isExtSession */
            ifeq 16
         8: .line 268
            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 269
            aload 7 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            astore 10 /* extSession */
        start local 10 // javax.net.ssl.ExtendedSSLSession extSession
        10: .line 271
            aload 10 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getLocalSupportedSignatureAlgorithms:()[Ljava/lang/String;
        11: .line 270
            astore 11 /* localSupportedSignAlgs */
        start local 11 // java.lang.String[] localSupportedSignAlgs
        12: .line 273
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        13: .line 274
            aload 3 /* engine */
            aload 11 /* localSupportedSignAlgs */
            iconst_0
        14: .line 273
            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 275
            goto 17
        end local 9 // java.security.AlgorithmConstraints constraints
        16: .line 276
      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 280
      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 281
            iload 4 /* checkClientTrusted */
            ifne 21
            iload 8 /* isExtSession */
            ifeq 21
        19: .line 283
            aload 7 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getStatusResponses:()Ljava/util/List;
        20: .line 282
            astore 10 /* responseList */
        21: .line 285
      StackMap locals: java.util.List
      StackMap stack:
            aload 5 /* v */
            aload 1 /* chain */
            aconst_null
            aload 10 /* responseList */
        22: .line 286
            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[] null java.util.List java.security.AlgorithmConstraints
        23: aload 2 /* authType */
        24: .line 285
      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[] null java.util.List java.security.AlgorithmConstraints java.lang.String
            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 6 /* trustedChain */
        25: .line 289
            aload 3 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
        26: .line 290
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
        27: .line 289
            astore 11 /* identityAlg */
        start local 11 // java.lang.String identityAlg
        28: .line 291
            aload 11 /* identityAlg */
            ifnull 37
            aload 11 /* identityAlg */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 37
        29: .line 292
            aload 7 /* session */
            aload 6 /* trustedChain */
        30: .line 293
            aload 11 /* identityAlg */
            iload 4 /* checkClientTrusted */
        31: .line 292
            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 295
            goto 37
        33: .line 296
      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 */
            aconst_null
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
        34: .line 297
            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[] null java.util.List null
        35: aload 2 /* authType */
        36: .line 296
      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[] null java.util.List null java.lang.String
            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 6 /* trustedChain */
        37: .line 300
      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 301
            ldc "Found trusted certificate"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        39: .line 302
            aload 6 /* trustedChain */
            aload 6 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
            aastore
        40: .line 301
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        41: .line 304
      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 308
            aload 0 /* this */
            getfield sun.security.ssl.X509TrustManagerImpl.pkixParams:Ljava/security/cert/PKIXBuilderParameters;
            ifnonnull 3
         1: .line 309
            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 310
            goto 4
        end local 2 // sun.security.validator.Validator v
         3: .line 311
      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 313
      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.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 321
            aconst_null
            astore 1 /* hostname */
        start local 1 // javax.net.ssl.SNIHostName hostname
         1: .line 322
            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 323
            aload 2 /* sniName */
            invokevirtual javax.net.ssl.SNIServerName.getType:()I
            ifeq 5
         4: .line 324
            goto 14
         5: .line 327
      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 328
            aload 2 /* sniName */
            checkcast javax.net.ssl.SNIHostName
            astore 1 /* hostname */
         7: .line 329
            goto 15
         8: .line 331
      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 332
            goto 15
      StackMap locals:
      StackMap stack: java.lang.IllegalArgumentException
        10: pop
        11: .line 334
            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 335
            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 341
            goto 15
        end local 2 // javax.net.ssl.SNIServerName sniName
        14: .line 322
      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 344
      StackMap locals: java.util.List javax.net.ssl.SNIHostName
      StackMap stack:
            aload 1 /* hostname */
            ifnull 17
        16: .line 345
            aload 1 /* hostname */
            invokevirtual javax.net.ssl.SNIHostName.getAsciiName:()Ljava/lang/String;
            areturn
        17: .line 348
      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 353
            aload 0 /* socket */
            ifnull 4
            aload 0 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 4
         1: .line 354
            aload 0 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 4
         2: .line 356
            aload 0 /* socket */
            checkcast javax.net.ssl.SSLSocket
            invokevirtual javax.net.ssl.SSLSocket.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
         3: .line 355
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljavax/net/ssl/SSLSession;)Ljava/util/List;
            areturn
         4: .line 359
      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 364
            aload 0 /* engine */
            ifnull 2
         1: .line 365
            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 368
      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 373
            aload 0 /* session */
            ifnull 2
            aload 0 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 2
         1: .line 374
            aload 0 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
            invokevirtual javax.net.ssl.ExtendedSSLSession.getRequestedServerNames:()Ljava/util/List;
            areturn
         2: .line 377
      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 403
            aload 1 /* trustedChain */
            aload 1 /* trustedChain */
            arraylength
            iconst_1
            isub
            aaload
         1: .line 402
            invokestatic sun.security.util.AnchorCertificates.contains:(Ljava/security/cert/X509Certificate;)Z
            istore 4 /* chainsToPublicCA */
        start local 4 // boolean chainsToPublicCA
         2: .line 405
            iconst_0
            istore 5 /* identifiable */
        start local 5 // boolean identifiable
         3: .line 406
            aload 0 /* session */
            invokeinterface javax.net.ssl.SSLSession.getPeerHost:()Ljava/lang/String;
            astore 6 /* peerHost */
        start local 6 // java.lang.String peerHost
         4: .line 407
            iload 3 /* checkClientTrusted */
            ifne 16
         5: .line 408
            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 409
            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 410
            aload 8 /* sniHostName */
            ifnull 16
         8: .line 412
            aload 8 /* sniHostName */
         9: .line 413
            aload 1 /* trustedChain */
            iconst_0
            aaload
            aload 2 /* algorithm */
            iload 4 /* chainsToPublicCA */
        10: .line 412
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
        11: .line 414
            iconst_1
            istore 5 /* identifiable */
        12: .line 415
            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 416
            aload 8 /* sniHostName */
            aload 6 /* peerHost */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 16
        15: .line 417
            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 425
      StackMap locals:
      StackMap stack:
            iload 5 /* identifiable */
            ifne 20
        17: .line 426
            aload 6 /* peerHost */
        18: .line 427
            aload 1 /* trustedChain */
            iconst_0
            aaload
            aload 2 /* algorithm */
            iload 4 /* chainsToPublicCA */
        19: .line 426
            invokestatic sun.security.ssl.X509TrustManagerImpl.checkIdentity:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Ljava/lang/String;Z)V
        20: .line 429
      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 438
            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 439
            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 444
            aload 2 /* algorithm */
            ifnull 18
            aload 2 /* algorithm */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 18
         1: .line 446
            aload 0 /* hostname */
            ifnull 4
            aload 0 /* hostname */
            ldc "["
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 4
         2: .line 447
            aload 0 /* hostname */
            ldc "]"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 448
            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 451
      StackMap locals:
      StackMap stack:
            aload 2 /* algorithm */
            ldc "HTTPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 9
         5: .line 452
            iconst_1
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
         6: .line 453
            aload 0 /* hostname */
            aload 1 /* cert */
            iload 3 /* chainsToPublicCA */
         7: .line 452
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Z)V
         8: .line 454
            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 455
            aload 2 /* algorithm */
            ldc "LDAPS"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 15
        11: .line 456
      StackMap locals:
      StackMap stack:
            iconst_2
            invokestatic sun.security.util.HostnameChecker.getInstance:(B)Lsun/security/util/HostnameChecker;
        12: .line 457
            aload 0 /* hostname */
            aload 1 /* cert */
            iload 3 /* chainsToPublicCA */
        13: .line 456
            invokevirtual sun.security.util.HostnameChecker.match:(Ljava/lang/String;Ljava/security/cert/X509Certificate;Z)V
        14: .line 458
            goto 18
        15: .line 459
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateException
            dup
        16: .line 460
            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 459
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 463
      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"