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-debug-jdk15to18 Show documentation
Show all versions of bcpkix-debug-jdk15to18 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.5 to JDK 1.8. The APIs can be used in conjunction with a JCE/JCA provider such as the one provided with the Bouncy Castle Cryptography APIs.
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