public final class java.security.KeyStore$PrivateKeyEntry implements java.security.KeyStore$Entry
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: java.security.KeyStore$PrivateKeyEntry
  super_class: java.lang.Object
{
  private final java.security.PrivateKey privKey;
    descriptor: Ljava/security/PrivateKey;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.security.cert.Certificate[] chain;
    descriptor: [Ljava/security/cert/Certificate;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(java.security.PrivateKey, java.security.cert.Certificate[]);
    descriptor: (Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // java.security.KeyStore$PrivateKeyEntry this
        start local 1 // java.security.PrivateKey privateKey
        start local 2 // java.security.cert.Certificate[] chain
         0: .line 375
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 376
            aload 1 /* privateKey */
            ifnull 2
            aload 2 /* chain */
            ifnonnull 3
         2: .line 377
      StackMap locals: java.security.KeyStore$PrivateKeyEntry java.security.PrivateKey java.security.cert.Certificate[]
      StackMap stack:
            new java.lang.NullPointerException
            dup
            ldc "invalid null input"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 379
      StackMap locals:
      StackMap stack:
            aload 2 /* chain */
            arraylength
            ifne 7
         4: .line 380
            new java.lang.IllegalArgumentException
            dup
         5: .line 381
            ldc "invalid zero-length input chain"
         6: .line 380
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 384
      StackMap locals:
      StackMap stack:
            aload 2 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            astore 3 /* clonedChain */
        start local 3 // java.security.cert.Certificate[] clonedChain
         8: .line 385
            aload 3 /* clonedChain */
            iconst_0
            aaload
            invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
            astore 4 /* certType */
        start local 4 // java.lang.String certType
         9: .line 386
            iconst_1
            istore 5 /* i */
        start local 5 // int i
        10: goto 16
        11: .line 387
      StackMap locals: java.security.cert.Certificate[] java.lang.String int
      StackMap stack:
            aload 4 /* certType */
            aload 3 /* clonedChain */
            iload 5 /* i */
            aaload
            invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 15
        12: .line 388
            new java.lang.IllegalArgumentException
            dup
        13: .line 389
            ldc "chain does not contain certificates of the same type"
        14: .line 388
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 386
      StackMap locals:
      StackMap stack:
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        16: iload 5 /* i */
            aload 3 /* clonedChain */
            arraylength
            if_icmplt 11
        end local 5 // int i
        17: .line 393
            aload 1 /* privateKey */
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
        18: .line 394
            aload 3 /* clonedChain */
            iconst_0
            aaload
            invokevirtual java.security.cert.Certificate.getPublicKey:()Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
        19: .line 393
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        20: .line 394
            ifne 24
        21: .line 395
            new java.lang.IllegalArgumentException
            dup
        22: .line 396
            ldc "private key algorithm does not match algorithm of public key in end entity certificate (at index 0)"
        23: .line 395
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        24: .line 400
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* privateKey */
            putfield java.security.KeyStore$PrivateKeyEntry.privKey:Ljava/security/PrivateKey;
        25: .line 402
            aload 3 /* clonedChain */
            iconst_0
            aaload
            instanceof java.security.cert.X509Certificate
            ifeq 32
        26: .line 403
            aload 3 /* clonedChain */
            instanceof java.security.cert.X509Certificate[]
            ifne 32
        27: .line 405
            aload 0 /* this */
            aload 3 /* clonedChain */
            arraylength
            anewarray java.security.cert.X509Certificate
            putfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
        28: .line 406
            aload 3 /* clonedChain */
            iconst_0
        29: .line 407
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aload 3 /* clonedChain */
            arraylength
        30: .line 406
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        31: .line 408
            goto 33
        32: .line 409
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* clonedChain */
            putfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
        33: .line 411
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.lang.String certType
        end local 3 // java.security.cert.Certificate[] clonedChain
        end local 2 // java.security.cert.Certificate[] chain
        end local 1 // java.security.PrivateKey privateKey
        end local 0 // java.security.KeyStore$PrivateKeyEntry this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   34     0         this  Ljava/security/KeyStore$PrivateKeyEntry;
            0   34     1   privateKey  Ljava/security/PrivateKey;
            0   34     2        chain  [Ljava/security/cert/Certificate;
            8   34     3  clonedChain  [Ljava/security/cert/Certificate;
            9   34     4     certType  Ljava/lang/String;
           10   17     5            i  I
    MethodParameters:
            Name  Flags
      privateKey  
      chain       

  public java.security.PrivateKey getPrivateKey();
    descriptor: ()Ljava/security/PrivateKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.KeyStore$PrivateKeyEntry this
         0: .line 419
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.privKey:Ljava/security/PrivateKey;
            areturn
        end local 0 // java.security.KeyStore$PrivateKeyEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/KeyStore$PrivateKeyEntry;

  public java.security.cert.Certificate[] getCertificateChain();
    descriptor: ()[Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.KeyStore$PrivateKeyEntry this
         0: .line 434
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            areturn
        end local 0 // java.security.KeyStore$PrivateKeyEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/KeyStore$PrivateKeyEntry;

  public java.security.cert.Certificate getCertificate();
    descriptor: ()Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.security.KeyStore$PrivateKeyEntry this
         0: .line 448
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aaload
            areturn
        end local 0 // java.security.KeyStore$PrivateKeyEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/KeyStore$PrivateKeyEntry;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // java.security.KeyStore$PrivateKeyEntry this
         0: .line 456
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 457
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "Private key entry and certificate chain with "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 458
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " elements:\r\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 457
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 459
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 9
      StackMap locals: java.security.KeyStore$PrivateKeyEntry java.lang.StringBuilder top int int java.security.cert.Certificate[]
      StackMap stack:
         5: aload 5
            iload 3
            aaload
            astore 2 /* cert */
        start local 2 // java.security.cert.Certificate cert
         6: .line 460
            aload 1 /* sb */
            aload 2 /* cert */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         7: .line 461
            aload 1 /* sb */
            ldc "\r\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 2 // java.security.cert.Certificate cert
         8: .line 459
            iinc 3 1
      StackMap locals:
      StackMap stack:
         9: iload 3
            iload 4
            if_icmplt 5
        10: .line 463
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder sb
        end local 0 // java.security.KeyStore$PrivateKeyEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Ljava/security/KeyStore$PrivateKeyEntry;
            1   11     1    sb  Ljava/lang/StringBuilder;
            6    8     2  cert  Ljava/security/cert/Certificate;
}
SourceFile: "KeyStore.java"
NestHost: java.security.KeyStore
InnerClasses:
  public abstract Entry = java.security.KeyStore$Entry of java.security.KeyStore
  public final PrivateKeyEntry = java.security.KeyStore$PrivateKeyEntry of java.security.KeyStore