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

Gost3410PublicKeyAlgParameters

using System; namespace Org.BouncyCastle.Asn1.CryptoPro { public class Gost3410PublicKeyAlgParameters : Asn1Encodable { private readonly DerObjectIdentifier m_publicKeyParamSet; private readonly DerObjectIdentifier m_digestParamSet; private readonly DerObjectIdentifier m_encryptionParamSet; public DerObjectIdentifier PublicKeyParamSet => m_publicKeyParamSet; public DerObjectIdentifier DigestParamSet => m_digestParamSet; public DerObjectIdentifier EncryptionParamSet => m_encryptionParamSet; public static Gost3410PublicKeyAlgParameters GetInstance(object obj) { if (obj == null) return null; Gost3410PublicKeyAlgParameters gost3410PublicKeyAlgParameters = obj as Gost3410PublicKeyAlgParameters; if (gost3410PublicKeyAlgParameters != null) return gost3410PublicKeyAlgParameters; return new Gost3410PublicKeyAlgParameters(Asn1Sequence.GetInstance(obj)); } public static Gost3410PublicKeyAlgParameters GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new Gost3410PublicKeyAlgParameters(Asn1Sequence.GetInstance(taggedObject, declaredExplicit)); } public static Gost3410PublicKeyAlgParameters GetTagged(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new Gost3410PublicKeyAlgParameters(Asn1Sequence.GetTagged(taggedObject, declaredExplicit)); } private Gost3410PublicKeyAlgParameters(Asn1Sequence seq) { int count = seq.Count; int sequencePosition = 0; if (count < 2 || count > 3) throw new ArgumentException("Bad sequence size: " + count.ToString(), "seq"); m_publicKeyParamSet = DerObjectIdentifier.GetInstance(seq[sequencePosition++]); m_digestParamSet = DerObjectIdentifier.GetInstance(seq[sequencePosition++]); m_encryptionParamSet = Asn1Utilities.ReadOptional(seq, ref sequencePosition, DerObjectIdentifier.GetOptional); if (sequencePosition != count) throw new ArgumentException("Unexpected elements in sequence", "seq"); } public Gost3410PublicKeyAlgParameters(DerObjectIdentifier publicKeyParamSet, DerObjectIdentifier digestParamSet) : this(publicKeyParamSet, digestParamSet, null) { } public Gost3410PublicKeyAlgParameters(DerObjectIdentifier publicKeyParamSet, DerObjectIdentifier digestParamSet, DerObjectIdentifier encryptionParamSet) { if (publicKeyParamSet == null) throw new ArgumentNullException("publicKeyParamSet"); m_publicKeyParamSet = publicKeyParamSet; if (digestParamSet == null) throw new ArgumentNullException("digestParamSet"); m_digestParamSet = digestParamSet; m_encryptionParamSet = encryptionParamSet; } public override Asn1Object ToAsn1Object() { if (m_encryptionParamSet != null) return new DerSequence(m_publicKeyParamSet, m_digestParamSet, m_encryptionParamSet); return new DerSequence(m_publicKeyParamSet, m_digestParamSet); } } }