public abstract class java.security.KeyStoreSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: java.security.KeyStoreSpi
  super_class: java.lang.Object
{
  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.KeyStoreSpi this
         0: .line 54
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/KeyStoreSpi;

  public abstract java.security.Key engineGetKey(java.lang.String, char[]);
    descriptor: (Ljava/lang/String;[C)Ljava/security/Key;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
          Name  Flags
      alias     
      password  

  public abstract java.security.cert.Certificate[] engineGetCertificateChain(java.lang.String);
    descriptor: (Ljava/lang/String;)[Ljava/security/cert/Certificate;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      alias  

  public abstract java.security.cert.Certificate engineGetCertificate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/cert/Certificate;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      alias  

  public abstract java.util.Date engineGetCreationDate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/Date;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      alias  

  public abstract 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: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
          Name  Flags
      alias     
      key       
      password  
      chain     

  public abstract void engineSetKeyEntry(java.lang.String, byte[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;[B[Ljava/security/cert/Certificate;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      key    
      chain  

  public abstract void engineSetCertificateEntry(java.lang.String, java.security.cert.Certificate);
    descriptor: (Ljava/lang/String;Ljava/security/cert/Certificate;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      cert   

  public abstract void engineDeleteEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  

  public abstract java.util.Enumeration<java.lang.String> engineAliases();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Signature: ()Ljava/util/Enumeration<Ljava/lang/String;>;

  public abstract boolean engineContainsAlias(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      alias  

  public abstract int engineSize();
    descriptor: ()I
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract boolean engineIsKeyEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      alias  

  public abstract boolean engineIsCertificateEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      alias  

  public abstract java.lang.String engineGetCertificateAlias(java.security.cert.Certificate);
    descriptor: (Ljava/security/cert/Certificate;)Ljava/lang/String;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
      Name  Flags
      cert  

  public abstract void engineStore(java.io.OutputStream, char[]);
    descriptor: (Ljava/io/OutputStream;[C)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  public void engineStore(java.security.KeyStore$LoadStoreParameter);
    descriptor: (Ljava/security/KeyStore$LoadStoreParameter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.security.KeyStoreSpi this
        start local 1 // java.security.KeyStore$LoadStoreParameter param
         0: .line 320
            new java.lang.UnsupportedOperationException
            dup
            invokespecial java.lang.UnsupportedOperationException.<init>:()V
            athrow
        end local 1 // java.security.KeyStore$LoadStoreParameter param
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Ljava/security/KeyStoreSpi;
            0    1     1  param  Ljava/security/KeyStore$LoadStoreParameter;
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
       Name  Flags
      param  

  public abstract void engineLoad(java.io.InputStream, char[]);
    descriptor: (Ljava/io/InputStream;[C)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  public void engineLoad(java.security.KeyStore$LoadStoreParameter);
    descriptor: (Ljava/security/KeyStore$LoadStoreParameter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.security.KeyStoreSpi this
        start local 1 // java.security.KeyStore$LoadStoreParameter param
         0: .line 398
            aload 0 /* this */
            aconst_null
            aload 1 /* param */
            invokevirtual java.security.KeyStoreSpi.engineLoad:(Ljava/io/InputStream;Ljava/security/KeyStore$LoadStoreParameter;)V
         1: .line 399
            return
        end local 1 // java.security.KeyStore$LoadStoreParameter param
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Ljava/security/KeyStoreSpi;
            0    2     1  param  Ljava/security/KeyStore$LoadStoreParameter;
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
       Name  Flags
      param  

  void engineLoad(java.io.InputStream, java.security.KeyStore$LoadStoreParameter);
    descriptor: (Ljava/io/InputStream;Ljava/security/KeyStore$LoadStoreParameter;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=8, args_size=3
        start local 0 // java.security.KeyStoreSpi this
        start local 1 // java.io.InputStream stream
        start local 2 // java.security.KeyStore$LoadStoreParameter param
         0: .line 405
            aload 2 /* param */
            ifnonnull 3
         1: .line 406
            aload 0 /* this */
            aconst_null
            aconst_null
            invokevirtual java.security.KeyStoreSpi.engineLoad:(Ljava/io/InputStream;[C)V
         2: .line 407
            return
         3: .line 410
      StackMap locals:
      StackMap stack:
            aload 2 /* param */
            invokeinterface java.security.KeyStore$LoadStoreParameter.getProtectionParameter:()Ljava/security/KeyStore$ProtectionParameter;
            astore 3 /* protection */
        start local 3 // java.security.KeyStore$ProtectionParameter protection
         4: .line 412
            aload 3 /* protection */
            instanceof java.security.KeyStore$PasswordProtection
            ifeq 7
         5: .line 413
            aload 3 /* protection */
            checkcast java.security.KeyStore$PasswordProtection
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            astore 4 /* password */
        start local 4 // char[] password
         6: .line 414
            goto 23
        end local 4 // char[] password
      StackMap locals: java.security.KeyStore$ProtectionParameter
      StackMap stack:
         7: aload 3 /* protection */
            instanceof java.security.KeyStore$CallbackHandlerProtection
            ifeq 22
         8: .line 416
            aload 3 /* protection */
            checkcast java.security.KeyStore$CallbackHandlerProtection
            invokevirtual java.security.KeyStore$CallbackHandlerProtection.getCallbackHandler:()Ljavax/security/auth/callback/CallbackHandler;
         9: .line 415
            astore 5 /* handler */
        start local 5 // javax.security.auth.callback.CallbackHandler handler
        10: .line 418
            new javax.security.auth.callback.PasswordCallback
            dup
            ldc "Password: "
            iconst_0
            invokespecial javax.security.auth.callback.PasswordCallback.<init>:(Ljava/lang/String;Z)V
        11: .line 417
            astore 6 /* callback */
        start local 6 // javax.security.auth.callback.PasswordCallback callback
        12: .line 420
            aload 5 /* handler */
            iconst_1
            anewarray javax.security.auth.callback.Callback
            dup
            iconst_0
            aload 6 /* callback */
            aastore
            invokeinterface javax.security.auth.callback.CallbackHandler.handle:([Ljavax/security/auth/callback/Callback;)V
        13: .line 421
            goto 18
      StackMap locals: java.security.KeyStoreSpi java.io.InputStream java.security.KeyStore$LoadStoreParameter java.security.KeyStore$ProtectionParameter top javax.security.auth.callback.CallbackHandler javax.security.auth.callback.PasswordCallback
      StackMap stack: javax.security.auth.callback.UnsupportedCallbackException
        14: astore 7 /* e */
        start local 7 // javax.security.auth.callback.UnsupportedCallbackException e
        15: .line 422
            new java.security.NoSuchAlgorithmException
            dup
        16: .line 423
            ldc "Could not obtain password"
            aload 7 /* e */
        17: .line 422
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 7 // javax.security.auth.callback.UnsupportedCallbackException e
        18: .line 425
      StackMap locals:
      StackMap stack:
            aload 6 /* callback */
            invokevirtual javax.security.auth.callback.PasswordCallback.getPassword:()[C
            astore 4 /* password */
        start local 4 // char[] password
        19: .line 426
            aload 6 /* callback */
            invokevirtual javax.security.auth.callback.PasswordCallback.clearPassword:()V
        20: .line 427
            aload 4 /* password */
            ifnonnull 23
        21: .line 428
            new java.security.NoSuchAlgorithmException
            dup
            ldc "No password provided"
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        end local 6 // javax.security.auth.callback.PasswordCallback callback
        end local 5 // javax.security.auth.callback.CallbackHandler handler
        end local 4 // char[] password
        22: .line 431
      StackMap locals: java.security.KeyStoreSpi java.io.InputStream java.security.KeyStore$LoadStoreParameter java.security.KeyStore$ProtectionParameter
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
            ldc "ProtectionParameter must be PasswordProtection or CallbackHandlerProtection"
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        start local 4 // char[] password
        23: .line 434
      StackMap locals: char[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* stream */
            aload 4 /* password */
            invokevirtual java.security.KeyStoreSpi.engineLoad:(Ljava/io/InputStream;[C)V
        24: .line 435
            return
        end local 4 // char[] password
        end local 3 // java.security.KeyStore$ProtectionParameter protection
        end local 2 // java.security.KeyStore$LoadStoreParameter param
        end local 1 // java.io.InputStream stream
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   25     0        this  Ljava/security/KeyStoreSpi;
            0   25     1      stream  Ljava/io/InputStream;
            0   25     2       param  Ljava/security/KeyStore$LoadStoreParameter;
            4   25     3  protection  Ljava/security/KeyStore$ProtectionParameter;
            6    7     4    password  [C
           19   22     4    password  [C
           23   25     4    password  [C
           10   22     5     handler  Ljavax/security/auth/callback/CallbackHandler;
           12   22     6    callback  Ljavax/security/auth/callback/PasswordCallback;
           15   18     7           e  Ljavax/security/auth/callback/UnsupportedCallbackException;
      Exception table:
        from    to  target  type
          12    13      14  Class javax.security.auth.callback.UnsupportedCallbackException
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
        Name  Flags
      stream  
      param   

  public java.security.KeyStore$Entry engineGetEntry(java.lang.String, java.security.KeyStore$ProtectionParameter);
    descriptor: (Ljava/lang/String;Ljava/security/KeyStore$ProtectionParameter;)Ljava/security/KeyStore$Entry;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=3
        start local 0 // java.security.KeyStoreSpi this
        start local 1 // java.lang.String alias
        start local 2 // java.security.KeyStore$ProtectionParameter protParam
         0: .line 467
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineContainsAlias:(Ljava/lang/String;)Z
            ifne 2
         1: .line 468
            aconst_null
            areturn
         2: .line 471
      StackMap locals:
      StackMap stack:
            aload 2 /* protParam */
            ifnonnull 10
         3: .line 472
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 7
         4: .line 473
            new java.security.KeyStore$TrustedCertificateEntry
            dup
         5: .line 474
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineGetCertificate:(Ljava/lang/String;)Ljava/security/cert/Certificate;
         6: .line 473
            invokespecial java.security.KeyStore$TrustedCertificateEntry.<init>:(Ljava/security/cert/Certificate;)V
            areturn
         7: .line 476
      StackMap locals:
      StackMap stack:
            new java.security.UnrecoverableKeyException
            dup
         8: .line 477
            ldc "requested entry requires a password"
         9: .line 476
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 481
      StackMap locals:
      StackMap stack:
            aload 2 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifeq 29
        11: .line 482
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 15
        12: .line 483
            new java.lang.UnsupportedOperationException
            dup
        13: .line 484
            ldc "trusted certificate entries are not password-protected"
        14: .line 483
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 485
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifeq 29
        16: .line 487
            aload 2 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
        17: .line 486
            astore 3 /* pp */
        start local 3 // java.security.KeyStore$PasswordProtection pp
        18: .line 488
            aload 3 /* pp */
            invokevirtual java.security.KeyStore$PasswordProtection.getProtectionAlgorithm:()Ljava/lang/String;
            ifnull 22
        19: .line 489
            new java.security.KeyStoreException
            dup
        20: .line 490
            ldc "unsupported password protection algorithm"
        21: .line 489
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 492
      StackMap locals: java.security.KeyStore$PasswordProtection
      StackMap stack:
            aload 3 /* pp */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            astore 4 /* password */
        start local 4 // char[] password
        23: .line 494
            aload 0 /* this */
            aload 1 /* alias */
            aload 4 /* password */
            invokevirtual java.security.KeyStoreSpi.engineGetKey:(Ljava/lang/String;[C)Ljava/security/Key;
            astore 5 /* key */
        start local 5 // java.security.Key key
        24: .line 495
            aload 5 /* key */
            instanceof java.security.PrivateKey
            ifeq 27
        25: .line 496
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineGetCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/Certificate;
            astore 6 /* chain */
        start local 6 // java.security.cert.Certificate[] chain
        26: .line 497
            new java.security.KeyStore$PrivateKeyEntry
            dup
            aload 5 /* key */
            checkcast java.security.PrivateKey
            aload 6 /* chain */
            invokespecial java.security.KeyStore$PrivateKeyEntry.<init>:(Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;)V
            areturn
        end local 6 // java.security.cert.Certificate[] chain
        27: .line 498
      StackMap locals: char[] java.security.Key
      StackMap stack:
            aload 5 /* key */
            instanceof javax.crypto.SecretKey
            ifeq 29
        28: .line 499
            new java.security.KeyStore$SecretKeyEntry
            dup
            aload 5 /* key */
            checkcast javax.crypto.SecretKey
            invokespecial java.security.KeyStore$SecretKeyEntry.<init>:(Ljavax/crypto/SecretKey;)V
            areturn
        end local 5 // java.security.Key key
        end local 4 // char[] password
        end local 3 // java.security.KeyStore$PasswordProtection pp
        29: .line 504
      StackMap locals:
      StackMap stack:
            new java.lang.UnsupportedOperationException
            dup
            invokespecial java.lang.UnsupportedOperationException.<init>:()V
            athrow
        end local 2 // java.security.KeyStore$ProtectionParameter protParam
        end local 1 // java.lang.String alias
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   30     0       this  Ljava/security/KeyStoreSpi;
            0   30     1      alias  Ljava/lang/String;
            0   30     2  protParam  Ljava/security/KeyStore$ProtectionParameter;
           18   29     3         pp  Ljava/security/KeyStore$PasswordProtection;
           23   29     4   password  [C
           24   29     5        key  Ljava/security/Key;
           26   27     6      chain  [Ljava/security/cert/Certificate;
    Exceptions:
      throws java.security.KeyStoreException, java.security.NoSuchAlgorithmException, java.security.UnrecoverableEntryException
    MethodParameters:
           Name  Flags
      alias      
      protParam  

  public void engineSetEntry(java.lang.String, java.security.KeyStore$Entry, java.security.KeyStore$ProtectionParameter);
    descriptor: (Ljava/lang/String;Ljava/security/KeyStore$Entry;Ljava/security/KeyStore$ProtectionParameter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // java.security.KeyStoreSpi this
        start local 1 // java.lang.String alias
        start local 2 // java.security.KeyStore$Entry entry
        start local 3 // java.security.KeyStore$ProtectionParameter protParam
         0: .line 530
            aload 3 /* protParam */
            ifnull 3
         1: .line 531
            aload 3 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifne 3
         2: .line 532
            new java.security.KeyStoreException
            dup
            ldc "unsupported protection parameter"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 534
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* pProtect */
        start local 4 // java.security.KeyStore$PasswordProtection pProtect
         4: .line 535
            aload 3 /* protParam */
            ifnull 10
         5: .line 536
            aload 3 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
            astore 4 /* pProtect */
         6: .line 537
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getProtectionAlgorithm:()Ljava/lang/String;
            ifnull 10
         7: .line 538
            new java.security.KeyStoreException
            dup
         8: .line 539
            ldc "unsupported password protection algorithm"
         9: .line 538
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 544
      StackMap locals: java.security.KeyStore$PasswordProtection
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$TrustedCertificateEntry
            ifeq 19
        11: .line 545
            aload 3 /* protParam */
            ifnull 15
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnull 15
        12: .line 547
            new java.security.KeyStoreException
            dup
        13: .line 548
            ldc "trusted certificate entries are not password-protected"
        14: .line 547
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 551
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$TrustedCertificateEntry
        16: .line 550
            astore 5 /* tce */
        start local 5 // java.security.KeyStore$TrustedCertificateEntry tce
        17: .line 552
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* tce */
            invokevirtual java.security.KeyStore$TrustedCertificateEntry.getTrustedCertificate:()Ljava/security/cert/Certificate;
            invokevirtual java.security.KeyStoreSpi.engineSetCertificateEntry:(Ljava/lang/String;Ljava/security/cert/Certificate;)V
        18: .line 553
            return
        end local 5 // java.security.KeyStore$TrustedCertificateEntry tce
        19: .line 555
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$PrivateKeyEntry
            ifeq 31
        20: .line 556
            aload 4 /* pProtect */
            ifnull 21
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 24
        21: .line 558
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        22: .line 559
            ldc "non-null password required to create PrivateKeyEntry"
        23: .line 558
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        24: .line 561
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        25: .line 562
            aload 1 /* alias */
        26: .line 563
            aload 2 /* entry */
            checkcast java.security.KeyStore$PrivateKeyEntry
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getPrivateKey:()Ljava/security/PrivateKey;
        27: .line 564
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
        28: .line 565
            aload 2 /* entry */
            checkcast java.security.KeyStore$PrivateKeyEntry
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
        29: .line 561
            invokevirtual java.security.KeyStoreSpi.engineSetKeyEntry:(Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;)V
        30: .line 566
            return
        31: .line 568
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$SecretKeyEntry
            ifeq 43
        32: .line 569
            aload 4 /* pProtect */
            ifnull 33
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 36
        33: .line 571
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        34: .line 572
            ldc "non-null password required to create SecretKeyEntry"
        35: .line 571
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        36: .line 574
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        37: .line 575
            aload 1 /* alias */
        38: .line 576
            aload 2 /* entry */
            checkcast java.security.KeyStore$SecretKeyEntry
            invokevirtual java.security.KeyStore$SecretKeyEntry.getSecretKey:()Ljavax/crypto/SecretKey;
        39: .line 577
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
        40: .line 578
            aconst_null
        41: .line 574
            invokevirtual java.security.KeyStoreSpi.engineSetKeyEntry:(Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;)V
        42: .line 579
            return
        43: .line 583
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        44: .line 584
            new java.lang.StringBuilder
            dup
            ldc "unsupported entry type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* entry */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        45: .line 583
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.KeyStore$PasswordProtection pProtect
        end local 3 // java.security.KeyStore$ProtectionParameter protParam
        end local 2 // java.security.KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   46     0       this  Ljava/security/KeyStoreSpi;
            0   46     1      alias  Ljava/lang/String;
            0   46     2      entry  Ljava/security/KeyStore$Entry;
            0   46     3  protParam  Ljava/security/KeyStore$ProtectionParameter;
            4   46     4   pProtect  Ljava/security/KeyStore$PasswordProtection;
           17   19     5        tce  Ljava/security/KeyStore$TrustedCertificateEntry;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
           Name  Flags
      alias      
      entry      
      protParam  

  public boolean engineEntryInstanceOf(java.lang.String, java.lang.Class<? extends java.security.KeyStore$Entry>);
    descriptor: (Ljava/lang/String;Ljava/lang/Class;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // java.security.KeyStoreSpi this
        start local 1 // java.lang.String alias
        start local 2 // java.lang.Class entryClass
         0: .line 605
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$TrustedCertificateEntry;
            if_acmpne 2
         1: .line 606
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ireturn
         2: .line 608
      StackMap locals:
      StackMap stack:
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$PrivateKeyEntry;
            if_acmpne 7
         3: .line 609
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifeq 6
         4: .line 610
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineGetCertificate:(Ljava/lang/String;)Ljava/security/cert/Certificate;
            ifnull 6
         5: .line 609
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         6: iconst_0
            ireturn
         7: .line 612
      StackMap locals:
      StackMap stack:
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$SecretKeyEntry;
            if_acmpne 12
         8: .line 613
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifeq 11
         9: .line 614
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual java.security.KeyStoreSpi.engineGetCertificate:(Ljava/lang/String;)Ljava/security/cert/Certificate;
            ifnonnull 11
        10: .line 613
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
        11: iconst_0
            ireturn
        12: .line 616
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.lang.Class entryClass
        end local 1 // java.lang.String alias
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   13     0        this  Ljava/security/KeyStoreSpi;
            0   13     1       alias  Ljava/lang/String;
            0   13     2  entryClass  Ljava/lang/Class<+Ljava/security/KeyStore$Entry;>;
    Signature: (Ljava/lang/String;Ljava/lang/Class<+Ljava/security/KeyStore$Entry;>;)Z
    MethodParameters:
            Name  Flags
      alias       
      entryClass  

  public boolean engineProbe(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.security.KeyStoreSpi this
        start local 1 // java.io.InputStream stream
         0: .line 638
            aload 1 /* stream */
            ifnonnull 2
         1: .line 639
            new java.lang.NullPointerException
            dup
            ldc "input stream must not be null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 641
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // java.io.InputStream stream
        end local 0 // java.security.KeyStoreSpi this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Ljava/security/KeyStoreSpi;
            0    3     1  stream  Ljava/io/InputStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      stream  
}
SourceFile: "KeyStoreSpi.java"
InnerClasses:
  public CallbackHandlerProtection = java.security.KeyStore$CallbackHandlerProtection of java.security.KeyStore
  public abstract Entry = java.security.KeyStore$Entry of java.security.KeyStore
  public abstract LoadStoreParameter = java.security.KeyStore$LoadStoreParameter of java.security.KeyStore
  public PasswordProtection = java.security.KeyStore$PasswordProtection of java.security.KeyStore
  public final PrivateKeyEntry = java.security.KeyStore$PrivateKeyEntry of java.security.KeyStore
  public abstract ProtectionParameter = java.security.KeyStore$ProtectionParameter of java.security.KeyStore
  public final SecretKeyEntry = java.security.KeyStore$SecretKeyEntry of java.security.KeyStore
  public final TrustedCertificateEntry = java.security.KeyStore$TrustedCertificateEntry of java.security.KeyStore