.class public final Lcom/google/android/gms/internal/ads/zzgun; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Lcom/google/android/gms/internal/ads/zzgdn; # instance fields .field private final zza:Ljavax/crypto/SecretKey; .field private final zzb:[B # direct methods .method private constructor ([BLcom/google/android/gms/internal/ads/zzgvo;)V .locals 1 .annotation system Ldalvik/annotation/Throws; value = { Ljava/security/GeneralSecurityException; } .end annotation .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V const/4 v0, 0x2 invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzgks;->zza(I)Z move-result v0 if-eqz v0, :cond_0 .line 3 invoke-static {p1}, Lcom/google/android/gms/internal/ads/zzgjd;->zzc([B)Ljavax/crypto/SecretKey; move-result-object p1 iput-object p1, p0, Lcom/google/android/gms/internal/ads/zzgun;->zza:Ljavax/crypto/SecretKey; .line 4 invoke-virtual {p2}, Lcom/google/android/gms/internal/ads/zzgvo;->zzc()[B move-result-object p1 iput-object p1, p0, Lcom/google/android/gms/internal/ads/zzgun;->zzb:[B return-void .line 2 :cond_0 new-instance p1, Ljava/security/GeneralSecurityException; const-string p2, "Can not use AES-GCM in FIPS-mode, as BoringCrypto module is not available." invoke-direct {p1, p2}, Ljava/security/GeneralSecurityException;->(Ljava/lang/String;)V throw p1 .end method .method public static zzb(Lcom/google/android/gms/internal/ads/zzgfx;)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/zzgun; invoke-virtual {p0}, Lcom/google/android/gms/internal/ads/zzgfx;->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/zzgfx;->zzc()Lcom/google/android/gms/internal/ads/zzgvo; move-result-object p0 invoke-direct {v0, v1, p0}, Lcom/google/android/gms/internal/ads/zzgun;->([BLcom/google/android/gms/internal/ads/zzgvo;)V return-object v0 .end method # virtual methods .method public final zza([B[B)[B .locals 5 .annotation system Ldalvik/annotation/Throws; value = { Ljava/security/GeneralSecurityException; } .end annotation if-eqz p1, :cond_3 iget-object v0, p0, Lcom/google/android/gms/internal/ads/zzgun;->zzb:[B .line 1 array-length v1, p1 array-length v2, v0 add-int/lit8 v2, v2, 0x1c if-lt v1, v2, :cond_2 .line 3 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/zzgun;->zzb:[B .line 4 array-length v0, v0 const/16 v2, 0xc .line 5 invoke-static {p1, v0, v2}, Lcom/google/android/gms/internal/ads/zzgjd;->zza([BII)Ljava/security/spec/AlgorithmParameterSpec; move-result-object v0 iget-object v2, p0, Lcom/google/android/gms/internal/ads/zzgun;->zza:Ljavax/crypto/SecretKey; .line 6 invoke-static {}, Lcom/google/android/gms/internal/ads/zzgjd;->zzb()Ljavax/crypto/Cipher; move-result-object v3 const/4 v4, 0x2 .line 7 invoke-virtual {v3, v4, v2, v0}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V if-eqz p2, :cond_0 array-length v0, p2 if-eqz v0, :cond_0 .line 8 invoke-virtual {v3, p2}, Ljavax/crypto/Cipher;->updateAAD([B)V :cond_0 iget-object p2, p0, Lcom/google/android/gms/internal/ads/zzgun;->zzb:[B array-length p2, p2 add-int/lit8 v0, p2, 0xc sub-int/2addr v1, p2 add-int/lit8 v1, v1, -0xc .line 9 invoke-virtual {v3, p1, v0, v1}, Ljavax/crypto/Cipher;->doFinal([BII)[B move-result-object p1 return-object p1 .line 4 :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 .line 2 :cond_2 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 1 :cond_3 new-instance p1, Ljava/lang/NullPointerException; const-string p2, "ciphertext is null" invoke-direct {p1, p2}, Ljava/lang/NullPointerException;->(Ljava/lang/String;)V throw p1 .end method