using System; using Org.BouncyCastle.Asn1.Crmf; using Org.BouncyCastle.Asn1.X509; namespace Org.BouncyCastle.Asn1.Cmp { public class RevDetails : Asn1Encodable { private readonly CertTemplate certDetails; private readonly X509Extensions crlEntryDetails; private RevDetails(Asn1Sequence seq) { certDetails = CertTemplate.GetInstance(seq[0]); if (seq.Count > 1) { crlEntryDetails = X509Extensions.GetInstance(seq[1]); } } public static RevDetails GetInstance(object obj) { if (obj is RevDetails) return (RevDetails)obj; if (obj is Asn1Sequence) return new RevDetails((Asn1Sequence)obj); throw new ArgumentException("Invalid object: " + obj.GetType().Name, "obj"); } public RevDetails(CertTemplate certDetails) { this.certDetails = certDetails; } public RevDetails(CertTemplate certDetails, X509Extensions crlEntryDetails) { this.crlEntryDetails = crlEntryDetails; } public virtual CertTemplate CertDetails { get { return certDetails; } } public virtual X509Extensions CrlEntryDetails { get { return crlEntryDetails; } } /** *
		* RevDetails ::= SEQUENCE {
		*                  certDetails         CertTemplate,
		*                   -- allows requester to specify as much as they can about
		*                   -- the cert. for which revocation is requested
		*                   -- (e.g., for cases in which serialNumber is not available)
		*                   crlEntryDetails     Extensions       OPTIONAL
		*                   -- requested crlEntryExtensions
		*             }
		* 
* @return a basic ASN.1 object representation. */ public override Asn1Object ToAsn1Object() { Asn1EncodableVector v = new Asn1EncodableVector(certDetails); v.AddOptional(crlEntryDetails); return new DerSequence(v); } } }