diff options
Diffstat (limited to 'android_bcprov/src/main/java/com/android/org/bouncycastle/jcajce/provider/asymmetric/util/DHUtil.java')
-rw-r--r-- | android_bcprov/src/main/java/com/android/org/bouncycastle/jcajce/provider/asymmetric/util/DHUtil.java | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/android_bcprov/src/main/java/com/android/org/bouncycastle/jcajce/provider/asymmetric/util/DHUtil.java b/android_bcprov/src/main/java/com/android/org/bouncycastle/jcajce/provider/asymmetric/util/DHUtil.java new file mode 100644 index 00000000..ba3fd493 --- /dev/null +++ b/android_bcprov/src/main/java/com/android/org/bouncycastle/jcajce/provider/asymmetric/util/DHUtil.java @@ -0,0 +1,56 @@ +/* GENERATED SOURCE. DO NOT MODIFY. */ +package com.android.org.bouncycastle.jcajce.provider.asymmetric.util; + +import java.security.InvalidKeyException; +import java.security.PrivateKey; +import java.security.PublicKey; + +import javax.crypto.interfaces.DHPrivateKey; +import javax.crypto.interfaces.DHPublicKey; + +import com.android.org.bouncycastle.crypto.params.AsymmetricKeyParameter; +import com.android.org.bouncycastle.crypto.params.DHParameters; +import com.android.org.bouncycastle.crypto.params.DHPrivateKeyParameters; +import com.android.org.bouncycastle.crypto.params.DHPublicKeyParameters; +import com.android.org.bouncycastle.jcajce.provider.asymmetric.dh.BCDHPublicKey; + +/** + * utility class for converting jce/jca DH objects + * objects into their org.bouncycastle.crypto counterparts. + */ +public class DHUtil +{ + static public AsymmetricKeyParameter generatePublicKeyParameter( + PublicKey key) + throws InvalidKeyException + { + if (key instanceof BCDHPublicKey) + { + return ((BCDHPublicKey)key).engineGetKeyParameters(); + } + if (key instanceof DHPublicKey) + { + DHPublicKey k = (DHPublicKey)key; + + return new DHPublicKeyParameters(k.getY(), + new DHParameters(k.getParams().getP(), k.getParams().getG(), null, k.getParams().getL())); + } + + throw new InvalidKeyException("can't identify DH public key."); + } + + static public AsymmetricKeyParameter generatePrivateKeyParameter( + PrivateKey key) + throws InvalidKeyException + { + if (key instanceof DHPrivateKey) + { + DHPrivateKey k = (DHPrivateKey)key; + + return new DHPrivateKeyParameters(k.getX(), + new DHParameters(k.getParams().getP(), k.getParams().getG(), null, k.getParams().getL())); + } + + throw new InvalidKeyException("can't identify DH private key."); + } +} |