public final class apple.security.KeychainStore extends java.security.KeyStoreSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: apple.security.KeychainStore
  super_class: java.security.KeyStoreSpi
{
  private java.util.Hashtable<java.lang.String, java.lang.Object> deletedEntries;
    descriptor: Ljava/util/Hashtable;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;

  private java.util.Hashtable<java.lang.String, java.lang.Object> addedEntries;
    descriptor: Ljava/util/Hashtable;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;

  private java.util.Hashtable<java.lang.String, java.lang.Object> entries;
    descriptor: Ljava/util/Hashtable;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;

  private static final int[] keyBag;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] pbeWithSHAAnd3KeyTripleDESCBC;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static sun.security.util.ObjectIdentifier PKCS8ShroudedKeyBag_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier pbeWithSHAAnd3KeyTripleDESCBC_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static final int iterationCount;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1024

  private static final int SALT_LEN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 20

  private static final sun.security.util.Debug debug;
    descriptor: Lsun/security/util/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private java.security.SecureRandom random;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 94
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            bipush 10
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_2
            iastore
            putstatic apple.security.KeychainStore.keyBag:[I
         1: .line 95
            bipush 8
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            iconst_1
            iastore
            dup
            bipush 7
            iconst_3
            iastore
            putstatic apple.security.KeychainStore.pbeWithSHAAnd3KeyTripleDESCBC:[I
         2: .line 105
            ldc "keystore"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic apple.security.KeychainStore.debug:Lsun/security/util/Debug;
         3: .line 109
            new apple.security.KeychainStore$1
            dup
            invokespecial apple.security.KeychainStore$1.<init>:()V
         4: .line 108
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            pop
         5: .line 116
            new sun.security.util.ObjectIdentifier
            dup
            getstatic apple.security.KeychainStore.keyBag:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic apple.security.KeychainStore.PKCS8ShroudedKeyBag_OID:Lsun/security/util/ObjectIdentifier;
         6: .line 117
            new sun.security.util.ObjectIdentifier
            dup
            getstatic apple.security.KeychainStore.pbeWithSHAAnd3KeyTripleDESCBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic apple.security.KeychainStore.pbeWithSHAAnd3KeyTripleDESCBC_OID:Lsun/security/util/ObjectIdentifier;
         7: .line 118
            goto 9
      StackMap locals:
      StackMap stack: java.io.IOException
         8: pop
         9: .line 121
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           5     7       8  Class java.io.IOException

  private static void permissionCheck();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=1, args_size=0
         0: .line 124
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 0 /* sec */
        start local 0 // java.lang.SecurityManager sec
         1: .line 126
            aload 0 /* sec */
            ifnull 3
         2: .line 127
            aload 0 /* sec */
            new java.lang.RuntimePermission
            dup
            ldc "useKeychainStore"
            invokespecial java.lang.RuntimePermission.<init>:(Ljava/lang/String;)V
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         3: .line 129
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            return
        end local 0 // java.lang.SecurityManager sec
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            1    4     0   sec  Ljava/lang/SecurityManager;

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // apple.security.KeychainStore this
         0: .line 138
            aload 0 /* this */
            invokespecial java.security.KeyStoreSpi.<init>:()V
         1: .line 77
            aload 0 /* this */
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            putfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
         2: .line 83
            aload 0 /* this */
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            putfield apple.security.KeychainStore.addedEntries:Ljava/util/Hashtable;
         3: .line 89
            aload 0 /* this */
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            putfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
         4: .line 138
            return
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lapple/security/KeychainStore;

  public java.security.Key engineGetKey(java.lang.String, char[]);
    descriptor: (Ljava/lang/String;[C)Ljava/security/Key;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=20, args_size=3
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
        start local 2 // char[] password
         0: .line 159
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 166
            aload 2 /* password */
            ifnull 2
            aload 2 /* password */
            arraylength
            ifne 5
         2: .line 169
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.random:Ljava/security/SecureRandom;
            ifnonnull 4
         3: .line 170
            aload 0 /* this */
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            putfield apple.security.KeychainStore.random:Ljava/security/SecureRandom;
         4: .line 172
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.random:Ljava/security/SecureRandom;
            invokevirtual java.security.SecureRandom.nextLong:()J
            invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
            invokevirtual java.lang.String.toCharArray:()[C
            astore 2 /* password */
         5: .line 175
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* entry */
        start local 3 // java.lang.Object entry
         6: .line 177
            aload 3 /* entry */
            ifnull 7
            aload 3 /* entry */
            instanceof apple.security.KeychainStore$KeyEntry
            ifne 8
         7: .line 178
      StackMap locals: java.lang.Object
      StackMap stack:
            aconst_null
            areturn
         8: .line 182
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            getfield apple.security.KeychainStore$KeyEntry.keyRef:J
            aload 2 /* password */
            invokevirtual apple.security.KeychainStore._getEncodedKeyData:(J[C)[B
            astore 4 /* exportedKeyInfo */
        start local 4 // byte[] exportedKeyInfo
         9: .line 183
            aload 4 /* exportedKeyInfo */
            ifnonnull 11
        10: .line 184
            aconst_null
            areturn
        11: .line 187
      StackMap locals: byte[]
      StackMap stack:
            aconst_null
            astore 5 /* returnValue */
        start local 5 // java.security.PrivateKey returnValue
        12: .line 190
            aload 0 /* this */
            aload 4 /* exportedKeyInfo */
            invokevirtual apple.security.KeychainStore.fetchPrivateKeyFromBag:([B)[B
            astore 6 /* pkcs8KeyData */
        start local 6 // byte[] pkcs8KeyData
        13: .line 196
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 6 /* pkcs8KeyData */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
            astore 10 /* encrInfo */
        start local 10 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        14: .line 197
            aload 10 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncryptedData:()[B
            astore 7 /* encryptedKey */
        start local 7 // byte[] encryptedKey
        15: .line 200
            new sun.security.util.DerValue
            dup
            aload 10 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getAlgorithm:()Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.encode:()[B
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 11 /* val */
        start local 11 // sun.security.util.DerValue val
        16: .line 201
            aload 11 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 12 /* in */
        start local 12 // sun.security.util.DerInputStream in
        17: .line 202
            aload 12 /* in */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 9 /* algOid */
        start local 9 // sun.security.util.ObjectIdentifier algOid
        18: .line 203
            aload 0 /* this */
            aload 12 /* in */
            invokevirtual apple.security.KeychainStore.parseAlgParameters:(Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
            astore 8 /* algParams */
        end local 12 // sun.security.util.DerInputStream in
        end local 11 // sun.security.util.DerValue val
        end local 10 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        start local 8 // java.security.AlgorithmParameters algParams
        19: .line 205
            goto 27
        end local 9 // sun.security.util.ObjectIdentifier algOid
        end local 8 // java.security.AlgorithmParameters algParams
        end local 7 // byte[] encryptedKey
      StackMap locals: apple.security.KeychainStore java.lang.String char[] java.lang.Object byte[] java.security.PrivateKey byte[]
      StackMap stack: java.io.IOException
        20: astore 10 /* ioe */
        start local 10 // java.io.IOException ioe
        21: .line 207
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Private key not stored as PKCS#8 EncryptedPrivateKeyInfo: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        22: .line 208
            aload 10 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        23: .line 207
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        24: .line 206
            astore 11 /* uke */
        start local 11 // java.security.UnrecoverableKeyException uke
        25: .line 209
            aload 11 /* uke */
            aload 10 /* ioe */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        26: .line 210
            aload 11 /* uke */
            athrow
        end local 11 // java.security.UnrecoverableKeyException uke
        end local 10 // java.io.IOException ioe
        start local 7 // byte[] encryptedKey
        start local 8 // java.security.AlgorithmParameters algParams
        start local 9 // sun.security.util.ObjectIdentifier algOid
        27: .line 214
      StackMap locals: byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier
      StackMap stack:
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual apple.security.KeychainStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 10 /* skey */
        start local 10 // javax.crypto.SecretKey skey
        28: .line 215
            aload 9 /* algOid */
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 11 /* cipher */
        start local 11 // javax.crypto.Cipher cipher
        29: .line 216
            aload 11 /* cipher */
            iconst_2
            aload 10 /* skey */
            aload 8 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        30: .line 217
            aload 11 /* cipher */
            aload 7 /* encryptedKey */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 12 /* decryptedPrivateKey */
        start local 12 // byte[] decryptedPrivateKey
        31: .line 218
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 12 /* decryptedPrivateKey */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            astore 13 /* kspec */
        start local 13 // java.security.spec.PKCS8EncodedKeySpec kspec
        32: .line 221
            new sun.security.util.DerValue
            dup
            aload 12 /* decryptedPrivateKey */
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 14 /* val */
        start local 14 // sun.security.util.DerValue val
        33: .line 222
            aload 14 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 15 /* in */
        start local 15 // sun.security.util.DerInputStream in
        34: .line 225
            aload 15 /* in */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
        35: .line 228
            aload 15 /* in */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 16 /* value */
        start local 16 // sun.security.util.DerValue[] value
        36: .line 229
            aload 16 /* value */
            arraylength
            iconst_1
            if_icmplt 37
            aload 16 /* value */
            arraylength
            iconst_2
            if_icmple 38
        37: .line 230
      StackMap locals: apple.security.KeychainStore java.lang.String char[] java.lang.Object byte[] java.security.PrivateKey byte[] byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier javax.crypto.SecretKey javax.crypto.Cipher byte[] java.security.spec.PKCS8EncodedKeySpec sun.security.util.DerValue sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            new java.io.IOException
            dup
            ldc "Invalid length for AlgorithmIdentifier"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        38: .line 232
      StackMap locals:
      StackMap stack:
            new sun.security.x509.AlgorithmId
            dup
            aload 16 /* value */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;)V
            astore 17 /* algId */
        start local 17 // sun.security.x509.AlgorithmId algId
        39: .line 233
            aload 17 /* algId */
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            astore 18 /* algName */
        start local 18 // java.lang.String algName
        40: .line 236
            aload 18 /* algName */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 19 /* kfac */
        start local 19 // java.security.KeyFactory kfac
        41: .line 237
            aload 19 /* kfac */
            aload 13 /* kspec */
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
            astore 5 /* returnValue */
        end local 19 // java.security.KeyFactory kfac
        end local 18 // java.lang.String algName
        end local 17 // sun.security.x509.AlgorithmId algId
        end local 16 // sun.security.util.DerValue[] value
        end local 15 // sun.security.util.DerInputStream in
        end local 14 // sun.security.util.DerValue val
        end local 13 // java.security.spec.PKCS8EncodedKeySpec kspec
        end local 12 // byte[] decryptedPrivateKey
        end local 11 // javax.crypto.Cipher cipher
        end local 10 // javax.crypto.SecretKey skey
        end local 9 // sun.security.util.ObjectIdentifier algOid
        end local 8 // java.security.AlgorithmParameters algParams
        end local 7 // byte[] encryptedKey
        end local 6 // byte[] pkcs8KeyData
        42: .line 238
            goto 50
      StackMap locals: apple.security.KeychainStore java.lang.String char[] java.lang.Object byte[] java.security.PrivateKey
      StackMap stack: java.lang.Exception
        43: astore 6 /* e */
        start local 6 // java.lang.Exception e
        44: .line 240
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Get Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        45: .line 241
            aload 6 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        46: .line 240
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        47: .line 239
            astore 7 /* uke */
        start local 7 // java.security.UnrecoverableKeyException uke
        48: .line 242
            aload 7 /* uke */
            aload 6 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        49: .line 243
            aload 7 /* uke */
            athrow
        end local 7 // java.security.UnrecoverableKeyException uke
        end local 6 // java.lang.Exception e
        50: .line 246
      StackMap locals:
      StackMap stack:
            aload 5 /* returnValue */
            areturn
        end local 5 // java.security.PrivateKey returnValue
        end local 4 // byte[] exportedKeyInfo
        end local 3 // java.lang.Object entry
        end local 2 // char[] password
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   51     0                 this  Lapple/security/KeychainStore;
            0   51     1                alias  Ljava/lang/String;
            0   51     2             password  [C
            6   51     3                entry  Ljava/lang/Object;
            9   51     4      exportedKeyInfo  [B
           12   51     5          returnValue  Ljava/security/PrivateKey;
           13   42     6         pkcs8KeyData  [B
           15   20     7         encryptedKey  [B
           27   42     7         encryptedKey  [B
           19   20     8            algParams  Ljava/security/AlgorithmParameters;
           27   42     8            algParams  Ljava/security/AlgorithmParameters;
           18   20     9               algOid  Lsun/security/util/ObjectIdentifier;
           27   42     9               algOid  Lsun/security/util/ObjectIdentifier;
           14   19    10             encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           16   19    11                  val  Lsun/security/util/DerValue;
           17   19    12                   in  Lsun/security/util/DerInputStream;
           21   27    10                  ioe  Ljava/io/IOException;
           25   27    11                  uke  Ljava/security/UnrecoverableKeyException;
           28   42    10                 skey  Ljavax/crypto/SecretKey;
           29   42    11               cipher  Ljavax/crypto/Cipher;
           31   42    12  decryptedPrivateKey  [B
           32   42    13                kspec  Ljava/security/spec/PKCS8EncodedKeySpec;
           33   42    14                  val  Lsun/security/util/DerValue;
           34   42    15                   in  Lsun/security/util/DerInputStream;
           36   42    16                value  [Lsun/security/util/DerValue;
           39   42    17                algId  Lsun/security/x509/AlgorithmId;
           40   42    18              algName  Ljava/lang/String;
           41   42    19                 kfac  Ljava/security/KeyFactory;
           44   50     6                    e  Ljava/lang/Exception;
           48   50     7                  uke  Ljava/security/UnrecoverableKeyException;
      Exception table:
        from    to  target  type
          13    19      20  Class java.io.IOException
          12    42      43  Class java.lang.Exception
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
          Name  Flags
      alias     
      password  

  private native byte[] _getEncodedKeyData(long, char[]);
    descriptor: (J[C)[B
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    MethodParameters:
           Name  Flags
      secKeyRef  
      password   

  public java.security.cert.Certificate[] engineGetCertificateChain(java.lang.String);
    descriptor: (Ljava/lang/String;)[Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
         0: .line 263
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 265
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         2: .line 267
            aload 2 /* entry */
            ifnull 6
            aload 2 /* entry */
            instanceof apple.security.KeychainStore$KeyEntry
            ifeq 6
         3: .line 268
            aload 2 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 5
         4: .line 269
            aconst_null
            areturn
         5: .line 271
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 2 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            areturn
         6: .line 274
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Lapple/security/KeychainStore;
            0    7     1  alias  Ljava/lang/String;
            2    7     2  entry  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      alias  

  public java.security.cert.Certificate engineGetCertificate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
         0: .line 294
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 296
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         2: .line 298
            aload 2 /* entry */
            ifnull 9
         3: .line 299
            aload 2 /* entry */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 5
         4: .line 300
            aload 2 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            areturn
         5: .line 302
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 2 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            astore 3 /* ke */
        start local 3 // apple.security.KeychainStore$KeyEntry ke
         6: .line 303
            aload 3 /* ke */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 7
            aload 3 /* ke */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            ifne 8
         7: .line 304
      StackMap locals: apple.security.KeychainStore$KeyEntry
      StackMap stack:
            aconst_null
            areturn
         8: .line 306
      StackMap locals:
      StackMap stack:
            aload 3 /* ke */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aaload
            areturn
        end local 3 // apple.security.KeychainStore$KeyEntry ke
         9: .line 309
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   10     0   this  Lapple/security/KeychainStore;
            0   10     1  alias  Ljava/lang/String;
            2   10     2  entry  Ljava/lang/Object;
            6    9     3     ke  Lapple/security/KeychainStore$KeyEntry;
    MethodParameters:
       Name  Flags
      alias  

  public java.util.Date engineGetCreationDate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/Date;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
         0: .line 322
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 324
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         2: .line 326
            aload 2 /* entry */
            ifnull 6
         3: .line 327
            aload 2 /* entry */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 5
         4: .line 328
            new java.util.Date
            dup
            aload 2 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokespecial java.util.Date.<init>:(J)V
            areturn
         5: .line 330
      StackMap locals: java.lang.Object
      StackMap stack:
            new java.util.Date
            dup
            aload 2 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            getfield apple.security.KeychainStore$KeyEntry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokespecial java.util.Date.<init>:(J)V
            areturn
         6: .line 333
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Lapple/security/KeychainStore;
            0    7     1  alias  Ljava/lang/String;
            2    7     2  entry  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      alias  

  public void engineSetKeyEntry(java.lang.String, java.security.Key, char[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=8, args_size=5
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.Key key
        start local 3 // char[] password
        start local 4 // java.security.cert.Certificate[] chain
         0: .line 363
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 365
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            dup
            astore 5
            monitorenter
         2: .line 367
            new apple.security.KeychainStore$KeyEntry
            dup
            aload 0 /* this */
            invokespecial apple.security.KeychainStore$KeyEntry.<init>:(Lapple/security/KeychainStore;)V
            astore 6 /* entry */
        start local 6 // apple.security.KeychainStore$KeyEntry entry
         3: .line 368
            aload 6 /* entry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield apple.security.KeychainStore$KeyEntry.date:Ljava/util/Date;
         4: .line 370
            aload 2 /* key */
            instanceof java.security.PrivateKey
            ifeq 11
         5: .line 371
            aload 2 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            ldc "PKCS#8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 7
         6: .line 372
            aload 2 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            ldc "PKCS8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 10
         7: .line 373
      StackMap locals: java.util.Hashtable apple.security.KeychainStore$KeyEntry
      StackMap stack:
            aload 6 /* entry */
            aload 0 /* this */
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            aload 3 /* password */
            invokevirtual apple.security.KeychainStore.encryptPrivateKey:([B[C)[B
            putfield apple.security.KeychainStore$KeyEntry.protectedPrivKey:[B
         8: .line 374
            aload 6 /* entry */
            aload 3 /* password */
            invokevirtual char[].clone:()Ljava/lang/Object;
            checkcast char[]
            putfield apple.security.KeychainStore$KeyEntry.password:[C
         9: .line 375
            goto 12
        10: .line 376
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
            ldc "Private key is not encoded as PKCS#8"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 379
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
            ldc "Key is not a PrivateKey"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 383
      StackMap locals:
      StackMap stack:
            aload 4 /* chain */
            ifnull 17
        13: .line 384
            aload 4 /* chain */
            arraylength
            iconst_1
            if_icmple 15
            aload 0 /* this */
            aload 4 /* chain */
            invokevirtual apple.security.KeychainStore.validateChain:([Ljava/security/cert/Certificate;)Z
            ifne 15
        14: .line 385
            new java.security.KeyStoreException
            dup
            ldc "Certificate chain does not validate"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 388
      StackMap locals:
      StackMap stack:
            aload 6 /* entry */
            aload 4 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        16: .line 389
            aload 6 /* entry */
            aload 6 /* entry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            newarray 11
            putfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
        17: .line 392
      StackMap locals:
      StackMap stack:
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            astore 7 /* lowerAlias */
        start local 7 // java.lang.String lowerAlias
        18: .line 393
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnull 20
        19: .line 394
            aload 0 /* this */
            getfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        20: .line 397
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            aload 6 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        21: .line 398
            aload 0 /* this */
            getfield apple.security.KeychainStore.addedEntries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            aload 6 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // java.lang.String lowerAlias
        end local 6 // apple.security.KeychainStore$KeyEntry entry
        22: .line 399
            goto 27
      StackMap locals: apple.security.KeychainStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.util.Hashtable
      StackMap stack: java.lang.Exception
        23: astore 6 /* nsae */
        start local 6 // java.lang.Exception nsae
        24: .line 400
            new java.security.KeyStoreException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Key protection algorithm not found: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* nsae */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            astore 7 /* ke */
        start local 7 // java.security.KeyStoreException ke
        25: .line 401
            aload 7 /* ke */
            aload 6 /* nsae */
            invokevirtual java.security.KeyStoreException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        26: .line 402
            aload 7 /* ke */
            athrow
        end local 7 // java.security.KeyStoreException ke
        end local 6 // java.lang.Exception nsae
        27: .line 365
      StackMap locals:
      StackMap stack:
            aload 5
            monitorexit
        28: goto 31
      StackMap locals:
      StackMap stack: java.lang.Throwable
        29: aload 5
            monitorexit
        30: athrow
        31: .line 405
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.security.cert.Certificate[] chain
        end local 3 // char[] password
        end local 2 // java.security.Key key
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   32     0        this  Lapple/security/KeychainStore;
            0   32     1       alias  Ljava/lang/String;
            0   32     2         key  Ljava/security/Key;
            0   32     3    password  [C
            0   32     4       chain  [Ljava/security/cert/Certificate;
            3   22     6       entry  Lapple/security/KeychainStore$KeyEntry;
           18   22     7  lowerAlias  Ljava/lang/String;
           24   27     6        nsae  Ljava/lang/Exception;
           25   27     7          ke  Ljava/security/KeyStoreException;
      Exception table:
        from    to  target  type
           2    22      23  Class java.lang.Exception
           2    28      29  any
          29    30      29  any
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
          Name  Flags
      alias     
      key       
      password  
      chain     

  public void engineSetKeyEntry(java.lang.String, byte[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;[B[Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=4
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
        start local 2 // byte[] key
        start local 3 // java.security.cert.Certificate[] chain
         0: .line 434
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 436
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            dup
            astore 4
            monitorenter
         2: .line 439
            new apple.security.KeychainStore$KeyEntry
            dup
            aload 0 /* this */
            invokespecial apple.security.KeychainStore$KeyEntry.<init>:(Lapple/security/KeychainStore;)V
            astore 5 /* entry */
        start local 5 // apple.security.KeychainStore$KeyEntry entry
         3: .line 441
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 2 /* key */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
            astore 6 /* privateKey */
        start local 6 // sun.security.pkcs.EncryptedPrivateKeyInfo privateKey
         4: .line 442
            aload 5 /* entry */
            aload 6 /* privateKey */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncoded:()[B
            putfield apple.security.KeychainStore$KeyEntry.protectedPrivKey:[B
        end local 6 // sun.security.pkcs.EncryptedPrivateKeyInfo privateKey
         5: .line 443
            goto 8
      StackMap locals: apple.security.KeychainStore java.lang.String byte[] java.security.cert.Certificate[] java.util.Hashtable apple.security.KeychainStore$KeyEntry
      StackMap stack: java.io.IOException
         6: pop
         7: .line 444
            new java.security.KeyStoreException
            dup
            ldc "key is not encoded as EncryptedPrivateKeyInfo"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 448
      StackMap locals:
      StackMap stack:
            aload 5 /* entry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield apple.security.KeychainStore$KeyEntry.date:Ljava/util/Date;
         9: .line 450
            aload 3 /* chain */
            ifnull 13
        10: .line 451
            aload 3 /* chain */
            arraylength
            ifeq 13
        11: .line 452
            aload 5 /* entry */
            aload 3 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        12: .line 453
            aload 5 /* entry */
            aload 5 /* entry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            newarray 11
            putfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
        13: .line 456
      StackMap locals:
      StackMap stack:
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            astore 6 /* lowerAlias */
        start local 6 // java.lang.String lowerAlias
        14: .line 457
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 6 /* lowerAlias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnull 16
        15: .line 458
            aload 0 /* this */
            getfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
            aload 6 /* lowerAlias */
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        16: .line 460
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 6 /* lowerAlias */
            aload 5 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        17: .line 461
            aload 0 /* this */
            getfield apple.security.KeychainStore.addedEntries:Ljava/util/Hashtable;
            aload 6 /* lowerAlias */
            aload 5 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 6 // java.lang.String lowerAlias
        end local 5 // apple.security.KeychainStore$KeyEntry entry
        18: .line 436
            aload 4
            monitorexit
        19: goto 22
      StackMap locals: apple.security.KeychainStore java.lang.String byte[] java.security.cert.Certificate[] java.util.Hashtable
      StackMap stack: java.lang.Throwable
        20: aload 4
            monitorexit
        21: athrow
        22: .line 463
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.security.cert.Certificate[] chain
        end local 2 // byte[] key
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   23     0        this  Lapple/security/KeychainStore;
            0   23     1       alias  Ljava/lang/String;
            0   23     2         key  [B
            0   23     3       chain  [Ljava/security/cert/Certificate;
            3   18     5       entry  Lapple/security/KeychainStore$KeyEntry;
            4    5     6  privateKey  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           14   18     6  lowerAlias  Ljava/lang/String;
      Exception table:
        from    to  target  type
           3     5       6  Class java.io.IOException
           2    19      20  any
          20    21      20  any
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      key    
      chain  

  public void engineSetCertificateEntry(java.lang.String, java.security.cert.Certificate);
    descriptor: (Ljava/lang/String;Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=9, args_size=3
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.cert.Certificate cert
         0: .line 482
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 484
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            dup
            astore 3
            monitorenter
         2: .line 486
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 4 /* entry */
        start local 4 // java.lang.Object entry
         3: .line 487
            aload 4 /* entry */
            ifnull 7
            aload 4 /* entry */
            instanceof apple.security.KeychainStore$KeyEntry
            ifeq 7
         4: .line 488
            new java.security.KeyStoreException
            dup
         5: .line 489
            ldc "Cannot overwrite key entry with certificate"
         6: .line 488
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 494
      StackMap locals: java.util.Hashtable java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.values:()Ljava/util/Collection;
            astore 5 /* allValues */
        start local 5 // java.util.Collection allValues
         8: .line 496
            aload 5 /* allValues */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 14
      StackMap locals: apple.security.KeychainStore java.lang.String java.security.cert.Certificate java.util.Hashtable java.lang.Object java.util.Collection top java.util.Iterator
      StackMap stack:
         9: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 6 /* value */
        start local 6 // java.lang.Object value
        10: .line 497
            aload 6 /* value */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 14
        11: .line 498
            aload 6 /* value */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            astore 8 /* tce */
        start local 8 // apple.security.KeychainStore$TrustedCertEntry tce
        12: .line 499
            aload 8 /* tce */
            getfield apple.security.KeychainStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            aload 2 /* cert */
            invokevirtual java.security.cert.Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 14
        13: .line 500
            new java.security.KeyStoreException
            dup
            ldc "Keychain does not support mulitple copies of same certificate."
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        end local 8 // apple.security.KeychainStore$TrustedCertEntry tce
        end local 6 // java.lang.Object value
        14: .line 496
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        15: .line 505
            new apple.security.KeychainStore$TrustedCertEntry
            dup
            aload 0 /* this */
            invokespecial apple.security.KeychainStore$TrustedCertEntry.<init>:(Lapple/security/KeychainStore;)V
            astore 6 /* trustedCertEntry */
        start local 6 // apple.security.KeychainStore$TrustedCertEntry trustedCertEntry
        16: .line 506
            aload 6 /* trustedCertEntry */
            aload 2 /* cert */
            putfield apple.security.KeychainStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
        17: .line 507
            aload 6 /* trustedCertEntry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield apple.security.KeychainStore$TrustedCertEntry.date:Ljava/util/Date;
        18: .line 508
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            astore 7 /* lowerAlias */
        start local 7 // java.lang.String lowerAlias
        19: .line 509
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnull 21
        20: .line 510
            aload 0 /* this */
            getfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        21: .line 512
      StackMap locals: apple.security.KeychainStore java.lang.String java.security.cert.Certificate java.util.Hashtable java.lang.Object java.util.Collection apple.security.KeychainStore$TrustedCertEntry java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            aload 6 /* trustedCertEntry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        22: .line 513
            aload 0 /* this */
            getfield apple.security.KeychainStore.addedEntries:Ljava/util/Hashtable;
            aload 7 /* lowerAlias */
            aload 6 /* trustedCertEntry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // java.lang.String lowerAlias
        end local 6 // apple.security.KeychainStore$TrustedCertEntry trustedCertEntry
        end local 5 // java.util.Collection allValues
        end local 4 // java.lang.Object entry
        23: .line 484
            aload 3
            monitorexit
        24: goto 27
      StackMap locals: apple.security.KeychainStore java.lang.String java.security.cert.Certificate java.util.Hashtable
      StackMap stack: java.lang.Throwable
        25: aload 3
            monitorexit
        26: athrow
        27: .line 515
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.security.cert.Certificate cert
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   28     0              this  Lapple/security/KeychainStore;
            0   28     1             alias  Ljava/lang/String;
            0   28     2              cert  Ljava/security/cert/Certificate;
            3   23     4             entry  Ljava/lang/Object;
            8   23     5         allValues  Ljava/util/Collection<Ljava/lang/Object;>;
           10   14     6             value  Ljava/lang/Object;
           12   14     8               tce  Lapple/security/KeychainStore$TrustedCertEntry;
           16   23     6  trustedCertEntry  Lapple/security/KeychainStore$TrustedCertEntry;
           19   23     7        lowerAlias  Ljava/lang/String;
      Exception table:
        from    to  target  type
           2    24      25  any
          25    26      25  any
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      cert   

  public void engineDeleteEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
         0: .line 527
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 529
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            dup
            astore 2
            monitorenter
         2: .line 530
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* entry */
        start local 3 // java.lang.Object entry
         3: .line 531
            aload 0 /* this */
            getfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            aload 3 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 3 // java.lang.Object entry
         4: .line 529
            aload 2
            monitorexit
         5: goto 8
      StackMap locals: apple.security.KeychainStore java.lang.String java.util.Hashtable
      StackMap stack: java.lang.Throwable
         6: aload 2
            monitorexit
         7: athrow
         8: .line 533
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    9     0   this  Lapple/security/KeychainStore;
            0    9     1  alias  Ljava/lang/String;
            3    4     3  entry  Ljava/lang/Object;
      Exception table:
        from    to  target  type
           2     5       6  any
           6     7       6  any
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  

  public java.util.Enumeration<java.lang.String> engineAliases();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // apple.security.KeychainStore this
         0: .line 541
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 542
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            areturn
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lapple/security/KeychainStore;
    Signature: ()Ljava/util/Enumeration<Ljava/lang/String;>;

  public boolean engineContainsAlias(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
         0: .line 553
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 554
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.containsKey:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lapple/security/KeychainStore;
            0    2     1  alias  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      alias  

  public int engineSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // apple.security.KeychainStore this
         0: .line 563
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 564
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.size:()I
            ireturn
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lapple/security/KeychainStore;

  public boolean engineIsKeyEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
         0: .line 575
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 576
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         2: .line 577
            aload 2 /* entry */
            ifnull 4
            aload 2 /* entry */
            instanceof apple.security.KeychainStore$KeyEntry
            ifeq 4
         3: .line 578
            iconst_1
            ireturn
         4: .line 580
      StackMap locals: java.lang.Object
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lapple/security/KeychainStore;
            0    5     1  alias  Ljava/lang/String;
            2    5     2  entry  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      alias  

  public boolean engineIsCertificateEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
         0: .line 592
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 593
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         2: .line 594
            aload 2 /* entry */
            ifnull 4
            aload 2 /* entry */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 4
         3: .line 595
            iconst_1
            ireturn
         4: .line 597
      StackMap locals: java.lang.Object
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lapple/security/KeychainStore;
            0    5     1  alias  Ljava/lang/String;
            2    5     2  entry  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      alias  

  public java.lang.String engineGetCertificateAlias(java.security.cert.Certificate);
    descriptor: (Ljava/security/cert/Certificate;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.security.cert.Certificate cert
         0: .line 618
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 621
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            astore 3 /* e */
        start local 3 // java.util.Enumeration e
         2: goto 14
         3: .line 622
      StackMap locals: apple.security.KeychainStore java.security.cert.Certificate top java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* alias */
        start local 4 // java.lang.String alias
         4: .line 623
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 4 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 5 /* entry */
        start local 5 // java.lang.Object entry
         5: .line 624
            aload 5 /* entry */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 8
         6: .line 625
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            astore 2 /* certElem */
        start local 2 // java.security.cert.Certificate certElem
         7: .line 626
            goto 12
        end local 2 // java.security.cert.Certificate certElem
         8: .line 627
      StackMap locals: java.lang.String java.lang.Object
      StackMap stack:
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            astore 6 /* ke */
        start local 6 // apple.security.KeychainStore$KeyEntry ke
         9: .line 628
            aload 6 /* ke */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 14
            aload 6 /* ke */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            ifne 11
        10: .line 629
            goto 14
        11: .line 631
      StackMap locals: apple.security.KeychainStore$KeyEntry
      StackMap stack:
            aload 6 /* ke */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aaload
            astore 2 /* certElem */
        end local 6 // apple.security.KeychainStore$KeyEntry ke
        start local 2 // java.security.cert.Certificate certElem
        12: .line 633
      StackMap locals: apple.security.KeychainStore java.security.cert.Certificate java.security.cert.Certificate java.util.Enumeration java.lang.String java.lang.Object
      StackMap stack:
            aload 2 /* certElem */
            aload 1 /* cert */
            invokevirtual java.security.cert.Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 14
        13: .line 634
            aload 4 /* alias */
            areturn
        end local 5 // java.lang.Object entry
        end local 4 // java.lang.String alias
        end local 2 // java.security.cert.Certificate certElem
        14: .line 621
      StackMap locals: apple.security.KeychainStore java.security.cert.Certificate top java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        end local 3 // java.util.Enumeration e
        15: .line 637
            aconst_null
            areturn
        end local 1 // java.security.cert.Certificate cert
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   16     0      this  Lapple/security/KeychainStore;
            0   16     1      cert  Ljava/security/cert/Certificate;
            7    8     2  certElem  Ljava/security/cert/Certificate;
           12   14     2  certElem  Ljava/security/cert/Certificate;
            2   15     3         e  Ljava/util/Enumeration<Ljava/lang/String;>;
            4   14     4     alias  Ljava/lang/String;
            5   14     5     entry  Ljava/lang/Object;
            9   12     6        ke  Lapple/security/KeychainStore$KeyEntry;
    MethodParameters:
      Name  Flags
      cert  

  public void engineStore(java.io.OutputStream, char[]);
    descriptor: (Ljava/io/OutputStream;[C)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=8, args_size=3
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.io.OutputStream stream
        start local 2 // char[] password
         0: .line 656
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 659
            aload 0 /* this */
            getfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            astore 3 /* e */
        start local 3 // java.util.Enumeration e
         2: goto 22
         3: .line 660
      StackMap locals: java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* alias */
        start local 4 // java.lang.String alias
         4: .line 661
            aload 0 /* this */
            getfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
            aload 4 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 5 /* entry */
        start local 5 // java.lang.Object entry
         5: .line 662
            aload 5 /* entry */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 10
         6: .line 663
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.certRef:J
            lconst_0
            lcmp
            ifeq 22
         7: .line 664
            aload 0 /* this */
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.certRef:J
            invokevirtual apple.security.KeychainStore._removeItemFromKeychain:(J)I
            pop
         8: .line 665
            aload 0 /* this */
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.certRef:J
            invokevirtual apple.security.KeychainStore._releaseKeychainItemRef:(J)V
         9: .line 667
            goto 22
        10: .line 669
      StackMap locals: java.lang.String java.lang.Object
      StackMap stack:
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            astore 6 /* keyEntry */
        start local 6 // apple.security.KeychainStore$KeyEntry keyEntry
        11: .line 671
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 22
        12: .line 672
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        13: goto 18
        14: .line 673
      StackMap locals: apple.security.KeychainStore$KeyEntry int
      StackMap stack:
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
            iload 7 /* i */
            laload
            lconst_0
            lcmp
            ifeq 17
        15: .line 674
            aload 0 /* this */
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
            iload 7 /* i */
            laload
            invokevirtual apple.security.KeychainStore._removeItemFromKeychain:(J)I
            pop
        16: .line 675
            aload 0 /* this */
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
            iload 7 /* i */
            laload
            invokevirtual apple.security.KeychainStore._releaseKeychainItemRef:(J)V
        17: .line 672
      StackMap locals:
      StackMap stack:
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 7 /* i */
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            if_icmplt 14
        end local 7 // int i
        19: .line 679
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.keyRef:J
            lconst_0
            lcmp
            ifeq 22
        20: .line 680
            aload 0 /* this */
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.keyRef:J
            invokevirtual apple.security.KeychainStore._removeItemFromKeychain:(J)I
            pop
        21: .line 681
            aload 0 /* this */
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.keyRef:J
            invokevirtual apple.security.KeychainStore._releaseKeychainItemRef:(J)V
        end local 6 // apple.security.KeychainStore$KeyEntry keyEntry
        end local 5 // java.lang.Object entry
        end local 4 // java.lang.String alias
        22: .line 659
      StackMap locals: apple.security.KeychainStore java.io.OutputStream char[] java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        end local 3 // java.util.Enumeration e
        23: .line 689
            aload 0 /* this */
            getfield apple.security.KeychainStore.addedEntries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            astore 3 /* e */
        start local 3 // java.util.Enumeration e
        24: goto 40
        25: .line 690
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* alias */
        start local 4 // java.lang.String alias
        26: .line 691
            aload 0 /* this */
            getfield apple.security.KeychainStore.addedEntries:Ljava/util/Hashtable;
            aload 4 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 5 /* entry */
        start local 5 // java.lang.Object entry
        27: .line 692
            aload 5 /* entry */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 32
        28: .line 693
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            astore 6 /* tce */
        start local 6 // apple.security.KeychainStore$TrustedCertEntry tce
        29: .line 695
            aload 6 /* tce */
            getfield apple.security.KeychainStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            astore 7 /* certElem */
        start local 7 // java.security.cert.Certificate certElem
        30: .line 696
            aload 6 /* tce */
            aload 0 /* this */
            aload 4 /* alias */
            aload 7 /* certElem */
            invokevirtual apple.security.KeychainStore.addCertificateToKeychain:(Ljava/lang/String;Ljava/security/cert/Certificate;)J
            putfield apple.security.KeychainStore$TrustedCertEntry.certRef:J
        end local 7 // java.security.cert.Certificate certElem
        end local 6 // apple.security.KeychainStore$TrustedCertEntry tce
        31: .line 697
            goto 40
        32: .line 698
      StackMap locals: java.lang.String java.lang.Object
      StackMap stack:
            aload 5 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            astore 6 /* keyEntry */
        start local 6 // apple.security.KeychainStore$KeyEntry keyEntry
        33: .line 700
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 40
        34: .line 701
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        35: goto 38
        36: .line 702
      StackMap locals: apple.security.KeychainStore$KeyEntry int
      StackMap stack:
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
            iload 7 /* i */
            aload 0 /* this */
            aload 4 /* alias */
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            iload 7 /* i */
            aaload
            invokevirtual apple.security.KeychainStore.addCertificateToKeychain:(Ljava/lang/String;Ljava/security/cert/Certificate;)J
            lastore
        37: .line 701
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        38: iload 7 /* i */
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            if_icmplt 36
        end local 7 // int i
        39: .line 705
            aload 6 /* keyEntry */
            aload 0 /* this */
            aload 4 /* alias */
            iconst_0
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.protectedPrivKey:[B
            aload 6 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.password:[C
            invokevirtual apple.security.KeychainStore._addItemToKeychain:(Ljava/lang/String;Z[B[C)J
            putfield apple.security.KeychainStore$KeyEntry.keyRef:J
        end local 6 // apple.security.KeychainStore$KeyEntry keyEntry
        end local 5 // java.lang.Object entry
        end local 4 // java.lang.String alias
        40: .line 689
      StackMap locals: apple.security.KeychainStore java.io.OutputStream char[] java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 25
        end local 3 // java.util.Enumeration e
        41: .line 712
            aload 0 /* this */
            getfield apple.security.KeychainStore.deletedEntries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.clear:()V
        42: .line 713
            aload 0 /* this */
            getfield apple.security.KeychainStore.addedEntries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.clear:()V
        43: .line 714
            return
        end local 2 // char[] password
        end local 1 // java.io.OutputStream stream
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   44     0      this  Lapple/security/KeychainStore;
            0   44     1    stream  Ljava/io/OutputStream;
            0   44     2  password  [C
            2   23     3         e  Ljava/util/Enumeration<Ljava/lang/String;>;
            4   22     4     alias  Ljava/lang/String;
            5   22     5     entry  Ljava/lang/Object;
           11   22     6  keyEntry  Lapple/security/KeychainStore$KeyEntry;
           13   19     7         i  I
           24   41     3         e  Ljava/util/Enumeration<Ljava/lang/String;>;
           26   40     4     alias  Ljava/lang/String;
           27   40     5     entry  Ljava/lang/Object;
           29   31     6       tce  Lapple/security/KeychainStore$TrustedCertEntry;
           30   31     7  certElem  Ljava/security/cert/Certificate;
           33   40     6  keyEntry  Lapple/security/KeychainStore$KeyEntry;
           35   39     7         i  I
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  private long addCertificateToKeychain(java.lang.String, java.security.cert.Certificate);
    descriptor: (Ljava/lang/String;Ljava/security/cert/Certificate;)J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.cert.Certificate cert
         0: .line 717
            aconst_null
            astore 3 /* certblob */
        start local 3 // byte[] certblob
         1: .line 718
            lconst_0
            lstore 4 /* returnValue */
        start local 4 // long returnValue
         2: .line 721
            aload 2 /* cert */
            invokevirtual java.security.cert.Certificate.getEncoded:()[B
            astore 3 /* certblob */
         3: .line 722
            aload 0 /* this */
            aload 1 /* alias */
            iconst_1
            aload 3 /* certblob */
            aconst_null
            invokevirtual apple.security.KeychainStore._addItemToKeychain:(Ljava/lang/String;Z[B[C)J
            lstore 4 /* returnValue */
         4: .line 723
            goto 7
      StackMap locals: apple.security.KeychainStore java.lang.String java.security.cert.Certificate byte[] long
      StackMap stack: java.lang.Exception
         5: astore 6 /* e */
        start local 6 // java.lang.Exception e
         6: .line 724
            aload 6 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        end local 6 // java.lang.Exception e
         7: .line 727
      StackMap locals:
      StackMap stack:
            lload 4 /* returnValue */
            lreturn
        end local 4 // long returnValue
        end local 3 // byte[] certblob
        end local 2 // java.security.cert.Certificate cert
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0         this  Lapple/security/KeychainStore;
            0    8     1        alias  Ljava/lang/String;
            0    8     2         cert  Ljava/security/cert/Certificate;
            1    8     3     certblob  [B
            2    8     4  returnValue  J
            6    7     6            e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     4       5  Class java.lang.Exception
    MethodParameters:
       Name  Flags
      alias  
      cert   

  private native long _addItemToKeychain(java.lang.String, boolean, byte[], char[]);
    descriptor: (Ljava/lang/String;Z[B[C)J
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    MethodParameters:
               Name  Flags
      alias          
      isCertificate  
      datablob       
      password       

  private native int _removeItemFromKeychain(long);
    descriptor: (J)I
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    MethodParameters:
         Name  Flags
      certRef  

  private native void _releaseKeychainItemRef(long);
    descriptor: (J)V
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    MethodParameters:
                 Name  Flags
      keychainItemRef  

  public void engineLoad(java.io.InputStream, char[]);
    descriptor: (Ljava/io/InputStream;[C)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=9, args_size=3
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.io.InputStream stream
        start local 2 // char[] password
         0: .line 751
            invokestatic apple.security.KeychainStore.permissionCheck:()V
         1: .line 754
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            dup
            astore 3
            monitorenter
         2: .line 755
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            astore 4 /* e */
        start local 4 // java.util.Enumeration e
         3: goto 20
         4: .line 756
      StackMap locals: java.util.Hashtable java.util.Enumeration
      StackMap stack:
            aload 4 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* alias */
        start local 5 // java.lang.String alias
         5: .line 757
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 5 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 6 /* entry */
        start local 6 // java.lang.Object entry
         6: .line 758
            aload 6 /* entry */
            instanceof apple.security.KeychainStore$TrustedCertEntry
            ifeq 10
         7: .line 759
            aload 6 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.certRef:J
            lconst_0
            lcmp
            ifeq 20
         8: .line 760
            aload 0 /* this */
            aload 6 /* entry */
            checkcast apple.security.KeychainStore$TrustedCertEntry
            getfield apple.security.KeychainStore$TrustedCertEntry.certRef:J
            invokevirtual apple.security.KeychainStore._releaseKeychainItemRef:(J)V
         9: .line 762
            goto 20
        10: .line 763
      StackMap locals: java.lang.String java.lang.Object
      StackMap stack:
            aload 6 /* entry */
            checkcast apple.security.KeychainStore$KeyEntry
            astore 7 /* keyEntry */
        start local 7 // apple.security.KeychainStore$KeyEntry keyEntry
        11: .line 765
            aload 7 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 20
        12: .line 766
            iconst_0
            istore 8 /* i */
        start local 8 // int i
        13: goto 17
        14: .line 767
      StackMap locals: apple.security.KeychainStore$KeyEntry int
      StackMap stack:
            aload 7 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
            iload 8 /* i */
            laload
            lconst_0
            lcmp
            ifeq 16
        15: .line 768
            aload 0 /* this */
            aload 7 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
            iload 8 /* i */
            laload
            invokevirtual apple.security.KeychainStore._releaseKeychainItemRef:(J)V
        16: .line 766
      StackMap locals:
      StackMap stack:
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        17: iload 8 /* i */
            aload 7 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            if_icmplt 14
        end local 8 // int i
        18: .line 772
            aload 7 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.keyRef:J
            lconst_0
            lcmp
            ifeq 20
        19: .line 773
            aload 0 /* this */
            aload 7 /* keyEntry */
            getfield apple.security.KeychainStore$KeyEntry.keyRef:J
            invokevirtual apple.security.KeychainStore._releaseKeychainItemRef:(J)V
        end local 7 // apple.security.KeychainStore$KeyEntry keyEntry
        end local 6 // java.lang.Object entry
        end local 5 // java.lang.String alias
        20: .line 755
      StackMap locals: apple.security.KeychainStore java.io.InputStream char[] java.util.Hashtable java.util.Enumeration
      StackMap stack:
            aload 4 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 4
        end local 4 // java.util.Enumeration e
        21: .line 779
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.clear:()V
        22: .line 780
            aload 0 /* this */
            invokevirtual apple.security.KeychainStore._scanKeychain:()V
        23: .line 781
            getstatic apple.security.KeychainStore.debug:Lsun/security/util/Debug;
            ifnull 27
        24: .line 782
            getstatic apple.security.KeychainStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "KeychainStore load entry count: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        25: .line 783
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        26: .line 782
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        27: .line 754
      StackMap locals:
      StackMap stack:
            aload 3
            monitorexit
        28: goto 31
      StackMap locals:
      StackMap stack: java.lang.Throwable
        29: aload 3
            monitorexit
        30: athrow
        31: .line 786
      StackMap locals:
      StackMap stack:
            return
        end local 2 // char[] password
        end local 1 // java.io.InputStream stream
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   32     0      this  Lapple/security/KeychainStore;
            0   32     1    stream  Ljava/io/InputStream;
            0   32     2  password  [C
            3   21     4         e  Ljava/util/Enumeration<Ljava/lang/String;>;
            5   20     5     alias  Ljava/lang/String;
            6   20     6     entry  Ljava/lang/Object;
           11   20     7  keyEntry  Lapple/security/KeychainStore$KeyEntry;
           13   18     8         i  I
      Exception table:
        from    to  target  type
           2    28      29  any
          29    30      29  any
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  private native void _scanKeychain();
    descriptor: ()V
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE

  private void createTrustedCertEntry(java.lang.String, long, long, byte[]);
    descriptor: (Ljava/lang/String;JJ[B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=13, args_size=5
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
        start local 2 // long keychainItemRef
        start local 4 // long creationDate
        start local 6 // byte[] derStream
         0: .line 794
            new apple.security.KeychainStore$TrustedCertEntry
            dup
            aload 0 /* this */
            invokespecial apple.security.KeychainStore$TrustedCertEntry.<init>:(Lapple/security/KeychainStore;)V
            astore 7 /* tce */
        start local 7 // apple.security.KeychainStore$TrustedCertEntry tce
         1: .line 797
            ldc "X.509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 8 /* cf */
        start local 8 // java.security.cert.CertificateFactory cf
         2: .line 798
            new java.io.ByteArrayInputStream
            dup
            aload 6 /* derStream */
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 9 /* input */
        start local 9 // java.io.InputStream input
         3: .line 799
            aload 8 /* cf */
            aload 9 /* input */
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
            astore 10 /* cert */
        start local 10 // java.security.cert.X509Certificate cert
         4: .line 800
            aload 9 /* input */
            invokevirtual java.io.InputStream.close:()V
         5: .line 801
            aload 7 /* tce */
            aload 10 /* cert */
            putfield apple.security.KeychainStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
         6: .line 802
            aload 7 /* tce */
            lload 2 /* keychainItemRef */
            putfield apple.security.KeychainStore$TrustedCertEntry.certRef:J
         7: .line 805
            lload 4 /* creationDate */
            lconst_0
            lcmp
            ifeq 9
         8: .line 806
            aload 7 /* tce */
            new java.util.Date
            dup
            lload 4 /* creationDate */
            invokespecial java.util.Date.<init>:(J)V
            putfield apple.security.KeychainStore$TrustedCertEntry.date:Ljava/util/Date;
            goto 10
         9: .line 808
      StackMap locals: apple.security.KeychainStore java.lang.String long long byte[] apple.security.KeychainStore$TrustedCertEntry java.security.cert.CertificateFactory java.io.InputStream java.security.cert.X509Certificate
      StackMap stack:
            aload 7 /* tce */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield apple.security.KeychainStore$TrustedCertEntry.date:Ljava/util/Date;
        10: .line 810
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 11 /* uniqueVal */
        start local 11 // int uniqueVal
        11: .line 811
            aload 1 /* alias */
            astore 12 /* originalAlias */
        start local 12 // java.lang.String originalAlias
        12: .line 813
            goto 15
        13: .line 814
      StackMap locals: int java.lang.String
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 12 /* originalAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 11 /* uniqueVal */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 1 /* alias */
        14: .line 815
            iinc 11 /* uniqueVal */ 1
        15: .line 813
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.containsKey:(Ljava/lang/Object;)Z
            ifne 13
        16: .line 818
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            aload 7 /* tce */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 12 // java.lang.String originalAlias
        end local 11 // int uniqueVal
        end local 10 // java.security.cert.X509Certificate cert
        end local 9 // java.io.InputStream input
        end local 8 // java.security.cert.CertificateFactory cf
        17: .line 819
            goto 20
      StackMap locals: apple.security.KeychainStore java.lang.String long long byte[] apple.security.KeychainStore$TrustedCertEntry
      StackMap stack: java.lang.Exception
        18: astore 8 /* e */
        start local 8 // java.lang.Exception e
        19: .line 821
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "KeychainStore Ignored Exception: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 8 // java.lang.Exception e
        20: .line 823
      StackMap locals:
      StackMap stack:
            return
        end local 7 // apple.security.KeychainStore$TrustedCertEntry tce
        end local 6 // byte[] derStream
        end local 4 // long creationDate
        end local 2 // long keychainItemRef
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   21     0             this  Lapple/security/KeychainStore;
            0   21     1            alias  Ljava/lang/String;
            0   21     2  keychainItemRef  J
            0   21     4     creationDate  J
            0   21     6        derStream  [B
            1   21     7              tce  Lapple/security/KeychainStore$TrustedCertEntry;
            2   17     8               cf  Ljava/security/cert/CertificateFactory;
            3   17     9            input  Ljava/io/InputStream;
            4   17    10             cert  Ljava/security/cert/X509Certificate;
           11   17    11        uniqueVal  I
           12   17    12    originalAlias  Ljava/lang/String;
           19   20     8                e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    17      18  Class java.lang.Exception
    MethodParameters:
                 Name  Flags
      alias            
      keychainItemRef  
      creationDate     
      derStream        

  private void createKeyEntry(java.lang.String, long, long, long[], byte[][]);
    descriptor: (Ljava/lang/String;JJ[J[[B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=15, args_size=6
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String alias
        start local 2 // long creationDate
        start local 4 // long secKeyRef
        start local 6 // long[] secCertificateRefs
        start local 7 // byte[][] rawCertData
         0: .line 831
            new apple.security.KeychainStore$KeyEntry
            dup
            aload 0 /* this */
            invokespecial apple.security.KeychainStore$KeyEntry.<init>:(Lapple/security/KeychainStore;)V
            astore 8 /* ke */
        start local 8 // apple.security.KeychainStore$KeyEntry ke
         1: .line 834
            aload 8 /* ke */
            aconst_null
            putfield apple.security.KeychainStore$KeyEntry.protectedPrivKey:[B
         2: .line 835
            aload 8 /* ke */
            lload 4 /* secKeyRef */
            putfield apple.security.KeychainStore$KeyEntry.keyRef:J
         3: .line 838
            lload 2 /* creationDate */
            lconst_0
            lcmp
            ifeq 5
         4: .line 839
            aload 8 /* ke */
            new java.util.Date
            dup
            lload 2 /* creationDate */
            invokespecial java.util.Date.<init>:(J)V
            putfield apple.security.KeychainStore$KeyEntry.date:Ljava/util/Date;
            goto 6
         5: .line 841
      StackMap locals: apple.security.KeychainStore$KeyEntry
      StackMap stack:
            aload 8 /* ke */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield apple.security.KeychainStore$KeyEntry.date:Ljava/util/Date;
         6: .line 845
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 9 /* createdCerts */
        start local 9 // java.util.List createdCerts
         7: .line 848
            ldc "X.509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 10 /* cf */
        start local 10 // java.security.cert.CertificateFactory cf
         8: .line 850
            iconst_0
            istore 11 /* i */
        start local 11 // int i
         9: goto 18
        10: .line 852
      StackMap locals: java.util.List java.security.cert.CertificateFactory int
      StackMap stack:
            new java.io.ByteArrayInputStream
            dup
            aload 7 /* rawCertData */
            iload 11 /* i */
            aaload
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 12 /* input */
        start local 12 // java.io.InputStream input
        11: .line 853
            aload 10 /* cf */
            aload 12 /* input */
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
            astore 13 /* cert */
        start local 13 // java.security.cert.X509Certificate cert
        12: .line 854
            aload 12 /* input */
            invokevirtual java.io.InputStream.close:()V
        13: .line 857
            aload 9 /* createdCerts */
            new apple.security.KeychainStore$CertKeychainItemPair
            dup
            aload 0 /* this */
            aload 6 /* secCertificateRefs */
            iload 11 /* i */
            laload
            aload 13 /* cert */
            invokespecial apple.security.KeychainStore$CertKeychainItemPair.<init>:(Lapple/security/KeychainStore;JLjava/security/cert/Certificate;)V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 13 // java.security.cert.X509Certificate cert
        end local 12 // java.io.InputStream input
        14: .line 858
            goto 17
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
        15: astore 12 /* e */
        start local 12 // java.security.cert.CertificateException e
        16: .line 860
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "KeychainStore Ignored Exception: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 12 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 12 // java.security.cert.CertificateException e
        17: .line 850
      StackMap locals:
      StackMap stack:
            iinc 11 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 11 /* i */
            aload 7 /* rawCertData */
            arraylength
            if_icmplt 10
        end local 11 // int i
        end local 10 // java.security.cert.CertificateFactory cf
        19: .line 863
            goto 25
      StackMap locals: apple.security.KeychainStore java.lang.String long long long[] byte[][] apple.security.KeychainStore$KeyEntry java.util.List
      StackMap stack: java.security.cert.CertificateException
        20: astore 10 /* e */
        start local 10 // java.security.cert.CertificateException e
        21: .line 864
            aload 10 /* e */
            invokevirtual java.security.cert.CertificateException.printStackTrace:()V
        end local 10 // java.security.cert.CertificateException e
        22: goto 25
        23: .line 865
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 10 /* ioe */
        start local 10 // java.io.IOException ioe
        24: .line 866
            aload 10 /* ioe */
            invokevirtual java.io.IOException.printStackTrace:()V
        end local 10 // java.io.IOException ioe
        25: .line 871
      StackMap locals:
      StackMap stack:
            aload 9 /* createdCerts */
            iconst_0
            anewarray apple.security.KeychainStore$CertKeychainItemPair
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast apple.security.KeychainStore$CertKeychainItemPair[]
            astore 10 /* objArray */
        start local 10 // apple.security.KeychainStore$CertKeychainItemPair[] objArray
        26: .line 872
            aload 10 /* objArray */
            arraylength
            anewarray java.security.cert.Certificate
            astore 11 /* certArray */
        start local 11 // java.security.cert.Certificate[] certArray
        27: .line 873
            aload 10 /* objArray */
            arraylength
            newarray 11
            astore 12 /* certRefArray */
        start local 12 // long[] certRefArray
        28: .line 875
            iconst_0
            istore 13 /* i */
        start local 13 // int i
        29: goto 34
        30: .line 876
      StackMap locals: apple.security.KeychainStore java.lang.String long long long[] byte[][] apple.security.KeychainStore$KeyEntry java.util.List apple.security.KeychainStore$CertKeychainItemPair[] java.security.cert.Certificate[] long[] int
      StackMap stack:
            aload 10 /* objArray */
            iload 13 /* i */
            aaload
            astore 14 /* addedItem */
        start local 14 // apple.security.KeychainStore$CertKeychainItemPair addedItem
        31: .line 877
            aload 11 /* certArray */
            iload 13 /* i */
            aload 14 /* addedItem */
            getfield apple.security.KeychainStore$CertKeychainItemPair.mCert:Ljava/security/cert/Certificate;
            aastore
        32: .line 878
            aload 12 /* certRefArray */
            iload 13 /* i */
            aload 14 /* addedItem */
            getfield apple.security.KeychainStore$CertKeychainItemPair.mCertificateRef:J
            lastore
        end local 14 // apple.security.KeychainStore$CertKeychainItemPair addedItem
        33: .line 875
            iinc 13 /* i */ 1
      StackMap locals:
      StackMap stack:
        34: iload 13 /* i */
            aload 10 /* objArray */
            arraylength
            if_icmplt 30
        end local 13 // int i
        35: .line 881
            aload 8 /* ke */
            aload 11 /* certArray */
            putfield apple.security.KeychainStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        36: .line 882
            aload 8 /* ke */
            aload 12 /* certRefArray */
            putfield apple.security.KeychainStore$KeyEntry.chainRefs:[J
        37: .line 886
            iconst_1
            istore 13 /* uniqueVal */
        start local 13 // int uniqueVal
        38: .line 887
            aload 1 /* alias */
            astore 14 /* originalAlias */
        start local 14 // java.lang.String originalAlias
        39: .line 889
            goto 42
        40: .line 890
      StackMap locals: java.lang.String
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 14 /* originalAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 13 /* uniqueVal */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 1 /* alias */
        41: .line 891
            iinc 13 /* uniqueVal */ 1
        42: .line 889
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            invokevirtual java.util.Hashtable.containsKey:(Ljava/lang/Object;)Z
            ifne 40
        43: .line 894
            aload 0 /* this */
            getfield apple.security.KeychainStore.entries:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            aload 8 /* ke */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        44: .line 895
            return
        end local 14 // java.lang.String originalAlias
        end local 13 // int uniqueVal
        end local 12 // long[] certRefArray
        end local 11 // java.security.cert.Certificate[] certArray
        end local 10 // apple.security.KeychainStore$CertKeychainItemPair[] objArray
        end local 9 // java.util.List createdCerts
        end local 8 // apple.security.KeychainStore$KeyEntry ke
        end local 7 // byte[][] rawCertData
        end local 6 // long[] secCertificateRefs
        end local 4 // long secKeyRef
        end local 2 // long creationDate
        end local 1 // java.lang.String alias
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   45     0                this  Lapple/security/KeychainStore;
            0   45     1               alias  Ljava/lang/String;
            0   45     2        creationDate  J
            0   45     4           secKeyRef  J
            0   45     6  secCertificateRefs  [J
            0   45     7         rawCertData  [[B
            1   45     8                  ke  Lapple/security/KeychainStore$KeyEntry;
            7   45     9        createdCerts  Ljava/util/List<Lapple/security/KeychainStore$CertKeychainItemPair;>;
            8   19    10                  cf  Ljava/security/cert/CertificateFactory;
            9   19    11                   i  I
           11   14    12               input  Ljava/io/InputStream;
           12   14    13                cert  Ljava/security/cert/X509Certificate;
           16   17    12                   e  Ljava/security/cert/CertificateException;
           21   22    10                   e  Ljava/security/cert/CertificateException;
           24   25    10                 ioe  Ljava/io/IOException;
           26   45    10            objArray  [Lapple/security/KeychainStore$CertKeychainItemPair;
           27   45    11           certArray  [Ljava/security/cert/Certificate;
           28   45    12        certRefArray  [J
           29   35    13                   i  I
           31   33    14           addedItem  Lapple/security/KeychainStore$CertKeychainItemPair;
           38   45    13           uniqueVal  I
           39   45    14       originalAlias  Ljava/lang/String;
      Exception table:
        from    to  target  type
          10    14      15  Class java.security.cert.CertificateException
           7    19      20  Class java.security.cert.CertificateException
           7    19      23  Class java.io.IOException
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
                    Name  Flags
      alias               
      creationDate        
      secKeyRef           
      secCertificateRefs  
      rawCertData         

  private boolean validateChain(java.security.cert.Certificate[]);
    descriptor: ([Ljava/security/cert/Certificate;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.security.cert.Certificate[] certChain
         0: .line 912
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 9
         2: .line 914
      StackMap locals: int
      StackMap stack:
            aload 1 /* certChain */
            iload 2 /* i */
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
         3: .line 913
            astore 3 /* issuerDN */
        start local 3 // javax.security.auth.x500.X500Principal issuerDN
         4: .line 916
            aload 1 /* certChain */
            iload 2 /* i */
            iconst_1
            iadd
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
         5: .line 915
            astore 4 /* subjectDN */
        start local 4 // javax.security.auth.x500.X500Principal subjectDN
         6: .line 917
            aload 3 /* issuerDN */
            aload 4 /* subjectDN */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 8
         7: .line 918
            iconst_0
            ireturn
        end local 4 // javax.security.auth.x500.X500Principal subjectDN
        end local 3 // javax.security.auth.x500.X500Principal issuerDN
         8: .line 912
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 2 /* i */
            aload 1 /* certChain */
            arraylength
            iconst_1
            isub
            if_icmplt 2
        end local 2 // int i
        10: .line 920
            iconst_1
            ireturn
        end local 1 // java.security.cert.Certificate[] certChain
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lapple/security/KeychainStore;
            0   11     1  certChain  [Ljava/security/cert/Certificate;
            1   10     2          i  I
            4    8     3   issuerDN  Ljavax/security/auth/x500/X500Principal;
            6    8     4  subjectDN  Ljavax/security/auth/x500/X500Principal;
    MethodParameters:
           Name  Flags
      certChain  

  private byte[] fetchPrivateKeyFromBag(byte[]);
    descriptor: ([B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=17, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // byte[] privateKeyInfo
         0: .line 925
            aconst_null
            astore 2 /* returnValue */
        start local 2 // byte[] returnValue
         1: .line 926
            new sun.security.util.DerValue
            dup
            new java.io.ByteArrayInputStream
            dup
            aload 1 /* privateKeyInfo */
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            invokespecial sun.security.util.DerValue.<init>:(Ljava/io/InputStream;)V
            astore 3 /* val */
        start local 3 // sun.security.util.DerValue val
         2: .line 927
            aload 3 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 4 /* s */
        start local 4 // sun.security.util.DerInputStream s
         3: .line 928
            aload 4 /* s */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            istore 5 /* version */
        start local 5 // int version
         4: .line 930
            iload 5 /* version */
            iconst_3
            if_icmpeq 6
         5: .line 931
            new java.io.IOException
            dup
            ldc "PKCS12 keystore not in version 3 format"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 938
      StackMap locals: apple.security.KeychainStore byte[] byte[] sun.security.util.DerValue sun.security.util.DerInputStream int
      StackMap stack:
            new sun.security.pkcs.ContentInfo
            dup
            aload 4 /* s */
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/DerInputStream;)V
            astore 7 /* authSafe */
        start local 7 // sun.security.pkcs.ContentInfo authSafe
         7: .line 939
            aload 7 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* contentType */
        start local 8 // sun.security.util.ObjectIdentifier contentType
         8: .line 941
            aload 8 /* contentType */
            getstatic sun.security.pkcs.ContentInfo.DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 11
         9: .line 942
            aload 7 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            astore 6 /* authSafeData */
        start local 6 // byte[] authSafeData
        10: .line 943
            goto 12
        end local 6 // byte[] authSafeData
        11: .line 944
      StackMap locals: apple.security.KeychainStore byte[] byte[] sun.security.util.DerValue sun.security.util.DerInputStream int top sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier
      StackMap stack:
            new java.io.IOException
            dup
            ldc "public key protected PKCS12 not supported"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 6 // byte[] authSafeData
        12: .line 947
      StackMap locals: apple.security.KeychainStore byte[] byte[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 6 /* authSafeData */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 9 /* as */
        start local 9 // sun.security.util.DerInputStream as
        13: .line 948
            aload 9 /* as */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 10 /* safeContentsArray */
        start local 10 // sun.security.util.DerValue[] safeContentsArray
        14: .line 949
            aload 10 /* safeContentsArray */
            arraylength
            istore 11 /* count */
        start local 11 // int count
        15: .line 954
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        16: goto 30
        17: .line 960
      StackMap locals: apple.security.KeychainStore byte[] byte[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int int
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 10 /* safeContentsArray */
            iload 12 /* i */
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 15 /* sci */
        start local 15 // sun.security.util.DerInputStream sci
        18: .line 961
            new sun.security.pkcs.ContentInfo
            dup
            aload 15 /* sci */
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/DerInputStream;)V
            astore 14 /* safeContents */
        start local 14 // sun.security.pkcs.ContentInfo safeContents
        19: .line 962
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* contentType */
        20: .line 963
            aconst_null
            astore 13 /* safeContentsData */
        start local 13 // byte[] safeContentsData
        21: .line 965
            aload 8 /* contentType */
            getstatic sun.security.pkcs.ContentInfo.DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 24
        22: .line 966
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            astore 13 /* safeContentsData */
        23: .line 967
            goto 27
      StackMap locals: byte[] sun.security.pkcs.ContentInfo sun.security.util.DerInputStream
      StackMap stack:
        24: aload 8 /* contentType */
            getstatic sun.security.pkcs.ContentInfo.ENCRYPTED_DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 26
        25: .line 971
            goto 29
        26: .line 973
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            ldc "public key protected PKCS12 not supported"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 976
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 13 /* safeContentsData */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 16 /* sc */
        start local 16 // sun.security.util.DerInputStream sc
        28: .line 977
            aload 0 /* this */
            aload 16 /* sc */
            invokevirtual apple.security.KeychainStore.extractKeyData:(Lsun/security/util/DerInputStream;)[B
            astore 2 /* returnValue */
        end local 16 // sun.security.util.DerInputStream sc
        end local 15 // sun.security.util.DerInputStream sci
        end local 14 // sun.security.pkcs.ContentInfo safeContents
        end local 13 // byte[] safeContentsData
        29: .line 954
      StackMap locals:
      StackMap stack:
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        30: iload 12 /* i */
            iload 11 /* count */
            if_icmplt 17
        end local 12 // int i
        31: .line 980
            aload 2 /* returnValue */
            areturn
        end local 11 // int count
        end local 10 // sun.security.util.DerValue[] safeContentsArray
        end local 9 // sun.security.util.DerInputStream as
        end local 8 // sun.security.util.ObjectIdentifier contentType
        end local 7 // sun.security.pkcs.ContentInfo authSafe
        end local 6 // byte[] authSafeData
        end local 5 // int version
        end local 4 // sun.security.util.DerInputStream s
        end local 3 // sun.security.util.DerValue val
        end local 2 // byte[] returnValue
        end local 1 // byte[] privateKeyInfo
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   32     0               this  Lapple/security/KeychainStore;
            0   32     1     privateKeyInfo  [B
            1   32     2        returnValue  [B
            2   32     3                val  Lsun/security/util/DerValue;
            3   32     4                  s  Lsun/security/util/DerInputStream;
            4   32     5            version  I
           10   11     6       authSafeData  [B
           12   32     6       authSafeData  [B
            7   32     7           authSafe  Lsun/security/pkcs/ContentInfo;
            8   32     8        contentType  Lsun/security/util/ObjectIdentifier;
           13   32     9                 as  Lsun/security/util/DerInputStream;
           14   32    10  safeContentsArray  [Lsun/security/util/DerValue;
           15   32    11              count  I
           16   31    12                  i  I
           21   29    13   safeContentsData  [B
           19   29    14       safeContents  Lsun/security/pkcs/ContentInfo;
           18   29    15                sci  Lsun/security/util/DerInputStream;
           28   29    16                 sc  Lsun/security/util/DerInputStream;
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
                Name  Flags
      privateKeyInfo  

  private byte[] extractKeyData(sun.security.util.DerInputStream);
    descriptor: (Lsun/security/util/DerInputStream;)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=9, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // sun.security.util.DerInputStream stream
         0: .line 986
            aconst_null
            astore 2 /* returnValue */
        start local 2 // byte[] returnValue
         1: .line 987
            aload 1 /* stream */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 3 /* safeBags */
        start local 3 // sun.security.util.DerValue[] safeBags
         2: .line 988
            aload 3 /* safeBags */
            arraylength
            istore 4 /* count */
        start local 4 // int count
         3: .line 993
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         4: goto 18
         5: .line 999
      StackMap locals: apple.security.KeychainStore sun.security.util.DerInputStream byte[] sun.security.util.DerValue[] int int
      StackMap stack:
            aload 3 /* safeBags */
            iload 5 /* i */
            aaload
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 7 /* sbi */
        start local 7 // sun.security.util.DerInputStream sbi
         6: .line 1000
            aload 7 /* sbi */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 6 /* bagId */
        start local 6 // sun.security.util.ObjectIdentifier bagId
         7: .line 1001
            aload 7 /* sbi */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 8 /* bagValue */
        start local 8 // sun.security.util.DerValue bagValue
         8: .line 1002
            aload 8 /* bagValue */
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 12
         9: .line 1003
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unsupported PKCS12 bag value type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        10: .line 1004
            aload 8 /* bagValue */
            getfield sun.security.util.DerValue.tag:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 1003
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 1006
      StackMap locals: sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue
      StackMap stack:
            aload 8 /* bagValue */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 8 /* bagValue */
        13: .line 1007
            aload 6 /* bagId */
            getstatic apple.security.KeychainStore.PKCS8ShroudedKeyBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 16
        14: .line 1009
            aload 8 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            astore 2 /* returnValue */
        15: .line 1010
            goto 17
        16: .line 1012
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Unsupported bag type '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* bagId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 8 // sun.security.util.DerValue bagValue
        end local 7 // sun.security.util.DerInputStream sbi
        end local 6 // sun.security.util.ObjectIdentifier bagId
        17: .line 993
      StackMap locals:
      StackMap stack:
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 5 /* i */
            iload 4 /* count */
            if_icmplt 5
        end local 5 // int i
        19: .line 1016
            aload 2 /* returnValue */
            areturn
        end local 4 // int count
        end local 3 // sun.security.util.DerValue[] safeBags
        end local 2 // byte[] returnValue
        end local 1 // sun.security.util.DerInputStream stream
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   20     0         this  Lapple/security/KeychainStore;
            0   20     1       stream  Lsun/security/util/DerInputStream;
            1   20     2  returnValue  [B
            2   20     3     safeBags  [Lsun/security/util/DerValue;
            3   20     4        count  I
            4   19     5            i  I
            7   17     6        bagId  Lsun/security/util/ObjectIdentifier;
            6   17     7          sbi  Lsun/security/util/DerInputStream;
            8   17     8     bagValue  Lsun/security/util/DerValue;
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
        Name  Flags
      stream  

  private java.security.AlgorithmParameters getAlgorithmParameters(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/AlgorithmParameters;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // java.lang.String algorithm
         0: .line 1025
            aconst_null
            astore 2 /* algParams */
        start local 2 // java.security.AlgorithmParameters algParams
         1: .line 1029
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 0 /* this */
            invokevirtual apple.security.KeychainStore.getSalt:()[B
            sipush 1024
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
         2: .line 1028
            astore 3 /* paramSpec */
        start local 3 // javax.crypto.spec.PBEParameterSpec paramSpec
         3: .line 1031
            aload 1 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 2 /* algParams */
         4: .line 1032
            aload 2 /* algParams */
            aload 3 /* paramSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         5: .line 1033
            goto 13
      StackMap locals: apple.security.KeychainStore java.lang.String java.security.AlgorithmParameters javax.crypto.spec.PBEParameterSpec
      StackMap stack: java.lang.Exception
         6: astore 4 /* e */
        start local 4 // java.lang.Exception e
         7: .line 1035
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getAlgorithmParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 1036
            aload 4 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 1035
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
        10: .line 1034
            astore 5 /* ioe */
        start local 5 // java.io.IOException ioe
        11: .line 1037
            aload 5 /* ioe */
            aload 4 /* e */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        12: .line 1038
            aload 5 /* ioe */
            athrow
        end local 5 // java.io.IOException ioe
        end local 4 // java.lang.Exception e
        13: .line 1040
      StackMap locals:
      StackMap stack:
            aload 2 /* algParams */
            areturn
        end local 3 // javax.crypto.spec.PBEParameterSpec paramSpec
        end local 2 // java.security.AlgorithmParameters algParams
        end local 1 // java.lang.String algorithm
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   14     0       this  Lapple/security/KeychainStore;
            0   14     1  algorithm  Ljava/lang/String;
            1   14     2  algParams  Ljava/security/AlgorithmParameters;
            3   14     3  paramSpec  Ljavax/crypto/spec/PBEParameterSpec;
            7   13     4          e  Ljava/lang/Exception;
           11   13     5        ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           3     5       6  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
           Name  Flags
      algorithm  

  private byte[] getSalt();
    descriptor: ()[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // apple.security.KeychainStore this
         0: .line 1052
            bipush 20
            newarray 8
            astore 1 /* salt */
        start local 1 // byte[] salt
         1: .line 1053
            aload 0 /* this */
            getfield apple.security.KeychainStore.random:Ljava/security/SecureRandom;
            ifnonnull 3
         2: .line 1054
            aload 0 /* this */
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            putfield apple.security.KeychainStore.random:Ljava/security/SecureRandom;
         3: .line 1056
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield apple.security.KeychainStore.random:Ljava/security/SecureRandom;
            bipush 20
            invokevirtual java.security.SecureRandom.generateSeed:(I)[B
            astore 1 /* salt */
         4: .line 1057
            aload 1 /* salt */
            areturn
        end local 1 // byte[] salt
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lapple/security/KeychainStore;
            1    5     1  salt  [B

  private java.security.AlgorithmParameters parseAlgParameters(sun.security.util.DerInputStream);
    descriptor: (Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // sun.security.util.DerInputStream in
         0: .line 1066
            aconst_null
            astore 2 /* algParams */
        start local 2 // java.security.AlgorithmParameters algParams
         1: .line 1069
            aload 1 /* in */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifne 4
         2: .line 1070
            aconst_null
            astore 3 /* params */
        start local 3 // sun.security.util.DerValue params
         3: .line 1071
            goto 7
        end local 3 // sun.security.util.DerValue params
         4: .line 1072
      StackMap locals: java.security.AlgorithmParameters
      StackMap stack:
            aload 1 /* in */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* params */
        start local 3 // sun.security.util.DerValue params
         5: .line 1073
            aload 3 /* params */
            getfield sun.security.util.DerValue.tag:B
            iconst_5
            if_icmpne 7
         6: .line 1074
            aconst_null
            astore 3 /* params */
         7: .line 1077
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 3 /* params */
            ifnull 18
         8: .line 1078
            ldc "PBE"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 2 /* algParams */
         9: .line 1079
            aload 2 /* algParams */
            aload 3 /* params */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokevirtual java.security.AlgorithmParameters.init:([B)V
        end local 3 // sun.security.util.DerValue params
        10: .line 1081
            goto 18
      StackMap locals: apple.security.KeychainStore sun.security.util.DerInputStream java.security.AlgorithmParameters
      StackMap stack: java.lang.Exception
        11: astore 3 /* e */
        start local 3 // java.lang.Exception e
        12: .line 1083
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "parseAlgParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        13: .line 1084
            aload 3 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 1083
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
        15: .line 1082
            astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
        16: .line 1085
            aload 4 /* ioe */
            aload 3 /* e */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        17: .line 1086
            aload 4 /* ioe */
            athrow
        end local 4 // java.io.IOException ioe
        end local 3 // java.lang.Exception e
        18: .line 1088
      StackMap locals:
      StackMap stack:
            aload 2 /* algParams */
            areturn
        end local 2 // java.security.AlgorithmParameters algParams
        end local 1 // sun.security.util.DerInputStream in
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   19     0       this  Lapple/security/KeychainStore;
            0   19     1         in  Lsun/security/util/DerInputStream;
            1   19     2  algParams  Ljava/security/AlgorithmParameters;
            3    4     3     params  Lsun/security/util/DerValue;
            5   10     3     params  Lsun/security/util/DerValue;
           12   18     3          e  Ljava/lang/Exception;
           16   18     4        ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1    10      11  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      in    

  private javax.crypto.SecretKey getPBEKey(char[]);
    descriptor: ([C)Ljavax/crypto/SecretKey;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // apple.security.KeychainStore this
        start local 1 // char[] password
         0: .line 1096
            aconst_null
            astore 2 /* skey */
        start local 2 // javax.crypto.SecretKey skey
         1: .line 1099
            new javax.crypto.spec.PBEKeySpec
            dup
            aload 1 /* password */
            invokespecial javax.crypto.spec.PBEKeySpec.<init>:([C)V
            astore 3 /* keySpec */
        start local 3 // javax.crypto.spec.PBEKeySpec keySpec
         2: .line 1100
            ldc "PBE"
            invokestatic javax.crypto.SecretKeyFactory.getInstance:(Ljava/lang/String;)Ljavax/crypto/SecretKeyFactory;
            astore 4 /* skFac */
        start local 4 // javax.crypto.SecretKeyFactory skFac
         3: .line 1101
            aload 4 /* skFac */
            aload 3 /* keySpec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            astore 2 /* skey */
        end local 4 // javax.crypto.SecretKeyFactory skFac
        end local 3 // javax.crypto.spec.PBEKeySpec keySpec
         4: .line 1102
            goto 11
      StackMap locals: apple.security.KeychainStore char[] javax.crypto.SecretKey
      StackMap stack: java.lang.Exception
         5: astore 3 /* e */
        start local 3 // java.lang.Exception e
         6: .line 1103
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getSecretKey failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         7: .line 1104
            aload 3 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 1103
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
         9: .line 1105
            aload 4 /* ioe */
            aload 3 /* e */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        10: .line 1106
            aload 4 /* ioe */
            athrow
        end local 4 // java.io.IOException ioe
        end local 3 // java.lang.Exception e
        11: .line 1108
      StackMap locals:
      StackMap stack:
            aload 2 /* skey */
            areturn
        end local 2 // javax.crypto.SecretKey skey
        end local 1 // char[] password
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   12     0      this  Lapple/security/KeychainStore;
            0   12     1  password  [C
            1   12     2      skey  Ljavax/crypto/SecretKey;
            2    4     3   keySpec  Ljavax/crypto/spec/PBEKeySpec;
            3    4     4     skFac  Ljavax/crypto/SecretKeyFactory;
            6   11     3         e  Ljava/lang/Exception;
            9   11     4       ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     4       5  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
          Name  Flags
      password  

  private byte[] encryptPrivateKey(byte[], char[]);
    descriptor: ([B[C)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=10, args_size=3
        start local 0 // apple.security.KeychainStore this
        start local 1 // byte[] data
        start local 2 // char[] password
         0: .line 1123
            aconst_null
            astore 3 /* key */
        start local 3 // byte[] key
         1: .line 1128
            aload 0 /* this */
            ldc "PBEWithSHA1AndDESede"
            invokevirtual apple.security.KeychainStore.getAlgorithmParameters:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
         2: .line 1127
            astore 4 /* algParams */
        start local 4 // java.security.AlgorithmParameters algParams
         3: .line 1131
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual apple.security.KeychainStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 5 /* skey */
        start local 5 // javax.crypto.SecretKey skey
         4: .line 1132
            ldc "PBEWithSHA1AndDESede"
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 6 /* cipher */
        start local 6 // javax.crypto.Cipher cipher
         5: .line 1133
            aload 6 /* cipher */
            iconst_1
            aload 5 /* skey */
            aload 4 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
         6: .line 1134
            aload 6 /* cipher */
            aload 1 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 7 /* encryptedKey */
        start local 7 // byte[] encryptedKey
         7: .line 1139
            new sun.security.x509.AlgorithmId
            dup
            getstatic apple.security.KeychainStore.pbeWithSHAAnd3KeyTripleDESCBC_OID:Lsun/security/util/ObjectIdentifier;
            aload 4 /* algParams */
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)V
         8: .line 1138
            astore 8 /* algid */
        start local 8 // sun.security.x509.AlgorithmId algid
         9: .line 1141
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 8 /* algid */
            aload 7 /* encryptedKey */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:(Lsun/security/x509/AlgorithmId;[B)V
        10: .line 1140
            astore 9 /* encrInfo */
        start local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        11: .line 1142
            aload 9 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncoded:()[B
            astore 3 /* key */
        end local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        end local 8 // sun.security.x509.AlgorithmId algid
        end local 7 // byte[] encryptedKey
        end local 6 // javax.crypto.Cipher cipher
        end local 5 // javax.crypto.SecretKey skey
        end local 4 // java.security.AlgorithmParameters algParams
        12: .line 1143
            goto 20
      StackMap locals: apple.security.KeychainStore byte[] char[] byte[]
      StackMap stack: java.lang.Exception
        13: astore 4 /* e */
        start local 4 // java.lang.Exception e
        14: .line 1145
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Encrypt Private Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        15: .line 1146
            aload 4 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 1145
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        17: .line 1144
            astore 5 /* uke */
        start local 5 // java.security.UnrecoverableKeyException uke
        18: .line 1147
            aload 5 /* uke */
            aload 4 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        19: .line 1148
            aload 5 /* uke */
            athrow
        end local 5 // java.security.UnrecoverableKeyException uke
        end local 4 // java.lang.Exception e
        20: .line 1151
      StackMap locals:
      StackMap stack:
            aload 3 /* key */
            areturn
        end local 3 // byte[] key
        end local 2 // char[] password
        end local 1 // byte[] data
        end local 0 // apple.security.KeychainStore this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   21     0          this  Lapple/security/KeychainStore;
            0   21     1          data  [B
            0   21     2      password  [C
            1   21     3           key  [B
            3   12     4     algParams  Ljava/security/AlgorithmParameters;
            4   12     5          skey  Ljavax/crypto/SecretKey;
            5   12     6        cipher  Ljavax/crypto/Cipher;
            7   12     7  encryptedKey  [B
            9   12     8         algid  Lsun/security/x509/AlgorithmId;
           11   12     9      encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           14   20     4             e  Ljava/lang/Exception;
           18   20     5           uke  Ljava/security/UnrecoverableKeyException;
      Exception table:
        from    to  target  type
           1    12      13  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
          Name  Flags
      data      
      password  
}
SourceFile: "KeychainStore.java"
NestMembers:
  apple.security.KeychainStore$1  apple.security.KeychainStore$CertKeychainItemPair  apple.security.KeychainStore$KeyEntry  apple.security.KeychainStore$TrustedCertEntry
InnerClasses:
  apple.security.KeychainStore$1
  private CertKeychainItemPair = apple.security.KeychainStore$CertKeychainItemPair of apple.security.KeychainStore
  KeyEntry = apple.security.KeychainStore$KeyEntry of apple.security.KeychainStore
  TrustedCertEntry = apple.security.KeychainStore$TrustedCertEntry of apple.security.KeychainStore