using System; namespace Org.BouncyCastle.Asn1.Cmp { /** * GenMsg: {id-it 20}, RootCaCertValue | < absent > * GenRep: {id-it 18}, RootCaKeyUpdateContent | < absent > *
* RootCaCertValue ::= CMPCertificate *
* RootCaKeyUpdateValue ::= RootCaKeyUpdateContent *
* RootCaKeyUpdateContent ::= SEQUENCE { * newWithNew CMPCertificate, * newWithOld [0] CMPCertificate OPTIONAL, * oldWithNew [1] CMPCertificate OPTIONAL * } *
*/ public class RootCaKeyUpdateContent : Asn1Encodable { public static RootCaKeyUpdateContent GetInstance(object obj) { if (obj is RootCaKeyUpdateContent rootCaKeyUpdateContent) return rootCaKeyUpdateContent; if (obj != null) return new RootCaKeyUpdateContent(Asn1Sequence.GetInstance(obj)); return null; } private readonly CmpCertificate m_newWithNew; private readonly CmpCertificate m_newWithOld; private readonly CmpCertificate m_oldWithNew; public RootCaKeyUpdateContent(CmpCertificate newWithNew, CmpCertificate newWithOld, CmpCertificate oldWithNew) { if (newWithNew == null) throw new ArgumentNullException(nameof(newWithNew)); m_newWithNew = newWithNew; m_newWithOld = newWithOld; m_oldWithNew = oldWithNew; } private RootCaKeyUpdateContent(Asn1Sequence seq) { if (seq.Count < 1 || seq.Count > 3) throw new ArgumentException("expected sequence of 1 to 3 elements only"); CmpCertificate newWithNew; CmpCertificate newWithOld = null; CmpCertificate oldWithNew = null; newWithNew = CmpCertificate.GetInstance(seq[0]); for (int pos = 1; pos < seq.Count; ++pos) { Asn1TaggedObject ato = Asn1TaggedObject.GetInstance(seq[pos]); if (ato.TagNo == 0) { newWithOld = CmpCertificate.GetInstance(ato, true); } else if (ato.TagNo == 1) { oldWithNew = CmpCertificate.GetInstance(ato, true); } } m_newWithNew = newWithNew; m_newWithOld = newWithOld; m_oldWithNew = oldWithNew; } public virtual CmpCertificate NewWithNew => m_newWithNew; public virtual CmpCertificate NewWithOld => m_newWithOld; public virtual CmpCertificate OldWithNew => m_oldWithNew; public override Asn1Object ToAsn1Object() { Asn1EncodableVector v = new Asn1EncodableVector(m_newWithNew); v.AddOptionalTagged(true, 0, m_newWithOld); v.AddOptionalTagged(true, 1, m_oldWithNew); return new DerSequence(v); } } }