using System; using Org.BouncyCastle.Asn1.X509; namespace Org.BouncyCastle.Asn1.Cmp { /** *
* KemCiphertextInfo ::= SEQUENCE { * kem AlgorithmIdentifier{KEM-ALGORITHM, {...}}, * ct OCTET STRING * } **/ public class KemCiphertextInfo : Asn1Encodable { public static KemCiphertextInfo GetInstance(object obj) { if (obj == null) return null; if (obj is KemCiphertextInfo kemCiphertextInfo) return kemCiphertextInfo; return new KemCiphertextInfo(Asn1Sequence.GetInstance(obj)); } public static KemCiphertextInfo GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) => new KemCiphertextInfo(Asn1Sequence.GetInstance(taggedObject, declaredExplicit)); private readonly AlgorithmIdentifier m_kem; private readonly Asn1OctetString m_ct; private KemCiphertextInfo(Asn1Sequence seq) { int count = seq.Count; if (count != 2) throw new ArgumentException("Bad sequence size: " + count, nameof(seq)); m_kem = AlgorithmIdentifier.GetInstance(seq[0]); m_ct = Asn1OctetString.GetInstance(seq[1]); } public KemCiphertextInfo(AlgorithmIdentifier kem, Asn1OctetString ct) { m_kem = kem ?? throw new ArgumentNullException(nameof(kem)); m_ct = ct ?? throw new ArgumentNullException(nameof(ct)); } public virtual AlgorithmIdentifier Kem => m_kem; public virtual Asn1OctetString Ct => m_ct; /** *
* KemCiphertextInfo ::= SEQUENCE { * kem AlgorithmIdentifier{KEM-ALGORITHM, {...}}, * ct OCTET STRING * } ** * @return a basic ASN.1 object representation. */ public override Asn1Object ToAsn1Object() => new DerSequence(m_kem, m_ct); } }