public class java.security.cert.TrustAnchor
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: java.security.cert.TrustAnchor
  super_class: java.lang.Object
{
  private final java.security.PublicKey pubKey;
    descriptor: Ljava/security/PublicKey;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String caName;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final javax.security.auth.x500.X500Principal caPrincipal;
    descriptor: Ljavax/security/auth/x500/X500Principal;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.security.cert.X509Certificate trustedCert;
    descriptor: Ljava/security/cert/X509Certificate;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private byte[] ncBytes;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private sun.security.x509.NameConstraintsExtension nc;
    descriptor: Lsun/security/x509/NameConstraintsExtension;
    flags: (0x0002) ACC_PRIVATE

  public void <init>(java.security.cert.X509Certificate, byte[]);
    descriptor: (Ljava/security/cert/X509Certificate;[B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // java.security.cert.TrustAnchor this
        start local 1 // java.security.cert.X509Certificate trustedCert
        start local 2 // byte[] nameConstraints
         0: .line 123
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 125
            aload 1 /* trustedCert */
            ifnonnull 3
         2: .line 126
            new java.lang.NullPointerException
            dup
            ldc "the trustedCert parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 128
      StackMap locals: java.security.cert.TrustAnchor java.security.cert.X509Certificate byte[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* trustedCert */
            putfield java.security.cert.TrustAnchor.trustedCert:Ljava/security/cert/X509Certificate;
         4: .line 129
            aload 0 /* this */
            aconst_null
            putfield java.security.cert.TrustAnchor.pubKey:Ljava/security/PublicKey;
         5: .line 130
            aload 0 /* this */
            aconst_null
            putfield java.security.cert.TrustAnchor.caName:Ljava/lang/String;
         6: .line 131
            aload 0 /* this */
            aconst_null
            putfield java.security.cert.TrustAnchor.caPrincipal:Ljavax/security/auth/x500/X500Principal;
         7: .line 132
            aload 0 /* this */
            aload 2 /* nameConstraints */
            invokevirtual java.security.cert.TrustAnchor.setNameConstraints:([B)V
         8: .line 133
            return
        end local 2 // byte[] nameConstraints
        end local 1 // java.security.cert.X509Certificate trustedCert
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Ljava/security/cert/TrustAnchor;
            0    9     1      trustedCert  Ljava/security/cert/X509Certificate;
            0    9     2  nameConstraints  [B
    MethodParameters:
                 Name  Flags
      trustedCert      
      nameConstraints  

  public void <init>(javax.security.auth.x500.X500Principal, java.security.PublicKey, byte[]);
    descriptor: (Ljavax/security/auth/x500/X500Principal;Ljava/security/PublicKey;[B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // java.security.cert.TrustAnchor this
        start local 1 // javax.security.auth.x500.X500Principal caPrincipal
        start local 2 // java.security.PublicKey pubKey
        start local 3 // byte[] nameConstraints
         0: .line 162
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 164
            aload 1 /* caPrincipal */
            ifnull 2
            aload 2 /* pubKey */
            ifnonnull 3
         2: .line 165
      StackMap locals: java.security.cert.TrustAnchor javax.security.auth.x500.X500Principal java.security.PublicKey byte[]
      StackMap stack:
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
         3: .line 167
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield java.security.cert.TrustAnchor.trustedCert:Ljava/security/cert/X509Certificate;
         4: .line 168
            aload 0 /* this */
            aload 1 /* caPrincipal */
            putfield java.security.cert.TrustAnchor.caPrincipal:Ljavax/security/auth/x500/X500Principal;
         5: .line 169
            aload 0 /* this */
            aload 1 /* caPrincipal */
            invokevirtual javax.security.auth.x500.X500Principal.getName:()Ljava/lang/String;
            putfield java.security.cert.TrustAnchor.caName:Ljava/lang/String;
         6: .line 170
            aload 0 /* this */
            aload 2 /* pubKey */
            putfield java.security.cert.TrustAnchor.pubKey:Ljava/security/PublicKey;
         7: .line 171
            aload 0 /* this */
            aload 3 /* nameConstraints */
            invokevirtual java.security.cert.TrustAnchor.setNameConstraints:([B)V
         8: .line 172
            return
        end local 3 // byte[] nameConstraints
        end local 2 // java.security.PublicKey pubKey
        end local 1 // javax.security.auth.x500.X500Principal caPrincipal
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Ljava/security/cert/TrustAnchor;
            0    9     1      caPrincipal  Ljavax/security/auth/x500/X500Principal;
            0    9     2           pubKey  Ljava/security/PublicKey;
            0    9     3  nameConstraints  [B
    MethodParameters:
                 Name  Flags
      caPrincipal      
      pubKey           
      nameConstraints  

  public void <init>(java.lang.String, java.security.PublicKey, byte[]);
    descriptor: (Ljava/lang/String;Ljava/security/PublicKey;[B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // java.security.cert.TrustAnchor this
        start local 1 // java.lang.String caName
        start local 2 // java.security.PublicKey pubKey
        start local 3 // byte[] nameConstraints
         0: .line 205
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 207
            aload 2 /* pubKey */
            ifnonnull 3
         2: .line 208
            new java.lang.NullPointerException
            dup
            ldc "the pubKey parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 210
      StackMap locals: java.security.cert.TrustAnchor java.lang.String java.security.PublicKey byte[]
      StackMap stack:
            aload 1 /* caName */
            ifnonnull 5
         4: .line 211
            new java.lang.NullPointerException
            dup
            ldc "the caName parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 213
      StackMap locals:
      StackMap stack:
            aload 1 /* caName */
            invokevirtual java.lang.String.length:()I
            ifne 7
         6: .line 214
            new java.lang.IllegalArgumentException
            dup
            ldc "the caName parameter must be a non-empty String"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 217
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new javax.security.auth.x500.X500Principal
            dup
            aload 1 /* caName */
            invokespecial javax.security.auth.x500.X500Principal.<init>:(Ljava/lang/String;)V
            putfield java.security.cert.TrustAnchor.caPrincipal:Ljavax/security/auth/x500/X500Principal;
         8: .line 218
            aload 0 /* this */
            aload 2 /* pubKey */
            putfield java.security.cert.TrustAnchor.pubKey:Ljava/security/PublicKey;
         9: .line 219
            aload 0 /* this */
            aload 1 /* caName */
            putfield java.security.cert.TrustAnchor.caName:Ljava/lang/String;
        10: .line 220
            aload 0 /* this */
            aconst_null
            putfield java.security.cert.TrustAnchor.trustedCert:Ljava/security/cert/X509Certificate;
        11: .line 221
            aload 0 /* this */
            aload 3 /* nameConstraints */
            invokevirtual java.security.cert.TrustAnchor.setNameConstraints:([B)V
        12: .line 222
            return
        end local 3 // byte[] nameConstraints
        end local 2 // java.security.PublicKey pubKey
        end local 1 // java.lang.String caName
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   13     0             this  Ljava/security/cert/TrustAnchor;
            0   13     1           caName  Ljava/lang/String;
            0   13     2           pubKey  Ljava/security/PublicKey;
            0   13     3  nameConstraints  [B
    MethodParameters:
                 Name  Flags
      caName           
      pubKey           
      nameConstraints  

  public final java.security.cert.X509Certificate getTrustedCert();
    descriptor: ()Ljava/security/cert/X509Certificate;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.cert.TrustAnchor this
         0: .line 231
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.trustedCert:Ljava/security/cert/X509Certificate;
            areturn
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/cert/TrustAnchor;

  public final javax.security.auth.x500.X500Principal getCA();
    descriptor: ()Ljavax/security/auth/x500/X500Principal;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.cert.TrustAnchor this
         0: .line 243
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.caPrincipal:Ljavax/security/auth/x500/X500Principal;
            areturn
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/cert/TrustAnchor;

  public final java.lang.String getCAName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.cert.TrustAnchor this
         0: .line 255
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.caName:Ljava/lang/String;
            areturn
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/cert/TrustAnchor;

  public final java.security.PublicKey getCAPublicKey();
    descriptor: ()Ljava/security/PublicKey;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.cert.TrustAnchor this
         0: .line 266
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.pubKey:Ljava/security/PublicKey;
            areturn
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/cert/TrustAnchor;

  private void setNameConstraints(byte[]);
    descriptor: ([B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // java.security.cert.TrustAnchor this
        start local 1 // byte[] bytes
         0: .line 273
            aload 1 /* bytes */
            ifnonnull 4
         1: .line 274
            aload 0 /* this */
            aconst_null
            putfield java.security.cert.TrustAnchor.ncBytes:[B
         2: .line 275
            aload 0 /* this */
            aconst_null
            putfield java.security.cert.TrustAnchor.nc:Lsun/security/x509/NameConstraintsExtension;
         3: .line 276
            goto 12
         4: .line 277
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* bytes */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield java.security.cert.TrustAnchor.ncBytes:[B
         5: .line 280
            aload 0 /* this */
            new sun.security.x509.NameConstraintsExtension
            dup
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            aload 1 /* bytes */
            invokespecial sun.security.x509.NameConstraintsExtension.<init>:(Ljava/lang/Boolean;Ljava/lang/Object;)V
            putfield java.security.cert.TrustAnchor.nc:Lsun/security/x509/NameConstraintsExtension;
         6: .line 281
            goto 12
      StackMap locals:
      StackMap stack: java.io.IOException
         7: astore 2 /* ioe */
        start local 2 // java.io.IOException ioe
         8: .line 283
            new java.lang.IllegalArgumentException
            dup
            aload 2 /* ioe */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
         9: .line 282
            astore 3 /* iae */
        start local 3 // java.lang.IllegalArgumentException iae
        10: .line 284
            aload 3 /* iae */
            aload 2 /* ioe */
            invokevirtual java.lang.IllegalArgumentException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        11: .line 285
            aload 3 /* iae */
            athrow
        end local 3 // java.lang.IllegalArgumentException iae
        end local 2 // java.io.IOException ioe
        12: .line 288
      StackMap locals:
      StackMap stack:
            return
        end local 1 // byte[] bytes
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   13     0   this  Ljava/security/cert/TrustAnchor;
            0   13     1  bytes  [B
            8   12     2    ioe  Ljava/io/IOException;
           10   12     3    iae  Ljava/lang/IllegalArgumentException;
      Exception table:
        from    to  target  type
           5     6       7  Class java.io.IOException
    MethodParameters:
       Name  Flags
      bytes  

  public final byte[] getNameConstraints();
    descriptor: ()[B
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.cert.TrustAnchor this
         0: .line 311
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.ncBytes:[B
            ifnonnull 1
            aconst_null
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            getfield java.security.cert.TrustAnchor.ncBytes:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
      StackMap locals:
      StackMap stack: byte[]
         2: areturn
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljava/security/cert/TrustAnchor;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // java.security.cert.TrustAnchor this
         0: .line 320
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuffer sb
         1: .line 321
            aload 1 /* sb */
            ldc "[\n"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         2: .line 322
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.pubKey:Ljava/security/PublicKey;
            ifnull 8
         3: .line 323
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "  Trusted CA Public Key: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.pubKey:Ljava/security/PublicKey;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         4: .line 324
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "  Trusted CA Issuer Name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         5: .line 325
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.caName:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         6: .line 324
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         7: .line 326
            goto 9
         8: .line 327
      StackMap locals: java.lang.StringBuffer
      StackMap stack:
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "  Trusted CA cert: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.trustedCert:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         9: .line 329
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.nc:Lsun/security/x509/NameConstraintsExtension;
            ifnull 11
        10: .line 330
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "  Name Constraints: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield java.security.cert.TrustAnchor.nc:Lsun/security/x509/NameConstraintsExtension;
            invokevirtual sun.security.x509.NameConstraintsExtension.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        11: .line 331
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuffer sb
        end local 0 // java.security.cert.TrustAnchor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Ljava/security/cert/TrustAnchor;
            1   12     1    sb  Ljava/lang/StringBuffer;
}
SourceFile: "TrustAnchor.java"