summary refs log tree commit diff
path: root/Crypto/src/crypto/parameters/ECPrivateKeyParameters.cs
blob: e6352d5d1f757d39a5bb63bee6c7d24d1501d966 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
using System;
using System.Globalization;

using Org.BouncyCastle.Asn1;
using Org.BouncyCastle.Math;

namespace Org.BouncyCastle.Crypto.Parameters
{
    public class ECPrivateKeyParameters
		: ECKeyParameters
    {
		private readonly BigInteger d;

		public ECPrivateKeyParameters(
			BigInteger			d,
			ECDomainParameters	parameters)
			: this("EC", d, parameters)
		{
		}

		[Obsolete("Use version with explicit 'algorithm' parameter")]
		public ECPrivateKeyParameters(
			BigInteger			d,
			DerObjectIdentifier publicKeyParamSet)
			: base("ECGOST3410", true, publicKeyParamSet)
		{
			if (d == null)
				throw new ArgumentNullException("d");

			this.d = d;
		}

		public ECPrivateKeyParameters(
			string				algorithm,
			BigInteger			d,
			ECDomainParameters	parameters)
			: base(algorithm, true, parameters)
		{
			if (d == null)
				throw new ArgumentNullException("d");

			this.d = d;
		}

		public ECPrivateKeyParameters(
			string				algorithm,
			BigInteger			d,
			DerObjectIdentifier publicKeyParamSet)
			: base(algorithm, true, publicKeyParamSet)
		{
			if (d == null)
				throw new ArgumentNullException("d");

			this.d = d;
		}

		public BigInteger D
		{
			get { return d; }
		}

		public override bool Equals(
			object obj)
        {
			if (obj == this)
				return true;

			ECPrivateKeyParameters other = obj as ECPrivateKeyParameters;

			if (other == null)
				return false;

			return Equals(other);
        }

		protected bool Equals(
			ECPrivateKeyParameters other)
		{
			return d.Equals(other.d) && base.Equals(other);
		}

		public override int GetHashCode()
        {
            return d.GetHashCode() ^ base.GetHashCode();
        }
	}
}