aboutsummaryrefslogtreecommitdiff
path: root/javascript/EcUtil.js
blob: 47efb25bc03596d2ac5ca76814892a0f9a8a4326 (plain)
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/**
 * @license
 * Copyright 2017 Google Inc. All rights reserved.
 * Licensed under the Apache License, Version 2.0 (the 'License');
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an 'AS IS' BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/**
 * Some utilities for testing Elliptic curve crypto.
 *
 */
goog.provide('wycheproof.EcUtil');
goog.require('wycheproof.BigInteger');
goog.require('wycheproof.BigPrimeInteger');

var BigInteger = wycheproof.BigInteger;
var BigPrimeInteger = wycheproof.BigPrimeInteger;

/**
 * Parameters of a NIST-recommended curve.
 * @param {!number} keySize The bit length of the order n
 * @param {!string} hexP The prime modulus p in hex format
 * @param {!string} hexN The order n in hex format
 * @param {!string} hexB The coefficient b in hex format
 * @param {!string} hexGX The x-coordinate of the public curve point
 * @param {!string} hexGY The y-coordinate of the public curve point
 */
var NistCurveSpec = function(keySize, hexP, hexN, hexB, hexGX, hexGY) {
  this.keySize = keySize;
  this.p = new BigPrimeInteger(BigInteger.fromHex(hexP).toByteArray());
  this.n = new BigPrimeInteger(BigInteger.fromHex(hexN).toByteArray());
  this.b = BigInteger.fromHex(hexB);
  this.gx = BigInteger.fromHex(hexGX);
  this.gy = BigInteger.fromHex(hexGY);
};


/**
 * Returns the NIST's recommended parameters of the given curve.
 * @param {!string} name The curve name
 *
 * @return {NistCurveSpec}
 */
wycheproof.EcUtil.getCurveSpec = function(name) {
  switch (name) {
    case 'P-256':
      return wycheproof.EcUtil.getNistP256Params();
    case 'P-384':
      return wycheproof.EcUtil.getNistP384Params();
    case 'P-521':
      return wycheproof.EcUtil.getNistP521Params();
    default:
      throw 'Curve not implemented:' + name;
  }
};

/**
 * Returns the NIST's recommended parameters of the secp256r1 curve.
 *
 * @return {NistCurveSpec}
 */
wycheproof.EcUtil.getNistP256Params = function() {
  return new NistCurveSpec(
      256,
      'ffffffff00000001000000000000000000000000ffffffffffffffffffffffff',
      'ffffffff00000000ffffffffffffffffbce6faada7179e84f3b9cac2fc632551',
      '5ac635d8aa3a93e7b3ebbd55769886bc651d06b0cc53b0f63bce3c3e27d2604b',
      '6b17d1f2e12c4247f8bce6e563a440f277037d812deb33a0f4a13945d898c296',
      '4fe342e2fe1a7f9b8ee7eb4a7c0f9e162bce33576b315ececbb6406837bf51f5');
};


/**
 * Returns the NIST's recommended parameters of the secp384r1 curve.
 *
 * @return {NistCurveSpec}
 */
wycheproof.EcUtil.getNistP384Params = function() {
  return new NistCurveSpec(
      384,
      'fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'
          + 'ffeffffffff0000000000000000ffffffff',
      'ffffffffffffffffffffffffffffffffffffffffffffffffc7634d81f4372'
          + 'ddf581a0db248b0a77aecec196accc52973',
      'b3312fa7e23ee7e4988e056be3f82d19181d9c6efe8141120314088f5013875a'
          + 'c656398d8a2ed19d2a85c8edd3ec2aef',
      'aa87ca22be8b05378eb1c71ef320ad746e1d3b628ba79b9859f741e082542a38'
          + '5502f25dbf55296c3a545e3872760ab7',
      '3617de4a96262c6f5d9e98bf9292dc29f8f41dbd289a147ce9da3113b5f0b8c0'
          + '0a60b1ce1d7e819d7a431d7c90ea0e5f');
};


/**
 * Returns the NIST's recommended parameters of the secp521r1 curve.
 *
 * @return {NistCurveSpec}
 */
wycheproof.EcUtil.getNistP521Params = function() {
return new NistCurveSpec(
    521,
    '1fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'
        + 'fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff',
    '1fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'
        + 'a51868783bf2f966b7fcc0148f709a5d03bb5c9b8899c47aebb6fb71e91386409',
    '051953eb9618e1c9a1f929a21a0b68540eea2da725b99b315f3b8b489918ef10'
        + '9e156193951ec7e937b1652c0bd3bb1bf073573df883d2c34f1ef451fd46b503f00',
    'c6858e06b70404e9cd9e3ecb662395b4429c648139053fb521f828af606b4d3d'
        + 'baa14b5e77efe75928fe1dc127a2ffa8de3348b3c1856a429bf97e7e31c2e5bd66',
    '11839296a789a3bc0045c8a5fb42c7d1bd998f54449579b446817afbd17273e6'
        + '62c97ee72995ef42640c550b9013fad0761353c7086a272c24088be94769fd16650');
};