using System; using Org.BouncyCastle.Asn1; using Org.BouncyCastle.Asn1.X509; namespace Org.BouncyCastle.Asn1.Cms { public class EncryptedContentInfo : Asn1Encodable { private DerObjectIdentifier contentType; private AlgorithmIdentifier contentEncryptionAlgorithm; private Asn1OctetString encryptedContent; public EncryptedContentInfo( DerObjectIdentifier contentType, AlgorithmIdentifier contentEncryptionAlgorithm, Asn1OctetString encryptedContent) { this.contentType = contentType; this.contentEncryptionAlgorithm = contentEncryptionAlgorithm; this.encryptedContent = encryptedContent; } public EncryptedContentInfo( Asn1Sequence seq) { contentType = (DerObjectIdentifier) seq[0]; contentEncryptionAlgorithm = AlgorithmIdentifier.GetInstance(seq[1]); if (seq.Count > 2) { encryptedContent = Asn1OctetString.GetInstance( (Asn1TaggedObject) seq[2], false); } } /** * return an EncryptedContentInfo object from the given object. * * @param obj the object we want converted. * @exception ArgumentException if the object cannot be converted. */ public static EncryptedContentInfo GetInstance( object obj) { if (obj == null || obj is EncryptedContentInfo) { return (EncryptedContentInfo)obj; } if (obj is Asn1Sequence) { return new EncryptedContentInfo((Asn1Sequence)obj); } throw new ArgumentException("Invalid EncryptedContentInfo: " + obj.GetType().Name); } public DerObjectIdentifier ContentType { get { return contentType; } } public AlgorithmIdentifier ContentEncryptionAlgorithm { get { return contentEncryptionAlgorithm; } } public Asn1OctetString EncryptedContent { get { return encryptedContent; } } /** * Produce an object suitable for an Asn1OutputStream. *
* EncryptedContentInfo ::= Sequence {
* contentType ContentType,
* contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
* encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
* }
*
*/
public override Asn1Object ToAsn1Object()
{
Asn1EncodableVector v = new Asn1EncodableVector(
contentType, contentEncryptionAlgorithm);
if (encryptedContent != null)
{
v.Add(new BerTaggedObject(false, 0, encryptedContent));
}
return new BerSequence(v);
}
}
}