<PackageReference Include="BouncyCastle.Cryptography" Version="2.7.0-beta.98" />

CcmParameters

public class CcmParameters : Asn1Encodable
using Org.BouncyCastle.Utilities; using System; namespace Org.BouncyCastle.Asn1.Cms { public class CcmParameters : Asn1Encodable { private const int DefaultIcvLen = 12; private readonly Asn1OctetString m_nonce; private readonly int m_icvLen; public int IcvLen => m_icvLen; public static CcmParameters GetInstance(object obj) { if (obj == null) return null; CcmParameters ccmParameters = obj as CcmParameters; if (ccmParameters != null) return ccmParameters; return new CcmParameters(Asn1Sequence.GetInstance(obj)); } public static CcmParameters GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new CcmParameters(Asn1Sequence.GetInstance(taggedObject, declaredExplicit)); } public static CcmParameters GetTagged(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new CcmParameters(Asn1Sequence.GetTagged(taggedObject, declaredExplicit)); } private CcmParameters(Asn1Sequence seq) { int count = seq.Count; int sequencePosition = 0; if (count < 1 || count > 2) throw new ArgumentException("Bad sequence size: " + count.ToString(), "seq"); m_nonce = Asn1OctetString.GetInstance(seq[sequencePosition++]); DerInteger derInteger = Asn1Utilities.ReadOptional(seq, ref sequencePosition, DerInteger.GetOptional); if (sequencePosition != count) throw new ArgumentException("Unexpected elements in sequence", "seq"); m_icvLen = (derInteger?.IntValueExact ?? 12); } public CcmParameters(byte[] nonce, int icvLen) { m_nonce = DerOctetString.FromContents(nonce); m_icvLen = icvLen; } public byte[] GetNonce() { return Arrays.Clone(m_nonce.GetOctets()); } public override Asn1Object ToAsn1Object() { if (m_icvLen != 12) return new DerSequence(m_nonce, new DerInteger(m_icvLen)); return new DerSequence(m_nonce); } } }