final class sun.security.ssl.CertificateRequest$T13CertificateRequestMessage 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$T13CertificateRequestMessage
  super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
  private final byte[] requestContext;
    descriptor: [B
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final sun.security.ssl.SSLExtensions extensions;
    descriptor: Lsun/security/ssl/SSLExtensions;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(sun.security.ssl.HandshakeContext);
    descriptor: (Lsun/security/ssl/HandshakeContext;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
         0: .line 789
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 791
            aload 0 /* this */
            iconst_0
            newarray 8
            putfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.requestContext:[B
         2: .line 792
            aload 0 /* this */
            new sun.security.ssl.SSLExtensions
            dup
            aload 0 /* this */
            invokespecial sun.security.ssl.SSLExtensions.<init>:(Lsun/security/ssl/SSLHandshake$HandshakeMessage;)V
            putfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.extensions:Lsun/security/ssl/SSLExtensions;
         3: .line 793
            return
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    4     0              this  Lsun/security/ssl/CertificateRequest$T13CertificateRequestMessage;
            0    4     1  handshakeContext  Lsun/security/ssl/HandshakeContext;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                  Name  Flags
      handshakeContext  

  void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
    descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
        start local 2 // java.nio.ByteBuffer m
         0: .line 797
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 803
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_5
            if_icmpge 5
         2: .line 804
            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 805
            ldc "Invalid CertificateRequest handshake message: no sufficient data"
         4: .line 804
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
         5: .line 808
      StackMap locals: sun.security.ssl.CertificateRequest$T13CertificateRequestMessage 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$T13CertificateRequestMessage.requestContext:[B
         6: .line 810
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_4
            if_icmpge 10
         7: .line 811
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
         8: .line 812
            ldc "Invalid CertificateRequest handshake message: no sufficient extensions data"
         9: .line 811
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        10: .line 816
      StackMap locals:
      StackMap stack:
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        11: .line 817
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_REQUEST:Lsun/security/ssl/SSLHandshake;
        12: .line 816
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;)[Lsun/security/ssl/SSLExtension;
        13: .line 815
            astore 3 /* enabledExtensions */
        start local 3 // sun.security.ssl.SSLExtension[] enabledExtensions
        14: .line 818
            aload 0 /* this */
            new sun.security.ssl.SSLExtensions
            dup
            aload 0 /* this */
            aload 2 /* m */
            aload 3 /* enabledExtensions */
            invokespecial sun.security.ssl.SSLExtensions.<init>:(Lsun/security/ssl/SSLHandshake$HandshakeMessage;Ljava/nio/ByteBuffer;[Lsun/security/ssl/SSLExtension;)V
            putfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.extensions:Lsun/security/ssl/SSLExtensions;
        15: .line 819
            return
        end local 3 // sun.security.ssl.SSLExtension[] enabledExtensions
        end local 2 // java.nio.ByteBuffer m
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   16     0               this  Lsun/security/ssl/CertificateRequest$T13CertificateRequestMessage;
            0   16     1   handshakeContext  Lsun/security/ssl/HandshakeContext;
            0   16     2                  m  Ljava/nio/ByteBuffer;
           14   16     3  enabledExtensions  [Lsun/security/ssl/SSLExtension;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                  Name  Flags
      handshakeContext  
      m                 

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

  int messageLength();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
         0: .line 829
            iconst_1
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.requestContext:[B
            arraylength
            iadd
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.length:()I
            iadd
            ireturn
        end local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/CertificateRequest$T13CertificateRequestMessage;

  void send(sun.security.ssl.HandshakeOutStream);
    descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
        start local 1 // sun.security.ssl.HandshakeOutStream hos
         0: .line 834
            aload 1 /* hos */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.requestContext:[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes8:([B)V
         1: .line 837
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 1 /* hos */
            invokevirtual sun.security.ssl.SSLExtensions.send:(Lsun/security/ssl/HandshakeOutStream;)V
         2: .line 838
            return
        end local 1 // sun.security.ssl.HandshakeOutStream hos
        end local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/CertificateRequest$T13CertificateRequestMessage;
            0    3     1   hos  Lsun/security/ssl/HandshakeOutStream;
    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=3, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
         0: .line 842
            new java.text.MessageFormat
            dup
         1: .line 843
            ldc "\"CertificateRequest\": '{'\n  \"certificate_request_context\": \"{0}\",\n  \"extensions\": [\n{1}\n  ]\n'}'"
         2: .line 849
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         3: .line 842
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         4: .line 850
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
         5: .line 851
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.requestContext:[B
            invokestatic sun.security.ssl.Utilities.toHexString:([B)Ljava/lang/String;
            aastore
            dup
            iconst_1
         6: .line 852
            aload 0 /* this */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            aastore
         7: .line 850
            astore 2 /* messageFields */
        start local 2 // java.lang.Object[] messageFields
         8: .line 855
            aload 1 /* messageFormat */
            aload 2 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 2 // java.lang.Object[] messageFields
        end local 1 // java.text.MessageFormat messageFormat
        end local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/ssl/CertificateRequest$T13CertificateRequestMessage;
            4    9     1  messageFormat  Ljava/text/MessageFormat;
            8    9     2  messageFields  [Ljava/lang/Object;
}
SourceFile: "CertificateRequest.java"
NestHost: sun.security.ssl.CertificateRequest
InnerClasses:
  final T13CertificateRequestMessage = sun.security.ssl.CertificateRequest$T13CertificateRequestMessage of sun.security.ssl.CertificateRequest
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake