KDFCounterParameters.smali
.class public final Lorg/spongycastle/crypto/params/KDFCounterParameters;
.super Ljava/lang/Object;
.source "KDFCounterParameters.java"
# interfaces
.implements Lorg/spongycastle/crypto/DerivationParameters;
# instance fields
.field private fixedInputDataCounterPrefix:[B
.field private fixedInputDataCounterSuffix:[B
.field private ki:[B
.field private r:I
# direct methods
.method public constructor <init>([B[BI)V
.registers 5
.prologue
.line 51
const/4 v0, 0x0
invoke-direct {p0, p1, v0, p2, p3}, Lorg/spongycastle/crypto/params/KDFCounterParameters;-><init>([B[B[BI)V
.line 52
return-void
.end method
.method public constructor <init>([B[B[BI)V
.registers 7
.prologue
const/4 v1, 0x0
.line 63
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 64
if-nez p1, :cond_e
.line 66
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "A KDF requires Ki (a seed) as input"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 68
:cond_e
invoke-static {p1}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->ki:[B
.line 70
if-nez p2, :cond_38
.line 72
new-array v0, v1, [B
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->fixedInputDataCounterPrefix:[B
.line 79
:goto_1a
if-nez p3, :cond_3f
.line 81
new-array v0, v1, [B
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->fixedInputDataCounterSuffix:[B
.line 88
:goto_20
const/16 v0, 0x8
if-eq p4, v0, :cond_46
const/16 v0, 0x10
if-eq p4, v0, :cond_46
const/16 v0, 0x18
if-eq p4, v0, :cond_46
const/16 v0, 0x20
if-eq p4, v0, :cond_46
.line 90
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Length of counter should be 8, 16, 24 or 32"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 76
:cond_38
invoke-static {p2}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->fixedInputDataCounterPrefix:[B
goto :goto_1a
.line 85
:cond_3f
invoke-static {p3}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->fixedInputDataCounterSuffix:[B
goto :goto_20
.line 92
:cond_46
iput p4, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->r:I
.line 93
return-void
.end method
# virtual methods
.method public final getFixedInputData()[B
.registers 2
.prologue
.line 103
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->fixedInputDataCounterSuffix:[B
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
return-object v0
.end method
.method public final getFixedInputDataCounterPrefix()[B
.registers 2
.prologue
.line 108
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->fixedInputDataCounterPrefix:[B
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
return-object v0
.end method
.method public final getFixedInputDataCounterSuffix()[B
.registers 2
.prologue
.line 113
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->fixedInputDataCounterSuffix:[B
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
return-object v0
.end method
.method public final getKI()[B
.registers 2
.prologue
.line 97
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->ki:[B
return-object v0
.end method
.method public final getR()I
.registers 2
.prologue
.line 118
iget v0, p0, Lorg/spongycastle/crypto/params/KDFCounterParameters;->r:I
return v0
.end method