MacBasedPRF.smali 
.class public Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;
.super Ljava/lang/Object;
# interfaces
.implements Lnet/lingala/zip4j/crypto/PBKDF2/PRF;
# instance fields
.field private hLen:I
.field private mac:Ljavax/crypto/Mac;
.field private macAlgorithm:Ljava/lang/String;
.field private macCache:Ljava/io/ByteArrayOutputStream;
# direct methods
.method public constructor <init>(Ljava/lang/String;)V
    .registers 4
    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V
    .line 2
    iput-object p1, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macAlgorithm:Ljava/lang/String;
    .line 3
    new-instance v0, Ljava/io/ByteArrayOutputStream;
    const/16 v1, 0x1000
    invoke-direct {v0, v1}, Ljava/io/ByteArrayOutputStream;-><init>(I)V
    iput-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macCache:Ljava/io/ByteArrayOutputStream;
    .line 5
    :try_start_e
    invoke-static {p1}, Ljavax/crypto/Mac;->getInstance(Ljava/lang/String;)Ljavax/crypto/Mac;
    move-result-object p1
    iput-object p1, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->mac:Ljavax/crypto/Mac;
    .line 6
    invoke-virtual {p1}, Ljavax/crypto/Mac;->getMacLength()I
    move-result p1
    iput p1, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->hLen:I
    :try_end_1a
    .catch Ljava/security/NoSuchAlgorithmException; {:try_start_e .. :try_end_1a} :catch_1b
    return-void
    :catch_1b
    move-exception p1
    .line 8
    new-instance v0, Ljava/lang/RuntimeException;
    invoke-direct {v0, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
    throw v0
.end method
.method private doMacUpdate(I)V
    .registers 7
    .line 1
    iget-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macCache:Ljava/io/ByteArrayOutputStream;
    invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B
    move-result-object v0
    .line 2
    array-length v1, v0
    sub-int/2addr v1, p1
    const/4 p1, 0x0
    :goto_9
    if-ge p1, v1, :cond_1b
    add-int/lit8 v2, p1, 0x10
    if-gt v2, v1, :cond_12
    const/16 v3, 0x10
    goto :goto_14
    :cond_12
    sub-int v3, v1, p1
    .line 6
    :goto_14
    iget-object v4, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->mac:Ljavax/crypto/Mac;
    invoke-virtual {v4, v0, p1, v3}, Ljavax/crypto/Mac;->update([BII)V
    move p1, v2
    goto :goto_9
    .line 8
    :cond_1b
    iget-object p1, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macCache:Ljava/io/ByteArrayOutputStream;
    invoke-virtual {p1}, Ljava/io/ByteArrayOutputStream;->reset()V
    return-void
.end method
# virtual methods
.method public doFinal()[B
    .registers 2
    const/4 v0, 0x0
    .line 5
    invoke-virtual {p0, v0}, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->doFinal(I)[B
    move-result-object v0
    return-object v0
.end method
.method public doFinal(I)[B
    .registers 3
    .line 6
    iget-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macCache:Ljava/io/ByteArrayOutputStream;
    invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->size()I
    move-result v0
    if-lez v0, :cond_b
    .line 7
    invoke-direct {p0, p1}, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->doMacUpdate(I)V
    .line 9
    :cond_b
    iget-object p1, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->mac:Ljavax/crypto/Mac;
    invoke-virtual {p1}, Ljavax/crypto/Mac;->doFinal()[B
    move-result-object p1
    return-object p1
.end method
.method public doFinal([B)[B
    .registers 3
    .line 1
    iget-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macCache:Ljava/io/ByteArrayOutputStream;
    invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->size()I
    move-result v0
    if-lez v0, :cond_c
    const/4 v0, 0x0
    .line 2
    invoke-direct {p0, v0}, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->doMacUpdate(I)V
    .line 4
    :cond_c
    iget-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->mac:Ljavax/crypto/Mac;
    invoke-virtual {v0, p1}, Ljavax/crypto/Mac;->doFinal([B)[B
    move-result-object p1
    return-object p1
.end method
.method public getHLen()I
    .registers 2
    .line 1
    iget v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->hLen:I
    return v0
.end method
.method public init([B)V
    .registers 5
    .line 1
    :try_start_0
    iget-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->mac:Ljavax/crypto/Mac;
    new-instance v1, Ljavax/crypto/spec/SecretKeySpec;
    iget-object v2, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macAlgorithm:Ljava/lang/String;
    invoke-direct {v1, p1, v2}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
    invoke-virtual {v0, v1}, Ljavax/crypto/Mac;->init(Ljava/security/Key;)V
    :try_end_c
    .catch Ljava/security/InvalidKeyException; {:try_start_0 .. :try_end_c} :catch_d
    return-void
    :catch_d
    move-exception p1
    .line 3
    new-instance v0, Ljava/lang/RuntimeException;
    invoke-direct {v0, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
    throw v0
.end method
.method public update([B)V
    .registers 4
    .line 1
    array-length v0, p1
    const/4 v1, 0x0
    invoke-virtual {p0, p1, v1, v0}, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->update([BII)V
    return-void
.end method
.method public update([BII)V
    .registers 6
    .line 2
    :try_start_0
    iget-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macCache:Ljava/io/ByteArrayOutputStream;
    invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->size()I
    move-result v0
    add-int/2addr v0, p3
    const/16 v1, 0x1000
    if-le v0, v1, :cond_f
    const/4 v0, 0x0
    .line 3
    invoke-direct {p0, v0}, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->doMacUpdate(I)V
    .line 5
    :cond_f
    iget-object v0, p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->macCache:Ljava/io/ByteArrayOutputStream;
    invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
    :try_end_14
    .catch Ljava/lang/IllegalStateException; {:try_start_0 .. :try_end_14} :catch_15
    return-void
    :catch_15
    move-exception p1
    .line 7
    new-instance p2, Ljava/lang/RuntimeException;
    invoke-direct {p2, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
    throw p2
.end method