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

DsaParameters

using Org.BouncyCastle.Math; using System; namespace Org.BouncyCastle.Crypto.Parameters { public class DsaParameters : ICipherParameters { private readonly BigInteger p; private readonly BigInteger q; private readonly BigInteger g; private readonly DsaValidationParameters validation; public BigInteger P => p; public BigInteger Q => q; public BigInteger G => g; public DsaValidationParameters ValidationParameters => validation; public DsaParameters(BigInteger p, BigInteger q, BigInteger g) : this(p, q, g, null) { } public DsaParameters(BigInteger p, BigInteger q, BigInteger g, DsaValidationParameters parameters) { if (p == null) throw new ArgumentNullException("p"); if (q == null) throw new ArgumentNullException("q"); if (g == null) throw new ArgumentNullException("g"); this.p = p; this.q = q; this.g = g; validation = parameters; } public override bool Equals(object obj) { if (obj == this) return true; DsaParameters dsaParameters = obj as DsaParameters; if (dsaParameters == null) return false; return Equals(dsaParameters); } protected bool Equals(DsaParameters other) { if (p.Equals(other.p) && q.Equals(other.q)) return g.Equals(other.g); return false; } public override int GetHashCode() { return p.GetHashCode() ^ q.GetHashCode() ^ g.GetHashCode(); } } }