class org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
  super_class: java.lang.Object
{
  int type;
    descriptor: I
    flags: (0x0000) 

  java.lang.String alias;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.lang.Object obj;
    descriptor: Ljava/lang/Object;
    flags: (0x0000) 

  java.security.cert.Certificate[] certChain;
    descriptor: [Ljava/security/cert/Certificate;
    flags: (0x0000) 

  java.util.Date date;
    descriptor: Ljava/util/Date;
    flags: (0x0000) 

  final org.bouncycastle.jce.provider.JDKKeyStore this$0;
    descriptor: Lorg/bouncycastle/jce/provider/JDKKeyStore;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(org.bouncycastle.jce.provider.JDKKeyStore, java.lang.String, java.security.cert.Certificate);
    descriptor: (Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/security/cert/Certificate;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
        start local 2 // java.lang.String alias
        start local 3 // java.security.cert.Certificate obj
         0: .line 102
            aload 0 /* this */
            aload 1
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
         1: .line 99
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         2: .line 97
            aload 0 /* this */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
         3: .line 103
            aload 0 /* this */
            iconst_1
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.type:I
         4: .line 104
            aload 0 /* this */
            aload 2 /* alias */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.alias:Ljava/lang/String;
         5: .line 105
            aload 0 /* this */
            aload 3 /* obj */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
         6: .line 106
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.certChain:[Ljava/security/cert/Certificate;
         7: .line 107
            return
        end local 3 // java.security.cert.Certificate obj
        end local 2 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    8     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            0    8     2  alias  Ljava/lang/String;
            0    8     3    obj  Ljava/security/cert/Certificate;
    MethodParameters:
        Name  Flags
      this$0  final
      alias   
      obj     

  void <init>(org.bouncycastle.jce.provider.JDKKeyStore, java.lang.String, byte[], java.security.cert.Certificate[]);
    descriptor: (Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;[B[Ljava/security/cert/Certificate;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
        start local 2 // java.lang.String alias
        start local 3 // byte[] obj
        start local 4 // java.security.cert.Certificate[] certChain
         0: .line 113
            aload 0 /* this */
            aload 1
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
         1: .line 109
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         2: .line 97
            aload 0 /* this */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
         3: .line 114
            aload 0 /* this */
            iconst_3
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.type:I
         4: .line 115
            aload 0 /* this */
            aload 2 /* alias */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.alias:Ljava/lang/String;
         5: .line 116
            aload 0 /* this */
            aload 3 /* obj */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
         6: .line 117
            aload 0 /* this */
            aload 4 /* certChain */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.certChain:[Ljava/security/cert/Certificate;
         7: .line 118
            return
        end local 4 // java.security.cert.Certificate[] certChain
        end local 3 // byte[] obj
        end local 2 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    8     0       this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            0    8     2      alias  Ljava/lang/String;
            0    8     3        obj  [B
            0    8     4  certChain  [Ljava/security/cert/Certificate;
    MethodParameters:
           Name  Flags
      this$0     final
      alias      
      obj        
      certChain  

  void <init>(org.bouncycastle.jce.provider.JDKKeyStore, java.lang.String, java.security.Key, char[], java.security.cert.Certificate[]);
    descriptor: (Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=12, args_size=6
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
        start local 2 // java.lang.String alias
        start local 3 // java.security.Key key
        start local 4 // char[] password
        start local 5 // java.security.cert.Certificate[] certChain
         0: .line 126
            aload 0 /* this */
            aload 1
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
         1: .line 120
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         2: .line 97
            aload 0 /* this */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
         3: .line 127
            aload 0 /* this */
            iconst_4
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.type:I
         4: .line 128
            aload 0 /* this */
            aload 2 /* alias */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.alias:Ljava/lang/String;
         5: .line 129
            aload 0 /* this */
            aload 5 /* certChain */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.certChain:[Ljava/security/cert/Certificate;
         6: .line 131
            bipush 20
            newarray 8
            astore 6 /* salt */
        start local 6 // byte[] salt
         7: .line 133
            aload 1
            getfield org.bouncycastle.jce.provider.JDKKeyStore.random:Ljava/security/SecureRandom;
            invokestatic java.lang.System.currentTimeMillis:()J
            invokevirtual java.security.SecureRandom.setSeed:(J)V
         8: .line 134
            aload 1
            getfield org.bouncycastle.jce.provider.JDKKeyStore.random:Ljava/security/SecureRandom;
            aload 6 /* salt */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         9: .line 136
            sipush 1024
            aload 1
            getfield org.bouncycastle.jce.provider.JDKKeyStore.random:Ljava/security/SecureRandom;
            invokevirtual java.security.SecureRandom.nextInt:()I
            sipush 1023
            iand
            iadd
            istore 7 /* iterationCount */
        start local 7 // int iterationCount
        10: .line 139
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 8 /* bOut */
        start local 8 // java.io.ByteArrayOutputStream bOut
        11: .line 140
            new java.io.DataOutputStream
            dup
            aload 8 /* bOut */
            invokespecial java.io.DataOutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 9 /* dOut */
        start local 9 // java.io.DataOutputStream dOut
        12: .line 142
            aload 9 /* dOut */
            aload 6 /* salt */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        13: .line 143
            aload 9 /* dOut */
            aload 6 /* salt */
            invokevirtual java.io.DataOutputStream.write:([B)V
        14: .line 144
            aload 9 /* dOut */
            iload 7 /* iterationCount */
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        15: .line 146
            aload 1
            ldc "PBEWithSHAAnd3-KeyTripleDES-CBC"
            iconst_1
            aload 4 /* password */
            aload 6 /* salt */
            iload 7 /* iterationCount */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.makePBECipher:(Ljava/lang/String;I[C[BI)Ljavax/crypto/Cipher;
            astore 10 /* cipher */
        start local 10 // javax.crypto.Cipher cipher
        16: .line 147
            new javax.crypto.CipherOutputStream
            dup
            aload 9 /* dOut */
            aload 10 /* cipher */
            invokespecial javax.crypto.CipherOutputStream.<init>:(Ljava/io/OutputStream;Ljavax/crypto/Cipher;)V
            astore 11 /* cOut */
        start local 11 // javax.crypto.CipherOutputStream cOut
        17: .line 149
            new java.io.DataOutputStream
            dup
            aload 11 /* cOut */
            invokespecial java.io.DataOutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 9 /* dOut */
        18: .line 151
            aload 1
            aload 3 /* key */
            aload 9 /* dOut */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.encodeKey:(Ljava/security/Key;Ljava/io/DataOutputStream;)V
        19: .line 153
            aload 9 /* dOut */
            invokevirtual java.io.DataOutputStream.close:()V
        20: .line 155
            aload 0 /* this */
            aload 8 /* bOut */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
        21: .line 156
            return
        end local 11 // javax.crypto.CipherOutputStream cOut
        end local 10 // javax.crypto.Cipher cipher
        end local 9 // java.io.DataOutputStream dOut
        end local 8 // java.io.ByteArrayOutputStream bOut
        end local 7 // int iterationCount
        end local 6 // byte[] salt
        end local 5 // java.security.cert.Certificate[] certChain
        end local 4 // char[] password
        end local 3 // java.security.Key key
        end local 2 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   22     0            this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            0   22     2           alias  Ljava/lang/String;
            0   22     3             key  Ljava/security/Key;
            0   22     4        password  [C
            0   22     5       certChain  [Ljava/security/cert/Certificate;
            7   22     6            salt  [B
           10   22     7  iterationCount  I
           11   22     8            bOut  Ljava/io/ByteArrayOutputStream;
           12   22     9            dOut  Ljava/io/DataOutputStream;
           16   22    10          cipher  Ljavax/crypto/Cipher;
           17   22    11            cOut  Ljavax/crypto/CipherOutputStream;
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
           Name  Flags
      this$0     final
      alias      
      key        
      password   
      certChain  

  void <init>(org.bouncycastle.jce.provider.JDKKeyStore, java.lang.String, java.util.Date, int, java.lang.Object);
    descriptor: (Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/util/Date;ILjava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=6, args_size=6
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
        start local 2 // java.lang.String alias
        start local 3 // java.util.Date date
        start local 4 // int type
        start local 5 // java.lang.Object obj
         0: .line 163
            aload 0 /* this */
            aload 1
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
         1: .line 158
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         2: .line 97
            aload 0 /* this */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
         3: .line 164
            aload 0 /* this */
            aload 2 /* alias */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.alias:Ljava/lang/String;
         4: .line 165
            aload 0 /* this */
            aload 3 /* date */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
         5: .line 166
            aload 0 /* this */
            iload 4 /* type */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.type:I
         6: .line 167
            aload 0 /* this */
            aload 5 /* obj */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
         7: .line 168
            return
        end local 5 // java.lang.Object obj
        end local 4 // int type
        end local 3 // java.util.Date date
        end local 2 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    8     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            0    8     2  alias  Ljava/lang/String;
            0    8     3   date  Ljava/util/Date;
            0    8     4   type  I
            0    8     5    obj  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      this$0  final
      alias   
      date    
      type    
      obj     

  void <init>(org.bouncycastle.jce.provider.JDKKeyStore, java.lang.String, java.util.Date, int, java.lang.Object, java.security.cert.Certificate[]);
    descriptor: (Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/util/Date;ILjava/lang/Object;[Ljava/security/cert/Certificate;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=7, args_size=7
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
        start local 2 // java.lang.String alias
        start local 3 // java.util.Date date
        start local 4 // int type
        start local 5 // java.lang.Object obj
        start local 6 // java.security.cert.Certificate[] certChain
         0: .line 176
            aload 0 /* this */
            aload 1
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
         1: .line 170
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         2: .line 97
            aload 0 /* this */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
         3: .line 177
            aload 0 /* this */
            aload 2 /* alias */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.alias:Ljava/lang/String;
         4: .line 178
            aload 0 /* this */
            aload 3 /* date */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
         5: .line 179
            aload 0 /* this */
            iload 4 /* type */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.type:I
         6: .line 180
            aload 0 /* this */
            aload 5 /* obj */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
         7: .line 181
            aload 0 /* this */
            aload 6 /* certChain */
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.certChain:[Ljava/security/cert/Certificate;
         8: .line 182
            return
        end local 6 // java.security.cert.Certificate[] certChain
        end local 5 // java.lang.Object obj
        end local 4 // int type
        end local 3 // java.util.Date date
        end local 2 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0       this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            0    9     2      alias  Ljava/lang/String;
            0    9     3       date  Ljava/util/Date;
            0    9     4       type  I
            0    9     5        obj  Ljava/lang/Object;
            0    9     6  certChain  [Ljava/security/cert/Certificate;
    MethodParameters:
           Name  Flags
      this$0     final
      alias      
      date       
      type       
      obj        
      certChain  

  int getType();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
         0: .line 186
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.type:I
            ireturn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;

  java.lang.String getAlias();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
         0: .line 191
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.alias:Ljava/lang/String;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;

  java.lang.Object getObject();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
         0: .line 196
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;

  java.lang.Object getObject(char[]);
    descriptor: ([C)Ljava/lang/Object;
    flags: (0x0000) 
    Code:
      stack=6, locals=13, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
        start local 1 // char[] password
         0: .line 203
            aload 1 /* password */
            ifnull 1
            aload 1 /* password */
            arraylength
            ifne 3
         1: .line 205
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
            instanceof java.security.Key
            ifeq 3
         2: .line 207
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
            areturn
         3: .line 211
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.type:I
            iconst_4
            if_icmpne 50
         4: .line 213
            new java.io.ByteArrayInputStream
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
            checkcast byte[]
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 2 /* bIn */
        start local 2 // java.io.ByteArrayInputStream bIn
         5: .line 214
            new java.io.DataInputStream
            dup
            aload 2 /* bIn */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 3 /* dIn */
        start local 3 // java.io.DataInputStream dIn
         6: .line 218
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            newarray 8
            astore 4 /* salt */
        start local 4 // byte[] salt
         7: .line 220
            aload 3 /* dIn */
            aload 4 /* salt */
            invokevirtual java.io.DataInputStream.readFully:([B)V
         8: .line 222
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 5 /* iterationCount */
        start local 5 // int iterationCount
         9: .line 224
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            ldc "PBEWithSHAAnd3-KeyTripleDES-CBC"
            iconst_2
            aload 1 /* password */
            aload 4 /* salt */
            iload 5 /* iterationCount */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.makePBECipher:(Ljava/lang/String;I[C[BI)Ljavax/crypto/Cipher;
            astore 6 /* cipher */
        start local 6 // javax.crypto.Cipher cipher
        10: .line 226
            new javax.crypto.CipherInputStream
            dup
            aload 3 /* dIn */
            aload 6 /* cipher */
            invokespecial javax.crypto.CipherInputStream.<init>:(Ljava/io/InputStream;Ljavax/crypto/Cipher;)V
            astore 7 /* cIn */
        start local 7 // javax.crypto.CipherInputStream cIn
        11: .line 230
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            new java.io.DataInputStream
            dup
            aload 7 /* cIn */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.decodeKey:(Ljava/io/DataInputStream;)Ljava/security/Key;
        12: areturn
        13: .line 232
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry char[] java.io.ByteArrayInputStream java.io.DataInputStream byte[] int javax.crypto.Cipher javax.crypto.CipherInputStream
      StackMap stack: java.lang.Exception
            pop
        14: .line 234
            new java.io.ByteArrayInputStream
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
            checkcast byte[]
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 2 /* bIn */
        15: .line 235
            new java.io.DataInputStream
            dup
            aload 2 /* bIn */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 3 /* dIn */
        16: .line 237
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            newarray 8
            astore 4 /* salt */
        17: .line 239
            aload 3 /* dIn */
            aload 4 /* salt */
            invokevirtual java.io.DataInputStream.readFully:([B)V
        18: .line 241
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 5 /* iterationCount */
        19: .line 243
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            ldc "BrokenPBEWithSHAAnd3-KeyTripleDES-CBC"
            iconst_2
            aload 1 /* password */
            aload 4 /* salt */
            iload 5 /* iterationCount */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.makePBECipher:(Ljava/lang/String;I[C[BI)Ljavax/crypto/Cipher;
            astore 6 /* cipher */
        20: .line 245
            new javax.crypto.CipherInputStream
            dup
            aload 3 /* dIn */
            aload 6 /* cipher */
            invokespecial javax.crypto.CipherInputStream.<init>:(Ljava/io/InputStream;Ljavax/crypto/Cipher;)V
            astore 7 /* cIn */
        21: .line 247
            aconst_null
            astore 8 /* k */
        start local 8 // java.security.Key k
        22: .line 251
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            new java.io.DataInputStream
            dup
            aload 7 /* cIn */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.decodeKey:(Ljava/io/DataInputStream;)Ljava/security/Key;
            astore 8 /* k */
        23: .line 252
            goto 33
        24: .line 253
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry char[] java.io.ByteArrayInputStream java.io.DataInputStream byte[] int javax.crypto.Cipher javax.crypto.CipherInputStream java.security.Key
      StackMap stack: java.lang.Exception
            pop
        25: .line 255
            new java.io.ByteArrayInputStream
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
            checkcast byte[]
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 2 /* bIn */
        26: .line 256
            new java.io.DataInputStream
            dup
            aload 2 /* bIn */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 3 /* dIn */
        27: .line 258
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            newarray 8
            astore 4 /* salt */
        28: .line 260
            aload 3 /* dIn */
            aload 4 /* salt */
            invokevirtual java.io.DataInputStream.readFully:([B)V
        29: .line 262
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 5 /* iterationCount */
        30: .line 264
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            ldc "OldPBEWithSHAAnd3-KeyTripleDES-CBC"
            iconst_2
            aload 1 /* password */
            aload 4 /* salt */
            iload 5 /* iterationCount */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.makePBECipher:(Ljava/lang/String;I[C[BI)Ljavax/crypto/Cipher;
            astore 6 /* cipher */
        31: .line 266
            new javax.crypto.CipherInputStream
            dup
            aload 3 /* dIn */
            aload 6 /* cipher */
            invokespecial javax.crypto.CipherInputStream.<init>:(Ljava/io/InputStream;Ljavax/crypto/Cipher;)V
            astore 7 /* cIn */
        32: .line 268
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            new java.io.DataInputStream
            dup
            aload 7 /* cIn */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.decodeKey:(Ljava/io/DataInputStream;)Ljava/security/Key;
            astore 8 /* k */
        33: .line 274
      StackMap locals:
      StackMap stack:
            aload 8 /* k */
            ifnull 47
        34: .line 276
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 9 /* bOut */
        start local 9 // java.io.ByteArrayOutputStream bOut
        35: .line 277
            new java.io.DataOutputStream
            dup
            aload 9 /* bOut */
            invokespecial java.io.DataOutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 10 /* dOut */
        start local 10 // java.io.DataOutputStream dOut
        36: .line 279
            aload 10 /* dOut */
            aload 4 /* salt */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        37: .line 280
            aload 10 /* dOut */
            aload 4 /* salt */
            invokevirtual java.io.DataOutputStream.write:([B)V
        38: .line 281
            aload 10 /* dOut */
            iload 5 /* iterationCount */
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        39: .line 283
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            ldc "PBEWithSHAAnd3-KeyTripleDES-CBC"
            iconst_1
            aload 1 /* password */
            aload 4 /* salt */
            iload 5 /* iterationCount */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.makePBECipher:(Ljava/lang/String;I[C[BI)Ljavax/crypto/Cipher;
            astore 11 /* out */
        start local 11 // javax.crypto.Cipher out
        40: .line 284
            new javax.crypto.CipherOutputStream
            dup
            aload 10 /* dOut */
            aload 11 /* out */
            invokespecial javax.crypto.CipherOutputStream.<init>:(Ljava/io/OutputStream;Ljavax/crypto/Cipher;)V
            astore 12 /* cOut */
        start local 12 // javax.crypto.CipherOutputStream cOut
        41: .line 286
            new java.io.DataOutputStream
            dup
            aload 12 /* cOut */
            invokespecial java.io.DataOutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 10 /* dOut */
        42: .line 288
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.this$0:Lorg/bouncycastle/jce/provider/JDKKeyStore;
            aload 8 /* k */
            aload 10 /* dOut */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.encodeKey:(Ljava/security/Key;Ljava/io/DataOutputStream;)V
        43: .line 290
            aload 10 /* dOut */
            invokevirtual java.io.DataOutputStream.close:()V
        44: .line 292
            aload 0 /* this */
            aload 9 /* bOut */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            putfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.obj:Ljava/lang/Object;
        45: .line 294
            aload 8 /* k */
        46: areturn
        end local 12 // javax.crypto.CipherOutputStream cOut
        end local 11 // javax.crypto.Cipher out
        end local 10 // java.io.DataOutputStream dOut
        end local 9 // java.io.ByteArrayOutputStream bOut
        47: .line 298
      StackMap locals:
      StackMap stack:
            new java.security.UnrecoverableKeyException
            dup
            ldc "no match"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 8 // java.security.Key k
        end local 7 // javax.crypto.CipherInputStream cIn
        end local 6 // javax.crypto.Cipher cipher
        end local 5 // int iterationCount
        end local 4 // byte[] salt
        48: .line 302
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry char[] java.io.ByteArrayInputStream java.io.DataInputStream
      StackMap stack: java.lang.Exception
            pop
        49: .line 304
            new java.security.UnrecoverableKeyException
            dup
            ldc "no match"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // java.io.DataInputStream dIn
        end local 2 // java.io.ByteArrayInputStream bIn
        50: .line 309
      StackMap locals:
      StackMap stack:
            new java.lang.RuntimeException
            dup
            ldc "forget something!"
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // char[] password
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   51     0            this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            0   51     1        password  [C
            5   50     2             bIn  Ljava/io/ByteArrayInputStream;
            6   50     3             dIn  Ljava/io/DataInputStream;
            7   48     4            salt  [B
            9   48     5  iterationCount  I
           10   48     6          cipher  Ljavax/crypto/Cipher;
           11   48     7             cIn  Ljavax/crypto/CipherInputStream;
           22   48     8               k  Ljava/security/Key;
           35   47     9            bOut  Ljava/io/ByteArrayOutputStream;
           36   47    10            dOut  Ljava/io/DataOutputStream;
           40   47    11             out  Ljavax/crypto/Cipher;
           41   47    12            cOut  Ljavax/crypto/CipherOutputStream;
      Exception table:
        from    to  target  type
          11    12      13  Class java.lang.Exception
          22    23      24  Class java.lang.Exception
           6    12      48  Class java.lang.Exception
          13    46      48  Class java.lang.Exception
          47    48      48  Class java.lang.Exception
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
          Name  Flags
      password  

  java.security.cert.Certificate[] getCertificateChain();
    descriptor: ()[Ljava/security/cert/Certificate;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
         0: .line 320
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.certChain:[Ljava/security/cert/Certificate;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;

  java.util.Date getDate();
    descriptor: ()Ljava/util/Date;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
         0: .line 325
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.date:Ljava/util/Date;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
}
SourceFile: "JDKKeyStore.java"
NestHost: org.bouncycastle.jce.provider.JDKKeyStore
InnerClasses:
  private StoreEntry = org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry of org.bouncycastle.jce.provider.JDKKeyStore