package org.bouncycastle.asn1.cmp;

import org.bouncycastle.asn1.ASN1Choice;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.DERObject;
import org.bouncycastle.asn1.DERTaggedObject;
import org.bouncycastle.asn1.x509.AttributeCertificate;
import org.bouncycastle.asn1.x509.X509CertificateStructure;

public class CMPCertificate
    extends ASN1Encodable
    implements ASN1Choice
{
    private X509CertificateStructure x509v3PKCert;
    private AttributeCertificate x509v2AttrCert;

    
Note: the addition of attribute certificates is a BC extension.
/** * Note: the addition of attribute certificates is a BC extension. */
public CMPCertificate(AttributeCertificate x509v2AttrCert) { this.x509v2AttrCert = x509v2AttrCert; } public CMPCertificate(X509CertificateStructure x509v3PKCert) { if (x509v3PKCert.getVersion() != 3) { throw new IllegalArgumentException("only version 3 certificates allowed"); } this.x509v3PKCert = x509v3PKCert; } public static CMPCertificate getInstance(Object o) { if (o instanceof CMPCertificate) { return (CMPCertificate)o; } if (o instanceof ASN1Sequence) { return new CMPCertificate(X509CertificateStructure.getInstance(o)); } if (o instanceof ASN1TaggedObject) { return new CMPCertificate(AttributeCertificate.getInstance(((ASN1TaggedObject)o).getObject())); } throw new IllegalArgumentException("Invalid object: " + o.getClass().getName()); } public boolean isX509v3PKCert() { return x509v3PKCert != null; } public X509CertificateStructure getX509v3PKCert() { return x509v3PKCert; } public AttributeCertificate getX509v2AttrCert() { return x509v2AttrCert; }
CMPCertificate ::= CHOICE {
           x509v3PKCert        Certificate
           x509v2AttrCert      [1] AttributeCertificate
 }
Note: the addition of attribute certificates is a BC extension.
Returns:a basic ASN.1 object representation.
/** * <pre> * CMPCertificate ::= CHOICE { * x509v3PKCert Certificate * x509v2AttrCert [1] AttributeCertificate * } * </pre> * Note: the addition of attribute certificates is a BC extension. * * @return a basic ASN.1 object representation. */
public DERObject toASN1Object() { if (x509v2AttrCert != null) { // explicit following CMP conventions return new DERTaggedObject(true, 1, x509v2AttrCert); } return x509v3PKCert.toASN1Object(); } }