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 55
            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 64
            aload 0 /* this */
            new sun.security.krb5.internal.KDCOptions
            dup
            invokespecial sun.security.krb5.internal.KDCOptions.<init>:()V
         1: .line 65
            aload 1 /* asCreds */
         2: .line 66
            aload 2 /* sname */
         3: .line 67
            aconst_null
         4: .line 68
            aconst_null
         5: .line 69
            aconst_null
         6: .line 70
            aconst_null
         7: .line 71
            aconst_null
         8: .line 72
            aconst_null
         9: .line 73
            aconst_null
        10: .line 74
            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 75
            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 78
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 51
            aload 0 /* this */
            aconst_null
            putfield sun.security.krb5.KrbTgsReq.secondTicket:Lsun/security/krb5/internal/Ticket;
         2: .line 52
            aload 0 /* this */
            iconst_0
            putfield sun.security.krb5.KrbTgsReq.useSubkey:Z
         3: .line 91
            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 92
            aload 0 /* this */
            aload 3 /* sname */
            putfield sun.security.krb5.KrbTgsReq.servName:Lsun/security/krb5/PrincipalName;
         5: .line 93
            aload 0 /* this */
            invokestatic sun.security.krb5.internal.KerberosTime.now:()Lsun/security/krb5/internal/KerberosTime;
            putfield sun.security.krb5.KrbTgsReq.ctime:Lsun/security/krb5/internal/KerberosTime;
         6: .line 97
            aload 1 /* options */
            iconst_1
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 9
         7: .line 98
            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 99
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
         9: .line 101
      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 102
            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 103
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        12: .line 105
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            iconst_3
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 15
        13: .line 106
            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 107
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        15: .line 109
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            iconst_4
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 18
        16: .line 110
            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 111
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        18: .line 113
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            iconst_5
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 21
        19: .line 114
            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 115
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        21: .line 117
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 8
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 24
        22: .line 118
            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 119
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        24: .line 122
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 6
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 27
        25: .line 123
            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 124
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        27: .line 126
      StackMap locals:
      StackMap stack:
            aload 4 /* from */
            ifnull 28
            aconst_null
            astore 4 /* from */
        28: .line 128
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 8
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 31
        29: .line 129
            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 130
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        31: .line 132
      StackMap locals:
      StackMap stack:
            aload 6 /* rtime */
            ifnull 32
            aconst_null
            astore 6 /* rtime */
        32: .line 134
      StackMap locals:
      StackMap stack:
            aload 1 /* options */
            bipush 28
            invokevirtual sun.security.krb5.internal.KDCOptions.get:(I)Z
            ifeq 37
        33: .line 135
            aload 10 /* additionalTickets */
            ifnonnull 35
        34: .line 136
            new sun.security.krb5.KrbException
            dup
            bipush 101
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        35: .line 140
      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 141
            goto 39
        37: .line 142
      StackMap locals:
      StackMap stack:
            aload 10 /* additionalTickets */
            ifnull 39
        38: .line 143
            aconst_null
            astore 10 /* additionalTickets */
        39: .line 146
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
        40: .line 147
            aload 1 /* options */
        41: .line 148
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.ticket:Lsun/security/krb5/internal/Ticket;
        42: .line 149
            aload 2 /* asCreds */
            getfield sun.security.krb5.Credentials.key:Lsun/security/krb5/EncryptionKey;
        43: .line 150
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.ctime:Lsun/security/krb5/internal/KerberosTime;
        44: .line 151
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.princName:Lsun/security/krb5/PrincipalName;
        45: .line 152
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.servName:Lsun/security/krb5/PrincipalName;
        46: .line 153
            aload 4 /* from */
        47: .line 154
            aload 5 /* till */
        48: .line 155
            aload 6 /* rtime */
        49: .line 156
            aload 7 /* eTypes */
        50: .line 157
            aload 8 /* addresses */
        51: .line 158
            aload 9 /* authorizationData */
        52: .line 159
            aload 10 /* additionalTickets */
        53: .line 160
            aload 11 /* subKey */
        54: .line 146
            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 161
            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 171
            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 172
            aload 1 /* options */
            iconst_2
            iconst_1
            invokevirtual sun.security.krb5.internal.KDCOptions.set:(IZ)V
        58: .line 175
      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 183
            aconst_null
            astore 1 /* realmStr */
        start local 1 // java.lang.String realmStr
         1: .line 184
            aload 0 /* this */
            getfield sun.security.krb5.KrbTgsReq.servName:Lsun/security/krb5/PrincipalName;
            ifnull 3
         2: .line 185
            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 186
      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 187
            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 188
            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 192
            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 200
            aconst_null
            astore 1 /* tgs_rep */
        start local 1 // sun.security.krb5.KrbTgsRep tgs_rep
         1: .line 202
            aload 0 /* this */
            invokevirtual sun.security.krb5.KrbTgsReq.send:()V
         2: .line 203
            aload 0 /* this */
            invokevirtual sun.security.krb5.KrbTgsReq.getReply:()Lsun/security/krb5/KrbTgsRep;
            astore 1 /* tgs_rep */
         3: .line 204
            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 208
            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 227
            aconst_null
            astore 15 /* req_till */
        start local 15 // sun.security.krb5.internal.KerberosTime req_till
         1: .line 228
            aload 8 /* till */
            ifnonnull 10
         2: .line 229
            invokestatic sun.security.krb5.Config.getInstance:()Lsun/security/krb5/Config;
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc "libdefaults"
            aastore
            dup
            iconst_1
            ldc "ticket_lifetime"
            aastore
            invokevirtual sun.security.krb5.Config.get:([Ljava/lang/String;)Ljava/lang/String;
            astore 16 /* d */
        start local 16 // java.lang.String d
         3: .line 230
            aload 16 /* d */
            ifnull 8
         4: .line 231
            invokestatic java.util.Calendar.getInstance:()Ljava/util/Calendar;
            astore 17 /* cal */
        start local 17 // java.util.Calendar cal
         5: .line 232
            aload 17 /* cal */
            bipush 13
            aload 16 /* d */
            invokestatic sun.security.krb5.Config.duration:(Ljava/lang/String;)I
            invokevirtual java.util.Calendar.add:(II)V
         6: .line 233
            new sun.security.krb5.internal.KerberosTime
            dup
            aload 17 /* cal */
            invokevirtual java.util.Calendar.getTime:()Ljava/util/Date;
            invokespecial sun.security.krb5.internal.KerberosTime.<init>:(Ljava/util/Date;)V
            astore 15 /* req_till */
        end local 17 // java.util.Calendar cal
         7: .line 234
            goto 11
         8: .line 235
      StackMap locals: sun.security.krb5.internal.KerberosTime java.lang.String
      StackMap stack:
            new sun.security.krb5.internal.KerberosTime
            dup
            lconst_0
            invokespecial sun.security.krb5.internal.KerberosTime.<init>:(J)V
            astore 15 /* req_till */
        end local 16 // java.lang.String d
         9: .line 237
            goto 11
        10: .line 238
      StackMap locals:
      StackMap stack:
            aload 8 /* till */
            astore 15 /* req_till */
        11: .line 250
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* key */
            putfield sun.security.krb5.KrbTgsReq.tgsReqKey:Lsun/security/krb5/EncryptionKey;
        12: .line 252
            aconst_null
            astore 16 /* req_eTypes */
        start local 16 // int[] req_eTypes
        13: .line 253
            aload 10 /* eTypes */
            ifnonnull 16
        14: .line 254
            ldc "default_tgs_enctypes"
            invokestatic sun.security.krb5.internal.crypto.EType.getDefaults:(Ljava/lang/String;)[I
            astore 16 /* req_eTypes */
        15: .line 255
            goto 17
        16: .line 256
      StackMap locals: int[]
      StackMap stack:
            aload 10 /* eTypes */
            astore 16 /* req_eTypes */
        17: .line 259
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 17 /* reqKey */
        start local 17 // sun.security.krb5.EncryptionKey reqKey
        18: .line 260
            aconst_null
            astore 18 /* encAuthorizationData */
        start local 18 // sun.security.krb5.EncryptedData encAuthorizationData
        19: .line 261
            aload 12 /* authorizationData */
            ifnull 32
        20: .line 262
            aload 12 /* authorizationData */
            invokevirtual sun.security.krb5.internal.AuthorizationData.asn1Encode:()[B
            astore 19 /* ad */
        start local 19 // byte[] ad
        21: .line 263
            aload 14 /* subKey */
            ifnull 29
        22: .line 264
            aload 14 /* subKey */
            astore 17 /* reqKey */
        23: .line 265
            aload 0 /* this */
            aload 14 /* subKey */
            putfield sun.security.krb5.KrbTgsReq.tgsReqKey:Lsun/security/krb5/EncryptionKey;
        24: .line 266
            aload 0 /* this */
            iconst_1
            putfield sun.security.krb5.KrbTgsReq.useSubkey:Z
        25: .line 267
            new sun.security.krb5.EncryptedData
            dup
            aload 17 /* reqKey */
            aload 19 /* ad */
        26: .line 268
            iconst_5
        27: .line 267
            invokespecial sun.security.krb5.EncryptedData.<init>:(Lsun/security/krb5/EncryptionKey;[BI)V
            astore 18 /* encAuthorizationData */
        28: .line 269
            goto 32
        29: .line 270
      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 */
        30: .line 271
            iconst_4
        31: .line 270
            invokespecial sun.security.krb5.EncryptedData.<init>:(Lsun/security/krb5/EncryptionKey;[BI)V
            astore 18 /* encAuthorizationData */
        end local 19 // byte[] ad
        32: .line 274
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.internal.KDCReqBody
            dup
        33: .line 275
            aload 1 /* kdc_options */
        34: .line 276
            aload 5 /* cname */
        35: .line 277
            aload 6 /* sname */
        36: .line 278
            aload 7 /* from */
        37: .line 279
            aload 15 /* req_till */
        38: .line 280
            aload 9 /* rtime */
        39: .line 281
            invokestatic sun.security.krb5.internal.crypto.Nonce.value:()I
        40: .line 282
            aload 16 /* req_eTypes */
        41: .line 283
            aload 11 /* addresses */
        42: .line 284
            aload 18 /* encAuthorizationData */
        43: .line 285
            aload 13 /* additionalTickets */
        44: .line 274
            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
        45: .line 287
            aload 19 /* reqBody */
            bipush 12
            invokevirtual sun.security.krb5.internal.KDCReqBody.asn1Encode:(I)[B
            astore 20 /* temp */
        start local 20 // byte[] temp
        46: .line 290
            new sun.security.krb5.Checksum
            dup
            getstatic sun.security.krb5.Checksum.CKSUMTYPE_DEFAULT:I
            aload 20 /* temp */
            aload 3 /* key */
        47: .line 291
            bipush 6
        48: .line 290
            invokespecial sun.security.krb5.Checksum.<init>:(I[BLsun/security/krb5/EncryptionKey;I)V
            astore 21 /* cksum */
        start local 21 // sun.security.krb5.Checksum cksum
        49: .line 295
            new sun.security.krb5.KrbApReq
            dup
        50: .line 296
            new sun.security.krb5.internal.APOptions
            dup
            invokespecial sun.security.krb5.internal.APOptions.<init>:()V
        51: .line 297
            aload 2 /* ticket */
        52: .line 298
            aload 3 /* key */
        53: .line 299
            aload 5 /* cname */
        54: .line 300
            aload 21 /* cksum */
        55: .line 301
            aload 4 /* ctime */
        56: .line 302
            aload 17 /* reqKey */
        57: .line 303
            aconst_null
        58: .line 304
            aconst_null
        59: .line 295
            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 304
            invokevirtual sun.security.krb5.KrbApReq.getMessage:()[B
        61: .line 295
            astore 22 /* tgs_ap_req */
        start local 22 // byte[] tgs_ap_req
        62: .line 306
            iconst_1
            anewarray sun.security.krb5.internal.PAData
            astore 23 /* tgsPAData */
        start local 23 // sun.security.krb5.internal.PAData[] tgsPAData
        63: .line 307
            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 309
            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;
            3    9    16                     d  Ljava/lang/String;
            5    7    17                   cal  Ljava/util/Calendar;
           13   65    16            req_eTypes  [I
           18   65    17                reqKey  Lsun/security/krb5/EncryptionKey;
           19   65    18  encAuthorizationData  Lsun/security/krb5/EncryptedData;
           21   32    19                    ad  [B
           45   65    19               reqBody  Lsun/security/krb5/internal/KDCReqBody;
           46   65    20                  temp  [B
           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 java.io.IOException, sun.security.krb5.KrbException, java.net.UnknownHostException
    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 313
            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 317
            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 322
            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 325
            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"