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

  private final java.util.Set<java.security.KeyStore$Entry$Attribute> attributes;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;

  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=4, locals=3, 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 506
            aload 0 /* this */
            aload 1 /* privateKey */
            aload 2 /* chain */
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            invokespecial java.security.KeyStore$PrivateKeyEntry.<init>:(Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;Ljava/util/Set;)V
         1: .line 507
            return
        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    2     0        this  Ljava/security/KeyStore$PrivateKeyEntry;
            0    2     1  privateKey  Ljava/security/PrivateKey;
            0    2     2       chain  [Ljava/security/cert/Certificate;
    MethodParameters:
            Name  Flags
      privateKey  
      chain       

  public void <init>(java.security.PrivateKey, java.security.cert.Certificate[], java.util.Set<java.security.KeyStore$Entry$Attribute>);
    descriptor: (Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;Ljava/util/Set;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=7, args_size=4
        start local 0 // java.security.KeyStore$PrivateKeyEntry this
        start local 1 // java.security.PrivateKey privateKey
        start local 2 // java.security.cert.Certificate[] chain
        start local 3 // java.util.Set attributes
         0: .line 535
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 538
            aload 1 /* privateKey */
            ifnull 2
            aload 2 /* chain */
            ifnull 2
            aload 3 /* attributes */
            ifnonnull 3
         2: .line 539
      StackMap locals: java.security.KeyStore$PrivateKeyEntry java.security.PrivateKey java.security.cert.Certificate[] java.util.Set
      StackMap stack:
            new java.lang.NullPointerException
            dup
            ldc "invalid null input"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 541
      StackMap locals:
      StackMap stack:
            aload 2 /* chain */
            arraylength
            ifne 7
         4: .line 542
            new java.lang.IllegalArgumentException
            dup
         5: .line 543
            ldc "invalid zero-length input chain"
         6: .line 542
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 546
      StackMap locals:
      StackMap stack:
            aload 2 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            astore 4 /* clonedChain */
        start local 4 // java.security.cert.Certificate[] clonedChain
         8: .line 547
            aload 4 /* clonedChain */
            iconst_0
            aaload
            invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
            astore 5 /* certType */
        start local 5 // java.lang.String certType
         9: .line 548
            iconst_1
            istore 6 /* i */
        start local 6 // int i
        10: goto 16
        11: .line 549
      StackMap locals: java.security.cert.Certificate[] java.lang.String int
      StackMap stack:
            aload 5 /* certType */
            aload 4 /* clonedChain */
            iload 6 /* i */
            aaload
            invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 15
        12: .line 550
            new java.lang.IllegalArgumentException
            dup
        13: .line 551
            ldc "chain does not contain certificates of the same type"
        14: .line 550
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 548
      StackMap locals:
      StackMap stack:
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        16: iload 6 /* i */
            aload 4 /* clonedChain */
            arraylength
            if_icmplt 11
        end local 6 // int i
        17: .line 555
            aload 1 /* privateKey */
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
        18: .line 556
            aload 4 /* clonedChain */
            iconst_0
            aaload
            invokevirtual java.security.cert.Certificate.getPublicKey:()Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
        19: .line 555
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        20: .line 556
            ifne 24
        21: .line 557
            new java.lang.IllegalArgumentException
            dup
        22: .line 558
            ldc "private key algorithm does not match algorithm of public key in end entity certificate (at index 0)"
        23: .line 557
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        24: .line 562
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* privateKey */
            putfield java.security.KeyStore$PrivateKeyEntry.privKey:Ljava/security/PrivateKey;
        25: .line 564
            aload 4 /* clonedChain */
            iconst_0
            aaload
            instanceof java.security.cert.X509Certificate
            ifeq 32
        26: .line 565
            aload 4 /* clonedChain */
            instanceof java.security.cert.X509Certificate[]
            ifne 32
        27: .line 567
            aload 0 /* this */
            aload 4 /* clonedChain */
            arraylength
            anewarray java.security.cert.X509Certificate
            putfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
        28: .line 568
            aload 4 /* clonedChain */
            iconst_0
        29: .line 569
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aload 4 /* clonedChain */
            arraylength
        30: .line 568
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        31: .line 570
            goto 33
        32: .line 571
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* clonedChain */
            putfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
        33: .line 574
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        34: .line 575
            new java.util.HashSet
            dup
            aload 3 /* attributes */
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            invokestatic java.util.Collections.unmodifiableSet:(Ljava/util/Set;)Ljava/util/Set;
        35: .line 574
            putfield java.security.KeyStore$PrivateKeyEntry.attributes:Ljava/util/Set;
        36: .line 576
            return
        end local 5 // java.lang.String certType
        end local 4 // java.security.cert.Certificate[] clonedChain
        end local 3 // java.util.Set attributes
        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   37     0         this  Ljava/security/KeyStore$PrivateKeyEntry;
            0   37     1   privateKey  Ljava/security/PrivateKey;
            0   37     2        chain  [Ljava/security/cert/Certificate;
            0   37     3   attributes  Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;
            8   37     4  clonedChain  [Ljava/security/cert/Certificate;
            9   37     5     certType  Ljava/lang/String;
           10   17     6            i  I
    Signature: (Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;)V
    MethodParameters:
            Name  Flags
      privateKey  
      chain       
      attributes  

  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 584
            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 599
            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 613
            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.util.Set<java.security.KeyStore$Entry$Attribute> getAttributes();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.KeyStore$PrivateKeyEntry this
         0: .line 625
            aload 0 /* this */
            getfield java.security.KeyStore$PrivateKeyEntry.attributes:Ljava/util/Set;
            areturn
        end local 0 // java.security.KeyStore$PrivateKeyEntry this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/KeyStore$PrivateKeyEntry;
    Signature: ()Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;

  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 633
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 634
            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 635
            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 634
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 636
            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 637
            aload 1 /* sb */
            aload 2 /* cert */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         7: .line 638
            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 636
            iinc 3 1
      StackMap locals:
      StackMap stack:
         9: iload 3
            iload 4
            if_icmplt 5
        10: .line 640
            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 abstract Attribute = java.security.KeyStore$Entry$Attribute of java.security.KeyStore$Entry
  public final PrivateKeyEntry = java.security.KeyStore$PrivateKeyEntry of java.security.KeyStore