final class sun.security.ssl.CertificateRequest$T10CertificateRequestMessage extends sun.security.ssl.SSLHandshake$HandshakeMessage
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage
  super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
  final byte[] types;
    descriptor: [B
    flags: (0x0010) ACC_FINAL

  final java.util.List<byte[]> authorities;
    descriptor: Ljava/util/List;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/List<[B>;

  void <init>(sun.security.ssl.HandshakeContext, java.security.cert.X509Certificate[], sun.security.ssl.CipherSuite$KeyExchange);
    descriptor: (Lsun/security/ssl/HandshakeContext;[Ljava/security/cert/X509Certificate;Lsun/security/ssl/CipherSuite$KeyExchange;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=9, args_size=4
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
        start local 2 // java.security.cert.X509Certificate[] trustedCerts
        start local 3 // sun.security.ssl.CipherSuite$KeyExchange keyExchange
         0: .line 154
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 156
            aload 0 /* this */
            new java.util.ArrayList
            dup
            aload 2 /* trustedCerts */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
            putfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
         2: .line 157
            aload 2 /* trustedCerts */
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 7
      StackMap locals: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage sun.security.ssl.HandshakeContext java.security.cert.X509Certificate[] sun.security.ssl.CipherSuite$KeyExchange top int int java.security.cert.X509Certificate[]
      StackMap stack:
         3: aload 7
            iload 5
            aaload
            astore 4 /* cert */
        start local 4 // java.security.cert.X509Certificate cert
         4: .line 158
            aload 4 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 8 /* x500Principal */
        start local 8 // javax.security.auth.x500.X500Principal x500Principal
         5: .line 159
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            aload 8 /* x500Principal */
            invokevirtual javax.security.auth.x500.X500Principal.getEncoded:()[B
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // javax.security.auth.x500.X500Principal x500Principal
        end local 4 // java.security.cert.X509Certificate cert
         6: .line 157
            iinc 5 1
      StackMap locals:
      StackMap stack:
         7: iload 5
            iload 6
            if_icmplt 3
         8: .line 162
            aload 0 /* this */
            getstatic sun.security.ssl.CertificateRequest$ClientCertificateType.CERT_TYPES:[B
            putfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.types:[B
         9: .line 163
            return
        end local 3 // sun.security.ssl.CipherSuite$KeyExchange keyExchange
        end local 2 // java.security.cert.X509Certificate[] trustedCerts
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   10     0              this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;
            0   10     1  handshakeContext  Lsun/security/ssl/HandshakeContext;
            0   10     2      trustedCerts  [Ljava/security/cert/X509Certificate;
            0   10     3       keyExchange  Lsun/security/ssl/CipherSuite$KeyExchange;
            4    6     4              cert  Ljava/security/cert/X509Certificate;
            5    6     8     x500Principal  Ljavax/security/auth/x500/X500Principal;
    MethodParameters:
                  Name  Flags
      handshakeContext  
      trustedCerts      
      keyExchange       

  void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
    descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
        start local 2 // java.nio.ByteBuffer m
         0: .line 167
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 173
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_4
            if_icmpge 5
         2: .line 174
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
         3: .line 175
            ldc "Incorrect CertificateRequest message: no sufficient data"
         4: .line 174
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
         5: .line 177
      StackMap locals: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer
      StackMap stack:
            aload 0 /* this */
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getBytes8:(Ljava/nio/ByteBuffer;)[B
            putfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.types:[B
         6: .line 179
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getInt16:(Ljava/nio/ByteBuffer;)I
            istore 3 /* listLen */
        start local 3 // int listLen
         7: .line 180
            iload 3 /* listLen */
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            if_icmple 11
         8: .line 181
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
         9: .line 182
            ldc "Incorrect CertificateRequest message:no sufficient data"
        10: .line 181
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        11: .line 185
      StackMap locals: int
      StackMap stack:
            iload 3 /* listLen */
            ifle 19
        12: .line 186
            aload 0 /* this */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            putfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
        13: .line 187
            goto 17
        14: .line 189
      StackMap locals:
      StackMap stack:
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getBytes16:(Ljava/nio/ByteBuffer;)[B
            astore 4 /* encoded */
        start local 4 // byte[] encoded
        15: .line 190
            iload 3 /* listLen */
            iconst_2
            aload 4 /* encoded */
            arraylength
            iadd
            isub
            istore 3 /* listLen */
        16: .line 191
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            aload 4 /* encoded */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // byte[] encoded
        17: .line 187
      StackMap locals:
      StackMap stack:
            iload 3 /* listLen */
            ifgt 14
        18: .line 193
            goto 20
        19: .line 194
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
        20: .line 196
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int listLen
        end local 2 // java.nio.ByteBuffer m
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   21     0              this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;
            0   21     1  handshakeContext  Lsun/security/ssl/HandshakeContext;
            0   21     2                 m  Ljava/nio/ByteBuffer;
            7   21     3           listLen  I
           15   17     4           encoded  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                  Name  Flags
      handshakeContext  
      m                 

  java.lang.String[] getKeyTypes();
    descriptor: ()[Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
         0: .line 199
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.types:[B
            invokestatic sun.security.ssl.CertificateRequest$ClientCertificateType.getKeyTypes:([B)[Ljava/lang/String;
            areturn
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;

  javax.security.auth.x500.X500Principal[] getAuthorities();
    descriptor: ()[Ljavax/security/auth/x500/X500Principal;
    flags: (0x0000) 
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
         0: .line 203
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            anewarray javax.security.auth.x500.X500Principal
            astore 1 /* principals */
        start local 1 // javax.security.auth.x500.X500Principal[] principals
         1: .line 204
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         2: .line 205
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 5
      StackMap locals: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage javax.security.auth.x500.X500Principal[] int top java.util.Iterator
      StackMap stack:
         3: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast byte[]
            astore 3 /* encoded */
        start local 3 // byte[] encoded
         4: .line 206
            aload 1 /* principals */
            iload 2 /* i */
            iinc 2 /* i */ 1
            new javax.security.auth.x500.X500Principal
            dup
            aload 3 /* encoded */
            invokespecial javax.security.auth.x500.X500Principal.<init>:([B)V
            aastore
        end local 3 // byte[] encoded
         5: .line 205
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 209
            aload 1 /* principals */
            areturn
        end local 2 // int i
        end local 1 // javax.security.auth.x500.X500Principal[] principals
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    7     0        this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;
            1    7     1  principals  [Ljavax/security/auth/x500/X500Principal;
            2    7     2           i  I
            4    5     3     encoded  [B

  public sun.security.ssl.SSLHandshake handshakeType();
    descriptor: ()Lsun/security/ssl/SSLHandshake;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
         0: .line 214
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_REQUEST:Lsun/security/ssl/SSLHandshake;
            areturn
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;

  public int messageLength();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
         0: .line 219
            iconst_1
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.types:[B
            arraylength
            iadd
            iconst_2
            iadd
            istore 1 /* len */
        start local 1 // int len
         1: .line 220
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage int top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast byte[]
            astore 2 /* encoded */
        start local 2 // byte[] encoded
         3: .line 221
            iload 1 /* len */
            aload 2 /* encoded */
            arraylength
            iconst_2
            iadd
            iadd
            istore 1 /* len */
        end local 2 // byte[] encoded
         4: .line 220
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 223
            iload 1 /* len */
            ireturn
        end local 1 // int len
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;
            1    6     1      len  I
            3    4     2  encoded  [B

  public void send(sun.security.ssl.HandshakeOutStream);
    descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
        start local 1 // sun.security.ssl.HandshakeOutStream hos
         0: .line 228
            aload 1 /* hos */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.types:[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes8:([B)V
         1: .line 230
            iconst_0
            istore 2 /* listLen */
        start local 2 // int listLen
         2: .line 231
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 5
      StackMap locals: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage sun.security.ssl.HandshakeOutStream int top java.util.Iterator
      StackMap stack:
         3: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast byte[]
            astore 3 /* encoded */
        start local 3 // byte[] encoded
         4: .line 232
            iload 2 /* listLen */
            aload 3 /* encoded */
            arraylength
            iconst_2
            iadd
            iadd
            istore 2 /* listLen */
        end local 3 // byte[] encoded
         5: .line 231
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 235
            aload 1 /* hos */
            iload 2 /* listLen */
            invokevirtual sun.security.ssl.HandshakeOutStream.putInt16:(I)V
         7: .line 236
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 10
      StackMap locals:
      StackMap stack:
         8: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast byte[]
            astore 3 /* encoded */
        start local 3 // byte[] encoded
         9: .line 237
            aload 1 /* hos */
            aload 3 /* encoded */
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
        end local 3 // byte[] encoded
        10: .line 236
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        11: .line 239
            return
        end local 2 // int listLen
        end local 1 // sun.security.ssl.HandshakeOutStream hos
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   12     0     this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;
            0   12     1      hos  Lsun/security/ssl/HandshakeOutStream;
            2   12     2  listLen  I
            4    5     3  encoded  [B
            9   10     3  encoded  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      hos   

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
         0: .line 243
            new java.text.MessageFormat
            dup
         1: .line 244
            ldc "\"CertificateRequest\": '{'\n  \"certificate types\": {0}\n  \"certificate authorities\": {1}\n'}'"
         2: .line 248
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         3: .line 243
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         4: .line 250
            new java.util.ArrayList
            dup
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.types:[B
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 2 /* typeNames */
        start local 2 // java.util.List typeNames
         5: .line 251
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.types:[B
            dup
            astore 6
            arraylength
            istore 5
            iconst_0
            istore 4
            goto 9
      StackMap locals: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage java.text.MessageFormat java.util.List top int int byte[]
      StackMap stack:
         6: aload 6
            iload 4
            baload
            istore 3 /* type */
        start local 3 // byte type
         7: .line 252
            aload 2 /* typeNames */
            iload 3 /* type */
            invokestatic sun.security.ssl.CertificateRequest$ClientCertificateType.nameOf:(B)Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // byte type
         8: .line 251
            iinc 4 1
      StackMap locals:
      StackMap stack:
         9: iload 4
            iload 5
            if_icmplt 6
        10: .line 255
            new java.util.ArrayList
            dup
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 3 /* authorityNames */
        start local 3 // java.util.List authorityNames
        11: .line 256
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.authorities:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 15
      StackMap locals: sun.security.ssl.CertificateRequest$T10CertificateRequestMessage java.text.MessageFormat java.util.List java.util.List top java.util.Iterator
      StackMap stack:
        12: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast byte[]
            astore 4 /* encoded */
        start local 4 // byte[] encoded
        13: .line 257
            new javax.security.auth.x500.X500Principal
            dup
            aload 4 /* encoded */
            invokespecial javax.security.auth.x500.X500Principal.<init>:([B)V
            astore 6 /* principal */
        start local 6 // javax.security.auth.x500.X500Principal principal
        14: .line 258
            aload 3 /* authorityNames */
            aload 6 /* principal */
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 6 // javax.security.auth.x500.X500Principal principal
        end local 4 // byte[] encoded
        15: .line 256
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        16: .line 260
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
        17: .line 261
            aload 2 /* typeNames */
            aastore
            dup
            iconst_1
        18: .line 262
            aload 3 /* authorityNames */
            aastore
        19: .line 260
            astore 4 /* messageFields */
        start local 4 // java.lang.Object[] messageFields
        20: .line 265
            aload 1 /* messageFormat */
            aload 4 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 4 // java.lang.Object[] messageFields
        end local 3 // java.util.List authorityNames
        end local 2 // java.util.List typeNames
        end local 1 // java.text.MessageFormat messageFormat
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   21     0            this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;
            4   21     1   messageFormat  Ljava/text/MessageFormat;
            5   21     2       typeNames  Ljava/util/List<Ljava/lang/String;>;
            7    8     3            type  B
           11   21     3  authorityNames  Ljava/util/List<Ljava/lang/String;>;
           13   15     4         encoded  [B
           14   15     6       principal  Ljavax/security/auth/x500/X500Principal;
           20   21     4   messageFields  [Ljava/lang/Object;
}
SourceFile: "CertificateRequest.java"
NestHost: sun.security.ssl.CertificateRequest
InnerClasses:
  private final ClientCertificateType = sun.security.ssl.CertificateRequest$ClientCertificateType of sun.security.ssl.CertificateRequest
  final T10CertificateRequestMessage = sun.security.ssl.CertificateRequest$T10CertificateRequestMessage of sun.security.ssl.CertificateRequest
  final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake