.class public final Lcom/google/android/gms/internal/ads/zzgjp; .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:Ljava/lang/ThreadLocal; # instance fields .field private final zze:Ljavax/crypto/SecretKey; .field private final zzf:[B # direct methods .method static constructor ()V .locals 1 const-string v0, "808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9f" .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/zzgjp;->zza:[B const-string v0, "070000004041424344454647" .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/zzgjp;->zzb:[B const-string v0, "a0784d7a4716f3feb4f64e7f4b39bf04" .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/zzgjp;->zzc:[B new-instance v0, Lcom/google/android/gms/internal/ads/zzgjo; .line 4 invoke-direct {v0}, Lcom/google/android/gms/internal/ads/zzgjo;->()V sput-object v0, Lcom/google/android/gms/internal/ads/zzgjp;->zzd:Ljava/lang/ThreadLocal; return-void .end method .method private constructor ([B[B)V .locals 2 .annotation system Ldalvik/annotation/Throws; value = { Ljava/security/GeneralSecurityException; } .end annotation .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V const/4 v0, 0x1 invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzgks;->zza(I)Z move-result v0 if-eqz v0, :cond_2 .line 3 invoke-static {}, Lcom/google/android/gms/internal/ads/zzgjp;->zze()Z move-result v0 if-eqz v0, :cond_1 .line 4 array-length v0, p1 const/16 v1, 0x20 if-ne v0, v1, :cond_0 .line 6 new-instance v0, Ljavax/crypto/spec/SecretKeySpec; const-string v1, "ChaCha20" invoke-direct {v0, p1, v1}, Ljavax/crypto/spec/SecretKeySpec;->([BLjava/lang/String;)V iput-object v0, p0, Lcom/google/android/gms/internal/ads/zzgjp;->zze:Ljavax/crypto/SecretKey; iput-object p2, p0, Lcom/google/android/gms/internal/ads/zzgjp;->zzf:[B return-void .line 5 :cond_0 new-instance p1, Ljava/security/InvalidKeyException; const-string p2, "The key length in bytes must be 32." invoke-direct {p1, p2}, Ljava/security/InvalidKeyException;->(Ljava/lang/String;)V throw p1 .line 4 :cond_1 new-instance p1, Ljava/security/GeneralSecurityException; const-string p2, "JCE does not support algorithm: ChaCha20-Poly1305" 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, "Can not use ChaCha20Poly1305 in FIPS-mode." 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/zzggr;)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/zzgjp; invoke-virtual {p0}, Lcom/google/android/gms/internal/ads/zzggr;->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/zzggr;->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/zzgjp;->([B[B)V return-object v0 .end method .method public static zzc()Ljavax/crypto/Cipher; .locals 1 sget-object v0, Lcom/google/android/gms/internal/ads/zzgjp;->zzd: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; return-object v0 .end method .method public static bridge synthetic zzd(Ljavax/crypto/Cipher;)Z .locals 0 invoke-static {p0}, Lcom/google/android/gms/internal/ads/zzgjp;->zzf(Ljavax/crypto/Cipher;)Z move-result p0 return p0 .end method .method public static zze()Z .locals 1 sget-object v0, Lcom/google/android/gms/internal/ads/zzgjp;->zzd:Ljava/lang/ThreadLocal; .line 1 invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object; move-result-object v0 if-eqz v0, :cond_0 const/4 v0, 0x1 return v0 :cond_0 const/4 v0, 0x0 return v0 .end method .method private static zzf(Ljavax/crypto/Cipher;)Z .locals 7 const-string v0, "ChaCha20" const/4 v1, 0x0 .line 1 :try_start_0 new-instance v2, Ljavax/crypto/spec/IvParameterSpec; sget-object v3, Lcom/google/android/gms/internal/ads/zzgjp;->zzb:[B invoke-direct {v2, v3}, Ljavax/crypto/spec/IvParameterSpec;->([B)V .line 2 new-instance v3, Ljavax/crypto/spec/SecretKeySpec; sget-object v4, Lcom/google/android/gms/internal/ads/zzgjp;->zza:[B invoke-direct {v3, v4, v0}, Ljavax/crypto/spec/SecretKeySpec;->([BLjava/lang/String;)V const/4 v5, 0x2 invoke-virtual {p0, v5, v3, v2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V sget-object v3, Lcom/google/android/gms/internal/ads/zzgjp;->zzc:[B .line 3 invoke-virtual {p0, v3}, Ljavax/crypto/Cipher;->doFinal([B)[B move-result-object v6 .line 4 array-length v6, v6 if-eqz v6, :cond_0 return v1 :cond_0 new-instance v6, Ljavax/crypto/spec/SecretKeySpec; .line 5 invoke-direct {v6, v4, v0}, Ljavax/crypto/spec/SecretKeySpec;->([BLjava/lang/String;)V invoke-virtual {p0, v5, v6, v2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V .line 6 invoke-virtual {p0, v3}, Ljavax/crypto/Cipher;->doFinal([B)[B move-result-object p0 .line 7 array-length p0, p0 :try_end_0 .catch Ljava/security/GeneralSecurityException; {:try_start_0 .. :try_end_0} :catch_0 if-eqz p0, :cond_1 return v1 :cond_1 const/4 p0, 0x1 return p0 :catch_0 return v1 .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/zzgjp;->zzf:[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/zzgjp;->zzf:[B .line 4 array-length v0, v0 const/16 v2, 0xc new-array v3, v2, [B const/4 v4, 0x0 .line 5 invoke-static {p1, v0, v3, v4, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V .line 6 new-instance v0, Ljavax/crypto/spec/IvParameterSpec; invoke-direct {v0, v3}, Ljavax/crypto/spec/IvParameterSpec;->([B)V sget-object v2, Lcom/google/android/gms/internal/ads/zzgjp;->zzd:Ljava/lang/ThreadLocal; .line 7 invoke-virtual {v2}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object; move-result-object v2 check-cast v2, Ljavax/crypto/Cipher; const/4 v3, 0x2 iget-object v4, p0, Lcom/google/android/gms/internal/ads/zzgjp;->zze:Ljavax/crypto/SecretKey; .line 8 invoke-virtual {v2, v3, v4, 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 9 invoke-virtual {v2, p2}, Ljavax/crypto/Cipher;->updateAAD([B)V :cond_0 iget-object p2, p0, Lcom/google/android/gms/internal/ads/zzgjp;->zzf:[B array-length p2, p2 add-int/lit8 v0, p2, 0xc sub-int/2addr v1, p2 add-int/lit8 v1, v1, -0xc .line 10 invoke-virtual {v2, 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