- Added realracing3-community.apk (71.57 MB) - Removed 32-bit support (armeabi-v7a) - Only includes arm64-v8a libraries - Decompiled source code included - Added README-community.md with analysis
74 lines
2.8 KiB
Java
74 lines
2.8 KiB
Java
package com.google.android.gms.internal.ads;
|
|
|
|
import java.security.GeneralSecurityException;
|
|
import java.security.MessageDigest;
|
|
import java.util.Arrays;
|
|
import javax.crypto.Cipher;
|
|
import javax.crypto.SecretKey;
|
|
import javax.crypto.spec.GCMParameterSpec;
|
|
import javax.crypto.spec.SecretKeySpec;
|
|
|
|
/* loaded from: classes3.dex */
|
|
public final class zzgkr implements zzgdn {
|
|
private static final byte[] zza = zzgvf.zza("7a806c");
|
|
private static final byte[] zzb = zzgvf.zza("46bb91c3c5");
|
|
private static final byte[] zzc = zzgvf.zza("36864200e0eaf5284d884a0e77d31646");
|
|
private static final byte[] zzd = zzgvf.zza("bae8e37fc83441b16034566b");
|
|
private static final byte[] zze = zzgvf.zza("af60eb711bd85bc1e4d3e0a462e074eea428a8");
|
|
private static final ThreadLocal zzf = new zzgkq();
|
|
private final SecretKey zzg;
|
|
private final byte[] zzh;
|
|
|
|
private zzgkr(byte[] bArr, byte[] bArr2) throws GeneralSecurityException {
|
|
this.zzh = bArr2;
|
|
zzgvm.zza(bArr.length);
|
|
this.zzg = new SecretKeySpec(bArr, "AES");
|
|
}
|
|
|
|
public static zzgdn zzb(zzggi zzggiVar) throws GeneralSecurityException {
|
|
return new zzgkr(zzggiVar.zzd().zzd(zzgdw.zza()), zzggiVar.zzc().zzc());
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static boolean zzd(Cipher cipher) {
|
|
try {
|
|
byte[] bArr = zzd;
|
|
cipher.init(2, new SecretKeySpec(zzc, "AES"), new GCMParameterSpec(128, bArr, 0, bArr.length));
|
|
cipher.updateAAD(zzb);
|
|
byte[] bArr2 = zze;
|
|
return MessageDigest.isEqual(cipher.doFinal(bArr2, 0, bArr2.length), zza);
|
|
} catch (GeneralSecurityException unused) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
private final byte[] zze(byte[] bArr, byte[] bArr2) throws GeneralSecurityException {
|
|
Cipher cipher = (Cipher) zzf.get();
|
|
if (cipher == null) {
|
|
throw new GeneralSecurityException("AES GCM SIV cipher is not available or is invalid.");
|
|
}
|
|
int length = bArr.length;
|
|
if (length < 28) {
|
|
throw new GeneralSecurityException("ciphertext too short");
|
|
}
|
|
cipher.init(2, this.zzg, new GCMParameterSpec(128, bArr, 0, 12));
|
|
if (bArr2 != null && bArr2.length != 0) {
|
|
cipher.updateAAD(bArr2);
|
|
}
|
|
return cipher.doFinal(bArr, 12, length - 12);
|
|
}
|
|
|
|
@Override // com.google.android.gms.internal.ads.zzgdn
|
|
public final byte[] zza(byte[] bArr, byte[] bArr2) throws GeneralSecurityException {
|
|
byte[] bArr3 = this.zzh;
|
|
if (bArr3.length == 0) {
|
|
return zze(bArr, bArr2);
|
|
}
|
|
if (!zzgnu.zzc(bArr3, bArr)) {
|
|
throw new GeneralSecurityException("Decryption failed (OutputPrefix mismatch).");
|
|
}
|
|
byte[] bArr4 = this.zzh;
|
|
return zze(Arrays.copyOfRange(bArr, bArr4.length, bArr.length), bArr2);
|
|
}
|
|
}
|