BCPBEKey.smali
.class public Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;
.super Ljava/lang/Object;
.source "BCPBEKey.java"
# interfaces
.implements Ljavax/crypto/interfaces/PBEKey;
# instance fields
.field algorithm:Ljava/lang/String;
.field digest:I
.field ivSize:I
.field keySize:I
.field oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.field param:Lorg/spongycastle/crypto/CipherParameters;
.field pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
.field tryWrong:Z
.field type:I
# direct methods
.method public constructor <init>(Ljava/lang/String;Lorg/spongycastle/asn1/ASN1ObjectIdentifier;IIIILjavax/crypto/spec/PBEKeySpec;Lorg/spongycastle/crypto/CipherParameters;)V
.registers 10
.prologue
.line 37
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 23
const/4 v0, 0x0
iput-boolean v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->tryWrong:Z
.line 38
iput-object p1, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->algorithm:Ljava/lang/String;
.line 39
iput-object p2, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.line 40
iput p3, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->type:I
.line 41
iput p4, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->digest:I
.line 42
iput p5, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->keySize:I
.line 43
iput p6, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->ivSize:I
.line 44
iput-object p7, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
.line 45
iput-object p8, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->param:Lorg/spongycastle/crypto/CipherParameters;
.line 46
return-void
.end method
# virtual methods
.method public getAlgorithm()Ljava/lang/String;
.registers 2
.prologue
.line 50
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->algorithm:Ljava/lang/String;
return-object v0
.end method
.method getDigest()I
.registers 2
.prologue
.line 99
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->digest:I
return v0
.end method
.method public getEncoded()[B
.registers 3
.prologue
.line 60
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->param:Lorg/spongycastle/crypto/CipherParameters;
if-eqz v0, :cond_1e
.line 64
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->param:Lorg/spongycastle/crypto/CipherParameters;
instance-of v0, v0, Lorg/spongycastle/crypto/params/ParametersWithIV;
if-eqz v0, :cond_19
.line 66
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->param:Lorg/spongycastle/crypto/CipherParameters;
check-cast v0, Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/params/KeyParameter;
.line 73
:goto_14
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/KeyParameter;->getKey()[B
move-result-object v0
.line 87
:goto_18
return-object v0
.line 70
:cond_19
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->param:Lorg/spongycastle/crypto/CipherParameters;
check-cast v0, Lorg/spongycastle/crypto/params/KeyParameter;
goto :goto_14
.line 77
:cond_1e
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->type:I
const/4 v1, 0x2
if-ne v0, v1, :cond_2e
.line 79
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
invoke-virtual {v0}, Ljavax/crypto/spec/PBEKeySpec;->getPassword()[C
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/crypto/PBEParametersGenerator;->PKCS12PasswordToBytes([C)[B
move-result-object v0
goto :goto_18
.line 81
:cond_2e
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->type:I
const/4 v1, 0x5
if-ne v0, v1, :cond_3e
.line 83
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
invoke-virtual {v0}, Ljavax/crypto/spec/PBEKeySpec;->getPassword()[C
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/crypto/PBEParametersGenerator;->PKCS5PasswordToUTF8Bytes([C)[B
move-result-object v0
goto :goto_18
.line 87
:cond_3e
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
invoke-virtual {v0}, Ljavax/crypto/spec/PBEKeySpec;->getPassword()[C
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/crypto/PBEParametersGenerator;->PKCS5PasswordToBytes([C)[B
move-result-object v0
goto :goto_18
.end method
.method public getFormat()Ljava/lang/String;
.registers 2
.prologue
.line 55
const-string v0, "RAW"
return-object v0
.end method
.method public getIterationCount()I
.registers 2
.prologue
.line 138
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
invoke-virtual {v0}, Ljavax/crypto/spec/PBEKeySpec;->getIterationCount()I
move-result v0
return v0
.end method
.method public getIvSize()I
.registers 2
.prologue
.line 109
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->ivSize:I
return v0
.end method
.method getKeySize()I
.registers 2
.prologue
.line 104
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->keySize:I
return v0
.end method
.method public getOID()Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.registers 2
.prologue
.line 143
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
return-object v0
.end method
.method public getParam()Lorg/spongycastle/crypto/CipherParameters;
.registers 2
.prologue
.line 114
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->param:Lorg/spongycastle/crypto/CipherParameters;
return-object v0
.end method
.method public getPassword()[C
.registers 2
.prologue
.line 122
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
invoke-virtual {v0}, Ljavax/crypto/spec/PBEKeySpec;->getPassword()[C
move-result-object v0
return-object v0
.end method
.method public getSalt()[B
.registers 2
.prologue
.line 130
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->pbeKeySpec:Ljavax/crypto/spec/PBEKeySpec;
invoke-virtual {v0}, Ljavax/crypto/spec/PBEKeySpec;->getSalt()[B
move-result-object v0
return-object v0
.end method
.method getType()I
.registers 2
.prologue
.line 94
iget v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->type:I
return v0
.end method
.method public setTryWrongPKCS12Zero(Z)V
.registers 2
.prologue
.line 148
iput-boolean p1, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->tryWrong:Z
.line 149
return-void
.end method
.method shouldTryWrongPKCS12()Z
.registers 2
.prologue
.line 153
iget-boolean v0, p0, Lorg/spongycastle/jcajce/provider/symmetric/util/BCPBEKey;->tryWrong:Z
return v0
.end method