public class sun.security.jgss.krb5.Krb5Util
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.jgss.krb5.Krb5Util
  super_class: java.lang.Object
{
  static final boolean DEBUG;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 54
            new sun.security.action.GetBooleanAction
            dup
         1: .line 55
            ldc "sun.security.krb5.debug"
         2: .line 54
            invokespecial sun.security.action.GetBooleanAction.<init>:(Ljava/lang/String;)V
         3: .line 53
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.Boolean
         4: .line 55
            invokevirtual java.lang.Boolean.booleanValue:()Z
         5: .line 52
            putstatic sun.security.jgss.krb5.Krb5Util.DEBUG:Z
         6: .line 55
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.jgss.krb5.Krb5Util this
         0: .line 60
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 61
            return
        end local 0 // sun.security.jgss.krb5.Krb5Util this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/jgss/krb5/Krb5Util;

  public static javax.security.auth.kerberos.KerberosTicket getTicketFromSubjectAndTgs(sun.security.jgss.GSSCaller, java.lang.String, java.lang.String, java.lang.String, java.security.AccessControlContext);
    descriptor: (Lsun/security/jgss/GSSCaller;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/security/AccessControlContext;)Ljavax/security/auth/kerberos/KerberosTicket;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=12, args_size=5
        start local 0 // sun.security.jgss.GSSCaller caller
        start local 1 // java.lang.String clientPrincipal
        start local 2 // java.lang.String serverPrincipal
        start local 3 // java.lang.String tgsPrincipal
        start local 4 // java.security.AccessControlContext acc
         0: .line 81
            aload 4 /* acc */
            invokestatic javax.security.auth.Subject.getSubject:(Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
            astore 5 /* accSubj */
        start local 5 // javax.security.auth.Subject accSubj
         1: .line 82
            aload 5 /* accSubj */
         2: .line 83
            aload 2 /* serverPrincipal */
            aload 1 /* clientPrincipal */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
         3: .line 82
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 6 /* ticket */
        start local 6 // javax.security.auth.kerberos.KerberosTicket ticket
         4: .line 85
            aload 6 /* ticket */
            ifnull 6
         5: .line 86
            aload 6 /* ticket */
            areturn
         6: .line 89
      StackMap locals: javax.security.auth.Subject javax.security.auth.kerberos.KerberosTicket
      StackMap stack:
            aconst_null
            astore 7 /* loginSubj */
        start local 7 // javax.security.auth.Subject loginSubj
         7: .line 90
            aload 0 /* caller */
            invokestatic sun.security.jgss.GSSUtil.useSubjectCredsOnly:(Lsun/security/jgss/GSSCaller;)Z
            ifne 16
         8: .line 93
            aload 0 /* caller */
            getstatic sun.security.jgss.GSSUtil.GSS_KRB5_MECH_OID:Lorg/ietf/jgss/Oid;
            invokestatic sun.security.jgss.GSSUtil.login:(Lsun/security/jgss/GSSCaller;Lorg/ietf/jgss/Oid;)Ljavax/security/auth/Subject;
            astore 7 /* loginSubj */
         9: .line 94
            aload 7 /* loginSubj */
        10: .line 95
            aload 2 /* serverPrincipal */
            aload 1 /* clientPrincipal */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
        11: .line 94
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 6 /* ticket */
        12: .line 96
            aload 6 /* ticket */
            ifnull 16
        13: .line 97
            aload 6 /* ticket */
        14: areturn
        15: .line 99
      StackMap locals: sun.security.jgss.GSSCaller java.lang.String java.lang.String java.lang.String java.security.AccessControlContext javax.security.auth.Subject javax.security.auth.kerberos.KerberosTicket javax.security.auth.Subject
      StackMap stack: javax.security.auth.login.LoginException
            pop
        16: .line 109
      StackMap locals:
      StackMap stack:
            aload 5 /* accSubj */
        17: .line 110
            aload 3 /* tgsPrincipal */
            aload 1 /* clientPrincipal */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
        18: .line 109
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 8 /* tgt */
        start local 8 // javax.security.auth.kerberos.KerberosTicket tgt
        19: .line 113
            aload 8 /* tgt */
            ifnonnull 25
            aload 7 /* loginSubj */
            ifnull 25
        20: .line 115
            aload 7 /* loginSubj */
        21: .line 116
            aload 3 /* tgsPrincipal */
            aload 1 /* clientPrincipal */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
        22: .line 115
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 8 /* tgt */
        23: .line 117
            iconst_0
            istore 9 /* fromAcc */
        start local 9 // boolean fromAcc
        24: .line 118
            goto 26
        end local 9 // boolean fromAcc
        25: .line 119
      StackMap locals: javax.security.auth.kerberos.KerberosTicket
      StackMap stack:
            iconst_1
            istore 9 /* fromAcc */
        start local 9 // boolean fromAcc
        26: .line 123
      StackMap locals: int
      StackMap stack:
            aload 8 /* tgt */
            ifnull 34
        27: .line 124
            aload 8 /* tgt */
            invokestatic sun.security.jgss.krb5.Krb5Util.ticketToCreds:(Ljavax/security/auth/kerberos/KerberosTicket;)Lsun/security/krb5/Credentials;
            astore 10 /* tgtCreds */
        start local 10 // sun.security.krb5.Credentials tgtCreds
        28: .line 126
            aload 2 /* serverPrincipal */
            aload 10 /* tgtCreds */
        29: .line 125
            invokestatic sun.security.krb5.Credentials.acquireServiceCreds:(Ljava/lang/String;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            astore 11 /* serviceCreds */
        start local 11 // sun.security.krb5.Credentials serviceCreds
        30: .line 127
            aload 11 /* serviceCreds */
            ifnull 34
        31: .line 128
            aload 11 /* serviceCreds */
            invokestatic sun.security.jgss.krb5.Krb5Util.credsToTicket:(Lsun/security/krb5/Credentials;)Ljavax/security/auth/kerberos/KerberosTicket;
            astore 6 /* ticket */
        32: .line 131
            iload 9 /* fromAcc */
            ifeq 34
            aload 5 /* accSubj */
            ifnull 34
            aload 5 /* accSubj */
            invokevirtual javax.security.auth.Subject.isReadOnly:()Z
            ifne 34
        33: .line 132
            aload 5 /* accSubj */
            invokevirtual javax.security.auth.Subject.getPrivateCredentials:()Ljava/util/Set;
            aload 6 /* ticket */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 11 // sun.security.krb5.Credentials serviceCreds
        end local 10 // sun.security.krb5.Credentials tgtCreds
        34: .line 136
      StackMap locals:
      StackMap stack:
            aload 6 /* ticket */
            areturn
        end local 9 // boolean fromAcc
        end local 8 // javax.security.auth.kerberos.KerberosTicket tgt
        end local 7 // javax.security.auth.Subject loginSubj
        end local 6 // javax.security.auth.kerberos.KerberosTicket ticket
        end local 5 // javax.security.auth.Subject accSubj
        end local 4 // java.security.AccessControlContext acc
        end local 3 // java.lang.String tgsPrincipal
        end local 2 // java.lang.String serverPrincipal
        end local 1 // java.lang.String clientPrincipal
        end local 0 // sun.security.jgss.GSSCaller caller
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   35     0           caller  Lsun/security/jgss/GSSCaller;
            0   35     1  clientPrincipal  Ljava/lang/String;
            0   35     2  serverPrincipal  Ljava/lang/String;
            0   35     3     tgsPrincipal  Ljava/lang/String;
            0   35     4              acc  Ljava/security/AccessControlContext;
            1   35     5          accSubj  Ljavax/security/auth/Subject;
            4   35     6           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
            7   35     7        loginSubj  Ljavax/security/auth/Subject;
           19   35     8              tgt  Ljavax/security/auth/kerberos/KerberosTicket;
           24   25     9          fromAcc  Z
           26   35     9          fromAcc  Z
           28   34    10         tgtCreds  Lsun/security/krb5/Credentials;
           30   34    11     serviceCreds  Lsun/security/krb5/Credentials;
      Exception table:
        from    to  target  type
           8    14      15  Class javax.security.auth.login.LoginException
    Exceptions:
      throws javax.security.auth.login.LoginException, sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
                 Name  Flags
      caller           
      clientPrincipal  
      serverPrincipal  
      tgsPrincipal     
      acc              

  static javax.security.auth.kerberos.KerberosTicket getServiceTicket(sun.security.jgss.GSSCaller, java.lang.String, java.lang.String, java.security.AccessControlContext);
    descriptor: (Lsun/security/jgss/GSSCaller;Ljava/lang/String;Ljava/lang/String;Ljava/security/AccessControlContext;)Ljavax/security/auth/kerberos/KerberosTicket;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // sun.security.jgss.GSSCaller caller
        start local 1 // java.lang.String clientPrincipal
        start local 2 // java.lang.String serverPrincipal
        start local 3 // java.security.AccessControlContext acc
         0: .line 148
            aload 3 /* acc */
            invokestatic javax.security.auth.Subject.getSubject:(Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
            astore 4 /* accSubj */
        start local 4 // javax.security.auth.Subject accSubj
         1: .line 150
            aload 4 /* accSubj */
            aload 2 /* serverPrincipal */
            aload 1 /* clientPrincipal */
         2: .line 151
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
         3: .line 150
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
         4: .line 149
            astore 5 /* ticket */
        start local 5 // javax.security.auth.kerberos.KerberosTicket ticket
         5: .line 153
            aload 5 /* ticket */
            areturn
        end local 5 // javax.security.auth.kerberos.KerberosTicket ticket
        end local 4 // javax.security.auth.Subject accSubj
        end local 3 // java.security.AccessControlContext acc
        end local 2 // java.lang.String serverPrincipal
        end local 1 // java.lang.String clientPrincipal
        end local 0 // sun.security.jgss.GSSCaller caller
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    6     0           caller  Lsun/security/jgss/GSSCaller;
            0    6     1  clientPrincipal  Ljava/lang/String;
            0    6     2  serverPrincipal  Ljava/lang/String;
            0    6     3              acc  Ljava/security/AccessControlContext;
            1    6     4          accSubj  Ljavax/security/auth/Subject;
            5    6     5           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
    Exceptions:
      throws javax.security.auth.login.LoginException
    MethodParameters:
                 Name  Flags
      caller           
      clientPrincipal  
      serverPrincipal  
      acc              

  static javax.security.auth.kerberos.KerberosTicket getInitialTicket(sun.security.jgss.GSSCaller, java.lang.String, java.security.AccessControlContext);
    descriptor: (Lsun/security/jgss/GSSCaller;Ljava/lang/String;Ljava/security/AccessControlContext;)Ljavax/security/auth/kerberos/KerberosTicket;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // sun.security.jgss.GSSCaller caller
        start local 1 // java.lang.String clientPrincipal
        start local 2 // java.security.AccessControlContext acc
         0: .line 168
            aload 2 /* acc */
            invokestatic javax.security.auth.Subject.getSubject:(Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
            astore 3 /* accSubj */
        start local 3 // javax.security.auth.Subject accSubj
         1: .line 170
            aload 3 /* accSubj */
            aconst_null
            aload 1 /* clientPrincipal */
         2: .line 171
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
         3: .line 170
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
         4: .line 169
            astore 4 /* ticket */
        start local 4 // javax.security.auth.kerberos.KerberosTicket ticket
         5: .line 174
            aload 4 /* ticket */
            ifnonnull 10
            aload 0 /* caller */
            invokestatic sun.security.jgss.GSSUtil.useSubjectCredsOnly:(Lsun/security/jgss/GSSCaller;)Z
            ifne 10
         6: .line 175
            aload 0 /* caller */
            getstatic sun.security.jgss.GSSUtil.GSS_KRB5_MECH_OID:Lorg/ietf/jgss/Oid;
            invokestatic sun.security.jgss.GSSUtil.login:(Lsun/security/jgss/GSSCaller;Lorg/ietf/jgss/Oid;)Ljavax/security/auth/Subject;
            astore 5 /* subject */
        start local 5 // javax.security.auth.Subject subject
         7: .line 176
            aload 5 /* subject */
         8: .line 177
            aconst_null
            aload 1 /* clientPrincipal */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
         9: .line 176
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 4 /* ticket */
        end local 5 // javax.security.auth.Subject subject
        10: .line 179
      StackMap locals: javax.security.auth.Subject javax.security.auth.kerberos.KerberosTicket
      StackMap stack:
            aload 4 /* ticket */
            areturn
        end local 4 // javax.security.auth.kerberos.KerberosTicket ticket
        end local 3 // javax.security.auth.Subject accSubj
        end local 2 // java.security.AccessControlContext acc
        end local 1 // java.lang.String clientPrincipal
        end local 0 // sun.security.jgss.GSSCaller caller
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   11     0           caller  Lsun/security/jgss/GSSCaller;
            0   11     1  clientPrincipal  Ljava/lang/String;
            0   11     2              acc  Ljava/security/AccessControlContext;
            1   11     3          accSubj  Ljavax/security/auth/Subject;
            5   11     4           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
            7   10     5          subject  Ljavax/security/auth/Subject;
    Exceptions:
      throws javax.security.auth.login.LoginException
    MethodParameters:
                 Name  Flags
      caller           
      clientPrincipal  
      acc              

  public static javax.security.auth.Subject getSubject(sun.security.jgss.GSSCaller, java.security.AccessControlContext);
    descriptor: (Lsun/security/jgss/GSSCaller;Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // sun.security.jgss.GSSCaller caller
        start local 1 // java.security.AccessControlContext acc
         0: .line 197
            aload 1 /* acc */
            invokestatic javax.security.auth.Subject.getSubject:(Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
            astore 2 /* subject */
        start local 2 // javax.security.auth.Subject subject
         1: .line 200
            aload 2 /* subject */
            ifnonnull 3
            aload 0 /* caller */
            invokestatic sun.security.jgss.GSSUtil.useSubjectCredsOnly:(Lsun/security/jgss/GSSCaller;)Z
            ifne 3
         2: .line 201
            aload 0 /* caller */
            getstatic sun.security.jgss.GSSUtil.GSS_KRB5_MECH_OID:Lorg/ietf/jgss/Oid;
            invokestatic sun.security.jgss.GSSUtil.login:(Lsun/security/jgss/GSSCaller;Lorg/ietf/jgss/Oid;)Ljavax/security/auth/Subject;
            astore 2 /* subject */
         3: .line 203
      StackMap locals: javax.security.auth.Subject
      StackMap stack:
            aload 2 /* subject */
            areturn
        end local 2 // javax.security.auth.Subject subject
        end local 1 // java.security.AccessControlContext acc
        end local 0 // sun.security.jgss.GSSCaller caller
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0   caller  Lsun/security/jgss/GSSCaller;
            0    4     1      acc  Ljava/security/AccessControlContext;
            1    4     2  subject  Ljavax/security/auth/Subject;
    Exceptions:
      throws javax.security.auth.login.LoginException
    MethodParameters:
        Name  Flags
      caller  
      acc     

  public static sun.security.jgss.krb5.ServiceCreds getServiceCreds(sun.security.jgss.GSSCaller, java.lang.String, java.security.AccessControlContext);
    descriptor: (Lsun/security/jgss/GSSCaller;Ljava/lang/String;Ljava/security/AccessControlContext;)Lsun/security/jgss/krb5/ServiceCreds;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=6, args_size=3
        start local 0 // sun.security.jgss.GSSCaller caller
        start local 1 // java.lang.String serverPrincipal
        start local 2 // java.security.AccessControlContext acc
         0: .line 217
            aload 2 /* acc */
            invokestatic javax.security.auth.Subject.getSubject:(Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
            astore 3 /* accSubj */
        start local 3 // javax.security.auth.Subject accSubj
         1: .line 218
            aconst_null
            astore 4 /* sc */
        start local 4 // sun.security.jgss.krb5.ServiceCreds sc
         2: .line 219
            aload 3 /* accSubj */
            ifnull 4
         3: .line 220
            aload 3 /* accSubj */
            aload 1 /* serverPrincipal */
            invokestatic sun.security.jgss.krb5.ServiceCreds.getInstance:(Ljavax/security/auth/Subject;Ljava/lang/String;)Lsun/security/jgss/krb5/ServiceCreds;
            astore 4 /* sc */
         4: .line 222
      StackMap locals: javax.security.auth.Subject sun.security.jgss.krb5.ServiceCreds
      StackMap stack:
            aload 4 /* sc */
            ifnonnull 7
            aload 0 /* caller */
            invokestatic sun.security.jgss.GSSUtil.useSubjectCredsOnly:(Lsun/security/jgss/GSSCaller;)Z
            ifne 7
         5: .line 223
            aload 0 /* caller */
            getstatic sun.security.jgss.GSSUtil.GSS_KRB5_MECH_OID:Lorg/ietf/jgss/Oid;
            invokestatic sun.security.jgss.GSSUtil.login:(Lsun/security/jgss/GSSCaller;Lorg/ietf/jgss/Oid;)Ljavax/security/auth/Subject;
            astore 5 /* subject */
        start local 5 // javax.security.auth.Subject subject
         6: .line 224
            aload 5 /* subject */
            aload 1 /* serverPrincipal */
            invokestatic sun.security.jgss.krb5.ServiceCreds.getInstance:(Ljavax/security/auth/Subject;Ljava/lang/String;)Lsun/security/jgss/krb5/ServiceCreds;
            astore 4 /* sc */
        end local 5 // javax.security.auth.Subject subject
         7: .line 226
      StackMap locals:
      StackMap stack:
            aload 4 /* sc */
            areturn
        end local 4 // sun.security.jgss.krb5.ServiceCreds sc
        end local 3 // javax.security.auth.Subject accSubj
        end local 2 // java.security.AccessControlContext acc
        end local 1 // java.lang.String serverPrincipal
        end local 0 // sun.security.jgss.GSSCaller caller
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    8     0           caller  Lsun/security/jgss/GSSCaller;
            0    8     1  serverPrincipal  Ljava/lang/String;
            0    8     2              acc  Ljava/security/AccessControlContext;
            1    8     3          accSubj  Ljavax/security/auth/Subject;
            2    8     4               sc  Lsun/security/jgss/krb5/ServiceCreds;
            6    7     5          subject  Ljavax/security/auth/Subject;
    Exceptions:
      throws javax.security.auth.login.LoginException
    MethodParameters:
                 Name  Flags
      caller           
      serverPrincipal  
      acc              

  public static javax.security.auth.kerberos.KerberosTicket credsToTicket(sun.security.krb5.Credentials);
    descriptor: (Lsun/security/krb5/Credentials;)Ljavax/security/auth/kerberos/KerberosTicket;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=13, locals=5, args_size=1
        start local 0 // sun.security.krb5.Credentials serviceCreds
         0: .line 230
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getSessionKey:()Lsun/security/krb5/EncryptionKey;
            astore 1 /* sessionKey */
        start local 1 // sun.security.krb5.EncryptionKey sessionKey
         1: .line 231
            new javax.security.auth.kerberos.KerberosTicket
            dup
         2: .line 232
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getEncoded:()[B
         3: .line 233
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
         4: .line 234
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
         5: .line 235
            iconst_2
         6: .line 234
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;I)V
         7: .line 236
            aload 1 /* sessionKey */
            invokevirtual sun.security.krb5.EncryptionKey.getBytes:()[B
         8: .line 237
            aload 1 /* sessionKey */
            invokevirtual sun.security.krb5.EncryptionKey.getEType:()I
         9: .line 238
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getFlags:()[Z
        10: .line 239
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getAuthTime:()Ljava/util/Date;
        11: .line 240
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getStartTime:()Ljava/util/Date;
        12: .line 241
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getEndTime:()Ljava/util/Date;
        13: .line 242
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getRenewTill:()Ljava/util/Date;
        14: .line 243
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getClientAddresses:()[Ljava/net/InetAddress;
        15: .line 231
            invokespecial javax.security.auth.kerberos.KerberosTicket.<init>:([BLjavax/security/auth/kerberos/KerberosPrincipal;Ljavax/security/auth/kerberos/KerberosPrincipal;[BI[ZLjava/util/Date;Ljava/util/Date;Ljava/util/Date;Ljava/util/Date;[Ljava/net/InetAddress;)V
            astore 2 /* kt */
        start local 2 // javax.security.auth.kerberos.KerberosTicket kt
        16: .line 244
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getClientAlias:()Lsun/security/krb5/PrincipalName;
            astore 3 /* clientAlias */
        start local 3 // sun.security.krb5.PrincipalName clientAlias
        17: .line 245
            aload 0 /* serviceCreds */
            invokevirtual sun.security.krb5.Credentials.getServerAlias:()Lsun/security/krb5/PrincipalName;
            astore 4 /* serverAlias */
        start local 4 // sun.security.krb5.PrincipalName serverAlias
        18: .line 246
            aload 3 /* clientAlias */
            ifnull 23
        19: .line 247
            invokestatic sun.security.krb5.KerberosSecrets.getJavaxSecurityAuthKerberosAccess:()Lsun/security/krb5/JavaxSecurityAuthKerberosAccess;
        20: .line 248
            aload 2 /* kt */
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
        21: .line 249
            aload 3 /* clientAlias */
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            aload 3 /* clientAlias */
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;I)V
        22: .line 248
            invokeinterface sun.security.krb5.JavaxSecurityAuthKerberosAccess.kerberosTicketSetClientAlias:(Ljavax/security/auth/kerberos/KerberosTicket;Ljavax/security/auth/kerberos/KerberosPrincipal;)V
        23: .line 251
      StackMap locals: sun.security.krb5.Credentials sun.security.krb5.EncryptionKey javax.security.auth.kerberos.KerberosTicket sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName
      StackMap stack:
            aload 4 /* serverAlias */
            ifnull 28
        24: .line 252
            invokestatic sun.security.krb5.KerberosSecrets.getJavaxSecurityAuthKerberosAccess:()Lsun/security/krb5/JavaxSecurityAuthKerberosAccess;
        25: .line 253
            aload 2 /* kt */
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
        26: .line 254
            aload 4 /* serverAlias */
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            aload 4 /* serverAlias */
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;I)V
        27: .line 253
            invokeinterface sun.security.krb5.JavaxSecurityAuthKerberosAccess.kerberosTicketSetServerAlias:(Ljavax/security/auth/kerberos/KerberosTicket;Ljavax/security/auth/kerberos/KerberosPrincipal;)V
        28: .line 256
      StackMap locals:
      StackMap stack:
            aload 2 /* kt */
            areturn
        end local 4 // sun.security.krb5.PrincipalName serverAlias
        end local 3 // sun.security.krb5.PrincipalName clientAlias
        end local 2 // javax.security.auth.kerberos.KerberosTicket kt
        end local 1 // sun.security.krb5.EncryptionKey sessionKey
        end local 0 // sun.security.krb5.Credentials serviceCreds
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   29     0  serviceCreds  Lsun/security/krb5/Credentials;
            1   29     1    sessionKey  Lsun/security/krb5/EncryptionKey;
           16   29     2            kt  Ljavax/security/auth/kerberos/KerberosTicket;
           17   29     3   clientAlias  Lsun/security/krb5/PrincipalName;
           18   29     4   serverAlias  Lsun/security/krb5/PrincipalName;
    MethodParameters:
              Name  Flags
      serviceCreds  

  public static sun.security.krb5.Credentials ticketToCreds(javax.security.auth.kerberos.KerberosTicket);
    descriptor: (Ljavax/security/auth/kerberos/KerberosTicket;)Lsun/security/krb5/Credentials;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=15, locals=3, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosTicket kerbTicket
         0: .line 262
            invokestatic sun.security.krb5.KerberosSecrets.getJavaxSecurityAuthKerberosAccess:()Lsun/security/krb5/JavaxSecurityAuthKerberosAccess;
         1: .line 263
            aload 0 /* kerbTicket */
            invokeinterface sun.security.krb5.JavaxSecurityAuthKerberosAccess.kerberosTicketGetClientAlias:(Ljavax/security/auth/kerberos/KerberosTicket;)Ljavax/security/auth/kerberos/KerberosPrincipal;
         2: .line 261
            astore 1 /* clientAlias */
        start local 1 // javax.security.auth.kerberos.KerberosPrincipal clientAlias
         3: .line 265
            invokestatic sun.security.krb5.KerberosSecrets.getJavaxSecurityAuthKerberosAccess:()Lsun/security/krb5/JavaxSecurityAuthKerberosAccess;
         4: .line 266
            aload 0 /* kerbTicket */
            invokeinterface sun.security.krb5.JavaxSecurityAuthKerberosAccess.kerberosTicketGetServerAlias:(Ljavax/security/auth/kerberos/KerberosTicket;)Ljavax/security/auth/kerberos/KerberosPrincipal;
         5: .line 264
            astore 2 /* serverAlias */
        start local 2 // javax.security.auth.kerberos.KerberosPrincipal serverAlias
         6: .line 267
            new sun.security.krb5.Credentials
            dup
         7: .line 268
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getEncoded:()[B
         8: .line 269
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getClient:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
         9: .line 270
            aload 1 /* clientAlias */
            ifnull 10
            aload 1 /* clientAlias */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            goto 11
      StackMap locals: javax.security.auth.kerberos.KerberosTicket javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack: new 6 new 6 byte[] java.lang.String
        10: aconst_null
        11: .line 271
      StackMap locals: javax.security.auth.kerberos.KerberosTicket javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack: new 6 new 6 byte[] java.lang.String java.lang.String
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getServer:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
        12: .line 272
            aload 2 /* serverAlias */
            ifnull 13
            aload 2 /* serverAlias */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            goto 14
      StackMap locals: javax.security.auth.kerberos.KerberosTicket javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack: new 6 new 6 byte[] java.lang.String java.lang.String java.lang.String
        13: aconst_null
        14: .line 273
      StackMap locals: javax.security.auth.kerberos.KerberosTicket javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack: new 6 new 6 byte[] java.lang.String java.lang.String java.lang.String java.lang.String
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getSessionKey:()Ljavax/crypto/SecretKey;
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
        15: .line 274
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getSessionKeyType:()I
        16: .line 275
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getFlags:()[Z
        17: .line 276
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getAuthTime:()Ljava/util/Date;
        18: .line 277
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getStartTime:()Ljava/util/Date;
        19: .line 278
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getEndTime:()Ljava/util/Date;
        20: .line 279
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getRenewTill:()Ljava/util/Date;
        21: .line 280
            aload 0 /* kerbTicket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getClientAddresses:()[Ljava/net/InetAddress;
        22: .line 267
            invokespecial sun.security.krb5.Credentials.<init>:([BLjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[BI[ZLjava/util/Date;Ljava/util/Date;Ljava/util/Date;Ljava/util/Date;[Ljava/net/InetAddress;)V
            areturn
        end local 2 // javax.security.auth.kerberos.KerberosPrincipal serverAlias
        end local 1 // javax.security.auth.kerberos.KerberosPrincipal clientAlias
        end local 0 // javax.security.auth.kerberos.KerberosTicket kerbTicket
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   23     0   kerbTicket  Ljavax/security/auth/kerberos/KerberosTicket;
            3   23     1  clientAlias  Ljavax/security/auth/kerberos/KerberosPrincipal;
            6   23     2  serverAlias  Ljavax/security/auth/kerberos/KerberosPrincipal;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
            Name  Flags
      kerbTicket  

  public static sun.security.krb5.internal.ktab.KeyTab snapshotFromJavaxKeyTab(javax.security.auth.kerberos.KeyTab);
    descriptor: (Ljavax/security/auth/kerberos/KeyTab;)Lsun/security/krb5/internal/ktab/KeyTab;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KeyTab ktab
         0: .line 290
            invokestatic sun.security.krb5.KerberosSecrets.getJavaxSecurityAuthKerberosAccess:()Lsun/security/krb5/JavaxSecurityAuthKerberosAccess;
         1: .line 291
            aload 0 /* ktab */
            invokeinterface sun.security.krb5.JavaxSecurityAuthKerberosAccess.keyTabTakeSnapshot:(Ljavax/security/auth/kerberos/KeyTab;)Lsun/security/krb5/internal/ktab/KeyTab;
         2: .line 290
            areturn
        end local 0 // javax.security.auth.kerberos.KeyTab ktab
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  ktab  Ljavax/security/auth/kerberos/KeyTab;
    MethodParameters:
      Name  Flags
      ktab  

  public static sun.security.krb5.EncryptionKey[] keysFromJavaxKeyTab(javax.security.auth.kerberos.KeyTab, sun.security.krb5.PrincipalName);
    descriptor: (Ljavax/security/auth/kerberos/KeyTab;Lsun/security/krb5/PrincipalName;)[Lsun/security/krb5/EncryptionKey;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // javax.security.auth.kerberos.KeyTab ktab
        start local 1 // sun.security.krb5.PrincipalName cname
         0: .line 302
            aload 0 /* ktab */
            invokestatic sun.security.jgss.krb5.Krb5Util.snapshotFromJavaxKeyTab:(Ljavax/security/auth/kerberos/KeyTab;)Lsun/security/krb5/internal/ktab/KeyTab;
            aload 1 /* cname */
            invokevirtual sun.security.krb5.internal.ktab.KeyTab.readServiceKeys:(Lsun/security/krb5/PrincipalName;)[Lsun/security/krb5/EncryptionKey;
            areturn
        end local 1 // sun.security.krb5.PrincipalName cname
        end local 0 // javax.security.auth.kerberos.KeyTab ktab
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   ktab  Ljavax/security/auth/kerberos/KeyTab;
            0    1     1  cname  Lsun/security/krb5/PrincipalName;
    MethodParameters:
       Name  Flags
      ktab   
      cname  
}
SourceFile: "Krb5Util.java"