.class public final Lbf/c; .super Ljava/lang/Object; .source "AesFlushingCipher.java" # instance fields .field public final a:Ljavax/crypto/Cipher; .field public final b:I .field public final c:[B .field public final d:[B .field public e:I # direct methods .method public constructor (I[BJJ)V .locals 6 .line 2 invoke-direct {p0}, Ljava/lang/Object;->()V :try_start_0 const-string v0, "AES/CTR/NoPadding" .line 3 invoke-static {v0}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher; move-result-object v0 iput-object v0, p0, Lbf/c;->a:Ljavax/crypto/Cipher; .line 4 invoke-virtual {v0}, Ljavax/crypto/Cipher;->getBlockSize()I move-result v1 iput v1, p0, Lbf/c;->b:I .line 5 new-array v2, v1, [B iput-object v2, p0, Lbf/c;->c:[B .line 6 new-array v2, v1, [B iput-object v2, p0, Lbf/c;->d:[B int-to-long v2, v1 .line 7 div-long v2, p5, v2 int-to-long v4, v1 .line 8 rem-long/2addr p5, v4 long-to-int p5, p5 .line 9 new-instance p6, Ljavax/crypto/spec/SecretKeySpec; .line 10 invoke-virtual {v0}, Ljavax/crypto/Cipher;->getAlgorithm()Ljava/lang/String; move-result-object v1 const-string v4, "/" invoke-static {v1, v4}, Lcom/tmapmobility/tmap/exoplayer2/util/m0;->s1(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String; move-result-object v1 const/4 v4, 0x0 aget-object v1, v1, v4 invoke-direct {p6, p2, v1}, Ljavax/crypto/spec/SecretKeySpec;->([BLjava/lang/String;)V new-instance p2, Ljavax/crypto/spec/IvParameterSpec; .line 11 invoke-virtual {p0, p3, p4, v2, v3}, Lbf/c;->b(JJ)[B move-result-object p3 invoke-direct {p2, p3}, Ljavax/crypto/spec/IvParameterSpec;->([B)V .line 12 invoke-virtual {v0, p1, p6, p2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V if-eqz p5, :cond_0 .line 13 new-array p1, p5, [B invoke-virtual {p0, p1, v4, p5}, Lbf/c;->e([BII)V :try_end_0 .catch Ljava/security/NoSuchAlgorithmException; {:try_start_0 .. :try_end_0} :catch_3 .catch Ljavax/crypto/NoSuchPaddingException; {:try_start_0 .. :try_end_0} :catch_2 .catch Ljava/security/InvalidKeyException; {:try_start_0 .. :try_end_0} :catch_1 .catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_0 .. :try_end_0} :catch_0 :cond_0 return-void :catch_0 move-exception p1 goto :goto_0 :catch_1 move-exception p1 goto :goto_0 :catch_2 move-exception p1 goto :goto_0 :catch_3 move-exception p1 .line 14 :goto_0 new-instance p2, Ljava/lang/RuntimeException; invoke-direct {p2, p1}, Ljava/lang/RuntimeException;->(Ljava/lang/Throwable;)V throw p2 .end method .method public constructor (I[BLjava/lang/String;J)V .locals 7 .param p3 # Ljava/lang/String; .annotation build Landroidx/annotation/Nullable; .end annotation .end param .line 1 invoke-static {p3}, Lbf/c;->a(Ljava/lang/String;)J move-result-wide v3 move-object v0, p0 move v1, p1 move-object v2, p2 move-wide v5, p4 invoke-direct/range {v0 .. v6}, Lbf/c;->(I[BJJ)V return-void .end method .method public static a(Ljava/lang/String;)J .locals 7 .param p0 # Ljava/lang/String; .annotation build Landroidx/annotation/Nullable; .end annotation .end param const-wide/16 v0, 0x0 if-nez p0, :cond_0 return-wide v0 :cond_0 const/4 v2, 0x0 .line 1 :goto_0 invoke-virtual {p0}, Ljava/lang/String;->length()I move-result v3 if-ge v2, v3, :cond_1 .line 2 invoke-virtual {p0, v2}, Ljava/lang/String;->charAt(I)C move-result v3 int-to-long v3, v3 xor-long/2addr v0, v3 const/4 v3, 0x1 shl-long v3, v0, v3 const/4 v5, 0x4 shl-long v5, v0, v5 add-long/2addr v3, v5 const/4 v5, 0x5 shl-long v5, v0, v5 add-long/2addr v3, v5 const/4 v5, 0x7 shl-long v5, v0, v5 add-long/2addr v3, v5 const/16 v5, 0x8 shl-long v5, v0, v5 add-long/2addr v3, v5 const/16 v5, 0x28 shl-long v5, v0, v5 add-long/2addr v3, v5 add-long/2addr v0, v3 add-int/lit8 v2, v2, 0x1 goto :goto_0 :cond_1 return-wide v0 .end method # virtual methods .method public final b(JJ)[B .locals 1 const/16 v0, 0x10 .line 1 invoke-static {v0}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer; move-result-object v0 invoke-virtual {v0, p1, p2}, Ljava/nio/ByteBuffer;->putLong(J)Ljava/nio/ByteBuffer; move-result-object p1 invoke-virtual {p1, p3, p4}, Ljava/nio/ByteBuffer;->putLong(J)Ljava/nio/ByteBuffer; move-result-object p1 invoke-virtual {p1}, Ljava/nio/ByteBuffer;->array()[B move-result-object p1 return-object p1 .end method .method public final c([BII[BI)I .locals 6 .line 1 :try_start_0 iget-object v0, p0, Lbf/c;->a:Ljavax/crypto/Cipher; move-object v1, p1 move v2, p2 move v3, p3 move-object v4, p4 move v5, p5 invoke-virtual/range {v0 .. v5}, Ljavax/crypto/Cipher;->update([BII[BI)I move-result p1 :try_end_0 .catch Ljavax/crypto/ShortBufferException; {:try_start_0 .. :try_end_0} :catch_0 return p1 :catch_0 move-exception p1 .line 2 new-instance p2, Ljava/lang/RuntimeException; invoke-direct {p2, p1}, Ljava/lang/RuntimeException;->(Ljava/lang/Throwable;)V throw p2 .end method .method public d([BII[BI)V .locals 8 move v2, p2 .line 1 :cond_0 iget p2, p0, Lbf/c;->e:I if-lez p2, :cond_1 .line 2 aget-byte v0, p1, v2 iget-object v1, p0, Lbf/c;->d:[B iget v3, p0, Lbf/c;->b:I sub-int/2addr v3, p2 aget-byte v1, v1, v3 xor-int/2addr v0, v1 int-to-byte v0, v0 aput-byte v0, p4, p5 add-int/lit8 p5, p5, 0x1 add-int/lit8 v2, v2, 0x1 add-int/lit8 p2, p2, -0x1 .line 3 iput p2, p0, Lbf/c;->e:I add-int/lit8 p3, p3, -0x1 if-nez p3, :cond_0 return-void :cond_1 move-object v0, p0 move-object v1, p1 move v3, p3 move-object v4, p4 move v5, p5 .line 4 invoke-virtual/range {v0 .. v5}, Lbf/c;->c([BII[BI)I move-result p1 if-ne p3, p1, :cond_2 return-void :cond_2 sub-int/2addr p3, p1 .line 5 iget p2, p0, Lbf/c;->b:I const/4 v0, 0x0 const/4 v1, 0x1 if-ge p3, p2, :cond_3 move p2, v1 goto :goto_0 :cond_3 move p2, v0 :goto_0 invoke-static {p2}, Lcom/tmapmobility/tmap/exoplayer2/util/a;->i(Z)V add-int/2addr p5, p1 .line 6 iget p1, p0, Lbf/c;->b:I sub-int v5, p1, p3 iput v5, p0, Lbf/c;->e:I .line 7 iget-object v3, p0, Lbf/c;->c:[B const/4 v4, 0x0 iget-object v6, p0, Lbf/c;->d:[B const/4 v7, 0x0 move-object v2, p0 invoke-virtual/range {v2 .. v7}, Lbf/c;->c([BII[BI)I move-result p1 .line 8 iget p2, p0, Lbf/c;->b:I if-ne p1, p2, :cond_4 goto :goto_1 :cond_4 move v1, v0 :goto_1 invoke-static {v1}, Lcom/tmapmobility/tmap/exoplayer2/util/a;->i(Z)V :goto_2 if-ge v0, p3, :cond_5 add-int/lit8 p1, p5, 0x1 .line 9 iget-object p2, p0, Lbf/c;->d:[B aget-byte p2, p2, v0 aput-byte p2, p4, p5 add-int/lit8 v0, v0, 0x1 move p5, p1 goto :goto_2 :cond_5 return-void .end method .method public e([BII)V .locals 6 move-object v0, p0 move-object v1, p1 move v2, p2 move v3, p3 move-object v4, p1 move v5, p2 .line 1 invoke-virtual/range {v0 .. v5}, Lbf/c;->d([BII[BI)V return-void .end method