public class sun.security.krb5.internal.CredentialsUtil
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.krb5.internal.CredentialsUtil
  super_class: java.lang.Object
{
  private static boolean DEBUG;
    descriptor: Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

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

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.CredentialsUtil this
         0: .line 42
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.krb5.internal.CredentialsUtil this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/CredentialsUtil;

  public static sun.security.krb5.Credentials acquireS4U2selfCreds(sun.security.krb5.PrincipalName, sun.security.krb5.Credentials);
    descriptor: (Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=11, locals=6, args_size=2
        start local 0 // sun.security.krb5.PrincipalName client
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 55
            aload 0 /* client */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 2 /* uRealm */
        start local 2 // java.lang.String uRealm
         1: .line 56
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 3 /* localRealm */
        start local 3 // java.lang.String localRealm
         2: .line 57
            aload 2 /* uRealm */
            aload 3 /* localRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 4
         3: .line 59
            new sun.security.krb5.KrbException
            dup
            ldc "Cross realm impersonation not supported"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 61
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.isForwardable:()Z
            ifne 6
         5: .line 62
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self needs a FORWARDABLE ticket"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 64
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.KrbTgsReq
            dup
         7: .line 65
            aload 1 /* ccreds */
         8: .line 66
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
         9: .line 67
            new sun.security.krb5.internal.PAData
            dup
            sipush 129
        10: .line 68
            new sun.security.krb5.internal.PAForUserEnc
            dup
            aload 0 /* client */
        11: .line 69
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getSessionKey:()Lsun/security/krb5/EncryptionKey;
        12: .line 68
            invokespecial sun.security.krb5.internal.PAForUserEnc.<init>:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/EncryptionKey;)V
        13: .line 69
            invokevirtual sun.security.krb5.internal.PAForUserEnc.asn1Encode:()[B
        14: .line 67
            invokespecial sun.security.krb5.internal.PAData.<init>:(I[B)V
        15: .line 64
            invokespecial sun.security.krb5.KrbTgsReq.<init>:(Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/internal/PAData;)V
            astore 4 /* req */
        start local 4 // sun.security.krb5.KrbTgsReq req
        16: .line 70
            aload 4 /* req */
            invokevirtual sun.security.krb5.KrbTgsReq.sendAndGetCreds:()Lsun/security/krb5/Credentials;
            astore 5 /* creds */
        start local 5 // sun.security.krb5.Credentials creds
        17: .line 71
            aload 5 /* creds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 0 /* client */
            invokevirtual sun.security.krb5.PrincipalName.equals:(Ljava/lang/Object;)Z
            ifne 19
        18: .line 72
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self request not honored by KDC"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 74
      StackMap locals: sun.security.krb5.KrbTgsReq sun.security.krb5.Credentials
      StackMap stack:
            aload 5 /* creds */
            invokevirtual sun.security.krb5.Credentials.isForwardable:()Z
            ifne 21
        20: .line 75
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self ticket must be FORWARDABLE"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 77
      StackMap locals:
      StackMap stack:
            aload 5 /* creds */
            areturn
        end local 5 // sun.security.krb5.Credentials creds
        end local 4 // sun.security.krb5.KrbTgsReq req
        end local 3 // java.lang.String localRealm
        end local 2 // java.lang.String uRealm
        end local 1 // sun.security.krb5.Credentials ccreds
        end local 0 // sun.security.krb5.PrincipalName client
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   22     0      client  Lsun/security/krb5/PrincipalName;
            0   22     1      ccreds  Lsun/security/krb5/Credentials;
            1   22     2      uRealm  Ljava/lang/String;
            2   22     3  localRealm  Ljava/lang/String;
           16   22     4         req  Lsun/security/krb5/KrbTgsReq;
           17   22     5       creds  Lsun/security/krb5/Credentials;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
        Name  Flags
      client  
      ccreds  

  public static sun.security.krb5.Credentials acquireS4U2proxyCreds(java.lang.String, sun.security.krb5.internal.Ticket, sun.security.krb5.PrincipalName, sun.security.krb5.Credentials);
    descriptor: (Ljava/lang/String;Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=7, locals=6, args_size=4
        start local 0 // java.lang.String backend
        start local 1 // sun.security.krb5.internal.Ticket second
        start local 2 // sun.security.krb5.PrincipalName client
        start local 3 // sun.security.krb5.Credentials ccreds
         0: .line 92
            new sun.security.krb5.KrbTgsReq
            dup
         1: .line 93
            aload 3 /* ccreds */
         2: .line 94
            aload 1 /* second */
         3: .line 95
            new sun.security.krb5.PrincipalName
            dup
            aload 0 /* backend */
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;)V
         4: .line 92
            invokespecial sun.security.krb5.KrbTgsReq.<init>:(Lsun/security/krb5/Credentials;Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/PrincipalName;)V
            astore 4 /* req */
        start local 4 // sun.security.krb5.KrbTgsReq req
         5: .line 96
            aload 4 /* req */
            invokevirtual sun.security.krb5.KrbTgsReq.sendAndGetCreds:()Lsun/security/krb5/Credentials;
            astore 5 /* creds */
        start local 5 // sun.security.krb5.Credentials creds
         6: .line 97
            aload 5 /* creds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 2 /* client */
            invokevirtual sun.security.krb5.PrincipalName.equals:(Ljava/lang/Object;)Z
            ifne 8
         7: .line 98
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2proxy request not honored by KDC"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 100
      StackMap locals: sun.security.krb5.KrbTgsReq sun.security.krb5.Credentials
      StackMap stack:
            aload 5 /* creds */
            areturn
        end local 5 // sun.security.krb5.Credentials creds
        end local 4 // sun.security.krb5.KrbTgsReq req
        end local 3 // sun.security.krb5.Credentials ccreds
        end local 2 // sun.security.krb5.PrincipalName client
        end local 1 // sun.security.krb5.internal.Ticket second
        end local 0 // java.lang.String backend
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    9     0  backend  Ljava/lang/String;
            0    9     1   second  Lsun/security/krb5/internal/Ticket;
            0    9     2   client  Lsun/security/krb5/PrincipalName;
            0    9     3   ccreds  Lsun/security/krb5/Credentials;
            5    9     4      req  Lsun/security/krb5/KrbTgsReq;
            6    9     5    creds  Lsun/security/krb5/Credentials;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
         Name  Flags
      backend  
      second   
      client   
      ccreds   

  public static sun.security.krb5.Credentials acquireServiceCreds(java.lang.String, sun.security.krb5.Credentials);
    descriptor: (Ljava/lang/String;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=9, args_size=2
        start local 0 // java.lang.String service
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 117
            new sun.security.krb5.PrincipalName
            dup
            aload 0 /* service */
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;)V
            astore 2 /* sname */
        start local 2 // sun.security.krb5.PrincipalName sname
         1: .line 118
            aload 2 /* sname */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 3 /* serviceRealm */
        start local 3 // java.lang.String serviceRealm
         2: .line 119
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 4 /* localRealm */
        start local 4 // java.lang.String localRealm
         3: .line 121
            aload 4 /* localRealm */
            aload 3 /* serviceRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 9
         4: .line 122
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 8
         5: .line 123
            getstatic java.lang.System.out:Ljava/io/PrintStream;
         6: .line 124
            ldc ">>> Credentials acquireServiceCreds: same realm"
         7: .line 123
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 126
      StackMap locals: sun.security.krb5.PrincipalName java.lang.String java.lang.String
      StackMap stack:
            aload 2 /* sname */
            aload 1 /* ccreds */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            areturn
         9: .line 128
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 5 /* theCreds */
        start local 5 // sun.security.krb5.Credentials theCreds
        10: .line 130
            iconst_1
            newarray 4
            astore 6 /* okAsDelegate */
        start local 6 // boolean[] okAsDelegate
        11: .line 131
            aload 4 /* localRealm */
            aload 3 /* serviceRealm */
        12: .line 132
            aload 1 /* ccreds */
            aload 6 /* okAsDelegate */
        13: .line 131
            invokestatic sun.security.krb5.internal.CredentialsUtil.getTGTforRealm:(Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;[Z)Lsun/security/krb5/Credentials;
            astore 7 /* theTgt */
        start local 7 // sun.security.krb5.Credentials theTgt
        14: .line 133
            aload 7 /* theTgt */
            ifnull 26
        15: .line 134
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 20
        16: .line 135
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: got right tgt"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        17: .line 137
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: obtaining service creds for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        18: .line 138
            aload 2 /* sname */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 137
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        20: .line 142
      StackMap locals: sun.security.krb5.Credentials boolean[] sun.security.krb5.Credentials
      StackMap stack:
            aload 2 /* sname */
            aload 7 /* theTgt */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            astore 5 /* theCreds */
        21: .line 143
            goto 26
      StackMap locals:
      StackMap stack: java.lang.Exception
        22: astore 8 /* exc */
        start local 8 // java.lang.Exception exc
        23: .line 144
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 25
        24: .line 145
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 8 /* exc */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/Object;)V
        25: .line 147
      StackMap locals: java.lang.Exception
      StackMap stack:
            aconst_null
            astore 5 /* theCreds */
        end local 8 // java.lang.Exception exc
        26: .line 151
      StackMap locals:
      StackMap stack:
            aload 5 /* theCreds */
            ifnull 33
        27: .line 152
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 30
        28: .line 153
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: returning creds:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        29: .line 155
            aload 5 /* theCreds */
            invokestatic sun.security.krb5.Credentials.printDebug:(Lsun/security/krb5/Credentials;)V
        30: .line 157
      StackMap locals:
      StackMap stack:
            aload 6 /* okAsDelegate */
            iconst_0
            baload
            ifne 32
        31: .line 158
            aload 5 /* theCreds */
            invokevirtual sun.security.krb5.Credentials.resetDelegate:()V
        32: .line 160
      StackMap locals:
      StackMap stack:
            aload 5 /* theCreds */
            areturn
        33: .line 162
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.internal.KrbApErrException
            dup
            bipush 63
        34: .line 163
            ldc "No service creds"
        35: .line 162
            invokespecial sun.security.krb5.internal.KrbApErrException.<init>:(ILjava/lang/String;)V
            athrow
        end local 7 // sun.security.krb5.Credentials theTgt
        end local 6 // boolean[] okAsDelegate
        end local 5 // sun.security.krb5.Credentials theCreds
        end local 4 // java.lang.String localRealm
        end local 3 // java.lang.String serviceRealm
        end local 2 // sun.security.krb5.PrincipalName sname
        end local 1 // sun.security.krb5.Credentials ccreds
        end local 0 // java.lang.String service
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   36     0       service  Ljava/lang/String;
            0   36     1        ccreds  Lsun/security/krb5/Credentials;
            1   36     2         sname  Lsun/security/krb5/PrincipalName;
            2   36     3  serviceRealm  Ljava/lang/String;
            3   36     4    localRealm  Ljava/lang/String;
           10   36     5      theCreds  Lsun/security/krb5/Credentials;
           11   36     6  okAsDelegate  [Z
           14   36     7        theTgt  Lsun/security/krb5/Credentials;
           23   26     8           exc  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          20    21      22  Class java.lang.Exception
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
         Name  Flags
      service  
      ccreds   

  private static sun.security.krb5.Credentials getTGTforRealm(java.lang.String, java.lang.String, sun.security.krb5.Credentials, boolean[]);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;[Z)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=12, args_size=4
        start local 0 // java.lang.String localRealm
        start local 1 // java.lang.String serviceRealm
        start local 2 // sun.security.krb5.Credentials ccreds
        start local 3 // boolean[] okAsDelegate
         0: .line 181
            aload 0 /* localRealm */
            aload 1 /* serviceRealm */
            invokestatic sun.security.krb5.Realm.getRealmsList:(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
            astore 4 /* realms */
        start local 4 // java.lang.String[] realms
         1: .line 183
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         2: iconst_0
            istore 6 /* k */
        start local 6 // int k
         3: .line 184
            aconst_null
            astore 7 /* cTgt */
        start local 7 // sun.security.krb5.Credentials cTgt
         4: aconst_null
            astore 8 /* newTgt */
        start local 8 // sun.security.krb5.Credentials newTgt
         5: aconst_null
            astore 9 /* theTgt */
        start local 9 // sun.security.krb5.Credentials theTgt
         6: .line 185
            aconst_null
            astore 10 /* tempService */
        start local 10 // sun.security.krb5.PrincipalName tempService
         7: .line 186
            aconst_null
            astore 11 /* newTgtRealm */
        start local 11 // java.lang.String newTgtRealm
         8: .line 188
            aload 3 /* okAsDelegate */
            iconst_0
            iconst_1
            bastore
         9: .line 189
            aload 2 /* ccreds */
            astore 7 /* cTgt */
            iconst_0
            istore 5 /* i */
            goto 69
        10: .line 190
      StackMap locals: java.lang.String java.lang.String sun.security.krb5.Credentials boolean[] java.lang.String[] int int sun.security.krb5.Credentials sun.security.krb5.Credentials sun.security.krb5.Credentials sun.security.krb5.PrincipalName java.lang.String
      StackMap stack:
            aload 1 /* serviceRealm */
            aload 4 /* realms */
            iload 5 /* i */
            aaload
            invokestatic sun.security.krb5.PrincipalName.tgsService:(Ljava/lang/String;Ljava/lang/String;)Lsun/security/krb5/PrincipalName;
            astore 10 /* tempService */
        11: .line 192
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 17
        12: .line 193
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        13: .line 194
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: main loop: ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        14: .line 195
            iload 5 /* i */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "] tempService="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 10 /* tempService */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        15: .line 194
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 193
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        17: .line 199
      StackMap locals:
      StackMap stack:
            aload 10 /* tempService */
            aload 7 /* cTgt */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            astore 8 /* newTgt */
        18: .line 200
            goto 21
      StackMap locals:
      StackMap stack: java.lang.Exception
        19: pop
        20: .line 201
            aconst_null
            astore 8 /* newTgt */
        21: .line 204
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            ifnonnull 41
        22: .line 205
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 24
        23: .line 206
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: no tgt; searching thru capath"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        24: .line 213
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* newTgt */
            iload 5 /* i */
            iconst_1
            iadd
            istore 6 /* k */
        25: .line 214
            goto 39
        26: .line 215
      StackMap locals:
      StackMap stack:
            aload 4 /* realms */
            iload 6 /* k */
            aaload
            aload 4 /* realms */
            iload 5 /* i */
            aaload
            invokestatic sun.security.krb5.PrincipalName.tgsService:(Ljava/lang/String;Ljava/lang/String;)Lsun/security/krb5/PrincipalName;
            astore 10 /* tempService */
        27: .line 216
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 34
        28: .line 217
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        29: .line 218
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: inner loop: ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        30: .line 219
            iload 6 /* k */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        31: .line 220
            ldc "] tempService="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 10 /* tempService */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        32: .line 218
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        33: .line 217
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        34: .line 223
      StackMap locals:
      StackMap stack:
            aload 10 /* tempService */
            aload 7 /* cTgt */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            astore 8 /* newTgt */
        35: .line 224
            goto 38
      StackMap locals:
      StackMap stack: java.lang.Exception
        36: pop
        37: .line 225
            aconst_null
            astore 8 /* newTgt */
        38: .line 214
      StackMap locals:
      StackMap stack:
            iinc 6 /* k */ 1
      StackMap locals:
      StackMap stack:
        39: aload 8 /* newTgt */
            ifnonnull 41
            iload 6 /* k */
            aload 4 /* realms */
            arraylength
        40: .line 213
            if_icmplt 26
        41: .line 230
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            ifnonnull 45
        42: .line 231
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 70
        43: .line 232
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: no tgt; cannot get creds"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        44: .line 235
            goto 70
        45: .line 242
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getInstanceComponent:()Ljava/lang/String;
            astore 11 /* newTgtRealm */
        46: .line 243
            aload 3 /* okAsDelegate */
            iconst_0
            baload
            ifeq 52
            aload 8 /* newTgt */
            invokevirtual sun.security.krb5.Credentials.checkDelegate:()Z
            ifne 52
        47: .line 244
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 51
        48: .line 245
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: global OK-AS-DELEGATE turned off at "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        49: .line 247
            aload 8 /* newTgt */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        50: .line 245
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        51: .line 249
      StackMap locals:
      StackMap stack:
            aload 3 /* okAsDelegate */
            iconst_0
            iconst_0
            bastore
        52: .line 252
      StackMap locals:
      StackMap stack:
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 54
        53: .line 253
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: got tgt"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        54: .line 257
      StackMap locals:
      StackMap stack:
            aload 11 /* newTgtRealm */
            aload 1 /* serviceRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 57
        55: .line 259
            aload 8 /* newTgt */
            astore 9 /* theTgt */
        56: .line 260
            goto 70
        57: .line 268
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            iconst_1
            iadd
            istore 6 /* k */
            goto 61
        58: .line 269
      StackMap locals:
      StackMap stack:
            aload 11 /* newTgtRealm */
            aload 4 /* realms */
            iload 6 /* k */
            aaload
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 60
        59: .line 270
            goto 62
        60: .line 268
      StackMap locals:
      StackMap stack:
            iinc 6 /* k */ 1
      StackMap locals:
      StackMap stack:
        61: iload 6 /* k */
            aload 4 /* realms */
            arraylength
            if_icmplt 58
        62: .line 274
      StackMap locals:
      StackMap stack:
            iload 6 /* k */
            aload 4 /* realms */
            arraylength
            if_icmpge 70
        63: .line 279
            iload 6 /* k */
            istore 5 /* i */
        64: .line 280
            aload 8 /* newTgt */
            astore 7 /* cTgt */
        65: .line 282
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 69
        66: .line 283
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: continuing with main loop counter reset to "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        67: .line 284
            iload 5 /* i */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        68: .line 283
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        69: .line 189
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            aload 4 /* realms */
            arraylength
            if_icmplt 10
        70: .line 299
      StackMap locals:
      StackMap stack:
            aload 9 /* theTgt */
            areturn
        end local 11 // java.lang.String newTgtRealm
        end local 10 // sun.security.krb5.PrincipalName tempService
        end local 9 // sun.security.krb5.Credentials theTgt
        end local 8 // sun.security.krb5.Credentials newTgt
        end local 7 // sun.security.krb5.Credentials cTgt
        end local 6 // int k
        end local 5 // int i
        end local 4 // java.lang.String[] realms
        end local 3 // boolean[] okAsDelegate
        end local 2 // sun.security.krb5.Credentials ccreds
        end local 1 // java.lang.String serviceRealm
        end local 0 // java.lang.String localRealm
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   71     0    localRealm  Ljava/lang/String;
            0   71     1  serviceRealm  Ljava/lang/String;
            0   71     2        ccreds  Lsun/security/krb5/Credentials;
            0   71     3  okAsDelegate  [Z
            1   71     4        realms  [Ljava/lang/String;
            2   71     5             i  I
            3   71     6             k  I
            4   71     7          cTgt  Lsun/security/krb5/Credentials;
            5   71     8        newTgt  Lsun/security/krb5/Credentials;
            6   71     9        theTgt  Lsun/security/krb5/Credentials;
            7   71    10   tempService  Lsun/security/krb5/PrincipalName;
            8   71    11   newTgtRealm  Ljava/lang/String;
      Exception table:
        from    to  target  type
          17    18      19  Class java.lang.Exception
          34    35      36  Class java.lang.Exception
    Exceptions:
      throws sun.security.krb5.KrbException
    MethodParameters:
              Name  Flags
      localRealm    
      serviceRealm  
      ccreds        
      okAsDelegate  

  private static sun.security.krb5.Credentials serviceCreds(sun.security.krb5.PrincipalName, sun.security.krb5.Credentials);
    descriptor: (Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.krb5.PrincipalName service
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 308
            new sun.security.krb5.KrbTgsReq
            dup
            aload 1 /* ccreds */
            aload 0 /* service */
            invokespecial sun.security.krb5.KrbTgsReq.<init>:(Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;)V
            invokevirtual sun.security.krb5.KrbTgsReq.sendAndGetCreds:()Lsun/security/krb5/Credentials;
            areturn
        end local 1 // sun.security.krb5.Credentials ccreds
        end local 0 // sun.security.krb5.PrincipalName service
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0  service  Lsun/security/krb5/PrincipalName;
            0    1     1   ccreds  Lsun/security/krb5/Credentials;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
         Name  Flags
      service  
      ccreds   
}
SourceFile: "CredentialsUtil.java"