PBEPBKDF2$BasePBKDF2.smali
.class public Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;
.super Lorg/spongycastle/jcajce/provider/symmetric/util/BaseSecretKeyFactory;
.source "PBEPBKDF2.java"
# instance fields
.field private scheme:I
# direct methods
.method public constructor <init>(Ljava/lang/String;I)V
.registers 4
.prologue
.line 125
sget-object v0, Lorg/spongycastle/asn1/pkcs/PKCSObjectIdentifiers;->id_PBKDF2:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
invoke-direct {p0, p1, v0}, Lorg/spongycastle/jcajce/provider/symmetric/util/BaseSecretKeyFactory;-><init>(Ljava/lang/String;Lorg/spongycastle/asn1/ASN1ObjectIdentifier;)V
.line 127
iput p2, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->scheme:I
.line 128
return-void
.end method
.method private getDigestCode(Lorg/spongycastle/asn1/ASN1ObjectIdentifier;)I
.registers 5
.prologue
.line 189
sget-object v0, Lorg/spongycastle/asn1/cryptopro/CryptoProObjectIdentifiers;->gostR3411Hmac:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
invoke-virtual {p1, v0}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_a
.line 191
const/4 v0, 0x6
.line 195
:goto_9
return v0
.line 193
:cond_a
sget-object v0, Lorg/spongycastle/asn1/pkcs/PKCSObjectIdentifiers;->id_hmacWithSHA1:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
invoke-virtual {p1, v0}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_14
.line 195
const/4 v0, 0x1
goto :goto_9
.line 198
:cond_14
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Invalid KeySpec: unknown PRF algorithm "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.end method
# virtual methods
.method protected engineGenerateSecret(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
.registers 11
.prologue
const/4 v4, 0x1
const/4 v6, -0x1
.line 134
instance-of v0, p1, Ljavax/crypto/spec/PBEKeySpec;
if-eqz v0, :cond_a3
move-object v7, p1
.line 136
check-cast v7, Ljavax/crypto/spec/PBEKeySpec;
.line 138
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getSalt()[B
move-result-object v0
if-nez v0, :cond_17
.line 140
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
const-string v1, "missing required salt"
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.line 143
:cond_17
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getIterationCount()I
move-result v0
if-gtz v0, :cond_36
.line 145
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "positive iteration count required: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 146
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getIterationCount()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.line 149
:cond_36
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getKeyLength()I
move-result v0
if-gtz v0, :cond_55
.line 151
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "positive key length required: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 152
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getKeyLength()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.line 155
:cond_55
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getPassword()[C
move-result-object v0
array-length v0, v0
if-nez v0, :cond_64
.line 157
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "password empty"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 160
:cond_64
instance-of v0, v7, Lorg/spongycastle/jcajce/spec/PBKDF2KeySpec;
if-eqz v0, :cond_8d
move-object v0, v7
.line 162
check-cast v0, Lorg/spongycastle/jcajce/spec/PBKDF2KeySpec;
.line 164
invoke-virtual {v0}, Lorg/spongycastle/jcajce/spec/PBKDF2KeySpec;->getPrf()Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;->getAlgorithm()Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
move-result-object v0
invoke-direct {p0, v0}, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->getDigestCode(Lorg/spongycastle/asn1/ASN1ObjectIdentifier;)I
move-result v4
.line 165
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getKeyLength()I
move-result v5
.line 167
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->scheme:I
invoke-static {v7, v0, v4, v5}, Lorg/spongycastle/jcajce/provider/symmetric/util/PBE$Util;->makePBEMacParameters(Ljavax/crypto/spec/PBEKeySpec;III)Lorg/spongycastle/crypto/CipherParameters;
move-result-object v8
.line 169
new-instance v0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->algName:Ljava/lang/String;
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->algOid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
iget v3, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->scheme:I
invoke-direct/range {v0 .. v8}, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;-><init>(Ljava/lang/String;Lorg/spongycastle/asn1/ASN1ObjectIdentifier;IIIILjavax/crypto/spec/PBEKeySpec;Lorg/spongycastle/crypto/CipherParameters;)V
.line 178
:goto_8c
return-object v0
.line 174
:cond_8d
invoke-virtual {v7}, Ljavax/crypto/spec/PBEKeySpec;->getKeyLength()I
move-result v5
.line 176
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->scheme:I
invoke-static {v7, v0, v4, v5}, Lorg/spongycastle/jcajce/provider/symmetric/util/PBE$Util;->makePBEMacParameters(Ljavax/crypto/spec/PBEKeySpec;III)Lorg/spongycastle/crypto/CipherParameters;
move-result-object v8
.line 178
new-instance v0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->algName:Ljava/lang/String;
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->algOid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
iget v3, p0, Lorg/spongycastle/jcajce/provider/symmetric/PBEPBKDF2$BasePBKDF2;->scheme:I
invoke-direct/range {v0 .. v8}, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;-><init>(Ljava/lang/String;Lorg/spongycastle/asn1/ASN1ObjectIdentifier;IIIILjavax/crypto/spec/PBEKeySpec;Lorg/spongycastle/crypto/CipherParameters;)V
goto :goto_8c
.line 182
:cond_a3
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
const-string v1, "Invalid KeySpec"
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.end method