diff --git a/core/java/src/net/i2p/crypto/KeyGenerator.java b/core/java/src/net/i2p/crypto/KeyGenerator.java index 025da6f59281d2a71b3e92b033484ba4a91a44d6..34cd1f3465dbf6b76d72b4dfa608f86550c8a94c 100644 --- a/core/java/src/net/i2p/crypto/KeyGenerator.java +++ b/core/java/src/net/i2p/crypto/KeyGenerator.java @@ -159,6 +159,7 @@ public class KeyGenerator { /** Convert a PrivateKey to its corresponding PublicKey * @param priv PrivateKey object * @return the corresponding PublicKey object + * @throws IllegalArgumentException on bad key */ public static PublicKey getPublicKey(PrivateKey priv) { BigInteger a = new NativeBigInteger(1, priv.toByteArray()); @@ -265,8 +266,11 @@ public class KeyGenerator { * * @param priv a SigningPrivateKey object * @return a SigningPublicKey object + * @throws IllegalArgumentException on bad key */ public static SigningPublicKey getSigningPublicKey(SigningPrivateKey priv) { + if (priv.getType() != SigType.DSA_SHA1) + throw new IllegalArgumentException(); BigInteger x = new NativeBigInteger(1, priv.toByteArray()); BigInteger y = CryptoConstants.dsag.modPow(x, CryptoConstants.dsap); SigningPublicKey pub = new SigningPublicKey();