ElGamalUtil.smali
.class public Lorg/spongycastle/jcajce/provider/asymmetric/elgamal/ElGamalUtil;
.super Ljava/lang/Object;
.source "ElGamalUtil.java"
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 21
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static generatePrivateKeyParameter(Ljava/security/PrivateKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.registers 6
.prologue
.line 49
instance-of v0, p0, Lorg/spongycastle/jce/interfaces/ElGamalPrivateKey;
if-eqz v0, :cond_25
.line 51
check-cast p0, Lorg/spongycastle/jce/interfaces/ElGamalPrivateKey;
.line 53
new-instance v0, Lorg/spongycastle/crypto/params/ElGamalPrivateKeyParameters;
invoke-interface {p0}, Lorg/spongycastle/jce/interfaces/ElGamalPrivateKey;->getX()Ljava/math/BigInteger;
move-result-object v1
new-instance v2, Lorg/spongycastle/crypto/params/ElGamalParameters;
.line 54
invoke-interface {p0}, Lorg/spongycastle/jce/interfaces/ElGamalPrivateKey;->getParameters()Lorg/spongycastle/jce/spec/ElGamalParameterSpec;
move-result-object v3
invoke-virtual {v3}, Lorg/spongycastle/jce/spec/ElGamalParameterSpec;->getP()Ljava/math/BigInteger;
move-result-object v3
invoke-interface {p0}, Lorg/spongycastle/jce/interfaces/ElGamalPrivateKey;->getParameters()Lorg/spongycastle/jce/spec/ElGamalParameterSpec;
move-result-object v4
invoke-virtual {v4}, Lorg/spongycastle/jce/spec/ElGamalParameterSpec;->getG()Ljava/math/BigInteger;
move-result-object v4
invoke-direct {v2, v3, v4}, Lorg/spongycastle/crypto/params/ElGamalParameters;-><init>(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
invoke-direct {v0, v1, v2}, Lorg/spongycastle/crypto/params/ElGamalPrivateKeyParameters;-><init>(Ljava/math/BigInteger;Lorg/spongycastle/crypto/params/ElGamalParameters;)V
.line 61
:goto_24
return-object v0
.line 56
:cond_25
instance-of v0, p0, Ljavax/crypto/interfaces/DHPrivateKey;
if-eqz v0, :cond_4a
.line 58
check-cast p0, Ljavax/crypto/interfaces/DHPrivateKey;
.line 60
new-instance v0, Lorg/spongycastle/crypto/params/ElGamalPrivateKeyParameters;
invoke-interface {p0}, Ljavax/crypto/interfaces/DHPrivateKey;->getX()Ljava/math/BigInteger;
move-result-object v1
new-instance v2, Lorg/spongycastle/crypto/params/ElGamalParameters;
.line 61
invoke-interface {p0}, Ljavax/crypto/interfaces/DHPrivateKey;->getParams()Ljavax/crypto/spec/DHParameterSpec;
move-result-object v3
invoke-virtual {v3}, Ljavax/crypto/spec/DHParameterSpec;->getP()Ljava/math/BigInteger;
move-result-object v3
invoke-interface {p0}, Ljavax/crypto/interfaces/DHPrivateKey;->getParams()Ljavax/crypto/spec/DHParameterSpec;
move-result-object v4
invoke-virtual {v4}, Ljavax/crypto/spec/DHParameterSpec;->getG()Ljava/math/BigInteger;
move-result-object v4
invoke-direct {v2, v3, v4}, Lorg/spongycastle/crypto/params/ElGamalParameters;-><init>(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
invoke-direct {v0, v1, v2}, Lorg/spongycastle/crypto/params/ElGamalPrivateKeyParameters;-><init>(Ljava/math/BigInteger;Lorg/spongycastle/crypto/params/ElGamalParameters;)V
goto :goto_24
.line 64
:cond_4a
new-instance v0, Ljava/security/InvalidKeyException;
const-string v1, "can\'t identify private key for El Gamal."
invoke-direct {v0, v1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public static generatePublicKeyParameter(Ljava/security/PublicKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.registers 6
.prologue
.line 27
instance-of v0, p0, Lorg/spongycastle/jce/interfaces/ElGamalPublicKey;
if-eqz v0, :cond_25
.line 29
check-cast p0, Lorg/spongycastle/jce/interfaces/ElGamalPublicKey;
.line 31
new-instance v0, Lorg/spongycastle/crypto/params/ElGamalPublicKeyParameters;
invoke-interface {p0}, Lorg/spongycastle/jce/interfaces/ElGamalPublicKey;->getY()Ljava/math/BigInteger;
move-result-object v1
new-instance v2, Lorg/spongycastle/crypto/params/ElGamalParameters;
.line 32
invoke-interface {p0}, Lorg/spongycastle/jce/interfaces/ElGamalPublicKey;->getParameters()Lorg/spongycastle/jce/spec/ElGamalParameterSpec;
move-result-object v3
invoke-virtual {v3}, Lorg/spongycastle/jce/spec/ElGamalParameterSpec;->getP()Ljava/math/BigInteger;
move-result-object v3
invoke-interface {p0}, Lorg/spongycastle/jce/interfaces/ElGamalPublicKey;->getParameters()Lorg/spongycastle/jce/spec/ElGamalParameterSpec;
move-result-object v4
invoke-virtual {v4}, Lorg/spongycastle/jce/spec/ElGamalParameterSpec;->getG()Ljava/math/BigInteger;
move-result-object v4
invoke-direct {v2, v3, v4}, Lorg/spongycastle/crypto/params/ElGamalParameters;-><init>(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
invoke-direct {v0, v1, v2}, Lorg/spongycastle/crypto/params/ElGamalPublicKeyParameters;-><init>(Ljava/math/BigInteger;Lorg/spongycastle/crypto/params/ElGamalParameters;)V
.line 39
:goto_24
return-object v0
.line 34
:cond_25
instance-of v0, p0, Ljavax/crypto/interfaces/DHPublicKey;
if-eqz v0, :cond_4a
.line 36
check-cast p0, Ljavax/crypto/interfaces/DHPublicKey;
.line 38
new-instance v0, Lorg/spongycastle/crypto/params/ElGamalPublicKeyParameters;
invoke-interface {p0}, Ljavax/crypto/interfaces/DHPublicKey;->getY()Ljava/math/BigInteger;
move-result-object v1
new-instance v2, Lorg/spongycastle/crypto/params/ElGamalParameters;
.line 39
invoke-interface {p0}, Ljavax/crypto/interfaces/DHPublicKey;->getParams()Ljavax/crypto/spec/DHParameterSpec;
move-result-object v3
invoke-virtual {v3}, Ljavax/crypto/spec/DHParameterSpec;->getP()Ljava/math/BigInteger;
move-result-object v3
invoke-interface {p0}, Ljavax/crypto/interfaces/DHPublicKey;->getParams()Ljavax/crypto/spec/DHParameterSpec;
move-result-object v4
invoke-virtual {v4}, Ljavax/crypto/spec/DHParameterSpec;->getG()Ljava/math/BigInteger;
move-result-object v4
invoke-direct {v2, v3, v4}, Lorg/spongycastle/crypto/params/ElGamalParameters;-><init>(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
invoke-direct {v0, v1, v2}, Lorg/spongycastle/crypto/params/ElGamalPublicKeyParameters;-><init>(Ljava/math/BigInteger;Lorg/spongycastle/crypto/params/ElGamalParameters;)V
goto :goto_24
.line 42
:cond_4a
new-instance v0, Ljava/security/InvalidKeyException;
const-string v1, "can\'t identify public key for El Gamal."
invoke-direct {v0, v1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.end method