final class sun.security.ssl.SSLConfiguration implements java.lang.Cloneable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.SSLConfiguration
  super_class: java.lang.Object
{
  java.security.AlgorithmConstraints userSpecifiedAlgorithmConstraints;
    descriptor: Ljava/security/AlgorithmConstraints;
    flags: (0x0000) 

  java.util.List<sun.security.ssl.ProtocolVersion> enabledProtocols;
    descriptor: Ljava/util/List;
    flags: (0x0000) 
    Signature: Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;

  java.util.List<sun.security.ssl.CipherSuite> enabledCipherSuites;
    descriptor: Ljava/util/List;
    flags: (0x0000) 
    Signature: Ljava/util/List<Lsun/security/ssl/CipherSuite;>;

  sun.security.ssl.ClientAuthType clientAuthType;
    descriptor: Lsun/security/ssl/ClientAuthType;
    flags: (0x0000) 

  java.lang.String identificationProtocol;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.util.List<javax.net.ssl.SNIServerName> serverNames;
    descriptor: Ljava/util/List;
    flags: (0x0000) 
    Signature: Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;

  java.util.Collection<javax.net.ssl.SNIMatcher> sniMatchers;
    descriptor: Ljava/util/Collection;
    flags: (0x0000) 
    Signature: Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;

  java.lang.String[] applicationProtocols;
    descriptor: [Ljava/lang/String;
    flags: (0x0000) 

  boolean preferLocalCipherSuites;
    descriptor: Z
    flags: (0x0000) 

  boolean enableRetransmissions;
    descriptor: Z
    flags: (0x0000) 

  int maximumPacketSize;
    descriptor: I
    flags: (0x0000) 

  java.util.List<sun.security.ssl.SignatureScheme> signatureSchemes;
    descriptor: Ljava/util/List;
    flags: (0x0000) 
    Signature: Ljava/util/List<Lsun/security/ssl/SignatureScheme;>;

  sun.security.ssl.ProtocolVersion maximumProtocolVersion;
    descriptor: Lsun/security/ssl/ProtocolVersion;
    flags: (0x0000) 

  boolean isClientMode;
    descriptor: Z
    flags: (0x0000) 

  boolean enableSessionCreation;
    descriptor: Z
    flags: (0x0000) 

  java.util.function.BiFunction<javax.net.ssl.SSLSocket, java.util.List<java.lang.String>, java.lang.String> socketAPSelector;
    descriptor: Ljava/util/function/BiFunction;
    flags: (0x0000) 
    Signature: Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLSocket;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;

  java.util.function.BiFunction<javax.net.ssl.SSLEngine, java.util.List<java.lang.String>, java.lang.String> engineAPSelector;
    descriptor: Ljava/util/function/BiFunction;
    flags: (0x0000) 
    Signature: Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLEngine;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;

  java.util.HashMap<javax.net.ssl.HandshakeCompletedListener, java.security.AccessControlContext> handshakeListeners;
    descriptor: Ljava/util/HashMap;
    flags: (0x0000) 
    Signature: Ljava/util/HashMap<Ljavax/net/ssl/HandshakeCompletedListener;Ljava/security/AccessControlContext;>;

  boolean noSniExtension;
    descriptor: Z
    flags: (0x0000) 

  boolean noSniMatcher;
    descriptor: Z
    flags: (0x0000) 

  static final boolean useExtendedMasterSecret;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean allowLegacyResumption;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean allowLegacyMasterSecret;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean useCompatibilityMode;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean acknowledgeCloseNotify;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  private static volatile int[] $SWITCH_TABLE$sun$security$ssl$ClientAuthType;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 93
            ldc "jdk.tls.allowLegacyResumption"
            iconst_1
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
         1: .line 92
            putstatic sun.security.ssl.SSLConfiguration.allowLegacyResumption:Z
         2: .line 97
            ldc "jdk.tls.allowLegacyMasterSecret"
            iconst_1
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
         3: .line 96
            putstatic sun.security.ssl.SSLConfiguration.allowLegacyMasterSecret:Z
         4: .line 101
            ldc "jdk.tls.client.useCompatibilityMode"
            iconst_1
         5: .line 100
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            putstatic sun.security.ssl.SSLConfiguration.useCompatibilityMode:Z
         6: .line 105
            ldc "jdk.tls.acknowledgeCloseNotify"
            iconst_0
         7: .line 104
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            putstatic sun.security.ssl.SSLConfiguration.acknowledgeCloseNotify:Z
         8: .line 110
            ldc "jdk.tls.useExtendedMasterSecret"
            iconst_1
         9: .line 109
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            istore 0 /* supportExtendedMasterSecret */
        start local 0 // boolean supportExtendedMasterSecret
        10: .line 111
            iload 0 /* supportExtendedMasterSecret */
            ifeq 15
        11: .line 113
            ldc "SunTlsExtendedMasterSecret"
            invokestatic javax.crypto.KeyGenerator.getInstance:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            pop
        12: .line 114
            goto 15
      StackMap locals: int
      StackMap stack: java.security.NoSuchAlgorithmException
        13: pop
        14: .line 115
            iconst_0
            istore 0 /* supportExtendedMasterSecret */
        15: .line 118
      StackMap locals:
      StackMap stack:
            iload 0 /* supportExtendedMasterSecret */
            putstatic sun.security.ssl.SSLConfiguration.useExtendedMasterSecret:Z
        end local 0 // boolean supportExtendedMasterSecret
        16: .line 119
            return
      LocalVariableTable:
        Start  End  Slot                         Name  Signature
           10   16     0  supportExtendedMasterSecret  Z
      Exception table:
        from    to  target  type
          11    12      13  Class java.security.NoSuchAlgorithmException

  void <init>(sun.security.ssl.SSLContextImpl, boolean);
    descriptor: (Lsun/security/ssl/SSLContextImpl;Z)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLContextImpl sslContext
        start local 2 // boolean isClientMode
         0: .line 121
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 124
            aload 0 /* this */
         2: .line 125
            getstatic sun.security.ssl.SSLAlgorithmConstraints.DEFAULT:Ljava/security/AlgorithmConstraints;
         3: .line 124
            putfield sun.security.ssl.SSLConfiguration.userSpecifiedAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
         4: .line 126
            aload 0 /* this */
         5: .line 127
            aload 1 /* sslContext */
            iload 2 /* isClientMode */
            ifeq 6
            iconst_0
            goto 7
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl
         6: iconst_1
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
         7: invokevirtual sun.security.ssl.SSLContextImpl.getDefaultProtocolVersions:(Z)Ljava/util/List;
         8: .line 126
            putfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
         9: .line 128
            aload 0 /* this */
        10: .line 129
            aload 1 /* sslContext */
            iload 2 /* isClientMode */
            ifeq 11
            iconst_0
            goto 12
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl
        11: iconst_1
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
        12: invokevirtual sun.security.ssl.SSLContextImpl.getDefaultCipherSuites:(Z)Ljava/util/List;
        13: .line 128
            putfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
        14: .line 130
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        15: .line 132
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
        16: .line 133
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
        17: .line 134
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
        18: .line 135
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
        19: .line 137
            aload 0 /* this */
            iconst_0
            anewarray java.lang.String
            putfield sun.security.ssl.SSLConfiguration.applicationProtocols:[Ljava/lang/String;
        20: .line 138
            aload 0 /* this */
            aload 1 /* sslContext */
            invokevirtual sun.security.ssl.SSLContextImpl.isDTLS:()Z
            putfield sun.security.ssl.SSLConfiguration.enableRetransmissions:Z
        21: .line 139
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLConfiguration.maximumPacketSize:I
        22: .line 141
            aload 0 /* this */
            iload 2 /* isClientMode */
            ifeq 24
        23: .line 142
            getstatic sun.security.ssl.SSLConfiguration$CustomizedClientSignatureSchemes.signatureSchemes:Ljava/util/List;
            goto 25
        24: .line 143
      StackMap locals:
      StackMap stack: sun.security.ssl.SSLConfiguration
            getstatic sun.security.ssl.SSLConfiguration$CustomizedServerSignatureSchemes.signatureSchemes:Ljava/util/List;
        25: .line 141
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration java.util.List
            putfield sun.security.ssl.SSLConfiguration.signatureSchemes:Ljava/util/List;
        26: .line 144
            aload 0 /* this */
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        27: .line 145
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 31
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int top java.util.Iterator
      StackMap stack:
        28: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 3 /* pv */
        start local 3 // sun.security.ssl.ProtocolVersion pv
        29: .line 146
            aload 3 /* pv */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.compareTo:(Ljava/lang/Enum;)I
            ifle 31
        30: .line 147
            aload 0 /* this */
            aload 3 /* pv */
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        end local 3 // sun.security.ssl.ProtocolVersion pv
        31: .line 145
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 28
        32: .line 152
            aload 0 /* this */
            iload 2 /* isClientMode */
            putfield sun.security.ssl.SSLConfiguration.isClientMode:Z
        33: .line 153
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.SSLConfiguration.enableSessionCreation:Z
        34: .line 154
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.socketAPSelector:Ljava/util/function/BiFunction;
        35: .line 155
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.engineAPSelector:Ljava/util/function/BiFunction;
        36: .line 157
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
        37: .line 158
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLConfiguration.noSniExtension:Z
        38: .line 159
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLConfiguration.noSniMatcher:Z
        39: .line 160
            return
        end local 2 // boolean isClientMode
        end local 1 // sun.security.ssl.SSLContextImpl sslContext
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   40     0          this  Lsun/security/ssl/SSLConfiguration;
            0   40     1    sslContext  Lsun/security/ssl/SSLContextImpl;
            0   40     2  isClientMode  Z
           29   31     3            pv  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
              Name  Flags
      sslContext    
      isClientMode  

  javax.net.ssl.SSLParameters getSSLParameters();
    descriptor: ()Ljavax/net/ssl/SSLParameters;
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.ssl.SSLConfiguration this
         0: .line 163
            new javax.net.ssl.SSLParameters
            dup
            invokespecial javax.net.ssl.SSLParameters.<init>:()V
            astore 1 /* params */
        start local 1 // javax.net.ssl.SSLParameters params
         1: .line 165
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.userSpecifiedAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
            invokevirtual javax.net.ssl.SSLParameters.setAlgorithmConstraints:(Ljava/security/AlgorithmConstraints;)V
         2: .line 166
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokestatic sun.security.ssl.ProtocolVersion.toStringArray:(Ljava/util/List;)[Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setProtocols:([Ljava/lang/String;)V
         3: .line 167
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
            invokestatic sun.security.ssl.CipherSuite.namesOf:(Ljava/util/List;)[Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setCipherSuites:([Ljava/lang/String;)V
         4: .line 168
            invokestatic sun.security.ssl.SSLConfiguration.$SWITCH_TABLE$sun$security$ssl$ClientAuthType:()[I
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iaload
            tableswitch { // 2 - 3
                    2: 7
                    3: 5
              default: 9
          }
         5: .line 170
      StackMap locals: javax.net.ssl.SSLParameters
      StackMap stack:
            aload 1 /* params */
            iconst_1
            invokevirtual javax.net.ssl.SSLParameters.setNeedClientAuth:(Z)V
         6: .line 171
            goto 10
         7: .line 173
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            iconst_1
            invokevirtual javax.net.ssl.SSLParameters.setWantClientAuth:(Z)V
         8: .line 174
            goto 10
         9: .line 176
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            iconst_0
            invokevirtual javax.net.ssl.SSLParameters.setWantClientAuth:(Z)V
        10: .line 178
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setEndpointIdentificationAlgorithm:(Ljava/lang/String;)V
        11: .line 180
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 14
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.noSniExtension:Z
            ifne 14
        12: .line 182
            aload 1 /* params */
            aconst_null
            invokevirtual javax.net.ssl.SSLParameters.setServerNames:(Ljava/util/List;)V
        13: .line 183
            goto 15
        14: .line 184
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
            invokevirtual javax.net.ssl.SSLParameters.setServerNames:(Ljava/util/List;)V
        15: .line 187
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 18
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.noSniMatcher:Z
            ifne 18
        16: .line 189
            aload 1 /* params */
            aconst_null
            invokevirtual javax.net.ssl.SSLParameters.setSNIMatchers:(Ljava/util/Collection;)V
        17: .line 190
            goto 19
        18: .line 191
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
            invokevirtual javax.net.ssl.SSLParameters.setSNIMatchers:(Ljava/util/Collection;)V
        19: .line 194
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.applicationProtocols:[Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setApplicationProtocols:([Ljava/lang/String;)V
        20: .line 195
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
            invokevirtual javax.net.ssl.SSLParameters.setUseCipherSuitesOrder:(Z)V
        21: .line 196
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enableRetransmissions:Z
            invokevirtual javax.net.ssl.SSLParameters.setEnableRetransmissions:(Z)V
        22: .line 197
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.maximumPacketSize:I
            invokevirtual javax.net.ssl.SSLParameters.setMaximumPacketSize:(I)V
        23: .line 199
            aload 1 /* params */
            areturn
        end local 1 // javax.net.ssl.SSLParameters params
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   24     0    this  Lsun/security/ssl/SSLConfiguration;
            1   24     1  params  Ljavax/net/ssl/SSLParameters;

  void setSSLParameters(javax.net.ssl.SSLParameters);
    descriptor: (Ljavax/net/ssl/SSLParameters;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // javax.net.ssl.SSLParameters params
         0: .line 203
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getAlgorithmConstraints:()Ljava/security/AlgorithmConstraints;
            astore 2 /* ac */
        start local 2 // java.security.AlgorithmConstraints ac
         1: .line 204
            aload 2 /* ac */
            ifnull 3
         2: .line 205
            aload 0 /* this */
            aload 2 /* ac */
            putfield sun.security.ssl.SSLConfiguration.userSpecifiedAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
         3: .line 208
      StackMap locals: java.security.AlgorithmConstraints
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getCipherSuites:()[Ljava/lang/String;
            astore 3 /* sa */
        start local 3 // java.lang.String[] sa
         4: .line 209
            aload 3 /* sa */
            ifnull 6
         5: .line 210
            aload 0 /* this */
            aload 3 /* sa */
            invokestatic sun.security.ssl.CipherSuite.validValuesOf:([Ljava/lang/String;)Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
         6: .line 213
      StackMap locals: java.lang.String[]
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getProtocols:()[Ljava/lang/String;
            astore 3 /* sa */
         7: .line 214
            aload 3 /* sa */
            ifnull 15
         8: .line 215
            aload 0 /* this */
            aload 3 /* sa */
            invokestatic sun.security.ssl.ProtocolVersion.namesOf:([Ljava/lang/String;)Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
         9: .line 217
            aload 0 /* this */
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        10: .line 218
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 14
      StackMap locals: sun.security.ssl.SSLConfiguration javax.net.ssl.SSLParameters java.security.AlgorithmConstraints java.lang.String[] top java.util.Iterator
      StackMap stack:
        11: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 4 /* pv */
        start local 4 // sun.security.ssl.ProtocolVersion pv
        12: .line 219
            aload 4 /* pv */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.compareTo:(Ljava/lang/Enum;)I
            ifle 14
        13: .line 220
            aload 0 /* this */
            aload 4 /* pv */
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        end local 4 // sun.security.ssl.ProtocolVersion pv
        14: .line 218
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        15: .line 225
      StackMap locals: sun.security.ssl.SSLConfiguration javax.net.ssl.SSLParameters java.security.AlgorithmConstraints java.lang.String[]
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getNeedClientAuth:()Z
            ifeq 18
        16: .line 226
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUIRED:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        17: .line 227
            goto 22
      StackMap locals:
      StackMap stack:
        18: aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getWantClientAuth:()Z
            ifeq 21
        19: .line 228
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUESTED:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        20: .line 229
            goto 22
        21: .line 230
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        22: .line 233
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
            astore 4 /* s */
        start local 4 // java.lang.String s
        23: .line 234
            aload 4 /* s */
            ifnull 25
        24: .line 235
            aload 0 /* this */
            aload 4 /* s */
            putfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
        25: .line 238
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getServerNames:()Ljava/util/List;
            astore 5 /* sniNames */
        start local 5 // java.util.List sniNames
        26: .line 239
            aload 5 /* sniNames */
            ifnull 29
        27: .line 240
            aload 0 /* this */
            aload 5 /* sniNames */
            invokeinterface java.util.List.isEmpty:()Z
            putfield sun.security.ssl.SSLConfiguration.noSniExtension:Z
        28: .line 241
            aload 0 /* this */
            aload 5 /* sniNames */
            putfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
        29: .line 244
      StackMap locals: java.util.List
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getSNIMatchers:()Ljava/util/Collection;
            astore 6 /* matchers */
        start local 6 // java.util.Collection matchers
        30: .line 245
            aload 6 /* matchers */
            ifnull 33
        31: .line 246
            aload 0 /* this */
            aload 6 /* matchers */
            invokeinterface java.util.Collection.isEmpty:()Z
            putfield sun.security.ssl.SSLConfiguration.noSniMatcher:Z
        32: .line 247
            aload 0 /* this */
            aload 6 /* matchers */
            putfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
        33: .line 250
      StackMap locals: java.util.Collection
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getApplicationProtocols:()[Ljava/lang/String;
            astore 3 /* sa */
        34: .line 251
            aload 3 /* sa */
            ifnull 36
        35: .line 252
            aload 0 /* this */
            aload 3 /* sa */
            putfield sun.security.ssl.SSLConfiguration.applicationProtocols:[Ljava/lang/String;
        36: .line 255
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getUseCipherSuitesOrder:()Z
            putfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
        37: .line 256
            aload 0 /* this */
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getEnableRetransmissions:()Z
            putfield sun.security.ssl.SSLConfiguration.enableRetransmissions:Z
        38: .line 257
            aload 0 /* this */
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getMaximumPacketSize:()I
            putfield sun.security.ssl.SSLConfiguration.maximumPacketSize:I
        39: .line 258
            return
        end local 6 // java.util.Collection matchers
        end local 5 // java.util.List sniNames
        end local 4 // java.lang.String s
        end local 3 // java.lang.String[] sa
        end local 2 // java.security.AlgorithmConstraints ac
        end local 1 // javax.net.ssl.SSLParameters params
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   40     0      this  Lsun/security/ssl/SSLConfiguration;
            0   40     1    params  Ljavax/net/ssl/SSLParameters;
            1   40     2        ac  Ljava/security/AlgorithmConstraints;
            4   40     3        sa  [Ljava/lang/String;
           12   14     4        pv  Lsun/security/ssl/ProtocolVersion;
           23   40     4         s  Ljava/lang/String;
           26   40     5  sniNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
           30   40     6  matchers  Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;
    MethodParameters:
        Name  Flags
      params  

  void addHandshakeCompletedListener(javax.net.ssl.HandshakeCompletedListener);
    descriptor: (Ljavax/net/ssl/HandshakeCompletedListener;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // javax.net.ssl.HandshakeCompletedListener listener
         0: .line 264
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            ifnonnull 2
         1: .line 265
            aload 0 /* this */
            new java.util.HashMap
            dup
            iconst_4
            invokespecial java.util.HashMap.<init>:(I)V
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
         2: .line 268
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            aload 1 /* listener */
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 269
            return
        end local 1 // javax.net.ssl.HandshakeCompletedListener listener
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lsun/security/ssl/SSLConfiguration;
            0    4     1  listener  Ljavax/net/ssl/HandshakeCompletedListener;
    MethodParameters:
          Name  Flags
      listener  

  void removeHandshakeCompletedListener(javax.net.ssl.HandshakeCompletedListener);
    descriptor: (Ljavax/net/ssl/HandshakeCompletedListener;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // javax.net.ssl.HandshakeCompletedListener listener
         0: .line 275
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            ifnonnull 2
         1: .line 276
            new java.lang.IllegalArgumentException
            dup
            ldc "no listeners"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 279
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            aload 1 /* listener */
            invokevirtual java.util.HashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnonnull 4
         3: .line 280
            new java.lang.IllegalArgumentException
            dup
            ldc "listener not registered"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 283
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.isEmpty:()Z
            ifeq 6
         5: .line 284
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
         6: .line 286
      StackMap locals:
      StackMap stack:
            return
        end local 1 // javax.net.ssl.HandshakeCompletedListener listener
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lsun/security/ssl/SSLConfiguration;
            0    7     1  listener  Ljavax/net/ssl/HandshakeCompletedListener;
    MethodParameters:
          Name  Flags
      listener  

  boolean isAvailable(sun.security.ssl.SSLExtension);
    descriptor: (Lsun/security/ssl/SSLExtension;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLExtension extension
         0: .line 292
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLExtension top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 2 /* protocolVersion */
        start local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         2: .line 293
            aload 1 /* extension */
            aload 2 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLExtension.isAvailable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifeq 7
         3: .line 294
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            ifeq 5
         4: .line 295
            getstatic sun.security.ssl.SSLExtension$ClientExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 7
            goto 6
         5: .line 296
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLExtension sun.security.ssl.ProtocolVersion java.util.Iterator
      StackMap stack:
            getstatic sun.security.ssl.SSLExtension$ServerExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 7
         6: .line 297
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         7: .line 292
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLExtension top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         8: .line 302
            iconst_0
            ireturn
        end local 1 // sun.security.ssl.SSLExtension extension
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Lsun/security/ssl/SSLConfiguration;
            0    9     1        extension  Lsun/security/ssl/SSLExtension;
            2    7     2  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
           Name  Flags
      extension  

  boolean isAvailable(sun.security.ssl.SSLExtension, sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/SSLExtension;Lsun/security/ssl/ProtocolVersion;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLExtension extension
        start local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 310
            aload 1 /* extension */
            aload 2 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLExtension.isAvailable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifeq 4
         1: .line 311
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            ifeq 2
            getstatic sun.security.ssl.SSLExtension$ClientExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 4
            goto 3
         2: .line 312
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLExtension$ServerExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 310
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         4: iconst_0
            ireturn
        end local 2 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 1 // sun.security.ssl.SSLExtension extension
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lsun/security/ssl/SSLConfiguration;
            0    5     1        extension  Lsun/security/ssl/SSLExtension;
            0    5     2  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      extension        
      protocolVersion  

  sun.security.ssl.SSLExtension[] getEnabledExtensions(sun.security.ssl.SSLHandshake);
    descriptor: (Lsun/security/ssl/SSLHandshake;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
         0: .line 321
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* extensions */
        start local 2 // java.util.List extensions
         1: .line 322
            invokestatic sun.security.ssl.SSLExtension.values:()[Lsun/security/ssl/SSLExtension;
            dup
            astore 6
            arraylength
            istore 5
            iconst_0
            istore 4
            goto 7
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
         2: aload 6
            iload 4
            aaload
            astore 3 /* extension */
        start local 3 // sun.security.ssl.SSLExtension extension
         3: .line 323
            aload 3 /* extension */
            getfield sun.security.ssl.SSLExtension.handshakeType:Lsun/security/ssl/SSLHandshake;
            aload 1 /* handshakeType */
            if_acmpne 6
         4: .line 324
            aload 0 /* this */
            aload 3 /* extension */
            invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
            ifeq 6
         5: .line 325
            aload 2 /* extensions */
            aload 3 /* extension */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // sun.security.ssl.SSLExtension extension
         6: .line 322
      StackMap locals:
      StackMap stack:
            iinc 4 1
      StackMap locals:
      StackMap stack:
         7: iload 4
            iload 5
            if_icmplt 2
         8: .line 330
            aload 2 /* extensions */
            iconst_0
            anewarray sun.security.ssl.SSLExtension
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.ssl.SSLExtension[]
            areturn
        end local 2 // java.util.List extensions
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/ssl/SSLConfiguration;
            0    9     1  handshakeType  Lsun/security/ssl/SSLHandshake;
            1    9     2     extensions  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            3    6     3      extension  Lsun/security/ssl/SSLExtension;
    MethodParameters:
               Name  Flags
      handshakeType  

  sun.security.ssl.SSLExtension[] getExclusiveExtensions(sun.security.ssl.SSLHandshake, java.util.List<sun.security.ssl.SSLExtension>);
    descriptor: (Lsun/security/ssl/SSLHandshake;Ljava/util/List;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=2, locals=8, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
        start local 2 // java.util.List excluded
         0: .line 341
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 3 /* extensions */
        start local 3 // java.util.List extensions
         1: .line 342
            invokestatic sun.security.ssl.SSLExtension.values:()[Lsun/security/ssl/SSLExtension;
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 7
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
         2: aload 7
            iload 5
            aaload
            astore 4 /* extension */
        start local 4 // sun.security.ssl.SSLExtension extension
         3: .line 343
            aload 4 /* extension */
            getfield sun.security.ssl.SSLExtension.handshakeType:Lsun/security/ssl/SSLHandshake;
            aload 1 /* handshakeType */
            if_acmpne 6
         4: .line 344
            aload 0 /* this */
            aload 4 /* extension */
            invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
            ifeq 6
            aload 2 /* excluded */
            aload 4 /* extension */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifne 6
         5: .line 345
            aload 3 /* extensions */
            aload 4 /* extension */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // sun.security.ssl.SSLExtension extension
         6: .line 342
      StackMap locals:
      StackMap stack:
            iinc 5 1
      StackMap locals:
      StackMap stack:
         7: iload 5
            iload 6
            if_icmplt 2
         8: .line 350
            aload 3 /* extensions */
            iconst_0
            anewarray sun.security.ssl.SSLExtension
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.ssl.SSLExtension[]
            areturn
        end local 3 // java.util.List extensions
        end local 2 // java.util.List excluded
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/ssl/SSLConfiguration;
            0    9     1  handshakeType  Lsun/security/ssl/SSLHandshake;
            0    9     2       excluded  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            1    9     3     extensions  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            3    6     4      extension  Lsun/security/ssl/SSLExtension;
    Signature: (Lsun/security/ssl/SSLHandshake;Ljava/util/List<Lsun/security/ssl/SSLExtension;>;)[Lsun/security/ssl/SSLExtension;
    MethodParameters:
               Name  Flags
      handshakeType  
      excluded       

  sun.security.ssl.SSLExtension[] getEnabledExtensions(sun.security.ssl.SSLHandshake, sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
        start local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 362
            aload 0 /* this */
         1: .line 363
            aload 1 /* handshakeType */
            iconst_1
            anewarray sun.security.ssl.ProtocolVersion
            dup
            iconst_0
            aload 2 /* protocolVersion */
            aastore
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
         2: .line 362
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Ljava/util/List;)[Lsun/security/ssl/SSLExtension;
            areturn
        end local 2 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lsun/security/ssl/SSLConfiguration;
            0    3     1    handshakeType  Lsun/security/ssl/SSLHandshake;
            0    3     2  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      handshakeType    
      protocolVersion  

  sun.security.ssl.SSLExtension[] getEnabledExtensions(sun.security.ssl.SSLHandshake, java.util.List<sun.security.ssl.ProtocolVersion>);
    descriptor: (Lsun/security/ssl/SSLHandshake;Ljava/util/List;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=2, locals=10, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
        start local 2 // java.util.List activeProtocols
         0: .line 375
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 3 /* extensions */
        start local 3 // java.util.List extensions
         1: .line 376
            invokestatic sun.security.ssl.SSLExtension.values:()[Lsun/security/ssl/SSLExtension;
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 13
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
         2: aload 7
            iload 5
            aaload
            astore 4 /* extension */
        start local 4 // sun.security.ssl.SSLExtension extension
         3: .line 377
            aload 4 /* extension */
            getfield sun.security.ssl.SSLExtension.handshakeType:Lsun/security/ssl/SSLHandshake;
            aload 1 /* handshakeType */
            if_acmpne 12
         4: .line 378
            aload 0 /* this */
            aload 4 /* extension */
            invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
            ifne 6
         5: .line 379
            goto 12
         6: .line 382
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List sun.security.ssl.SSLExtension int int sun.security.ssl.SSLExtension[]
      StackMap stack:
            aload 2 /* activeProtocols */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 11
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List sun.security.ssl.SSLExtension int int sun.security.ssl.SSLExtension[] top java.util.Iterator
      StackMap stack:
         7: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 8 /* protocolVersion */
        start local 8 // sun.security.ssl.ProtocolVersion protocolVersion
         8: .line 383
            aload 4 /* extension */
            aload 8 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLExtension.isAvailable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifeq 11
         9: .line 384
            aload 3 /* extensions */
            aload 4 /* extension */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        10: .line 385
            goto 12
        end local 8 // sun.security.ssl.ProtocolVersion protocolVersion
        11: .line 382
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        end local 4 // sun.security.ssl.SSLExtension extension
        12: .line 376
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
            iinc 5 1
      StackMap locals:
      StackMap stack:
        13: iload 5
            iload 6
            if_icmplt 2
        14: .line 391
            aload 3 /* extensions */
            iconst_0
            anewarray sun.security.ssl.SSLExtension
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.ssl.SSLExtension[]
            areturn
        end local 3 // java.util.List extensions
        end local 2 // java.util.List activeProtocols
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   15     0             this  Lsun/security/ssl/SSLConfiguration;
            0   15     1    handshakeType  Lsun/security/ssl/SSLHandshake;
            0   15     2  activeProtocols  Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
            1   15     3       extensions  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            3   12     4        extension  Lsun/security/ssl/SSLExtension;
            8   11     8  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    Signature: (Lsun/security/ssl/SSLHandshake;Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)[Lsun/security/ssl/SSLExtension;
    MethodParameters:
                 Name  Flags
      handshakeType    
      activeProtocols  

  void toggleClientMode();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLConfiguration this
         0: .line 395
            aload 0 /* this */
            dup
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            iconst_1
            ixor
            putfield sun.security.ssl.SSLConfiguration.isClientMode:Z
         1: .line 398
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            ifeq 3
         2: .line 399
            getstatic sun.security.ssl.SSLConfiguration$CustomizedClientSignatureSchemes.signatureSchemes:Ljava/util/List;
            goto 4
         3: .line 400
      StackMap locals:
      StackMap stack: sun.security.ssl.SSLConfiguration
            getstatic sun.security.ssl.SSLConfiguration$CustomizedServerSignatureSchemes.signatureSchemes:Ljava/util/List;
         4: .line 398
      StackMap locals: sun.security.ssl.SSLConfiguration
      StackMap stack: sun.security.ssl.SSLConfiguration java.util.List
            putfield sun.security.ssl.SSLConfiguration.signatureSchemes:Ljava/util/List;
         5: .line 401
            return
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lsun/security/ssl/SSLConfiguration;

  public java.lang.Object clone();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.ssl.SSLConfiguration this
         0: .line 408
            aload 0 /* this */
            invokespecial java.lang.Object.clone:()Ljava/lang/Object;
            checkcast sun.security.ssl.SSLConfiguration
            astore 1 /* config */
        start local 1 // sun.security.ssl.SSLConfiguration config
         1: .line 409
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            ifnull 6
         2: .line 410
            aload 1 /* config */
         3: .line 412
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.clone:()Ljava/lang/Object;
         4: .line 411
            checkcast java.util.HashMap
         5: .line 410
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
         6: .line 415
      StackMap locals: sun.security.ssl.SSLConfiguration
      StackMap stack:
            aload 1 /* config */
         7: areturn
        end local 1 // sun.security.ssl.SSLConfiguration config
         8: .line 416
      StackMap locals: sun.security.ssl.SSLConfiguration
      StackMap stack: java.lang.CloneNotSupportedException
            pop
         9: .line 420
            aconst_null
            areturn
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Lsun/security/ssl/SSLConfiguration;
            1    8     1  config  Lsun/security/ssl/SSLConfiguration;
      Exception table:
        from    to  target  type
           0     7       8  Class java.lang.CloneNotSupportedException

  private static java.util.List<sun.security.ssl.SignatureScheme> getCustomizedSignatureScheme(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // java.lang.String propertyName
         0: .line 447
            aload 0 /* propertyName */
            invokestatic sun.security.action.GetPropertyAction.privilegedGetProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* property */
        start local 1 // java.lang.String property
         1: .line 448
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 6
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 6
         2: .line 450
            new java.lang.StringBuilder
            dup
            ldc "System property "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* propertyName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " is set to '"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         3: .line 451
            aload 1 /* property */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 450
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
         5: .line 449
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
         6: .line 453
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* property */
            ifnull 10
            aload 1 /* property */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 10
         7: .line 455
            aload 1 /* property */
            invokevirtual java.lang.String.length:()I
            iconst_1
            if_icmple 10
            aload 1 /* property */
            iconst_0
            invokevirtual java.lang.String.charAt:(I)C
            bipush 34
            if_icmpne 10
         8: .line 456
            aload 1 /* property */
            aload 1 /* property */
            invokevirtual java.lang.String.length:()I
            iconst_1
            isub
            invokevirtual java.lang.String.charAt:(I)C
            bipush 34
            if_icmpne 10
         9: .line 457
            aload 1 /* property */
            iconst_1
            aload 1 /* property */
            invokevirtual java.lang.String.length:()I
            iconst_1
            isub
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 1 /* property */
        10: .line 461
      StackMap locals:
      StackMap stack:
            aload 1 /* property */
            ifnull 32
            aload 1 /* property */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 32
        11: .line 462
            aload 1 /* property */
            ldc ","
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            astore 2 /* signatureSchemeNames */
        start local 2 // java.lang.String[] signatureSchemeNames
        12: .line 464
            new java.util.ArrayList
            dup
            aload 2 /* signatureSchemeNames */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
        13: .line 463
            astore 3 /* signatureSchemes */
        start local 3 // java.util.List signatureSchemes
        14: .line 465
            iconst_0
            istore 4 /* i */
        start local 4 // int i
        15: goto 30
        16: .line 466
      StackMap locals: java.lang.String[] java.util.List int
      StackMap stack:
            aload 2 /* signatureSchemeNames */
            iload 4 /* i */
            aload 2 /* signatureSchemeNames */
            iload 4 /* i */
            aaload
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            aastore
        17: .line 467
            aload 2 /* signatureSchemeNames */
            iload 4 /* i */
            aaload
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 19
        18: .line 468
            goto 29
        19: .line 472
      StackMap locals:
      StackMap stack:
            aload 2 /* signatureSchemeNames */
            iload 4 /* i */
            aaload
            invokestatic sun.security.ssl.SignatureScheme.nameOf:(Ljava/lang/String;)Lsun/security/ssl/SignatureScheme;
        20: .line 471
            astore 5 /* scheme */
        start local 5 // sun.security.ssl.SignatureScheme scheme
        21: .line 473
            aload 5 /* scheme */
            ifnull 24
            aload 5 /* scheme */
            getfield sun.security.ssl.SignatureScheme.isAvailable:Z
            ifeq 24
        22: .line 474
            aload 3 /* signatureSchemes */
            aload 5 /* scheme */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        23: .line 475
            goto 29
        24: .line 476
      StackMap locals: sun.security.ssl.SignatureScheme
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 29
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 29
        25: .line 478
            new java.lang.StringBuilder
            dup
            ldc "The current installed providers do not support signature scheme: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        26: .line 480
            aload 2 /* signatureSchemeNames */
            iload 4 /* i */
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        27: .line 478
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        28: .line 477
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        end local 5 // sun.security.ssl.SignatureScheme scheme
        29: .line 465
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        30: iload 4 /* i */
            aload 2 /* signatureSchemeNames */
            arraylength
            if_icmplt 16
        end local 4 // int i
        31: .line 485
            aload 3 /* signatureSchemes */
            areturn
        end local 3 // java.util.List signatureSchemes
        end local 2 // java.lang.String[] signatureSchemeNames
        32: .line 488
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
        end local 1 // java.lang.String property
        end local 0 // java.lang.String propertyName
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   33     0          propertyName  Ljava/lang/String;
            1   33     1              property  Ljava/lang/String;
           12   32     2  signatureSchemeNames  [Ljava/lang/String;
           14   32     3      signatureSchemes  Ljava/util/List<Lsun/security/ssl/SignatureScheme;>;
           15   31     4                     i  I
           21   29     5                scheme  Lsun/security/ssl/SignatureScheme;
    Signature: (Ljava/lang/String;)Ljava/util/List<Lsun/security/ssl/SignatureScheme;>;
    MethodParameters:
              Name  Flags
      propertyName  

  static int[] $SWITCH_TABLE$sun$security$ssl$ClientAuthType();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 53
            getstatic sun.security.ssl.SSLConfiguration.$SWITCH_TABLE$sun$security$ssl$ClientAuthType:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic sun.security.ssl.ClientAuthType.values:()[Lsun/security/ssl/ClientAuthType;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iconst_1
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUESTED:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iconst_2
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUIRED:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iconst_3
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            dup
            putstatic sun.security.ssl.SSLConfiguration.$SWITCH_TABLE$sun$security$ssl$ClientAuthType:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError
}
SourceFile: "SSLConfiguration.java"
NestMembers:
  sun.security.ssl.SSLConfiguration$CustomizedClientSignatureSchemes  sun.security.ssl.SSLConfiguration$CustomizedServerSignatureSchemes
InnerClasses:
  private final CustomizedClientSignatureSchemes = sun.security.ssl.SSLConfiguration$CustomizedClientSignatureSchemes of sun.security.ssl.SSLConfiguration
  private final CustomizedServerSignatureSchemes = sun.security.ssl.SSLConfiguration$CustomizedServerSignatureSchemes of sun.security.ssl.SSLConfiguration
  final ClientExtensions = sun.security.ssl.SSLExtension$ClientExtensions of sun.security.ssl.SSLExtension
  final ServerExtensions = sun.security.ssl.SSLExtension$ServerExtensions of sun.security.ssl.SSLExtension