.class public final Lcom/google/android/gms/internal/ads/zzgkr; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Lcom/google/android/gms/internal/ads/zzgdn; # static fields .field private static final zza:[B .field private static final zzb:[B .field private static final zzc:[B .field private static final zzd:[B .field private static final zze:[B .field private static final zzf:Ljava/lang/ThreadLocal; # instance fields .field private final zzg:Ljavax/crypto/SecretKey; .field private final zzh:[B # direct methods .method static constructor ()V .locals 1 const-string v0, "7a806c" .line 1 invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzgvf;->zza(Ljava/lang/String;)[B move-result-object v0 sput-object v0, Lcom/google/android/gms/internal/ads/zzgkr;->zza:[B const-string v0, "46bb91c3c5" .line 2 invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzgvf;->zza(Ljava/lang/String;)[B move-result-object v0 sput-object v0, Lcom/google/android/gms/internal/ads/zzgkr;->zzb:[B const-string v0, "36864200e0eaf5284d884a0e77d31646" .line 3 invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzgvf;->zza(Ljava/lang/String;)[B move-result-object v0 sput-object v0, Lcom/google/android/gms/internal/ads/zzgkr;->zzc:[B const-string v0, "bae8e37fc83441b16034566b" .line 4 invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzgvf;->zza(Ljava/lang/String;)[B move-result-object v0 sput-object v0, Lcom/google/android/gms/internal/ads/zzgkr;->zzd:[B const-string v0, "af60eb711bd85bc1e4d3e0a462e074eea428a8" .line 5 invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzgvf;->zza(Ljava/lang/String;)[B move-result-object v0 sput-object v0, Lcom/google/android/gms/internal/ads/zzgkr;->zze:[B new-instance v0, Lcom/google/android/gms/internal/ads/zzgkq; .line 6 invoke-direct {v0}, Lcom/google/android/gms/internal/ads/zzgkq;->()V sput-object v0, Lcom/google/android/gms/internal/ads/zzgkr;->zzf:Ljava/lang/ThreadLocal; return-void .end method .method private constructor ([B[B)V .locals 1 .annotation system Ldalvik/annotation/Throws; value = { Ljava/security/GeneralSecurityException; } .end annotation .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V iput-object p2, p0, Lcom/google/android/gms/internal/ads/zzgkr;->zzh:[B array-length p2, p1 invoke-static {p2}, Lcom/google/android/gms/internal/ads/zzgvm;->zza(I)V .line 2 new-instance p2, Ljavax/crypto/spec/SecretKeySpec; const-string v0, "AES" invoke-direct {p2, p1, v0}, Ljavax/crypto/spec/SecretKeySpec;->([BLjava/lang/String;)V iput-object p2, p0, Lcom/google/android/gms/internal/ads/zzgkr;->zzg:Ljavax/crypto/SecretKey; return-void .end method .method public static zzb(Lcom/google/android/gms/internal/ads/zzggi;)Lcom/google/android/gms/internal/ads/zzgdn; .locals 3 .annotation system Ldalvik/annotation/Throws; value = { Ljava/security/GeneralSecurityException; } .end annotation .line 1 new-instance v0, Lcom/google/android/gms/internal/ads/zzgkr; invoke-virtual {p0}, Lcom/google/android/gms/internal/ads/zzggi;->zzd()Lcom/google/android/gms/internal/ads/zzgvp; move-result-object v1 invoke-static {}, Lcom/google/android/gms/internal/ads/zzgdw;->zza()Lcom/google/android/gms/internal/ads/zzgeo; move-result-object v2 invoke-virtual {v1, v2}, Lcom/google/android/gms/internal/ads/zzgvp;->zzd(Lcom/google/android/gms/internal/ads/zzgeo;)[B move-result-object v1 invoke-virtual {p0}, Lcom/google/android/gms/internal/ads/zzggi;->zzc()Lcom/google/android/gms/internal/ads/zzgvo; move-result-object p0 .line 2 invoke-virtual {p0}, Lcom/google/android/gms/internal/ads/zzgvo;->zzc()[B move-result-object p0 invoke-direct {v0, v1, p0}, Lcom/google/android/gms/internal/ads/zzgkr;->([B[B)V return-object v0 .end method .method public static bridge synthetic zzc(Ljavax/crypto/Cipher;)Z .locals 0 invoke-static {p0}, Lcom/google/android/gms/internal/ads/zzgkr;->zzd(Ljavax/crypto/Cipher;)Z move-result p0 return p0 .end method .method private static zzd(Ljavax/crypto/Cipher;)Z .locals 5 const/4 v0, 0x0 :try_start_0 sget-object v1, Lcom/google/android/gms/internal/ads/zzgkr;->zzd:[B .line 1 array-length v2, v1 .line 2 new-instance v3, Ljavax/crypto/spec/GCMParameterSpec; const/16 v4, 0x80 invoke-direct {v3, v4, v1, v0, v2}, Ljavax/crypto/spec/GCMParameterSpec;->(I[BII)V .line 3 new-instance v1, Ljavax/crypto/spec/SecretKeySpec; sget-object v2, Lcom/google/android/gms/internal/ads/zzgkr;->zzc:[B const-string v4, "AES" invoke-direct {v1, v2, v4}, Ljavax/crypto/spec/SecretKeySpec;->([BLjava/lang/String;)V const/4 v2, 0x2 invoke-virtual {p0, v2, v1, v3}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V sget-object v1, Lcom/google/android/gms/internal/ads/zzgkr;->zzb:[B .line 4 invoke-virtual {p0, v1}, Ljavax/crypto/Cipher;->updateAAD([B)V sget-object v1, Lcom/google/android/gms/internal/ads/zzgkr;->zze:[B .line 5 array-length v2, v1 invoke-virtual {p0, v1, v0, v2}, Ljavax/crypto/Cipher;->doFinal([BII)[B move-result-object p0 sget-object v1, Lcom/google/android/gms/internal/ads/zzgkr;->zza:[B .line 6 invoke-static {p0, v1}, Ljava/security/MessageDigest;->isEqual([B[B)Z move-result p0 :try_end_0 .catch Ljava/security/GeneralSecurityException; {:try_start_0 .. :try_end_0} :catch_0 return p0 :catch_0 return v0 .end method .method private final zze([B[B)[B .locals 6 .annotation system Ldalvik/annotation/Throws; value = { Ljava/security/GeneralSecurityException; } .end annotation sget-object v0, Lcom/google/android/gms/internal/ads/zzgkr;->zzf:Ljava/lang/ThreadLocal; .line 1 invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Ljavax/crypto/Cipher; if-eqz v0, :cond_2 .line 3 array-length v1, p1 const/16 v2, 0x1c if-lt v1, v2, :cond_1 .line 4 new-instance v2, Ljavax/crypto/spec/GCMParameterSpec; const/16 v3, 0x80 const/4 v4, 0x0 const/16 v5, 0xc invoke-direct {v2, v3, p1, v4, v5}, Ljavax/crypto/spec/GCMParameterSpec;->(I[BII)V const/4 v3, 0x2 iget-object v4, p0, Lcom/google/android/gms/internal/ads/zzgkr;->zzg:Ljavax/crypto/SecretKey; .line 5 invoke-virtual {v0, v3, v4, v2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V if-eqz p2, :cond_0 array-length v2, p2 if-eqz v2, :cond_0 .line 6 invoke-virtual {v0, p2}, Ljavax/crypto/Cipher;->updateAAD([B)V :cond_0 add-int/lit8 v1, v1, -0xc .line 7 invoke-virtual {v0, p1, v5, v1}, Ljavax/crypto/Cipher;->doFinal([BII)[B move-result-object p1 return-object p1 .line 8 :cond_1 new-instance p1, Ljava/security/GeneralSecurityException; const-string p2, "ciphertext too short" invoke-direct {p1, p2}, Ljava/security/GeneralSecurityException;->(Ljava/lang/String;)V throw p1 .line 2 :cond_2 new-instance p1, Ljava/security/GeneralSecurityException; const-string p2, "AES GCM SIV cipher is not available or is invalid." invoke-direct {p1, p2}, Ljava/security/GeneralSecurityException;->(Ljava/lang/String;)V throw p1 .end method # virtual methods .method public final zza([B[B)[B .locals 2 .annotation system Ldalvik/annotation/Throws; value = { Ljava/security/GeneralSecurityException; } .end annotation iget-object v0, p0, Lcom/google/android/gms/internal/ads/zzgkr;->zzh:[B .line 1 array-length v1, v0 if-nez v1, :cond_0 invoke-direct {p0, p1, p2}, Lcom/google/android/gms/internal/ads/zzgkr;->zze([B[B)[B move-result-object p1 return-object p1 .line 2 :cond_0 invoke-static {v0, p1}, Lcom/google/android/gms/internal/ads/zzgnu;->zzc([B[B)Z move-result v0 if-eqz v0, :cond_1 iget-object v0, p0, Lcom/google/android/gms/internal/ads/zzgkr;->zzh:[B .line 4 array-length v1, p1 array-length v0, v0 .line 5 invoke-static {p1, v0, v1}, Ljava/util/Arrays;->copyOfRange([BII)[B move-result-object p1 .line 6 invoke-direct {p0, p1, p2}, Lcom/google/android/gms/internal/ads/zzgkr;->zze([B[B)[B move-result-object p1 return-object p1 .line 3 :cond_1 new-instance p1, Ljava/security/GeneralSecurityException; const-string p2, "Decryption failed (OutputPrefix mismatch)." invoke-direct {p1, p2}, Ljava/security/GeneralSecurityException;->(Ljava/lang/String;)V throw p1 .end method