PKCS12ParametersGenerator.smali
.class public Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;
.super Lorg/spongycastle/crypto/PBEParametersGenerator;
.source "PKCS12ParametersGenerator.java"
# static fields
.field public static final IV_MATERIAL:I = 0x2
.field public static final KEY_MATERIAL:I = 0x1
.field public static final MAC_MATERIAL:I = 0x3
# instance fields
.field private digest:Lorg/spongycastle/crypto/Digest;
.field private u:I
.field private v:I
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/Digest;)V
.registers 5
.prologue
.line 38
invoke-direct {p0}, Lorg/spongycastle/crypto/PBEParametersGenerator;-><init>()V
.line 39
iput-object p1, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->digest:Lorg/spongycastle/crypto/Digest;
.line 40
instance-of v0, p1, Lorg/spongycastle/crypto/ExtendedDigest;
if-eqz v0, :cond_18
.line 42
invoke-interface {p1}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
iput v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->u:I
.line 43
check-cast p1, Lorg/spongycastle/crypto/ExtendedDigest;
invoke-interface {p1}, Lorg/spongycastle/crypto/ExtendedDigest;->getByteLength()I
move-result v0
iput v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
return-void
.line 47
:cond_18
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Digest "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-interface {p1}, Lorg/spongycastle/crypto/Digest;->getAlgorithmName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, " unsupported"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)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/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private adjust([BI[B)V
.registers 8
.prologue
.line 61
array-length v0, p3
add-int/lit8 v0, v0, -0x1
aget-byte v0, p3, v0
and-int/lit16 v0, v0, 0xff
array-length v1, p3
add-int/2addr v1, p2
add-int/lit8 v1, v1, -0x1
aget-byte v1, p1, v1
and-int/lit16 v1, v1, 0xff
add-int/2addr v0, v1
add-int/lit8 v0, v0, 0x1
.line 63
array-length v1, p3
add-int/2addr v1, p2
add-int/lit8 v1, v1, -0x1
int-to-byte v2, v0
aput-byte v2, p1, v1
.line 64
ushr-int/lit8 v1, v0, 0x8
.line 66
array-length v0, p3
add-int/lit8 v0, v0, -0x2
:goto_1e
if-ltz v0, :cond_36
.line 68
aget-byte v2, p3, v0
and-int/lit16 v2, v2, 0xff
add-int v3, p2, v0
aget-byte v3, p1, v3
and-int/lit16 v3, v3, 0xff
add-int/2addr v2, v3
add-int/2addr v1, v2
.line 69
add-int v2, p2, v0
int-to-byte v3, v1
aput-byte v3, p1, v2
.line 70
ushr-int/lit8 v1, v1, 0x8
.line 66
add-int/lit8 v0, v0, -0x1
goto :goto_1e
.line 72
:cond_36
return-void
.end method
.method private generateDerivedKey(II)[B
.registers 15
.prologue
const/4 v4, 0x1
const/4 v1, 0x0
.line 81
iget v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
new-array v5, v0, [B
.line 82
new-array v6, p2, [B
move v0, v1
.line 84
:goto_9
array-length v2, v5
if-eq v0, v2, :cond_12
.line 86
int-to-byte v2, p1
aput-byte v2, v5, v0
.line 84
add-int/lit8 v0, v0, 0x1
goto :goto_9
.line 91
:cond_12
iget-object v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->salt:[B
if-eqz v0, :cond_69
iget-object v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->salt:[B
array-length v0, v0
if-eqz v0, :cond_69
.line 93
iget v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
iget-object v2, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->salt:[B
array-length v2, v2
iget v3, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
add-int/2addr v2, v3
add-int/lit8 v2, v2, -0x1
iget v3, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
div-int/2addr v2, v3
mul-int/2addr v0, v2
new-array v2, v0, [B
move v0, v1
.line 95
:goto_2c
array-length v3, v2
if-eq v0, v3, :cond_3d
.line 97
iget-object v3, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->salt:[B
iget-object v7, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->salt:[B
array-length v7, v7
rem-int v7, v0, v7
aget-byte v3, v3, v7
aput-byte v3, v2, v0
.line 95
add-int/lit8 v0, v0, 0x1
goto :goto_2c
:cond_3d
move-object v0, v2
.line 107
:goto_3e
iget-object v2, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->password:[B
if-eqz v2, :cond_b3
iget-object v2, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->password:[B
array-length v2, v2
if-eqz v2, :cond_b3
.line 109
iget v2, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
iget-object v3, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->password:[B
array-length v3, v3
iget v7, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
add-int/2addr v3, v7
add-int/lit8 v3, v3, -0x1
iget v7, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
div-int/2addr v3, v7
mul-int/2addr v2, v3
new-array v3, v2, [B
move v2, v1
.line 111
:goto_58
array-length v7, v3
if-eq v2, v7, :cond_6c
.line 113
iget-object v7, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->password:[B
iget-object v8, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->password:[B
array-length v8, v8
rem-int v8, v2, v8
aget-byte v7, v7, v8
aput-byte v7, v3, v2
.line 111
add-int/lit8 v2, v2, 0x1
goto :goto_58
.line 102
:cond_69
new-array v0, v1, [B
goto :goto_3e
:cond_6c
move-object v2, v3
.line 121
:goto_6d
array-length v3, v0
array-length v7, v2
add-int/2addr v3, v7
new-array v3, v3, [B
.line 123
array-length v7, v0
invoke-static {v0, v1, v3, v1, v7}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 124
array-length v0, v0
array-length v7, v2
invoke-static {v2, v1, v3, v0, v7}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 126
iget v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
new-array v7, v0, [B
.line 127
iget v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->u:I
add-int/2addr v0, p2
add-int/lit8 v0, v0, -0x1
iget v2, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->u:I
div-int v8, v0, v2
.line 128
iget v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->u:I
new-array v9, v0, [B
move v2, v4
.line 130
:goto_8d
if-gt v2, v8, :cond_f3
.line 132
iget-object v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->digest:Lorg/spongycastle/crypto/Digest;
array-length v10, v5
invoke-interface {v0, v5, v1, v10}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 133
iget-object v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->digest:Lorg/spongycastle/crypto/Digest;
array-length v10, v3
invoke-interface {v0, v3, v1, v10}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 134
iget-object v0, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0, v9, v1}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
move v0, v4
.line 135
:goto_a1
iget v10, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->iterationCount:I
if-ge v0, v10, :cond_b6
.line 137
iget-object v10, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->digest:Lorg/spongycastle/crypto/Digest;
array-length v11, v9
invoke-interface {v10, v9, v1, v11}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 138
iget-object v10, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v10, v9, v1}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 135
add-int/lit8 v0, v0, 0x1
goto :goto_a1
.line 118
:cond_b3
new-array v2, v1, [B
goto :goto_6d
:cond_b6
move v0, v1
.line 141
:goto_b7
array-length v10, v7
if-eq v0, v10, :cond_c4
.line 143
array-length v10, v9
rem-int v10, v0, v10
aget-byte v10, v9, v10
aput-byte v10, v7, v0
.line 141
add-int/lit8 v0, v0, 0x1
goto :goto_b7
:cond_c4
move v0, v1
.line 146
:goto_c5
array-length v10, v3
iget v11, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
div-int/2addr v10, v11
if-eq v0, v10, :cond_d4
.line 148
iget v10, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->v:I
mul-int/2addr v10, v0
invoke-direct {p0, v3, v10, v7}, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->adjust([BI[B)V
.line 146
add-int/lit8 v0, v0, 0x1
goto :goto_c5
.line 151
:cond_d4
if-ne v2, v8, :cond_e9
.line 153
add-int/lit8 v0, v2, -0x1
iget v10, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->u:I
mul-int/2addr v0, v10
add-int/lit8 v10, v2, -0x1
iget v11, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->u:I
mul-int/2addr v10, v11
sub-int v10, p2, v10
invoke-static {v9, v1, v6, v0, v10}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 130
:goto_e5
add-int/lit8 v0, v2, 0x1
move v2, v0
goto :goto_8d
.line 157
:cond_e9
add-int/lit8 v0, v2, -0x1
iget v10, p0, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->u:I
mul-int/2addr v0, v10
array-length v10, v9
invoke-static {v9, v1, v6, v0, v10}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
goto :goto_e5
.line 161
:cond_f3
return-object v6
.end method
# virtual methods
.method public generateDerivedMacParameters(I)Lorg/spongycastle/crypto/CipherParameters;
.registers 6
.prologue
.line 214
div-int/lit8 v0, p1, 0x8
.line 216
const/4 v1, 0x3
invoke-direct {p0, v1, v0}, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->generateDerivedKey(II)[B
move-result-object v1
.line 218
new-instance v2, Lorg/spongycastle/crypto/params/KeyParameter;
const/4 v3, 0x0
invoke-direct {v2, v1, v3, v0}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
return-object v2
.end method
.method public generateDerivedParameters(I)Lorg/spongycastle/crypto/CipherParameters;
.registers 6
.prologue
.line 174
div-int/lit8 v0, p1, 0x8
.line 176
const/4 v1, 0x1
invoke-direct {p0, v1, v0}, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->generateDerivedKey(II)[B
move-result-object v1
.line 178
new-instance v2, Lorg/spongycastle/crypto/params/KeyParameter;
const/4 v3, 0x0
invoke-direct {v2, v1, v3, v0}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
return-object v2
.end method
.method public generateDerivedParameters(II)Lorg/spongycastle/crypto/CipherParameters;
.registers 10
.prologue
const/4 v6, 0x0
.line 194
div-int/lit8 v0, p1, 0x8
.line 195
div-int/lit8 v1, p2, 0x8
.line 197
const/4 v2, 0x1
invoke-direct {p0, v2, v0}, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->generateDerivedKey(II)[B
move-result-object v2
.line 199
const/4 v3, 0x2
invoke-direct {p0, v3, v1}, Lorg/spongycastle/crypto/generators/PKCS12ParametersGenerator;->generateDerivedKey(II)[B
move-result-object v3
.line 201
new-instance v4, Lorg/spongycastle/crypto/params/ParametersWithIV;
new-instance v5, Lorg/spongycastle/crypto/params/KeyParameter;
invoke-direct {v5, v2, v6, v0}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
invoke-direct {v4, v5, v3, v6, v1}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[BII)V
return-object v4
.end method