final class sun.security.ssl.NewSessionTicket$NewSessionTicketMessage extends sun.security.ssl.SSLHandshake$HandshakeMessage
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.NewSessionTicket$NewSessionTicketMessage
  super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
  final int ticketLifetime;
    descriptor: I
    flags: (0x0010) ACC_FINAL

  final int ticketAgeAdd;
    descriptor: I
    flags: (0x0010) ACC_FINAL

  final byte[] ticketNonce;
    descriptor: [B
    flags: (0x0010) ACC_FINAL

  final byte[] ticket;
    descriptor: [B
    flags: (0x0010) ACC_FINAL

  final sun.security.ssl.SSLExtensions extensions;
    descriptor: Lsun/security/ssl/SSLExtensions;
    flags: (0x0010) ACC_FINAL

  void <init>(sun.security.ssl.HandshakeContext, int, java.security.SecureRandom, byte[], byte[]);
    descriptor: (Lsun/security/ssl/HandshakeContext;ILjava/security/SecureRandom;[B[B)V
    flags: (0x0000) 
    Code:
      stack=4, locals=6, args_size=6
        start local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
        start local 1 // sun.security.ssl.HandshakeContext context
        start local 2 // int ticketLifetime
        start local 3 // java.security.SecureRandom generator
        start local 4 // byte[] ticketNonce
        start local 5 // byte[] ticket
         0: .line 68
            aload 0 /* this */
            aload 1 /* context */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 70
            aload 0 /* this */
            iload 2 /* ticketLifetime */
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketLifetime:I
         2: .line 71
            aload 0 /* this */
            aload 3 /* generator */
            invokevirtual java.security.SecureRandom.nextInt:()I
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketAgeAdd:I
         3: .line 72
            aload 0 /* this */
            aload 4 /* ticketNonce */
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketNonce:[B
         4: .line 73
            aload 0 /* this */
            aload 5 /* ticket */
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticket:[B
         5: .line 74
            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.NewSessionTicket$NewSessionTicketMessage.extensions:Lsun/security/ssl/SSLExtensions;
         6: .line 75
            return
        end local 5 // byte[] ticket
        end local 4 // byte[] ticketNonce
        end local 3 // java.security.SecureRandom generator
        end local 2 // int ticketLifetime
        end local 1 // sun.security.ssl.HandshakeContext context
        end local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    7     0            this  Lsun/security/ssl/NewSessionTicket$NewSessionTicketMessage;
            0    7     1         context  Lsun/security/ssl/HandshakeContext;
            0    7     2  ticketLifetime  I
            0    7     3       generator  Ljava/security/SecureRandom;
            0    7     4     ticketNonce  [B
            0    7     5          ticket  [B
    MethodParameters:
                Name  Flags
      context         
      ticketLifetime  
      generator       
      ticketNonce     
      ticket          

  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.NewSessionTicket$NewSessionTicketMessage this
        start local 1 // sun.security.ssl.HandshakeContext context
        start local 2 // java.nio.ByteBuffer m
         0: .line 79
            aload 0 /* this */
            aload 1 /* context */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 88
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            bipush 14
            if_icmpge 5
         2: .line 89
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
         3: .line 90
            ldc "Invalid NewSessionTicket message: no sufficient data"
         4: .line 89
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
         5: .line 93
      StackMap locals: sun.security.ssl.NewSessionTicket$NewSessionTicketMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer
      StackMap stack:
            aload 0 /* this */
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getInt32:(Ljava/nio/ByteBuffer;)I
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketLifetime:I
         6: .line 94
            aload 0 /* this */
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getInt32:(Ljava/nio/ByteBuffer;)I
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketAgeAdd:I
         7: .line 95
            aload 0 /* this */
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getBytes8:(Ljava/nio/ByteBuffer;)[B
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketNonce:[B
         8: .line 97
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_5
            if_icmpge 12
         9: .line 98
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
        10: .line 99
            ldc "Invalid NewSessionTicket message: no sufficient data"
        11: .line 98
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        12: .line 102
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getBytes16:(Ljava/nio/ByteBuffer;)[B
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticket:[B
        13: .line 103
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticket:[B
            arraylength
            ifne 17
        14: .line 104
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
        15: .line 105
            ldc "No ticket in the NewSessionTicket handshake message"
        16: .line 104
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        17: .line 108
      StackMap locals:
      StackMap stack:
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_2
            if_icmpge 21
        18: .line 109
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
        19: .line 110
            ldc "Invalid NewSessionTicket message: no sufficient data"
        20: .line 109
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        21: .line 114
      StackMap locals:
      StackMap stack:
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        22: .line 115
            getstatic sun.security.ssl.SSLHandshake.NEW_SESSION_TICKET:Lsun/security/ssl/SSLHandshake;
        23: .line 114
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;)[Lsun/security/ssl/SSLExtension;
        24: .line 113
            astore 3 /* supportedExtensions */
        start local 3 // sun.security.ssl.SSLExtension[] supportedExtensions
        25: .line 116
            aload 0 /* this */
            new sun.security.ssl.SSLExtensions
            dup
            aload 0 /* this */
            aload 2 /* m */
            aload 3 /* supportedExtensions */
            invokespecial sun.security.ssl.SSLExtensions.<init>:(Lsun/security/ssl/SSLHandshake$HandshakeMessage;Ljava/nio/ByteBuffer;[Lsun/security/ssl/SSLExtension;)V
            putfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.extensions:Lsun/security/ssl/SSLExtensions;
        26: .line 117
            return
        end local 3 // sun.security.ssl.SSLExtension[] supportedExtensions
        end local 2 // java.nio.ByteBuffer m
        end local 1 // sun.security.ssl.HandshakeContext context
        end local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   27     0                 this  Lsun/security/ssl/NewSessionTicket$NewSessionTicketMessage;
            0   27     1              context  Lsun/security/ssl/HandshakeContext;
            0   27     2                    m  Ljava/nio/ByteBuffer;
           25   27     3  supportedExtensions  [Lsun/security/ssl/SSLExtension;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
      m        

  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.NewSessionTicket$NewSessionTicketMessage this
         0: .line 121
            getstatic sun.security.ssl.SSLHandshake.NEW_SESSION_TICKET:Lsun/security/ssl/SSLHandshake;
            areturn
        end local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/NewSessionTicket$NewSessionTicketMessage;

  public int messageLength();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
         0: .line 126
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.length:()I
            istore 1 /* extLen */
        start local 1 // int extLen
         1: .line 127
            iload 1 /* extLen */
            ifne 3
         2: .line 128
            iconst_2
            istore 1 /* extLen */
         3: .line 131
      StackMap locals: int
      StackMap stack:
            bipush 8
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketNonce:[B
            arraylength
            iadd
            iconst_1
            iadd
         4: .line 132
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticket:[B
            arraylength
         5: .line 131
            iadd
         6: .line 132
            iconst_2
         7: .line 131
            iadd
         8: .line 132
            iload 1 /* extLen */
         9: .line 131
            iadd
            ireturn
        end local 1 // int extLen
        end local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Lsun/security/ssl/NewSessionTicket$NewSessionTicketMessage;
            1   10     1  extLen  I

  public void send(sun.security.ssl.HandshakeOutStream);
    descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
        start local 1 // sun.security.ssl.HandshakeOutStream hos
         0: .line 137
            aload 1 /* hos */
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketLifetime:I
            invokevirtual sun.security.ssl.HandshakeOutStream.putInt32:(I)V
         1: .line 138
            aload 1 /* hos */
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketAgeAdd:I
            invokevirtual sun.security.ssl.HandshakeOutStream.putInt32:(I)V
         2: .line 139
            aload 1 /* hos */
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketNonce:[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes8:([B)V
         3: .line 140
            aload 1 /* hos */
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticket:[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         4: .line 143
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.length:()I
            ifne 7
         5: .line 144
            aload 1 /* hos */
            iconst_0
            invokevirtual sun.security.ssl.HandshakeOutStream.putInt16:(I)V
         6: .line 145
            goto 8
         7: .line 146
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 1 /* hos */
            invokevirtual sun.security.ssl.SSLExtensions.send:(Lsun/security/ssl/HandshakeOutStream;)V
         8: .line 148
      StackMap locals:
      StackMap stack:
            return
        end local 1 // sun.security.ssl.HandshakeOutStream hos
        end local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lsun/security/ssl/NewSessionTicket$NewSessionTicketMessage;
            0    9     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=5, locals=3, args_size=1
        start local 0 // sun.security.ssl.NewSessionTicket$NewSessionTicketMessage this
         0: .line 152
            new java.text.MessageFormat
            dup
         1: .line 153
            ldc "\"NewSessionTicket\": '{'\n  \"ticket_lifetime\"      : \"{0}\",\n  \"ticket_age_add\"       : \"{1}\",\n  \"ticket_nonce\"         : \"{2}\",\n  \"ticket\"               : \"{3}\",\n  \"extensions\"           : [\n{4}\n  ]\n'}'"
         2: .line 162
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         3: .line 152
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         4: .line 164
            iconst_5
            anewarray java.lang.Object
            dup
            iconst_0
         5: .line 165
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketLifetime:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
         6: .line 166
            ldc "<omitted>"
            aastore
            dup
            iconst_2
         7: .line 167
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticketNonce:[B
            invokestatic sun.security.ssl.Utilities.toHexString:([B)Ljava/lang/String;
            aastore
            dup
            iconst_3
         8: .line 168
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.ticket:[B
            invokestatic sun.security.ssl.Utilities.toHexString:([B)Ljava/lang/String;
            aastore
            dup
            iconst_4
         9: .line 169
            aload 0 /* this */
            getfield sun.security.ssl.NewSessionTicket$NewSessionTicketMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.toString:()Ljava/lang/String;
            ldc "    "
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            aastore
        10: .line 164
            astore 2 /* messageFields */
        start local 2 // java.lang.Object[] messageFields
        11: .line 172
            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.NewSessionTicket$NewSessionTicketMessage this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Lsun/security/ssl/NewSessionTicket$NewSessionTicketMessage;
            4   12     1  messageFormat  Ljava/text/MessageFormat;
           11   12     2  messageFields  [Ljava/lang/Object;
}
SourceFile: "NewSessionTicket.java"
NestHost: sun.security.ssl.NewSessionTicket
InnerClasses:
  final NewSessionTicketMessage = sun.security.ssl.NewSessionTicket$NewSessionTicketMessage of sun.security.ssl.NewSessionTicket
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake