public class javax.security.auth.kerberos.KerberosKey implements javax.crypto.SecretKey, javax.security.auth.Destroyable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: javax.security.auth.kerberos.KerberosKey
  super_class: java.lang.Object
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -4625402278148246993

  private javax.security.auth.kerberos.KerberosPrincipal principal;
    descriptor: Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0002) ACC_PRIVATE

  private int versionNum;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private javax.security.auth.kerberos.KeyImpl key;
    descriptor: Ljavax/security/auth/kerberos/KeyImpl;
    flags: (0x0002) ACC_PRIVATE

  private transient boolean destroyed;
    descriptor: Z
    flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT

  public void <init>(javax.security.auth.kerberos.KerberosPrincipal, byte[], int, int);
    descriptor: (Ljavax/security/auth/kerberos/KerberosPrincipal;[BII)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=5
        start local 0 // javax.security.auth.kerberos.KerberosKey this
        start local 1 // javax.security.auth.kerberos.KerberosPrincipal principal
        start local 2 // byte[] keyBytes
        start local 3 // int keyType
        start local 4 // int versionNum
         0: .line 104
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 91
            aload 0 /* this */
            iconst_0
            putfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
         2: .line 108
            aload 0 /* this */
            aload 1 /* principal */
            putfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
         3: .line 109
            aload 0 /* this */
            iload 4 /* versionNum */
            putfield javax.security.auth.kerberos.KerberosKey.versionNum:I
         4: .line 110
            aload 0 /* this */
            new javax.security.auth.kerberos.KeyImpl
            dup
            aload 2 /* keyBytes */
            iload 3 /* keyType */
            invokespecial javax.security.auth.kerberos.KeyImpl.<init>:([BI)V
            putfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
         5: .line 111
            return
        end local 4 // int versionNum
        end local 3 // int keyType
        end local 2 // byte[] keyBytes
        end local 1 // javax.security.auth.kerberos.KerberosPrincipal principal
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    6     0        this  Ljavax/security/auth/kerberos/KerberosKey;
            0    6     1   principal  Ljavax/security/auth/kerberos/KerberosPrincipal;
            0    6     2    keyBytes  [B
            0    6     3     keyType  I
            0    6     4  versionNum  I
    MethodParameters:
            Name  Flags
      principal   
      keyBytes    
      keyType     
      versionNum  

  public void <init>(javax.security.auth.kerberos.KerberosPrincipal, char[], java.lang.String);
    descriptor: (Ljavax/security/auth/kerberos/KerberosPrincipal;[CLjava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // javax.security.auth.kerberos.KerberosKey this
        start local 1 // javax.security.auth.kerberos.KerberosPrincipal principal
        start local 2 // char[] password
        start local 3 // java.lang.String algorithm
         0: .line 124
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 91
            aload 0 /* this */
            iconst_0
            putfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
         2: .line 128
            aload 0 /* this */
            aload 1 /* principal */
            putfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
         3: .line 130
            aload 0 /* this */
            new javax.security.auth.kerberos.KeyImpl
            dup
            aload 1 /* principal */
            aload 2 /* password */
            aload 3 /* algorithm */
            invokespecial javax.security.auth.kerberos.KeyImpl.<init>:(Ljavax/security/auth/kerberos/KerberosPrincipal;[CLjava/lang/String;)V
            putfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
         4: .line 131
            return
        end local 3 // java.lang.String algorithm
        end local 2 // char[] password
        end local 1 // javax.security.auth.kerberos.KerberosPrincipal principal
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    5     0       this  Ljavax/security/auth/kerberos/KerberosKey;
            0    5     1  principal  Ljavax/security/auth/kerberos/KerberosPrincipal;
            0    5     2   password  [C
            0    5     3  algorithm  Ljava/lang/String;
    MethodParameters:
           Name  Flags
      principal  
      password   
      algorithm  

  public final javax.security.auth.kerberos.KerberosPrincipal getPrincipal();
    descriptor: ()Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 139
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifeq 2
         1: .line 140
            new java.lang.IllegalStateException
            dup
            ldc "This key is no longer valid"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 141
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            areturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public final int getVersionNumber();
    descriptor: ()I
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 150
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifeq 2
         1: .line 151
            new java.lang.IllegalStateException
            dup
            ldc "This key is no longer valid"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 152
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.versionNum:I
            ireturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public final int getKeyType();
    descriptor: ()I
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 161
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifeq 2
         1: .line 162
            new java.lang.IllegalStateException
            dup
            ldc "This key is no longer valid"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 163
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
            invokevirtual javax.security.auth.kerberos.KeyImpl.getKeyType:()I
            ireturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public final java.lang.String getAlgorithm();
    descriptor: ()Ljava/lang/String;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 182
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifeq 2
         1: .line 183
            new java.lang.IllegalStateException
            dup
            ldc "This key is no longer valid"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 184
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
            invokevirtual javax.security.auth.kerberos.KeyImpl.getAlgorithm:()Ljava/lang/String;
            areturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public final java.lang.String getFormat();
    descriptor: ()Ljava/lang/String;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 193
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifeq 2
         1: .line 194
            new java.lang.IllegalStateException
            dup
            ldc "This key is no longer valid"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 195
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
            invokevirtual javax.security.auth.kerberos.KeyImpl.getFormat:()Ljava/lang/String;
            areturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public final byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 204
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifeq 2
         1: .line 205
            new java.lang.IllegalStateException
            dup
            ldc "This key is no longer valid"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
            invokevirtual javax.security.auth.kerberos.KeyImpl.getEncoded:()[B
            areturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public void destroy();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 217
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifne 4
         1: .line 218
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
            invokevirtual javax.security.auth.kerberos.KeyImpl.destroy:()V
         2: .line 219
            aload 0 /* this */
            aconst_null
            putfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
         3: .line 220
            aload 0 /* this */
            iconst_1
            putfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
         4: .line 222
      StackMap locals:
      StackMap stack:
            return
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Ljavax/security/auth/kerberos/KerberosKey;
    Exceptions:
      throws javax.security.auth.DestroyFailedException

  public boolean isDestroyed();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 227
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ireturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 231
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.destroyed:Z
            ifeq 2
         1: .line 232
            ldc "Destroyed Principal"
            areturn
         2: .line 234
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "Kerberos Principal "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         3: .line 235
            ldc "Key Version "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.versionNum:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         4: .line 236
            ldc "key "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.key:Ljavax/security/auth/kerberos/KeyImpl;
            invokevirtual javax.security.auth.kerberos.KeyImpl.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         5: .line 234
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljavax/security/auth/kerberos/KerberosKey;

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // javax.security.auth.kerberos.KerberosKey this
         0: .line 246
            bipush 17
            istore 1 /* result */
        start local 1 // int result
         1: .line 247
            aload 0 /* this */
            invokevirtual javax.security.auth.kerberos.KerberosKey.isDestroyed:()Z
            ifeq 3
         2: .line 248
            iload 1 /* result */
            ireturn
         3: .line 250
      StackMap locals: int
      StackMap stack:
            bipush 37
            iload 1 /* result */
            imul
            aload 0 /* this */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
            invokestatic java.util.Arrays.hashCode:([B)I
            iadd
            istore 1 /* result */
         4: .line 251
            bipush 37
            iload 1 /* result */
            imul
            aload 0 /* this */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
            iadd
            istore 1 /* result */
         5: .line 252
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            ifnull 7
         6: .line 253
            bipush 37
            iload 1 /* result */
            imul
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.hashCode:()I
            iadd
            istore 1 /* result */
         7: .line 255
      StackMap locals:
      StackMap stack:
            iload 1 /* result */
            bipush 37
            imul
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.versionNum:I
            iadd
            ireturn
        end local 1 // int result
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Ljavax/security/auth/kerberos/KerberosKey;
            1    8     1  result  I

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // javax.security.auth.kerberos.KerberosKey this
        start local 1 // java.lang.Object other
         0: .line 272
            aload 1 /* other */
            aload 0 /* this */
            if_acmpne 2
         1: .line 273
            iconst_1
            ireturn
         2: .line 275
      StackMap locals:
      StackMap stack:
            aload 1 /* other */
            instanceof javax.security.auth.kerberos.KerberosKey
            ifne 4
         3: .line 276
            iconst_0
            ireturn
         4: .line 279
      StackMap locals:
      StackMap stack:
            aload 1 /* other */
            checkcast javax.security.auth.kerberos.KerberosKey
            astore 2 /* otherKey */
        start local 2 // javax.security.auth.kerberos.KerberosKey otherKey
         5: .line 280
            aload 0 /* this */
            invokevirtual javax.security.auth.kerberos.KerberosKey.isDestroyed:()Z
            ifne 6
            aload 2 /* otherKey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.isDestroyed:()Z
            ifeq 7
         6: .line 281
      StackMap locals: javax.security.auth.kerberos.KerberosKey
      StackMap stack:
            iconst_0
            ireturn
         7: .line 284
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.versionNum:I
            aload 2 /* otherKey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getVersionNumber:()I
            if_icmpne 10
         8: .line 285
            aload 0 /* this */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
            aload 2 /* otherKey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
            if_icmpne 10
         9: .line 286
            aload 0 /* this */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
            aload 2 /* otherKey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
            invokestatic java.util.Arrays.equals:([B[B)Z
            ifne 11
        10: .line 287
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        11: .line 290
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            ifnonnull 14
        12: .line 291
            aload 2 /* otherKey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            ifnull 16
        13: .line 292
            iconst_0
            ireturn
        14: .line 295
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KerberosKey.principal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            aload 2 /* otherKey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.equals:(Ljava/lang/Object;)Z
            ifne 16
        15: .line 296
            iconst_0
            ireturn
        16: .line 300
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // javax.security.auth.kerberos.KerberosKey otherKey
        end local 1 // java.lang.Object other
        end local 0 // javax.security.auth.kerberos.KerberosKey this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   17     0      this  Ljavax/security/auth/kerberos/KerberosKey;
            0   17     1     other  Ljava/lang/Object;
            5   17     2  otherKey  Ljavax/security/auth/kerberos/KerberosKey;
    MethodParameters:
       Name  Flags
      other  
}
SourceFile: "KerberosKey.java"