AesCipherUtil.smali
.class public Lnet/lingala/zip4j/crypto/AesCipherUtil;
.super Ljava/lang/Object;
# static fields
.field private static final START_INDEX:I
# direct methods
.method public constructor <init>()V
.registers 1
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static derivePasswordBasedKey([B[CLnet/lingala/zip4j/model/enums/AesKeyStrength;Z)[B
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Lnet/lingala/zip4j/exception/ZipException;
}
.end annotation
.line 1
new-instance v0, Lnet/lingala/zip4j/crypto/PBKDF2/PBKDF2Parameters;
const-string v1, "HmacSHA1"
const-string v2, "ISO-8859-1"
const/16 v3, 0x3e8
invoke-direct {v0, v1, v2, p0, v3}, Lnet/lingala/zip4j/crypto/PBKDF2/PBKDF2Parameters;-><init>(Ljava/lang/String;Ljava/lang/String;[BI)V
.line 2
new-instance p0, Lnet/lingala/zip4j/crypto/PBKDF2/PBKDF2Engine;
invoke-direct {p0, v0}, Lnet/lingala/zip4j/crypto/PBKDF2/PBKDF2Engine;-><init>(Lnet/lingala/zip4j/crypto/PBKDF2/PBKDF2Parameters;)V
.line 4
invoke-virtual {p2}, Lnet/lingala/zip4j/model/enums/AesKeyStrength;->getKeyLength()I
move-result v0
.line 5
invoke-virtual {p2}, Lnet/lingala/zip4j/model/enums/AesKeyStrength;->getMacLength()I
move-result p2
add-int v1, v0, p2
const/4 v2, 0x2
add-int/2addr v1, v2
.line 7
invoke-virtual {p0, p1, v1, p3}, Lnet/lingala/zip4j/crypto/PBKDF2/PBKDF2Engine;->deriveKey([CIZ)[B
move-result-object p0
if-eqz p0, :cond_26
.line 8
array-length p1, p0
if-ne p1, v1, :cond_26
return-object p0
:cond_26
new-array p0, v2, [Ljava/lang/Object;
.line 11
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
const/4 p3, 0x0
aput-object p1, p0, p3
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
const/4 p2, 0x1
aput-object p1, p0, p2
const-string p1, "Derived Key invalid for Key Length [%d] MAC Length [%d]"
invoke-static {p1, p0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
.line 12
new-instance p1, Lnet/lingala/zip4j/exception/ZipException;
invoke-direct {p1, p0}, Lnet/lingala/zip4j/exception/ZipException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public static derivePasswordVerifier([BLnet/lingala/zip4j/model/enums/AesKeyStrength;)[B
.registers 5
const/4 v0, 0x2
new-array v1, v0, [B
.line 2
invoke-virtual {p1}, Lnet/lingala/zip4j/model/enums/AesKeyStrength;->getKeyLength()I
move-result v2
invoke-virtual {p1}, Lnet/lingala/zip4j/model/enums/AesKeyStrength;->getMacLength()I
move-result p1
add-int/2addr v2, p1
const/4 p1, 0x0
.line 3
invoke-static {p0, v2, v1, p1, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
return-object v1
.end method
.method public static getAESEngine([BLnet/lingala/zip4j/model/enums/AesKeyStrength;)Lnet/lingala/zip4j/crypto/engine/AESEngine;
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Lnet/lingala/zip4j/exception/ZipException;
}
.end annotation
.line 1
invoke-virtual {p1}, Lnet/lingala/zip4j/model/enums/AesKeyStrength;->getKeyLength()I
move-result p1
.line 2
new-array v0, p1, [B
const/4 v1, 0x0
.line 3
invoke-static {p0, v1, v0, v1, p1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 4
new-instance p0, Lnet/lingala/zip4j/crypto/engine/AESEngine;
invoke-direct {p0, v0}, Lnet/lingala/zip4j/crypto/engine/AESEngine;-><init>([B)V
return-object p0
.end method
.method public static getMacBasedPRF([BLnet/lingala/zip4j/model/enums/AesKeyStrength;)Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;
.registers 5
.line 1
invoke-virtual {p1}, Lnet/lingala/zip4j/model/enums/AesKeyStrength;->getMacLength()I
move-result v0
.line 2
new-array v1, v0, [B
.line 3
invoke-virtual {p1}, Lnet/lingala/zip4j/model/enums/AesKeyStrength;->getKeyLength()I
move-result p1
const/4 v2, 0x0
invoke-static {p0, p1, v1, v2, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 4
new-instance p0, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;
const-string p1, "HmacSHA1"
invoke-direct {p0, p1}, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;-><init>(Ljava/lang/String;)V
.line 5
invoke-virtual {p0, v1}, Lnet/lingala/zip4j/crypto/PBKDF2/MacBasedPRF;->init([B)V
return-object p0
.end method
.method public static prepareBuffAESIVBytes([BI)V
.registers 5
int-to-byte v0, p1
const/4 v1, 0x0
.line 1
aput-byte v0, p0, v1
shr-int/lit8 v0, p1, 0x8
int-to-byte v0, v0
const/4 v2, 0x1
.line 2
aput-byte v0, p0, v2
shr-int/lit8 v0, p1, 0x10
int-to-byte v0, v0
const/4 v2, 0x2
.line 3
aput-byte v0, p0, v2
shr-int/lit8 p1, p1, 0x18
int-to-byte p1, p1
const/4 v0, 0x3
.line 4
aput-byte p1, p0, v0
const/4 p1, 0x4
:goto_17
const/16 v0, 0xf
if-gt p1, v0, :cond_20
.line 7
aput-byte v1, p0, p1
add-int/lit8 p1, p1, 0x1
goto :goto_17
:cond_20
return-void
.end method