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

MonetaryLimit

public class MonetaryLimit : Asn1Encodable
using Org.BouncyCastle.Math; using System; namespace Org.BouncyCastle.Asn1.IsisMtt.X509 { public class MonetaryLimit : Asn1Encodable { private readonly DerPrintableString m_currency; private readonly DerInteger m_amount; private readonly DerInteger m_exponent; public virtual string Currency => m_currency.GetString(); public virtual BigInteger Amount => m_amount.Value; public virtual BigInteger Exponent => m_exponent.Value; public static MonetaryLimit GetInstance(object obj) { if (obj == null) return null; MonetaryLimit monetaryLimit = obj as MonetaryLimit; if (monetaryLimit != null) return monetaryLimit; return new MonetaryLimit(Asn1Sequence.GetInstance(obj)); } public static MonetaryLimit GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new MonetaryLimit(Asn1Sequence.GetInstance(taggedObject, declaredExplicit)); } public static MonetaryLimit GetTagged(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new MonetaryLimit(Asn1Sequence.GetTagged(taggedObject, declaredExplicit)); } private MonetaryLimit(Asn1Sequence seq) { int count = seq.Count; if (count != 3) throw new ArgumentException("Bad sequence size: " + count.ToString(), "seq"); m_currency = DerPrintableString.GetInstance(seq[0]); m_amount = DerInteger.GetInstance(seq[1]); m_exponent = DerInteger.GetInstance(seq[2]); } public MonetaryLimit(string currency, int amount, int exponent) { m_currency = new DerPrintableString(currency, true); m_amount = new DerInteger(amount); m_exponent = new DerInteger(exponent); } public override Asn1Object ToAsn1Object() { return new DerSequence(m_currency, m_amount, m_exponent); } } }