public class sun.security.krb5.internal.PAForUserEnc
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.krb5.internal.PAForUserEnc
  super_class: java.lang.Object
{
  public final sun.security.krb5.PrincipalName name;
    descriptor: Lsun/security/krb5/PrincipalName;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  private final sun.security.krb5.EncryptionKey key;
    descriptor: Lsun/security/krb5/EncryptionKey;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public static final java.lang.String AUTH_PACKAGE;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "Kerberos"

  public void <init>(sun.security.krb5.PrincipalName, sun.security.krb5.EncryptionKey);
    descriptor: (Lsun/security/krb5/PrincipalName;Lsun/security/krb5/EncryptionKey;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.krb5.internal.PAForUserEnc this
        start local 1 // sun.security.krb5.PrincipalName name
        start local 2 // sun.security.krb5.EncryptionKey key
         0: .line 63
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 64
            aload 0 /* this */
            aload 1 /* name */
            putfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
         2: .line 65
            aload 0 /* this */
            aload 2 /* key */
            putfield sun.security.krb5.internal.PAForUserEnc.key:Lsun/security/krb5/EncryptionKey;
         3: .line 66
            return
        end local 2 // sun.security.krb5.EncryptionKey key
        end local 1 // sun.security.krb5.PrincipalName name
        end local 0 // sun.security.krb5.internal.PAForUserEnc this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/krb5/internal/PAForUserEnc;
            0    4     1  name  Lsun/security/krb5/PrincipalName;
            0    4     2   key  Lsun/security/krb5/EncryptionKey;
    MethodParameters:
      Name  Flags
      name  
      key   

  public void <init>(sun.security.util.DerValue, sun.security.krb5.EncryptionKey);
    descriptor: (Lsun/security/util/DerValue;Lsun/security/krb5/EncryptionKey;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=3
        start local 0 // sun.security.krb5.internal.PAForUserEnc this
        start local 1 // sun.security.util.DerValue encoding
        start local 2 // sun.security.krb5.EncryptionKey key
         0: .line 76
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 78
            aconst_null
            astore 3 /* der */
        start local 3 // sun.security.util.DerValue der
         2: .line 79
            aload 0 /* this */
            aload 2 /* key */
            putfield sun.security.krb5.internal.PAForUserEnc.key:Lsun/security/krb5/EncryptionKey;
         3: .line 81
            aload 1 /* encoding */
            invokevirtual sun.security.util.DerValue.getTag:()B
            bipush 48
            if_icmpeq 5
         4: .line 82
            new sun.security.krb5.Asn1Exception
            dup
            sipush 906
            invokespecial sun.security.krb5.Asn1Exception.<init>:(I)V
            athrow
         5: .line 86
      StackMap locals: sun.security.krb5.internal.PAForUserEnc sun.security.util.DerValue sun.security.krb5.EncryptionKey sun.security.util.DerValue
      StackMap stack:
            aconst_null
            astore 4 /* tmpName */
        start local 4 // sun.security.krb5.PrincipalName tmpName
         6: .line 87
            aload 1 /* encoding */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* der */
         7: .line 88
            aload 3 /* der */
            invokevirtual sun.security.util.DerValue.getTag:()B
            bipush 31
            iand
            ifne 14
         8: .line 90
            new sun.security.krb5.PrincipalName
            dup
            aload 3 /* der */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
         9: .line 91
            new sun.security.krb5.Realm
            dup
            ldc "PLACEHOLDER"
            invokespecial sun.security.krb5.Realm.<init>:(Ljava/lang/String;)V
        10: .line 90
            invokespecial sun.security.krb5.PrincipalName.<init>:(Lsun/security/util/DerValue;Lsun/security/krb5/Realm;)V
            astore 4 /* tmpName */
        11: .line 92
            goto 15
      StackMap locals: sun.security.krb5.internal.PAForUserEnc sun.security.util.DerValue sun.security.krb5.EncryptionKey sun.security.util.DerValue sun.security.krb5.PrincipalName
      StackMap stack: sun.security.krb5.RealmException
        12: pop
        13: .line 95
            goto 15
        14: .line 96
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.Asn1Exception
            dup
            sipush 906
            invokespecial sun.security.krb5.Asn1Exception.<init>:(I)V
            athrow
        15: .line 99
      StackMap locals:
      StackMap stack:
            aload 1 /* encoding */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* der */
        16: .line 100
            aload 3 /* der */
            invokevirtual sun.security.util.DerValue.getTag:()B
            bipush 31
            iand
            iconst_1
            if_icmpne 24
        17: .line 102
            new sun.security.krb5.Realm
            dup
            aload 3 /* der */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            invokespecial sun.security.krb5.Realm.<init>:(Lsun/security/util/DerValue;)V
            astore 5 /* realm */
        start local 5 // sun.security.krb5.Realm realm
        18: .line 103
            aload 0 /* this */
            new sun.security.krb5.PrincipalName
            dup
        19: .line 104
            aload 4 /* tmpName */
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
            aload 4 /* tmpName */
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            aload 5 /* realm */
            invokespecial sun.security.krb5.PrincipalName.<init>:(I[Ljava/lang/String;Lsun/security/krb5/Realm;)V
        20: .line 103
            putfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
        end local 5 // sun.security.krb5.Realm realm
        21: .line 105
            goto 25
      StackMap locals:
      StackMap stack: sun.security.krb5.RealmException
        22: astore 5 /* re */
        start local 5 // sun.security.krb5.RealmException re
        23: .line 106
            new java.io.IOException
            dup
            aload 5 /* re */
            invokespecial java.io.IOException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 5 // sun.security.krb5.RealmException re
        24: .line 109
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.Asn1Exception
            dup
            sipush 906
            invokespecial sun.security.krb5.Asn1Exception.<init>:(I)V
            athrow
        25: .line 112
      StackMap locals:
      StackMap stack:
            aload 1 /* encoding */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* der */
        26: .line 113
            aload 3 /* der */
            invokevirtual sun.security.util.DerValue.getTag:()B
            bipush 31
            iand
            iconst_2
            if_icmpeq 28
        27: .line 116
            new sun.security.krb5.Asn1Exception
            dup
            sipush 906
            invokespecial sun.security.krb5.Asn1Exception.<init>:(I)V
            athrow
        28: .line 119
      StackMap locals:
      StackMap stack:
            aload 1 /* encoding */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* der */
        29: .line 120
            aload 3 /* der */
            invokevirtual sun.security.util.DerValue.getTag:()B
            bipush 31
            iand
            iconst_3
            if_icmpne 33
        30: .line 121
            new sun.security.krb5.internal.util.KerberosString
            dup
            aload 3 /* der */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            invokespecial sun.security.krb5.internal.util.KerberosString.<init>:(Lsun/security/util/DerValue;)V
            invokevirtual sun.security.krb5.internal.util.KerberosString.toString:()Ljava/lang/String;
            astore 5 /* authPackage */
        start local 5 // java.lang.String authPackage
        31: .line 122
            aload 5 /* authPackage */
            ldc "Kerberos"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 34
        32: .line 123
            new java.io.IOException
            dup
            ldc "Incorrect auth-package"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.lang.String authPackage
        33: .line 126
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.Asn1Exception
            dup
            sipush 906
            invokespecial sun.security.krb5.Asn1Exception.<init>:(I)V
            athrow
        34: .line 128
      StackMap locals:
      StackMap stack:
            aload 1 /* encoding */
            invokevirtual sun.security.util.DerValue.getData:()Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifle 36
        35: .line 129
            new sun.security.krb5.Asn1Exception
            dup
            sipush 906
            invokespecial sun.security.krb5.Asn1Exception.<init>:(I)V
            athrow
        36: .line 130
      StackMap locals:
      StackMap stack:
            return
        end local 4 // sun.security.krb5.PrincipalName tmpName
        end local 3 // sun.security.util.DerValue der
        end local 2 // sun.security.krb5.EncryptionKey key
        end local 1 // sun.security.util.DerValue encoding
        end local 0 // sun.security.krb5.internal.PAForUserEnc this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   37     0         this  Lsun/security/krb5/internal/PAForUserEnc;
            0   37     1     encoding  Lsun/security/util/DerValue;
            0   37     2          key  Lsun/security/krb5/EncryptionKey;
            2   37     3          der  Lsun/security/util/DerValue;
            6   37     4      tmpName  Lsun/security/krb5/PrincipalName;
           18   21     5        realm  Lsun/security/krb5/Realm;
           23   24     5           re  Lsun/security/krb5/RealmException;
           31   33     5  authPackage  Ljava/lang/String;
      Exception table:
        from    to  target  type
           8    11      12  Class sun.security.krb5.RealmException
          17    21      22  Class sun.security.krb5.RealmException
    Exceptions:
      throws sun.security.krb5.Asn1Exception, sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
          Name  Flags
      encoding  
      key       

  public byte[] asn1Encode();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // sun.security.krb5.internal.PAForUserEnc this
         0: .line 133
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 1 /* bytes */
        start local 1 // sun.security.util.DerOutputStream bytes
         1: .line 134
            aload 1 /* bytes */
            bipush -128
            iconst_1
            iconst_0
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
            aload 0 /* this */
            getfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.asn1Encode:()[B
            invokevirtual sun.security.util.DerOutputStream.write:(B[B)V
         2: .line 135
            aload 1 /* bytes */
            bipush -128
            iconst_1
            iconst_1
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
            aload 0 /* this */
            getfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealm:()Lsun/security/krb5/Realm;
            invokevirtual sun.security.krb5.Realm.asn1Encode:()[B
            invokevirtual sun.security.util.DerOutputStream.write:(B[B)V
         3: .line 139
            new sun.security.krb5.Checksum
            dup
         4: .line 140
            sipush -138
         5: .line 141
            aload 0 /* this */
            invokevirtual sun.security.krb5.internal.PAForUserEnc.getS4UByteArray:()[B
         6: .line 142
            aload 0 /* this */
            getfield sun.security.krb5.internal.PAForUserEnc.key:Lsun/security/krb5/EncryptionKey;
         7: .line 143
            bipush 17
         8: .line 139
            invokespecial sun.security.krb5.Checksum.<init>:(I[BLsun/security/krb5/EncryptionKey;I)V
            astore 2 /* cks */
        start local 2 // sun.security.krb5.Checksum cks
         9: .line 144
            aload 1 /* bytes */
            bipush -128
            iconst_1
            iconst_2
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
            aload 2 /* cks */
            invokevirtual sun.security.krb5.Checksum.asn1Encode:()[B
            invokevirtual sun.security.util.DerOutputStream.write:(B[B)V
        end local 2 // sun.security.krb5.Checksum cks
        10: .line 145
            goto 13
      StackMap locals: sun.security.krb5.internal.PAForUserEnc sun.security.util.DerOutputStream
      StackMap stack: sun.security.krb5.KrbException
        11: astore 2 /* ke */
        start local 2 // sun.security.krb5.KrbException ke
        12: .line 146
            new java.io.IOException
            dup
            aload 2 /* ke */
            invokespecial java.io.IOException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // sun.security.krb5.KrbException ke
        13: .line 149
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* temp */
        start local 2 // sun.security.util.DerOutputStream temp
        14: .line 150
            aload 2 /* temp */
            new sun.security.krb5.internal.util.KerberosString
            dup
            ldc "Kerberos"
            invokespecial sun.security.krb5.internal.util.KerberosString.<init>:(Ljava/lang/String;)V
            invokevirtual sun.security.krb5.internal.util.KerberosString.toDerValue:()Lsun/security/util/DerValue;
            invokevirtual sun.security.util.DerOutputStream.putDerValue:(Lsun/security/util/DerValue;)V
        15: .line 151
            aload 1 /* bytes */
            bipush -128
            iconst_1
            iconst_3
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
            aload 2 /* temp */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        16: .line 153
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* temp */
        17: .line 154
            aload 2 /* temp */
            bipush 48
            aload 1 /* bytes */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        18: .line 155
            aload 2 /* temp */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 2 // sun.security.util.DerOutputStream temp
        end local 1 // sun.security.util.DerOutputStream bytes
        end local 0 // sun.security.krb5.internal.PAForUserEnc this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   19     0   this  Lsun/security/krb5/internal/PAForUserEnc;
            1   19     1  bytes  Lsun/security/util/DerOutputStream;
            9   10     2    cks  Lsun/security/krb5/Checksum;
           12   13     2     ke  Lsun/security/krb5/KrbException;
           14   19     2   temp  Lsun/security/util/DerOutputStream;
      Exception table:
        from    to  target  type
           3    10      11  Class sun.security.krb5.KrbException
    Exceptions:
      throws sun.security.krb5.Asn1Exception, java.io.IOException

  public byte[] getS4UByteArray();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // sun.security.krb5.internal.PAForUserEnc this
         0: .line 169
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* ba */
        start local 1 // java.io.ByteArrayOutputStream ba
         1: .line 170
            aload 1 /* ba */
            iconst_4
            newarray 8
            invokevirtual java.io.ByteArrayOutputStream.writeBytes:([B)V
         2: .line 171
            aload 0 /* this */
            getfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 6
      StackMap locals: sun.security.krb5.internal.PAForUserEnc java.io.ByteArrayOutputStream top int int java.lang.String[]
      StackMap stack:
         3: aload 5
            iload 3
            aaload
            astore 2 /* s */
        start local 2 // java.lang.String s
         4: .line 172
            aload 1 /* ba */
            aload 2 /* s */
            getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
            invokevirtual java.lang.String.getBytes:(Ljava/nio/charset/Charset;)[B
            invokevirtual java.io.ByteArrayOutputStream.writeBytes:([B)V
        end local 2 // java.lang.String s
         5: .line 171
            iinc 3 1
      StackMap locals:
      StackMap stack:
         6: iload 3
            iload 4
            if_icmplt 3
         7: .line 174
            aload 1 /* ba */
            aload 0 /* this */
            getfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealm:()Lsun/security/krb5/Realm;
            invokevirtual sun.security.krb5.Realm.toString:()Ljava/lang/String;
            getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
            invokevirtual java.lang.String.getBytes:(Ljava/nio/charset/Charset;)[B
            invokevirtual java.io.ByteArrayOutputStream.writeBytes:([B)V
         8: .line 175
            aload 1 /* ba */
            ldc "Kerberos"
            getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
            invokevirtual java.lang.String.getBytes:(Ljava/nio/charset/Charset;)[B
            invokevirtual java.io.ByteArrayOutputStream.writeBytes:([B)V
         9: .line 176
            aload 1 /* ba */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            astore 2 /* output */
        start local 2 // byte[] output
        10: .line 177
            aload 0 /* this */
            getfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
            istore 3 /* pnType */
        start local 3 // int pnType
        11: .line 178
            aload 2 /* output */
            iconst_0
            iload 3 /* pnType */
            sipush 255
            iand
            i2b
            bastore
        12: .line 179
            aload 2 /* output */
            iconst_1
            iload 3 /* pnType */
            bipush 8
            ishr
            sipush 255
            iand
            i2b
            bastore
        13: .line 180
            aload 2 /* output */
            iconst_2
            iload 3 /* pnType */
            bipush 16
            ishr
            sipush 255
            iand
            i2b
            bastore
        14: .line 181
            aload 2 /* output */
            iconst_3
            iload 3 /* pnType */
            bipush 24
            ishr
            sipush 255
            iand
            i2b
            bastore
        15: .line 182
            aload 2 /* output */
            areturn
        end local 3 // int pnType
        end local 2 // byte[] output
        end local 1 // java.io.ByteArrayOutputStream ba
        end local 0 // sun.security.krb5.internal.PAForUserEnc this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   16     0    this  Lsun/security/krb5/internal/PAForUserEnc;
            1   16     1      ba  Ljava/io/ByteArrayOutputStream;
            4    5     2       s  Ljava/lang/String;
           10   16     2  output  [B
           11   16     3  pnType  I

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.PAForUserEnc this
         0: .line 186
            new java.lang.StringBuilder
            dup
            ldc "PA-FOR-USER: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.krb5.internal.PAForUserEnc.name:Lsun/security/krb5/PrincipalName;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 0 // sun.security.krb5.internal.PAForUserEnc this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/PAForUserEnc;
}
SourceFile: "PAForUserEnc.java"