public class sun.security.krb5.KrbTgsReq
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.krb5.KrbTgsReq
  super_class: java.lang.Object
{
  private sun.security.krb5.PrincipalName princName;
    descriptor: Lsun/security/krb5/PrincipalName;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.krb5.PrincipalName servName;
    descriptor: Lsun/security/krb5/PrincipalName;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.krb5.internal.TGSReq tgsReqMessg;
    descriptor: Lsun/security/krb5/internal/TGSReq;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.krb5.internal.KerberosTime ctime;
    descriptor: Lsun/security/krb5/internal/KerberosTime;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.krb5.internal.Ticket secondTicket;
    descriptor: Lsun/security/krb5/internal/Ticket;
    flags: (0x0002) ACC_PRIVATE

  private boolean useSubkey;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  sun.security.krb5.EncryptionKey tgsReqKey;
    descriptor: Lsun/security/krb5/EncryptionKey;
    flags: (0x0000) 

  private static final boolean DEBUG;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private byte[] obuf;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private byte[] ibuf;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 52
            getstatic sun.security.krb5.internal.Krb5.DEBUG:Z
            putstatic sun.security.krb5.KrbTgsReq.DEBUG:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(sun.security.krb5.Credentials, sun.security.krb5.PrincipalName);
    descriptor: (Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=12, locals=3, args_size=3
        start local 0 // sun.security.krb5.KrbTgsReq this
        start local 1 // sun.security.krb5.Credentials asCreds
        start local 2 // sun.security.krb5.PrincipalName sname
         0: .line 61
            aload 0 /* this */
            new sun.security.krb5.internal.KDCOptions
            dup
            invokespecial sun.security.krb5.internal.KDCOptions.<init>:()V
         1: .line 62
            aload 1 /* asCreds */
         2: .line 63
            aload 2 /* sname */
         3: .line 64
            aconst_null
         4: .line 65
            aconst_null
         5: .line 66
            aconst_null
         6: .line 67
            aconst_null
         7: .line 68
            aconst_null
         8: .line 69
            aconst_null
         9: .line 70
            aconst_null
        10: .line 71
            aconst_null
            invokespecial sun.security.krb5.KrbTgsReq.<init>:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;[ILsun/security/krb5/internal/HostAddresses;Lsun/security/krb5/internal/AuthorizationData;[Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/EncryptionKey;)V
        11: .line 72
            return
        end local 2 // sun.security.krb5.PrincipalName sname
        end local 1 // sun.security.krb5.Credentials asCreds
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   12     0     this  Lsun/security/krb5/KrbTgsReq;
            0   12     1  asCreds  Lsun/security/krb5/Credentials;
            0   12     2    sname  Lsun/security/krb5/PrincipalName;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
         Name  Flags
      asCreds  
      sname    

  void <init>(sun.security.krb5.internal.KDCOptions, sun.security.krb5.Credentials, sun.security.krb5.PrincipalName, sun.security.krb5.internal.KerberosTime, sun.security.krb5.internal.KerberosTime, sun.security.krb5.internal.KerberosTime, int[], sun.security.krb5.internal.HostAddresses, sun.security.krb5.internal.AuthorizationData, sun.security.krb5.internal.Ticket[], sun.security.krb5.EncryptionKey);
    descriptor: (Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;[ILsun/security/krb5/internal/HostAddresses;Lsun/security/krb5/internal/AuthorizationData;[Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/EncryptionKey;)V
    flags: (0x0000) 
    Code:
      stack=16, locals=12, args_size=12
        start local 0 // sun.security.krb5.KrbTgsReq this
        start local 1 // sun.security.krb5.internal.KDCOptions options
        start local 2 // sun.security.krb5.Credentials asCreds
        start local 3 // sun.security.krb5.PrincipalName sname
        start local 4 // sun.security.krb5.internal.KerberosTime from
        start local 5 // sun.security.krb5.internal.KerberosTime till
        start local 6 // sun.security.krb5.internal.KerberosTime rtime
        start local 7 // int[] eTypes
        start local 8 // sun.security.krb5.internal.HostAddresses addresses
        start local 9 // sun.security.krb5.internal.AuthorizationData authorizationData
        start local 10 // sun.security.krb5.internal.Ticket[] additionalTickets
        start local 11 // sun.security.krb5.EncryptionKey subKey
         0: .line 75
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 48
            aload 0 /* this */
            aconst_null
            putfield sun.security.krb5.KrbTgsReq.secondTicket:Lsun/security/krb5/internal/Ticket;
         2: .line 49
            aload 0 /* this */
            iconst_0
            putfield sun.security.krb5.KrbTgsReq.useSubkey:Z
         3: .line 88
            aload 0 /* this */
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.client:Lsun/security/krb5/PrincipalName;
            putfield sun.security.krb5.KrbTgsReq.princName:Lsun/security/krb5/PrincipalName;
         4: .line 89
            aload 0 /* this */
            aload 3 /* sname */
            putfield sun.security.krb5.KrbTgsReq.servName:Lsun/security/krb5/PrincipalName;
         5: .line 90
            aload 0 /* this */
            new sun.security.krb5.internal.KerberosTime
            dup
            iconst_1
            invokespecial sun.security.krb5.internal.KerberosTime.<init>:(Z)V
            putfield sun.security.krb5.KrbTgsReq.ctime:Lsun/security/krb5/internal/KerberosTime;
         6: .line 95
            aload 1 /* options */
            iconst_1
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 9
         7: .line 96
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            iconst_1
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 9
         8: .line 97
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
         9: .line 99
      StackMap locals: sun.security.krb5.KrbTgsReq sun.security.krb5.internal.KDCOptions sun.security.krb5.Credentials sun.security.krb5.PrincipalName sun.security.krb5.internal.KerberosTime sun.security.krb5.internal.KerberosTime sun.security.krb5.internal.KerberosTime int[] sun.security.krb5.internal.HostAddresses sun.security.krb5.internal.AuthorizationData sun.security.krb5.internal.Ticket[] sun.security.krb5.EncryptionKey
      StackMap stack:
            aload 1 /* options */
            iconst_2
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 12
        10: .line 100
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            iconst_1
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 12
        11: .line 101
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        12: .line 103
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            iconst_3
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 15
        13: .line 104
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            iconst_3
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 15
        14: .line 105
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        15: .line 107
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            iconst_4
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 18
        16: .line 108
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            iconst_3
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 18
        17: .line 109
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        18: .line 111
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            iconst_5
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 21
        19: .line 112
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            iconst_5
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 21
        20: .line 113
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        21: .line 115
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 8
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 24
        22: .line 116
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            bipush 8
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 24
        23: .line 117
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        24: .line 120
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 6
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 27
        25: .line 121
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            bipush 6
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 28
        26: .line 122
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        27: .line 124
      StackMap locals:
      StackMap stack:
            aload 4 /* from */
            ifnull 28
            aconst_null
            astore 4 /* from */
        28: .line 126
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 8
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 31
        29: .line 127
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            bipush 8
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifne 32
        30: .line 128
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        31: .line 130
      StackMap locals:
      StackMap stack:
            aload 6 /* rtime */
            ifnull 32
            aconst_null
            astore 6 /* rtime */
        32: .line 132
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 28
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 37
        33: .line 133
            aload 10 /* additionalTickets */
            ifnonnull 35
        34: .line 134
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        35: .line 138
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 10 /* additionalTickets */
            iconst_0
            aaload
            putfield sun.security.krb5.KrbTgsReq.secondTicket:Lsun/security/krb5/internal/Ticket;
        36: .line 139
            goto 39
        37: .line 140
      StackMap locals:
      StackMap stack:
            aload 10 /* additionalTickets */
            ifnull 39
        38: .line 141
            aconst_null
            astore 10 /* additionalTickets */
        39: .line 144
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
        40: .line 145
            aload 1 /* options */
        41: .line 146
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.ticket:Lsun/security/krb5/internal/Ticket;
        42: .line 147
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.key:Lsun/security/krb5/EncryptionKey;
        43: .line 148
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.ctime:Lsun/security/krb5/internal/KerberosTime;
        44: .line 149
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.princName:Lsun/security/krb5/PrincipalName;
        45: .line 150
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.servName:Lsun/security/krb5/PrincipalName;
        46: .line 151
            aload 4 /* from */
        47: .line 152
            aload 5 /* till */
        48: .line 153
            aload 6 /* rtime */
        49: .line 154
            aload 7 /* eTypes */
        50: .line 155
            aload 8 /* addresses */
        51: .line 156
            aload 9 /* authorizationData */
        52: .line 157
            aload 10 /* additionalTickets */
        53: .line 158
            aload 11 /* subKey */
        54: .line 144
            invokevirtual sun.security.krb5.KrbTgsReq.createRequest:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/EncryptionKey;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;[ILsun/security/krb5/internal/HostAddresses;Lsun/security/krb5/internal/AuthorizationData;[Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/EncryptionKey;)Lsun/security/krb5/internal/TGSReq;
            putfield sun.security.krb5.KrbTgsReq.tgsReqMessg:Lsun/security/krb5/internal/TGSReq;
        55: .line 159
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.tgsReqMessg:Lsun/security/krb5/internal/TGSReq;
            invokevirtual sun.security.krb5.internal.TGSReq.asn1Encode:()[B
            putfield sun.security.krb5.KrbTgsReq.obuf:[B
        56: .line 169
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.flags:Lsun/security/krb5/internal/TicketFlags;
            iconst_2
            invokevirtual sun.security.krb5.internal.TicketFlags.get:(I)Z
            ifeq 58
        57: .line 170
            aload 1 /* options */
            iconst_2
            iconst_1
            invokevirtual sun.security.krb5.internal.KDCOptions.set:(IZ)V
        58: .line 173
      StackMap locals:
      StackMap stack:
            return
        end local 11 // sun.security.krb5.EncryptionKey subKey
        end local 10 // sun.security.krb5.internal.Ticket[] additionalTickets
        end local 9 // sun.security.krb5.internal.AuthorizationData authorizationData
        end local 8 // sun.security.krb5.internal.HostAddresses addresses
        end local 7 // int[] eTypes
        end local 6 // sun.security.krb5.internal.KerberosTime rtime
        end local 5 // sun.security.krb5.internal.KerberosTime till
        end local 4 // sun.security.krb5.internal.KerberosTime from
        end local 3 // sun.security.krb5.PrincipalName sname
        end local 2 // sun.security.krb5.Credentials asCreds
        end local 1 // sun.security.krb5.internal.KDCOptions options
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   59     0               this  Lsun/security/krb5/KrbTgsReq;
            0   59     1            options  Lsun/security/krb5/internal/KDCOptions;
            0   59     2            asCreds  Lsun/security/krb5/Credentials;
            0   59     3              sname  Lsun/security/krb5/PrincipalName;
            0   59     4               from  Lsun/security/krb5/internal/KerberosTime;
            0   59     5               till  Lsun/security/krb5/internal/KerberosTime;
            0   59     6              rtime  Lsun/security/krb5/internal/KerberosTime;
            0   59     7             eTypes  [I
            0   59     8          addresses  Lsun/security/krb5/internal/HostAddresses;
            0   59     9  authorizationData  Lsun/security/krb5/internal/AuthorizationData;
            0   59    10  additionalTickets  [Lsun/security/krb5/internal/Ticket;
            0   59    11             subKey  Lsun/security/krb5/EncryptionKey;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
                   Name  Flags
      options            
      asCreds            
      sname              
      from               
      till               
      rtime              
      eTypes             
      addresses          
      authorizationData  
      additionalTickets  
      subKey             

  public void send();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // sun.security.krb5.KrbTgsReq this
         0: .line 181
            aconst_null
            astore 1 /* realmStr */
        start local 1 // java.lang.String realmStr
         1: .line 182
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.servName:Lsun/security/krb5/PrincipalName;
            ifnull 3
         2: .line 183
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.servName:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 1 /* realmStr */
         3: .line 184
      StackMap locals: java.lang.String
      StackMap stack:
            new sun.security.krb5.KdcComm
            dup
            aload 1 /* realmStr */
            invokespecial sun.security.krb5.KdcComm.<init>:(Ljava/lang/String;)V
            astore 2 /* comm */
        start local 2 // sun.security.krb5.KdcComm comm
         4: .line 185
            aload 0 /* this */
            aload 2 /* comm */
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.obuf:[B
            invokevirtual sun.security.krb5.KdcComm.send:([B)[B
            putfield sun.security.krb5.KrbTgsReq.ibuf:[B
         5: .line 186
            return
        end local 2 // sun.security.krb5.KdcComm comm
        end local 1 // java.lang.String realmStr
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lsun/security/krb5/KrbTgsReq;
            1    6     1  realmStr  Ljava/lang/String;
            4    6     2      comm  Lsun/security/krb5/KdcComm;
    Exceptions:
      throws java.io.IOException, sun.security.krb5.KrbException

  public sun.security.krb5.KrbTgsRep getReply();
    descriptor: ()Lsun/security/krb5/KrbTgsRep;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // sun.security.krb5.KrbTgsReq this
         0: .line 190
            new sun.security.krb5.KrbTgsRep
            dup
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.ibuf:[B
            aload 0 /* this */
            invokespecial sun.security.krb5.KrbTgsRep.<init>:([BLsun/security/krb5/KrbTgsReq;)V
            areturn
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/KrbTgsReq;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException

  public sun.security.krb5.Credentials sendAndGetCreds();
    descriptor: ()Lsun/security/krb5/Credentials;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // sun.security.krb5.KrbTgsReq this
         0: .line 198
            aconst_null
            astore 1 /* tgs_rep */
        start local 1 // sun.security.krb5.KrbTgsRep tgs_rep
         1: .line 200
            aload 0 /* this */
            invokevirtual sun.security.krb5.KrbTgsReq.send:()V
         2: .line 201
            aload 0 /* this */
            invokevirtual sun.security.krb5.KrbTgsReq.getReply:()Lsun/security/krb5/KrbTgsRep;
            astore 1 /* tgs_rep */
         3: .line 202
            aload 1 /* tgs_rep */
            invokevirtual sun.security.krb5.KrbTgsRep.getCreds:()Lsun/security/krb5/Credentials;
            areturn
        end local 1 // sun.security.krb5.KrbTgsRep tgs_rep
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lsun/security/krb5/KrbTgsReq;
            1    4     1  tgs_rep  Lsun/security/krb5/KrbTgsRep;
    Exceptions:
      throws java.io.IOException, sun.security.krb5.KrbException

  sun.security.krb5.internal.KerberosTime getCtime();
    descriptor: ()Lsun/security/krb5/internal/KerberosTime;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.KrbTgsReq this
         0: .line 206
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.ctime:Lsun/security/krb5/internal/KerberosTime;
            areturn
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/KrbTgsReq;

  private sun.security.krb5.internal.TGSReq createRequest(sun.security.krb5.internal.KDCOptions, sun.security.krb5.internal.Ticket, sun.security.krb5.EncryptionKey, sun.security.krb5.internal.KerberosTime, sun.security.krb5.PrincipalName, sun.security.krb5.PrincipalName, sun.security.krb5.internal.KerberosTime, sun.security.krb5.internal.KerberosTime, sun.security.krb5.internal.KerberosTime, int[], sun.security.krb5.internal.HostAddresses, sun.security.krb5.internal.AuthorizationData, sun.security.krb5.internal.Ticket[], sun.security.krb5.EncryptionKey);
    descriptor: (Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/EncryptionKey;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;[ILsun/security/krb5/internal/HostAddresses;Lsun/security/krb5/internal/AuthorizationData;[Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/EncryptionKey;)Lsun/security/krb5/internal/TGSReq;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=13, locals=24, args_size=15
        start local 0 // sun.security.krb5.KrbTgsReq this
        start local 1 // sun.security.krb5.internal.KDCOptions kdc_options
        start local 2 // sun.security.krb5.internal.Ticket ticket
        start local 3 // sun.security.krb5.EncryptionKey key
        start local 4 // sun.security.krb5.internal.KerberosTime ctime
        start local 5 // sun.security.krb5.PrincipalName cname
        start local 6 // sun.security.krb5.PrincipalName sname
        start local 7 // sun.security.krb5.internal.KerberosTime from
        start local 8 // sun.security.krb5.internal.KerberosTime till
        start local 9 // sun.security.krb5.internal.KerberosTime rtime
        start local 10 // int[] eTypes
        start local 11 // sun.security.krb5.internal.HostAddresses addresses
        start local 12 // sun.security.krb5.internal.AuthorizationData authorizationData
        start local 13 // sun.security.krb5.internal.Ticket[] additionalTickets
        start local 14 // sun.security.krb5.EncryptionKey subKey
         0: .line 226
            aconst_null
            astore 15 /* req_till */
        start local 15 // sun.security.krb5.internal.KerberosTime req_till
         1: .line 227
            aload 8 /* till */
            ifnonnull 4
         2: .line 228
            new sun.security.krb5.internal.KerberosTime
            dup
            lconst_0
            invokespecial sun.security.krb5.internal.KerberosTime.<init>:(J)V
            astore 15 /* req_till */
         3: .line 229
            goto 5
         4: .line 230
      StackMap locals: sun.security.krb5.internal.KerberosTime
      StackMap stack:
            aload 8 /* till */
            astore 15 /* req_till */
         5: .line 242
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* key */
            putfield sun.security.krb5.KrbTgsReq.tgsReqKey:Lsun/security/krb5/EncryptionKey;
         6: .line 244
            aconst_null
            astore 16 /* req_eTypes */
        start local 16 // int[] req_eTypes
         7: .line 245
            aload 10 /* eTypes */
            ifnonnull 13
         8: .line 246
            ldc "default_tgs_enctypes"
            invokestatic sun.security.krb5.internal.crypto.EType.getDefaults:(Ljava/lang/String;)[I
            astore 16 /* req_eTypes */
         9: .line 247
            aload 16 /* req_eTypes */
            ifnonnull 14
        10: .line 248
            new sun.security.krb5.KrbCryptoException
            dup
        11: .line 249
            ldc "No supported encryption types listed in default_tgs_enctypes"
        12: .line 248
            invokespecial sun.security.krb5.KrbCryptoException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 252
      StackMap locals: int[]
      StackMap stack:
            aload 10 /* eTypes */
            astore 16 /* req_eTypes */
        14: .line 255
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 17 /* reqKey */
        start local 17 // sun.security.krb5.EncryptionKey reqKey
        15: .line 256
            aconst_null
            astore 18 /* encAuthorizationData */
        start local 18 // sun.security.krb5.EncryptedData encAuthorizationData
        16: .line 257
            aload 12 /* authorizationData */
            ifnull 29
        17: .line 258
            aload 12 /* authorizationData */
            invokevirtual sun.security.krb5.internal.AuthorizationData.asn1Encode:()[B
            astore 19 /* ad */
        start local 19 // byte[] ad
        18: .line 259
            aload 14 /* subKey */
            ifnull 26
        19: .line 260
            aload 14 /* subKey */
            astore 17 /* reqKey */
        20: .line 261
            aload 0 /* this */
            aload 14 /* subKey */
            putfield sun.security.krb5.KrbTgsReq.tgsReqKey:Lsun/security/krb5/EncryptionKey;
        21: .line 262
            aload 0 /* this */
            iconst_1
            putfield sun.security.krb5.KrbTgsReq.useSubkey:Z
        22: .line 263
            new sun.security.krb5.EncryptedData
            dup
            aload 17 /* reqKey */
            aload 19 /* ad */
        23: .line 264
            iconst_5
        24: .line 263
            invokespecial sun.security.krb5.EncryptedData.<init>:(Lsun/security/krb5/EncryptionKey;[BI)V
            astore 18 /* encAuthorizationData */
        25: .line 265
            goto 29
        26: .line 266
      StackMap locals: sun.security.krb5.EncryptionKey sun.security.krb5.EncryptedData byte[]
      StackMap stack:
            new sun.security.krb5.EncryptedData
            dup
            aload 3 /* key */
            aload 19 /* ad */
        27: .line 267
            iconst_4
        28: .line 266
            invokespecial sun.security.krb5.EncryptedData.<init>:(Lsun/security/krb5/EncryptionKey;[BI)V
            astore 18 /* encAuthorizationData */
        end local 19 // byte[] ad
        29: .line 270
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.internal.KDCReqBody
            dup
        30: .line 271
            aload 1 /* kdc_options */
        31: .line 272
            aload 5 /* cname */
        32: .line 273
            aload 6 /* sname */
        33: .line 274
            aload 7 /* from */
        34: .line 275
            aload 15 /* req_till */
        35: .line 276
            aload 9 /* rtime */
        36: .line 277
            invokestatic sun.security.krb5.internal.crypto.Nonce.value:()I
        37: .line 278
            aload 16 /* req_eTypes */
        38: .line 279
            aload 11 /* addresses */
        39: .line 280
            aload 18 /* encAuthorizationData */
        40: .line 281
            aload 13 /* additionalTickets */
        41: .line 270
            invokespecial sun.security.krb5.internal.KDCReqBody.<init>:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/internal/KerberosTime;I[ILsun/security/krb5/internal/HostAddresses;Lsun/security/krb5/EncryptedData;[Lsun/security/krb5/internal/Ticket;)V
            astore 19 /* reqBody */
        start local 19 // sun.security.krb5.internal.KDCReqBody reqBody
        42: .line 283
            aload 19 /* reqBody */
            bipush 12
            invokevirtual sun.security.krb5.internal.KDCReqBody.asn1Encode:(I)[B
            astore 20 /* temp */
        start local 20 // byte[] temp
        43: .line 287
            getstatic sun.security.krb5.Checksum.CKSUMTYPE_DEFAULT:I
            lookupswitch { // 12
                 -138: 44
                    1: 48
                    2: 48
                    3: 44
                    4: 44
                    5: 44
                    6: 44
                    7: 48
                    8: 44
                   12: 44
                   15: 44
                   16: 44
              default: 48
          }
        44: .line 297
      StackMap locals: sun.security.krb5.internal.KDCReqBody byte[]
      StackMap stack:
            new sun.security.krb5.Checksum
            dup
            getstatic sun.security.krb5.Checksum.CKSUMTYPE_DEFAULT:I
            aload 20 /* temp */
            aload 3 /* key */
        45: .line 298
            bipush 6
        46: .line 297
            invokespecial sun.security.krb5.Checksum.<init>:(I[BLsun/security/krb5/EncryptionKey;I)V
            astore 21 /* cksum */
        start local 21 // sun.security.krb5.Checksum cksum
        47: .line 299
            goto 49
        end local 21 // sun.security.krb5.Checksum cksum
        48: .line 304
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.Checksum
            dup
            getstatic sun.security.krb5.Checksum.CKSUMTYPE_DEFAULT:I
            aload 20 /* temp */
            invokespecial sun.security.krb5.Checksum.<init>:(I[B)V
            astore 21 /* cksum */
        start local 21 // sun.security.krb5.Checksum cksum
        49: .line 309
      StackMap locals: sun.security.krb5.Checksum
      StackMap stack:
            new sun.security.krb5.KrbApReq
            dup
        50: .line 310
            new sun.security.krb5.internal.APOptions
            dup
            invokespecial sun.security.krb5.internal.APOptions.<init>:()V
        51: .line 311
            aload 2 /* ticket */
        52: .line 312
            aload 3 /* key */
        53: .line 313
            aload 5 /* cname */
        54: .line 314
            aload 21 /* cksum */
        55: .line 315
            aload 4 /* ctime */
        56: .line 316
            aload 17 /* reqKey */
        57: .line 317
            aconst_null
        58: .line 318
            aconst_null
        59: .line 309
            invokespecial sun.security.krb5.KrbApReq.<init>:(Lsun/security/krb5/internal/APOptions;Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/EncryptionKey;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Checksum;Lsun/security/krb5/internal/KerberosTime;Lsun/security/krb5/EncryptionKey;Lsun/security/krb5/internal/SeqNumber;Lsun/security/krb5/internal/AuthorizationData;)V
        60: .line 318
            invokevirtual sun.security.krb5.KrbApReq.getMessage:()[B
        61: .line 309
            astore 22 /* tgs_ap_req */
        start local 22 // byte[] tgs_ap_req
        62: .line 320
            iconst_1
            anewarray sun.security.krb5.internal.PAData
            astore 23 /* tgsPAData */
        start local 23 // sun.security.krb5.internal.PAData[] tgsPAData
        63: .line 321
            aload 23 /* tgsPAData */
            iconst_0
            new sun.security.krb5.internal.PAData
            dup
            iconst_1
            aload 22 /* tgs_ap_req */
            invokespecial sun.security.krb5.internal.PAData.<init>:(I[B)V
            aastore
        64: .line 323
            new sun.security.krb5.internal.TGSReq
            dup
            aload 23 /* tgsPAData */
            aload 19 /* reqBody */
            invokespecial sun.security.krb5.internal.TGSReq.<init>:([Lsun/security/krb5/internal/PAData;Lsun/security/krb5/internal/KDCReqBody;)V
            areturn
        end local 23 // sun.security.krb5.internal.PAData[] tgsPAData
        end local 22 // byte[] tgs_ap_req
        end local 21 // sun.security.krb5.Checksum cksum
        end local 20 // byte[] temp
        end local 19 // sun.security.krb5.internal.KDCReqBody reqBody
        end local 18 // sun.security.krb5.EncryptedData encAuthorizationData
        end local 17 // sun.security.krb5.EncryptionKey reqKey
        end local 16 // int[] req_eTypes
        end local 15 // sun.security.krb5.internal.KerberosTime req_till
        end local 14 // sun.security.krb5.EncryptionKey subKey
        end local 13 // sun.security.krb5.internal.Ticket[] additionalTickets
        end local 12 // sun.security.krb5.internal.AuthorizationData authorizationData
        end local 11 // sun.security.krb5.internal.HostAddresses addresses
        end local 10 // int[] eTypes
        end local 9 // sun.security.krb5.internal.KerberosTime rtime
        end local 8 // sun.security.krb5.internal.KerberosTime till
        end local 7 // sun.security.krb5.internal.KerberosTime from
        end local 6 // sun.security.krb5.PrincipalName sname
        end local 5 // sun.security.krb5.PrincipalName cname
        end local 4 // sun.security.krb5.internal.KerberosTime ctime
        end local 3 // sun.security.krb5.EncryptionKey key
        end local 2 // sun.security.krb5.internal.Ticket ticket
        end local 1 // sun.security.krb5.internal.KDCOptions kdc_options
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   65     0                  this  Lsun/security/krb5/KrbTgsReq;
            0   65     1           kdc_options  Lsun/security/krb5/internal/KDCOptions;
            0   65     2                ticket  Lsun/security/krb5/internal/Ticket;
            0   65     3                   key  Lsun/security/krb5/EncryptionKey;
            0   65     4                 ctime  Lsun/security/krb5/internal/KerberosTime;
            0   65     5                 cname  Lsun/security/krb5/PrincipalName;
            0   65     6                 sname  Lsun/security/krb5/PrincipalName;
            0   65     7                  from  Lsun/security/krb5/internal/KerberosTime;
            0   65     8                  till  Lsun/security/krb5/internal/KerberosTime;
            0   65     9                 rtime  Lsun/security/krb5/internal/KerberosTime;
            0   65    10                eTypes  [I
            0   65    11             addresses  Lsun/security/krb5/internal/HostAddresses;
            0   65    12     authorizationData  Lsun/security/krb5/internal/AuthorizationData;
            0   65    13     additionalTickets  [Lsun/security/krb5/internal/Ticket;
            0   65    14                subKey  Lsun/security/krb5/EncryptionKey;
            1   65    15              req_till  Lsun/security/krb5/internal/KerberosTime;
            7   65    16            req_eTypes  [I
           15   65    17                reqKey  Lsun/security/krb5/EncryptionKey;
           16   65    18  encAuthorizationData  Lsun/security/krb5/EncryptedData;
           18   29    19                    ad  [B
           42   65    19               reqBody  Lsun/security/krb5/internal/KDCReqBody;
           43   65    20                  temp  [B
           47   48    21                 cksum  Lsun/security/krb5/Checksum;
           49   65    21                 cksum  Lsun/security/krb5/Checksum;
           62   65    22            tgs_ap_req  [B
           63   65    23             tgsPAData  [Lsun/security/krb5/internal/PAData;
    Exceptions:
      throws sun.security.krb5.Asn1Exception, java.io.IOException, sun.security.krb5.internal.KdcErrException, sun.security.krb5.internal.KrbApErrException, java.net.UnknownHostException, sun.security.krb5.KrbCryptoException
    MethodParameters:
                   Name  Flags
      kdc_options        
      ticket             
      key                
      ctime              
      cname              
      sname              
      from               
      till               
      rtime              
      eTypes             
      addresses          
      authorizationData  
      additionalTickets  
      subKey             

  sun.security.krb5.internal.TGSReq getMessage();
    descriptor: ()Lsun/security/krb5/internal/TGSReq;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.KrbTgsReq this
         0: .line 327
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.tgsReqMessg:Lsun/security/krb5/internal/TGSReq;
            areturn
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/KrbTgsReq;

  sun.security.krb5.internal.Ticket getSecondTicket();
    descriptor: ()Lsun/security/krb5/internal/Ticket;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.KrbTgsReq this
         0: .line 331
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.secondTicket:Lsun/security/krb5/internal/Ticket;
            areturn
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/KrbTgsReq;

  private static void debug(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // java.lang.String message
         0: .line 336
            return
        end local 0 // java.lang.String message
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0  message  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      message  

  boolean usedSubkey();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.KrbTgsReq this
         0: .line 339
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.useSubkey:Z
            ireturn
        end local 0 // sun.security.krb5.KrbTgsReq this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/KrbTgsReq;
}
SourceFile: "KrbTgsReq.java"