1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using Best.HTTP.SecureProtocol.Org.BouncyCastle.Math;
- using Best.HTTP.SecureProtocol.Org.BouncyCastle.Utilities;
- namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.CryptoPro
- {
- public class Gost3410ParamSetParameters
- : Asn1Encodable
- {
- private readonly int keySize;
- private readonly DerInteger p, q, a;
- public static Gost3410ParamSetParameters GetInstance(Asn1TaggedObject obj, bool explicitly)
- {
- return GetInstance(Asn1Sequence.GetInstance(obj, explicitly));
- }
- public static Gost3410ParamSetParameters GetInstance(object obj)
- {
- if (obj == null || obj is Gost3410ParamSetParameters)
- return (Gost3410ParamSetParameters) obj;
- if (obj is Asn1Sequence seq)
- return new Gost3410ParamSetParameters(seq);
- throw new ArgumentException("Invalid GOST3410Parameter: " + Org.BouncyCastle.Utilities.Platform.GetTypeName(obj));
- }
- public Gost3410ParamSetParameters(
- int keySize,
- BigInteger p,
- BigInteger q,
- BigInteger a)
- {
- this.keySize = keySize;
- this.p = new DerInteger(p);
- this.q = new DerInteger(q);
- this.a = new DerInteger(a);
- }
- private Gost3410ParamSetParameters(
- Asn1Sequence seq)
- {
- if (seq.Count != 4)
- throw new ArgumentException("Wrong number of elements in sequence", "seq");
- this.keySize = DerInteger.GetInstance(seq[0]).IntValueExact;
- this.p = DerInteger.GetInstance(seq[1]);
- this.q = DerInteger.GetInstance(seq[2]);
- this.a = DerInteger.GetInstance(seq[3]);
- }
- public int KeySize
- {
- get { return keySize; }
- }
- public BigInteger P
- {
- get { return p.PositiveValue; }
- }
- public BigInteger Q
- {
- get { return q.PositiveValue; }
- }
- public BigInteger A
- {
- get { return a.PositiveValue; }
- }
- public override Asn1Object ToAsn1Object()
- {
- return new DerSequence(new DerInteger(keySize), p, q, a);
- }
- }
- }
- #pragma warning restore
- #endif
|