final class sun.security.ssl.SessionTicketExtension$SessionTicketSpec implements sun.security.ssl.SSLExtension$SSLExtensionSpec
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.SessionTicketExtension$SessionTicketSpec
  super_class: java.lang.Object
{
  private static final int GCM_TAG_LEN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 128

  java.nio.ByteBuffer data;
    descriptor: Ljava/nio/ByteBuffer;
    flags: (0x0000) 

  static final java.nio.ByteBuffer zero;
    descriptor: Ljava/nio/ByteBuffer;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 234
            iconst_0
            newarray 8
            invokestatic java.nio.ByteBuffer.wrap:([B)Ljava/nio/ByteBuffer;
            putstatic sun.security.ssl.SessionTicketExtension$SessionTicketSpec.zero:Ljava/nio/ByteBuffer;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
         0: .line 236
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 237
            aload 0 /* this */
            getstatic sun.security.ssl.SessionTicketExtension$SessionTicketSpec.zero:Ljava/nio/ByteBuffer;
            putfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
         2: .line 238
            return
        end local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/SessionTicketExtension$SessionTicketSpec;

  void <init>(sun.security.ssl.HandshakeContext, byte[]);
    descriptor: (Lsun/security/ssl/HandshakeContext;[B)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
        start local 1 // sun.security.ssl.HandshakeContext hc
        start local 2 // byte[] b
         0: .line 241
            aload 0 /* this */
            aload 1 /* hc */
            aload 2 /* b */
            invokestatic java.nio.ByteBuffer.wrap:([B)Ljava/nio/ByteBuffer;
            invokespecial sun.security.ssl.SessionTicketExtension$SessionTicketSpec.<init>:(Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
         1: .line 242
            return
        end local 2 // byte[] b
        end local 1 // sun.security.ssl.HandshakeContext hc
        end local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/SessionTicketExtension$SessionTicketSpec;
            0    2     1    hc  Lsun/security/ssl/HandshakeContext;
            0    2     2     b  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      hc    
      b     

  void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
    descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
    flags: (0x0000) 
    Code:
      stack=7, locals=3, args_size=3
        start local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
        start local 1 // sun.security.ssl.HandshakeContext hc
        start local 2 // java.nio.ByteBuffer buf
         0: .line 244
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 246
            aload 2 /* buf */
            ifnonnull 7
         2: .line 247
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
         3: .line 248
            new javax.net.ssl.SSLProtocolException
            dup
         4: .line 249
            ldc "SessionTicket buffer too small"
         5: .line 248
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
         6: .line 247
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
         7: .line 251
      StackMap locals: sun.security.ssl.SessionTicketExtension$SessionTicketSpec sun.security.ssl.HandshakeContext java.nio.ByteBuffer
      StackMap stack:
            aload 2 /* buf */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            ldc 65536
            if_icmple 13
         8: .line 252
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
         9: .line 253
            new javax.net.ssl.SSLProtocolException
            dup
        10: .line 254
            new java.lang.StringBuilder
            dup
            ldc "SessionTicket buffer too large. "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* buf */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 253
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
        12: .line 252
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        13: .line 257
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* buf */
            putfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
        14: .line 258
            return
        end local 2 // java.nio.ByteBuffer buf
        end local 1 // sun.security.ssl.HandshakeContext hc
        end local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   15     0  this  Lsun/security/ssl/SessionTicketExtension$SessionTicketSpec;
            0   15     1    hc  Lsun/security/ssl/HandshakeContext;
            0   15     2   buf  Ljava/nio/ByteBuffer;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      hc    
      buf   

  public byte[] encrypt(sun.security.ssl.HandshakeContext, sun.security.ssl.SSLSessionImpl);
    descriptor: (Lsun/security/ssl/HandshakeContext;Lsun/security/ssl/SSLSessionImpl;)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=10, args_size=3
        start local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
        start local 1 // sun.security.ssl.HandshakeContext hc
        start local 2 // sun.security.ssl.SSLSessionImpl session
         0: .line 263
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.statelessResumption:Z
            ifeq 2
         1: .line 264
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.isStatelessable:()Z
            ifne 3
         2: .line 265
      StackMap locals:
      StackMap stack:
            iconst_0
            newarray 8
            areturn
         3: .line 269
      StackMap locals:
      StackMap stack:
            aload 1 /* hc */
            invokestatic sun.security.ssl.SessionTicketExtension$KeyState.getCurrentKey:(Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SessionTicketExtension$StatelessKey;
            astore 4 /* key */
        start local 4 // sun.security.ssl.SessionTicketExtension$StatelessKey key
         4: .line 270
            bipush 16
            newarray 8
            astore 5 /* iv */
        start local 5 // byte[] iv
         5: .line 272
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
            astore 6 /* random */
        start local 6 // java.security.SecureRandom random
         6: .line 273
            aload 6 /* random */
            aload 5 /* iv */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         7: .line 274
            ldc "AES/GCM/NoPadding"
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 7 /* c */
        start local 7 // javax.crypto.Cipher c
         8: .line 275
            aload 7 /* c */
            iconst_1
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.key:Ljavax/crypto/SecretKey;
         9: .line 276
            new javax.crypto.spec.GCMParameterSpec
            dup
            sipush 128
            aload 5 /* iv */
            invokespecial javax.crypto.spec.GCMParameterSpec.<init>:(I[B)V
        10: .line 275
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
        11: .line 277
            aload 7 /* c */
            iconst_4
            newarray 8
            dup
            iconst_0
        12: .line 278
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            bipush 24
            iushr
            i2b
            bastore
            dup
            iconst_1
        13: .line 279
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            bipush 16
            iushr
            i2b
            bastore
            dup
            iconst_2
        14: .line 280
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            bipush 8
            iushr
            i2b
            bastore
            dup
            iconst_3
        15: .line 281
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            i2b
            bastore
        16: .line 277
            invokevirtual javax.crypto.Cipher.updateAAD:([B)V
        17: .line 283
            aload 2 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.write:()[B
            astore 8 /* data */
        start local 8 // byte[] data
        18: .line 284
            aload 8 /* data */
            arraylength
            ifne 21
        19: .line 285
            aload 8 /* data */
        20: areturn
        21: .line 287
      StackMap locals: sun.security.ssl.SessionTicketExtension$SessionTicketSpec sun.security.ssl.HandshakeContext sun.security.ssl.SSLSessionImpl top sun.security.ssl.SessionTicketExtension$StatelessKey byte[] java.security.SecureRandom javax.crypto.Cipher byte[]
      StackMap stack:
            aload 7 /* c */
            aload 8 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 3 /* encrypted */
        start local 3 // byte[] encrypted
        22: .line 288
            aload 3 /* encrypted */
            arraylength
            iconst_4
            iadd
        23: .line 289
            aload 5 /* iv */
            arraylength
        24: .line 288
            iadd
            newarray 8
            astore 9 /* result */
        start local 9 // byte[] result
        25: .line 290
            aload 9 /* result */
            iconst_0
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            bipush 24
            iushr
            i2b
            bastore
        26: .line 291
            aload 9 /* result */
            iconst_1
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            bipush 16
            iushr
            i2b
            bastore
        27: .line 292
            aload 9 /* result */
            iconst_2
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            bipush 8
            iushr
            i2b
            bastore
        28: .line 293
            aload 9 /* result */
            iconst_3
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.num:I
            i2b
            bastore
        29: .line 294
            aload 5 /* iv */
            iconst_0
            aload 9 /* result */
            iconst_4
            aload 5 /* iv */
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        30: .line 295
            aload 3 /* encrypted */
            iconst_0
            aload 9 /* result */
        31: .line 296
            iconst_4
            aload 5 /* iv */
            arraylength
            iadd
            aload 3 /* encrypted */
            arraylength
        32: .line 295
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        33: .line 297
            aload 9 /* result */
        34: areturn
        end local 9 // byte[] result
        end local 8 // byte[] data
        end local 7 // javax.crypto.Cipher c
        end local 6 // java.security.SecureRandom random
        end local 5 // byte[] iv
        end local 4 // sun.security.ssl.SessionTicketExtension$StatelessKey key
        end local 3 // byte[] encrypted
        35: .line 298
      StackMap locals: sun.security.ssl.SessionTicketExtension$SessionTicketSpec sun.security.ssl.HandshakeContext sun.security.ssl.SSLSessionImpl
      StackMap stack: java.lang.Exception
            astore 4 /* e */
        start local 4 // java.lang.Exception e
        36: .line 299
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 38
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 38
        37: .line 300
            new java.lang.StringBuilder
            dup
            ldc "Encryption failed."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        38: .line 302
      StackMap locals: sun.security.ssl.SessionTicketExtension$SessionTicketSpec sun.security.ssl.HandshakeContext sun.security.ssl.SSLSessionImpl top java.lang.Exception
      StackMap stack:
            iconst_0
            newarray 8
            areturn
        end local 4 // java.lang.Exception e
        end local 2 // sun.security.ssl.SSLSessionImpl session
        end local 1 // sun.security.ssl.HandshakeContext hc
        end local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   39     0       this  Lsun/security/ssl/SessionTicketExtension$SessionTicketSpec;
            0   39     1         hc  Lsun/security/ssl/HandshakeContext;
            0   39     2    session  Lsun/security/ssl/SSLSessionImpl;
           22   35     3  encrypted  [B
            4   35     4        key  Lsun/security/ssl/SessionTicketExtension$StatelessKey;
            5   35     5         iv  [B
            6   35     6     random  Ljava/security/SecureRandom;
            8   35     7          c  Ljavax/crypto/Cipher;
           18   35     8       data  [B
           25   35     9     result  [B
           36   39     4          e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           3    20      35  Class java.lang.Exception
          21    34      35  Class java.lang.Exception
    MethodParameters:
         Name  Flags
      hc       
      session  

  java.nio.ByteBuffer decrypt(sun.security.ssl.HandshakeContext);
    descriptor: (Lsun/security/ssl/HandshakeContext;)Ljava/nio/ByteBuffer;
    flags: (0x0000) 
    Code:
      stack=7, locals=7, args_size=2
        start local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
        start local 1 // sun.security.ssl.HandshakeContext hc
         0: .line 310
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            invokevirtual java.nio.ByteBuffer.getInt:()I
            istore 2 /* keyID */
        start local 2 // int keyID
         1: .line 311
            aload 1 /* hc */
            iload 2 /* keyID */
            invokestatic sun.security.ssl.SessionTicketExtension$KeyState.getKey:(Lsun/security/ssl/HandshakeContext;I)Lsun/security/ssl/SessionTicketExtension$StatelessKey;
            astore 4 /* key */
        start local 4 // sun.security.ssl.SessionTicketExtension$StatelessKey key
         2: .line 312
            aload 4 /* key */
            ifnonnull 4
         3: .line 313
            aconst_null
            areturn
         4: .line 316
      StackMap locals: sun.security.ssl.SessionTicketExtension$SessionTicketSpec sun.security.ssl.HandshakeContext int top sun.security.ssl.SessionTicketExtension$StatelessKey
      StackMap stack:
            bipush 16
            newarray 8
            astore 3 /* iv */
        start local 3 // byte[] iv
         5: .line 317
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            aload 3 /* iv */
            invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
            pop
         6: .line 318
            ldc "AES/GCM/NoPadding"
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 5 /* c */
        start local 5 // javax.crypto.Cipher c
         7: .line 319
            aload 5 /* c */
            iconst_2
            aload 4 /* key */
            getfield sun.security.ssl.SessionTicketExtension$StatelessKey.key:Ljavax/crypto/SecretKey;
         8: .line 320
            new javax.crypto.spec.GCMParameterSpec
            dup
            sipush 128
            aload 3 /* iv */
            invokespecial javax.crypto.spec.GCMParameterSpec.<init>:(I[B)V
         9: .line 319
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
        10: .line 321
            aload 5 /* c */
            iconst_4
            newarray 8
            dup
            iconst_0
        11: .line 322
            iload 2 /* keyID */
            bipush 24
            iushr
            i2b
            bastore
            dup
            iconst_1
        12: .line 323
            iload 2 /* keyID */
            bipush 16
            iushr
            i2b
            bastore
            dup
            iconst_2
        13: .line 324
            iload 2 /* keyID */
            bipush 8
            iushr
            i2b
            bastore
            dup
            iconst_3
        14: .line 325
            iload 2 /* keyID */
            i2b
            bastore
        15: .line 321
            invokevirtual javax.crypto.Cipher.updateAAD:([B)V
        16: .line 329
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            invokevirtual java.nio.ByteBuffer.remaining:()I
            bipush 16
            isub
            invokestatic java.nio.ByteBuffer.allocate:(I)Ljava/nio/ByteBuffer;
            astore 6 /* out */
        start local 6 // java.nio.ByteBuffer out
        17: .line 330
            aload 5 /* c */
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            aload 6 /* out */
            invokevirtual javax.crypto.Cipher.doFinal:(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
            pop
        18: .line 331
            aload 6 /* out */
            invokevirtual java.nio.ByteBuffer.flip:()Ljava/nio/ByteBuffer;
            pop
        19: .line 332
            aload 6 /* out */
        20: areturn
        end local 6 // java.nio.ByteBuffer out
        end local 5 // javax.crypto.Cipher c
        end local 4 // sun.security.ssl.SessionTicketExtension$StatelessKey key
        end local 3 // byte[] iv
        end local 2 // int keyID
        21: .line 333
      StackMap locals: sun.security.ssl.SessionTicketExtension$SessionTicketSpec sun.security.ssl.HandshakeContext
      StackMap stack: java.lang.Exception
            astore 4 /* e */
        start local 4 // java.lang.Exception e
        22: .line 334
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 24
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 24
        23: .line 335
            new java.lang.StringBuilder
            dup
            ldc "Decryption failed."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        end local 4 // java.lang.Exception e
        24: .line 338
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 1 // sun.security.ssl.HandshakeContext hc
        end local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   25     0   this  Lsun/security/ssl/SessionTicketExtension$SessionTicketSpec;
            0   25     1     hc  Lsun/security/ssl/HandshakeContext;
            1   21     2  keyID  I
            5   21     3     iv  [B
            2   21     4    key  Lsun/security/ssl/SessionTicketExtension$StatelessKey;
            7   21     5      c  Ljavax/crypto/Cipher;
           17   21     6    out  Ljava/nio/ByteBuffer;
           22   24     4      e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0     3      21  Class java.lang.Exception
           4    20      21  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      hc    

  byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
         0: .line 342
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            invokevirtual java.nio.ByteBuffer.capacity:()I
            newarray 8
            astore 1 /* out */
        start local 1 // byte[] out
         1: .line 343
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            invokevirtual java.nio.ByteBuffer.duplicate:()Ljava/nio/ByteBuffer;
            aload 1 /* out */
            invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
            pop
         2: .line 344
            aload 1 /* out */
            areturn
        end local 1 // byte[] out
        end local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/SessionTicketExtension$SessionTicketSpec;
            1    3     1   out  [B

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
         0: .line 349
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            ifnonnull 2
         1: .line 350
            ldc "<null>"
            areturn
         2: .line 352
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            invokevirtual java.nio.ByteBuffer.capacity:()I
            ifne 4
         3: .line 353
            ldc "<empty>"
            areturn
         4: .line 356
      StackMap locals:
      StackMap stack:
            new java.text.MessageFormat
            dup
         5: .line 357
            ldc "  \"ticket\" : '{'\n{0}\n  '}'"
         6: .line 360
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         7: .line 356
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         8: .line 361
            new sun.security.util.HexDumpEncoder
            dup
            invokespecial sun.security.util.HexDumpEncoder.<init>:()V
            astore 2 /* hexEncoder */
        start local 2 // sun.security.util.HexDumpEncoder hexEncoder
         9: .line 363
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        10: .line 364
            aload 2 /* hexEncoder */
            aload 0 /* this */
            getfield sun.security.ssl.SessionTicketExtension$SessionTicketSpec.data:Ljava/nio/ByteBuffer;
            invokevirtual java.nio.ByteBuffer.duplicate:()Ljava/nio/ByteBuffer;
            invokevirtual sun.security.util.HexDumpEncoder.encode:(Ljava/nio/ByteBuffer;)Ljava/lang/String;
        11: .line 365
            ldc "    "
        12: .line 364
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            aastore
        13: .line 363
            astore 3 /* messageFields */
        start local 3 // java.lang.Object[] messageFields
        14: .line 368
            aload 1 /* messageFormat */
            aload 3 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 3 // java.lang.Object[] messageFields
        end local 2 // sun.security.util.HexDumpEncoder hexEncoder
        end local 1 // java.text.MessageFormat messageFormat
        end local 0 // sun.security.ssl.SessionTicketExtension$SessionTicketSpec this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   15     0           this  Lsun/security/ssl/SessionTicketExtension$SessionTicketSpec;
            8   15     1  messageFormat  Ljava/text/MessageFormat;
            9   15     2     hexEncoder  Lsun/security/util/HexDumpEncoder;
           14   15     3  messageFields  [Ljava/lang/Object;
}
SourceFile: "SessionTicketExtension.java"
NestHost: sun.security.ssl.SessionTicketExtension
InnerClasses:
  abstract SSLExtensionSpec = sun.security.ssl.SSLExtension$SSLExtensionSpec of sun.security.ssl.SSLExtension
  private final KeyState = sun.security.ssl.SessionTicketExtension$KeyState of sun.security.ssl.SessionTicketExtension
  final SessionTicketSpec = sun.security.ssl.SessionTicketExtension$SessionTicketSpec of sun.security.ssl.SessionTicketExtension
  final StatelessKey = sun.security.ssl.SessionTicketExtension$StatelessKey of sun.security.ssl.SessionTicketExtension