org.bouncycastle.cert.crmf.CertificateRepMessage Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcpkix-lts8on Show documentation
Show all versions of bcpkix-lts8on Show documentation
The Bouncy Castle Java APIs for CMS, PKCS, EAC, TSP, CMP, CRMF, OCSP, and certificate generation. This jar contains APIs for JDK 1.8 and up. The APIs are designed primarily to be used in conjunction with the BC LTS provider but may also be used with other providers providing cryptographic services.
package org.bouncycastle.cert.crmf;
import java.util.ArrayList;
import java.util.List;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.cmp.CMPCertificate;
import org.bouncycastle.asn1.cmp.CertRepMessage;
import org.bouncycastle.asn1.cmp.CertResponse;
import org.bouncycastle.asn1.cmp.PKIBody;
import org.bouncycastle.cert.X509CertificateHolder;
public class CertificateRepMessage
{
private final CertResponse[] resps;
private final CMPCertificate[] caCerts;
public CertificateRepMessage(CertRepMessage repMessage)
{
resps = repMessage.getResponse();
caCerts = repMessage.getCaPubs();
}
public static CertificateRepMessage fromPKIBody(PKIBody pkiBody)
{
if (!isCertificateRepMessage(pkiBody.getType()))
{
throw new IllegalArgumentException("content of PKIBody wrong type: " + pkiBody.getType());
}
return new CertificateRepMessage(CertRepMessage.getInstance(pkiBody.getContent()));
}
public static boolean isCertificateRepMessage(int bodyType)
{
switch (bodyType)
{
case PKIBody.TYPE_INIT_REP:
case PKIBody.TYPE_CERT_REP:
case PKIBody.TYPE_KEY_UPDATE_REP:
case PKIBody.TYPE_CROSS_CERT_REP:
return true;
default:
return false;
}
}
public CertificateResponse[] getResponses()
{
CertificateResponse[] responses = new CertificateResponse[resps.length];
for (int i = 0; i != responses.length; i++)
{
responses[i] = new CertificateResponse(resps[i]);
}
return responses;
}
public X509CertificateHolder[] getX509Certificates()
{
List certs = new ArrayList();
for (int i = 0; i != caCerts.length; i++)
{
if (caCerts[i].isX509v3PKCert())
{
certs.add(new X509CertificateHolder(caCerts[i].getX509v3PKCert()));
}
}
return (X509CertificateHolder[])certs.toArray(new X509CertificateHolder[0]);
}
/**
* Return true if the message only contains X.509 public key certificates.
*
* @return true if only X.509 PK, false otherwise.
*/
public boolean isOnlyX509PKCertificates()
{
boolean isOnlyX509 = true;
for (int i = 0; i != caCerts.length; i++)
{
isOnlyX509 &= caCerts[i].isX509v3PKCert();
}
return isOnlyX509;
}
/**
* Return the actual CMP certificates - useful if the array also contains non-X509 PK certificates.
*
* @return CMPCertificate array
*/
public CMPCertificate[] getCMPCertificates()
{
CMPCertificate[] certs = new CMPCertificate[caCerts.length];
System.arraycopy(caCerts, 0, certs, 0, certs.length);
return certs;
}
public ASN1Encodable toASN1Structure()
{
return new CertRepMessage(caCerts, resps);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy