com.distrimind.bouncycastle.jcajce.provider.asymmetric.x509.X509CertificateInternal Maven / Gradle / Ivy
package com.distrimind.bouncycastle.jcajce.provider.asymmetric.x509;
import java.security.cert.CertificateEncodingException;
import com.distrimind.bouncycastle.asn1.x509.Certificate;
import com.distrimind.bouncycastle.asn1.x509.BasicConstraints;
import com.distrimind.bouncycastle.jcajce.util.JcaJceHelper;
/**
* This class exists to let {@link #equals(Object)} and {@link #hashCode()} methods be delegated efficiently
* to the platform default implementations (especially important for compatibility of {@link #hashCode()}
* calculations). Those methods fall back to calling {@link #getEncoded()} for third-party subclasses, and
* this class allows us to avoid cloning the return value of {@link #getEncoded()} for those callers.
*/
class X509CertificateInternal extends X509CertificateImpl
{
private final byte[] encoding;
private final CertificateEncodingException exception;
X509CertificateInternal(JcaJceHelper bcHelper, Certificate c,
BasicConstraints basicConstraints, boolean[] keyUsage, String sigAlgName, byte[] sigAlgParams, byte[] encoding,
CertificateEncodingException exception)
{
super(bcHelper, c, basicConstraints, keyUsage, sigAlgName, sigAlgParams);
this.encoding = encoding;
this.exception = exception;
}
public byte[] getEncoded() throws CertificateEncodingException
{
if (null != exception)
{
throw exception;
}
if (null == encoding)
{
throw new CertificateEncodingException();
}
/*
* NOTE: Don't clone this return value. See class javadoc for details. Any necessary cloning is
* handled by the X509CertificateObject that is holding this instance.
*/
return encoding;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy