<PackageReference Include="BouncyCastle.Cryptography" Version="2.3.0" />

EncryptedData

public class EncryptedData : Asn1Encodable
using System; namespace Org.BouncyCastle.Asn1.Cms { public class EncryptedData : Asn1Encodable { private readonly DerInteger version; private readonly EncryptedContentInfo encryptedContentInfo; private readonly Asn1Set unprotectedAttrs; public virtual DerInteger Version => version; public virtual EncryptedContentInfo EncryptedContentInfo => encryptedContentInfo; public virtual Asn1Set UnprotectedAttrs => unprotectedAttrs; public static EncryptedData GetInstance(object obj) { if (obj == null) return null; EncryptedData encryptedData = obj as EncryptedData; if (encryptedData != null) return encryptedData; return new EncryptedData(Asn1Sequence.GetInstance(obj)); } public static EncryptedData GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new EncryptedData(Asn1Sequence.GetInstance(taggedObject, declaredExplicit)); } public EncryptedData(EncryptedContentInfo encInfo) : this(encInfo, null) { } public EncryptedData(EncryptedContentInfo encInfo, Asn1Set unprotectedAttrs) { if (encInfo == null) throw new ArgumentNullException("encInfo"); version = new DerInteger((unprotectedAttrs != null) ? 2 : 0); encryptedContentInfo = encInfo; this.unprotectedAttrs = unprotectedAttrs; } private EncryptedData(Asn1Sequence seq) { if (seq == null) throw new ArgumentNullException("seq"); if (seq.Count < 2 || seq.Count > 3) throw new ArgumentException("Bad sequence size: " + seq.Count.ToString(), "seq"); version = DerInteger.GetInstance(seq[0]); encryptedContentInfo = EncryptedContentInfo.GetInstance(seq[1]); if (seq.Count > 2) unprotectedAttrs = Asn1Set.GetInstance((Asn1TaggedObject)seq[2], false); } public override Asn1Object ToAsn1Object() { Asn1EncodableVector asn1EncodableVector = new Asn1EncodableVector(version, encryptedContentInfo); if (unprotectedAttrs != null) asn1EncodableVector.Add(new BerTaggedObject(false, 1, unprotectedAttrs)); return new BerSequence(asn1EncodableVector); } } }