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

CscaMasterList

public class CscaMasterList : Asn1Encodable
using Org.BouncyCastle.Asn1.X509; using System; namespace Org.BouncyCastle.Asn1.Icao { public class CscaMasterList : Asn1Encodable { private readonly DerInteger m_version; private readonly X509CertificateStructure[] m_certList; public virtual int Version => m_version.IntValueExact; public static CscaMasterList GetInstance(object obj) { if (obj == null) return null; CscaMasterList cscaMasterList = obj as CscaMasterList; if (cscaMasterList != null) return cscaMasterList; return new CscaMasterList(Asn1Sequence.GetInstance(obj)); } public static CscaMasterList GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new CscaMasterList(Asn1Sequence.GetInstance(taggedObject, declaredExplicit)); } public static CscaMasterList GetTagged(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new CscaMasterList(Asn1Sequence.GetTagged(taggedObject, declaredExplicit)); } private CscaMasterList(Asn1Sequence seq) { int count = seq.Count; if (count != 2) throw new ArgumentException("Bad sequence size: " + count.ToString(), "seq"); m_version = DerInteger.GetInstance(seq[0]); m_certList = Asn1Set.GetInstance(seq[1]).MapElements(X509CertificateStructure.GetInstance); } public CscaMasterList(X509CertificateStructure[] certStructs) { m_version = DerInteger.Zero; m_certList = CopyCertList(certStructs); } public X509CertificateStructure[] GetCertStructs() { return CopyCertList(m_certList); } private static X509CertificateStructure[] CopyCertList(X509CertificateStructure[] orig) { return (X509CertificateStructure[])orig.Clone(); } public override Asn1Object ToAsn1Object() { DerInteger version = m_version; Asn1Encodable[] certList = m_certList; return new DerSequence(version, new DerSet(certList)); } } }