AlgorithmParameterGeneratorSpi.smali
.class public Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;
.super Lorg/spongycastle/jcajce/provider/asymmetric/util/BaseAlgorithmParameterGeneratorSpi;
.source "AlgorithmParameterGeneratorSpi.java"
# instance fields
.field protected params:Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;
.field protected random:Ljava/security/SecureRandom;
.field protected strength:I
# direct methods
.method public constructor <init>()V
.registers 2
.prologue
.line 16
invoke-direct {p0}, Lorg/spongycastle/jcajce/provider/asymmetric/util/BaseAlgorithmParameterGeneratorSpi;-><init>()V
.line 20
const/16 v0, 0x400
iput v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->strength:I
return-void
.end method
# virtual methods
.method protected engineGenerateParameters()Ljava/security/AlgorithmParameters;
.registers 7
.prologue
const/16 v5, 0x50
const/16 v4, 0x400
.line 58
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->strength:I
if-gt v0, v4, :cond_4b
.line 60
new-instance v0, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;
invoke-direct {v0}, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;-><init>()V
.line 67
:goto_d
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->random:Ljava/security/SecureRandom;
if-nez v1, :cond_18
.line 69
new-instance v1, Ljava/security/SecureRandom;
invoke-direct {v1}, Ljava/security/SecureRandom;-><init>()V
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->random:Ljava/security/SecureRandom;
.line 72
:cond_18
iget v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->strength:I
if-ne v1, v4, :cond_56
.line 74
new-instance v1, Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;
const/16 v2, 0xa0
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->random:Ljava/security/SecureRandom;
invoke-direct {v1, v4, v2, v5, v3}, Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;-><init>(IIILjava/security/SecureRandom;)V
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->params:Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;
.line 75
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->params:Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;
invoke-virtual {v0, v1}, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;->init(Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;)V
.line 87
:goto_2c
invoke-virtual {v0}, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;->generateParameters()Lorg/spongycastle/crypto/params/DSAParameters;
move-result-object v0
.line 93
:try_start_30
const-string v1, "DSA"
invoke-virtual {p0, v1}, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->createParametersInstance(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
move-result-object v1
.line 94
new-instance v2, Ljava/security/spec/DSAParameterSpec;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/DSAParameters;->getP()Ljava/math/BigInteger;
move-result-object v3
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/DSAParameters;->getQ()Ljava/math/BigInteger;
move-result-object v4
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/DSAParameters;->getG()Ljava/math/BigInteger;
move-result-object v0
invoke-direct {v2, v3, v4, v0}, Ljava/security/spec/DSAParameterSpec;-><init>(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
invoke-virtual {v1, v2}, Ljava/security/AlgorithmParameters;->init(Ljava/security/spec/AlgorithmParameterSpec;)V
:try_end_4a
.catch Ljava/lang/Exception; {:try_start_30 .. :try_end_4a} :catch_77
.line 101
return-object v1
.line 64
:cond_4b
new-instance v0, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;
new-instance v1, Lorg/spongycastle/crypto/digests/SHA256Digest;
invoke-direct {v1}, Lorg/spongycastle/crypto/digests/SHA256Digest;-><init>()V
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;-><init>(Lorg/spongycastle/crypto/Digest;)V
goto :goto_d
.line 77
:cond_56
iget v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->strength:I
if-le v1, v4, :cond_6d
.line 79
new-instance v1, Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->strength:I
const/16 v3, 0x100
iget-object v4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->random:Ljava/security/SecureRandom;
invoke-direct {v1, v2, v3, v5, v4}, Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;-><init>(IIILjava/security/SecureRandom;)V
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->params:Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;
.line 80
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->params:Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;
invoke-virtual {v0, v1}, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;->init(Lorg/spongycastle/crypto/params/DSAParameterGenerationParameters;)V
goto :goto_2c
.line 84
:cond_6d
iget v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->strength:I
const/16 v2, 0x14
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->random:Ljava/security/SecureRandom;
invoke-virtual {v0, v1, v2, v3}, Lorg/spongycastle/crypto/generators/DSAParametersGenerator;->init(IILjava/security/SecureRandom;)V
goto :goto_2c
.line 96
:catch_77
move-exception v0
.line 98
new-instance v1, Ljava/lang/RuntimeException;
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method protected engineInit(ILjava/security/SecureRandom;)V
.registers 5
.prologue
const/16 v1, 0x400
.line 27
const/16 v0, 0x200
if-lt p1, v0, :cond_a
const/16 v0, 0xc00
if-le p1, v0, :cond_12
.line 29
:cond_a
new-instance v0, Ljava/security/InvalidParameterException;
const-string v1, "strength must be from 512 - 3072"
invoke-direct {v0, v1}, Ljava/security/InvalidParameterException;-><init>(Ljava/lang/String;)V
throw v0
.line 32
:cond_12
if-gt p1, v1, :cond_20
rem-int/lit8 v0, p1, 0x40
if-eqz v0, :cond_20
.line 34
new-instance v0, Ljava/security/InvalidParameterException;
const-string v1, "strength must be a multiple of 64 below 1024 bits."
invoke-direct {v0, v1}, Ljava/security/InvalidParameterException;-><init>(Ljava/lang/String;)V
throw v0
.line 37
:cond_20
if-le p1, v1, :cond_2e
rem-int/lit16 v0, p1, 0x400
if-eqz v0, :cond_2e
.line 39
new-instance v0, Ljava/security/InvalidParameterException;
const-string v1, "strength must be a multiple of 1024 above 1024 bits."
invoke-direct {v0, v1}, Ljava/security/InvalidParameterException;-><init>(Ljava/lang/String;)V
throw v0
.line 42
:cond_2e
iput p1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->strength:I
.line 43
iput-object p2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dsa/AlgorithmParameterGeneratorSpi;->random:Ljava/security/SecureRandom;
.line 44
return-void
.end method
.method protected engineInit(Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
.registers 5
.prologue
.line 51
new-instance v0, Ljava/security/InvalidAlgorithmParameterException;
const-string v1, "No supported AlgorithmParameterSpec for DSA parameter generation."
invoke-direct {v0, v1}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw v0
.end method