1 /* 2 * Copyright (C) 2014 The Android Open Source Project 3 * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved. 4 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 5 * 6 * This code is free software; you can redistribute it and/or modify it 7 * under the terms of the GNU General Public License version 2 only, as 8 * published by the Free Software Foundation. Oracle designates this 9 * particular file as subject to the "Classpath" exception as provided 10 * by Oracle in the LICENSE file that accompanied this code. 11 * 12 * This code is distributed in the hope that it will be useful, but WITHOUT 13 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 14 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 15 * version 2 for more details (a copy is included in the LICENSE file that 16 * accompanied this code). 17 * 18 * You should have received a copy of the GNU General Public License version 19 * 2 along with this work; if not, write to the Free Software Foundation, 20 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 21 * 22 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 23 * or visit www.oracle.com if you need additional information or have any 24 * questions. 25 */ 26 package java.security.spec; 27 28 import java.math.BigInteger; 29 30 /** 31 * This immutable class specifies the set of domain parameters 32 * used with elliptic curve cryptography (ECC). 33 * 34 * @see AlgorithmParameterSpec 35 * 36 * @author Valerie Peng 37 * 38 * @since 1.5 39 */ 40 public class ECParameterSpec implements AlgorithmParameterSpec { 41 42 private final EllipticCurve curve; 43 private final ECPoint g; 44 private final BigInteger n; 45 private final int h; 46 47 /** 48 * Creates elliptic curve domain parameters based on the 49 * specified values. 50 * @param curve the elliptic curve which this parameter 51 * defines. 52 * @param g the generator which is also known as the base point. 53 * @param n the order of the generator {@code g}. 54 * @param h the cofactor. 55 * @throws NullPointerException if {@code curve}, 56 * {@code g}, or {@code n} is null. 57 * @throws IllegalArgumentException if {@code n} 58 * or {@code h} is not positive. 59 */ ECParameterSpec(EllipticCurve curve, ECPoint g, BigInteger n, int h)60 public ECParameterSpec(EllipticCurve curve, ECPoint g, 61 BigInteger n, int h) { 62 if (curve == null) { 63 throw new NullPointerException("curve is null"); 64 } 65 if (g == null) { 66 throw new NullPointerException("g is null"); 67 } 68 if (n == null) { 69 throw new NullPointerException("n is null"); 70 } 71 if (n.signum() != 1) { 72 throw new IllegalArgumentException("n is not positive"); 73 } 74 if (h <= 0) { 75 throw new IllegalArgumentException("h is not positive"); 76 } 77 this.curve = curve; 78 this.g = g; 79 this.n = n; 80 this.h = h; 81 } 82 83 /** 84 * Returns the elliptic curve that this parameter defines. 85 * @return the elliptic curve that this parameter defines. 86 */ getCurve()87 public EllipticCurve getCurve() { 88 return curve; 89 } 90 91 /** 92 * Returns the generator which is also known as the base point. 93 * @return the generator which is also known as the base point. 94 */ getGenerator()95 public ECPoint getGenerator() { 96 return g; 97 } 98 99 /** 100 * Returns the order of the generator. 101 * @return the order of the generator. 102 */ getOrder()103 public BigInteger getOrder() { 104 return n; 105 } 106 107 /** 108 * Returns the cofactor. 109 * @return the cofactor. 110 */ getCofactor()111 public int getCofactor() { 112 return h; 113 } 114 // BEGIN Android-added: Store the curve name as part of the parameters 115 // Knowing the name of the curve sometimes allows implementations to operate 116 // more efficiently. 117 private String curveName; 118 119 /** 120 * Used to set the curve name if available. 121 * 122 * @hide 123 */ setCurveName(String curveName)124 public void setCurveName(String curveName) { 125 this.curveName = curveName; 126 } 127 128 /** 129 * Returns the name of the curve if this is a named curve. Returns 130 * {@code null} if this is not known to be a named curve. 131 * 132 * @hide 133 */ getCurveName()134 public String getCurveName() { 135 return curveName; 136 } 137 // END Android-added: Store the curve name as part of the parameters 138 } 139