.class final Lcom/google/android/gms/internal/gtm/zzcd; .super Landroid/database/sqlite/SQLiteOpenHelper; .source "com.google.android.gms:play-services-analytics-impl@@17.0.1" # annotations .annotation build Lcom/google/android/gms/common/util/VisibleForTesting; .end annotation # instance fields .field public final synthetic zza:Lcom/google/android/gms/internal/gtm/zzce; # direct methods .method public constructor (Lcom/google/android/gms/internal/gtm/zzce;Landroid/content/Context;Ljava/lang/String;)V .locals 1 iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; const-string p1, "google_analytics_v4.db" const/4 p3, 0x0 const/4 v0, 0x1 .line 1 invoke-direct {p0, p2, p1, p3, v0}, Landroid/database/sqlite/SQLiteOpenHelper;->(Landroid/content/Context;Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase$CursorFactory;I)V return-void .end method .method private final zza(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Z .locals 11 const/4 v0, 0x0 const/4 v1, 0x0 :try_start_0 const-string v2, "name" filled-new-array {v2}, [Ljava/lang/String; move-result-object v5 const/4 v2, 0x1 new-array v7, v2, [Ljava/lang/String; aput-object p2, v7, v0 const-string v4, "SQLITE_MASTER" const-string v6, "name=?" const/4 v8, 0x0 const/4 v9, 0x0 const/4 v10, 0x0 move-object v3, p1 .line 1 invoke-virtual/range {v3 .. v10}, Landroid/database/sqlite/SQLiteDatabase;->query(Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Landroid/database/Cursor; move-result-object v1 .line 2 invoke-interface {v1}, Landroid/database/Cursor;->moveToFirst()Z move-result p1 :try_end_0 .catch Landroid/database/sqlite/SQLiteException; {:try_start_0 .. :try_end_0} :catch_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 3 invoke-interface {v1}, Landroid/database/Cursor;->close()V return p1 :catchall_0 move-exception p1 goto :goto_0 :catch_0 move-exception p1 :try_start_1 iget-object v2, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; const-string v3, "Error querying for table" .line 4 invoke-virtual {v2, v3, p2, p1}, Lcom/google/android/gms/internal/gtm/zzbr;->zzT(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-eqz v1, :cond_0 .line 5 invoke-interface {v1}, Landroid/database/Cursor;->close()V :cond_0 return v0 :goto_0 if-eqz v1, :cond_1 invoke-interface {v1}, Landroid/database/Cursor;->close()V .line 6 :cond_1 throw p1 .end method .method private static final zzb(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Ljava/util/Set; .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Landroid/database/sqlite/SQLiteDatabase;", "Ljava/lang/String;", ")", "Ljava/util/Set<", "Ljava/lang/String;", ">;" } .end annotation new-instance v0, Ljava/util/HashSet; .line 1 invoke-direct {v0}, Ljava/util/HashSet;->()V .line 2 invoke-virtual {p1}, Ljava/lang/String;->length()I move-result v1 new-instance v2, Ljava/lang/StringBuilder; add-int/lit8 v1, v1, 0x16 invoke-direct {v2, v1}, Ljava/lang/StringBuilder;->(I)V const-string v1, "SELECT * FROM " const-string v3, " LIMIT 0" invoke-static {v2, v1, p1, v3}, Landroidx/fragment/app/z;->a(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object p1 const/4 v1, 0x0 .line 3 invoke-virtual {p0, p1, v1}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor; move-result-object p0 .line 4 :try_start_0 invoke-interface {p0}, Landroid/database/Cursor;->getColumnNames()[Ljava/lang/String; move-result-object p1 const/4 v1, 0x0 .line 5 :goto_0 array-length v2, p1 if-ge v1, v2, :cond_0 .line 6 aget-object v2, p1, v1 invoke-virtual {v0, v2}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 add-int/lit8 v1, v1, 0x1 goto :goto_0 .line 7 :cond_0 invoke-interface {p0}, Landroid/database/Cursor;->close()V return-object v0 :catchall_0 move-exception p1 invoke-interface {p0}, Landroid/database/Cursor;->close()V .line 8 throw p1 .end method # virtual methods .method public final getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase; .locals 3 iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzce;->zzg(Lcom/google/android/gms/internal/gtm/zzce;)Lcom/google/android/gms/internal/gtm/zzfo; move-result-object v0 const-wide/32 v1, 0x36ee80 .line 1 invoke-virtual {v0, v1, v2}, Lcom/google/android/gms/internal/gtm/zzfo;->zzc(J)Z move-result v0 if-eqz v0, :cond_0 .line 2 :try_start_0 invoke-super {p0}, Landroid/database/sqlite/SQLiteOpenHelper;->getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase; move-result-object v0 :try_end_0 .catch Landroid/database/sqlite/SQLiteException; {:try_start_0 .. :try_end_0} :catch_0 return-object v0 :catch_0 iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzce;->zzg(Lcom/google/android/gms/internal/gtm/zzce;)Lcom/google/android/gms/internal/gtm/zzfo; move-result-object v0 .line 3 invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzfo;->zzb()V iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; const-string v1, "Opening the database failed, dropping the table and recreating it" .line 4 invoke-virtual {v0, v1}, Lcom/google/android/gms/internal/gtm/zzbr;->zzJ(Ljava/lang/String;)V iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; .line 5 invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzce;->zzh(Lcom/google/android/gms/internal/gtm/zzce;)Ljava/lang/String; move-result-object v0 iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; .line 6 invoke-virtual {v1}, Lcom/google/android/gms/internal/gtm/zzbr;->zzo()Landroid/content/Context; move-result-object v1 invoke-virtual {v1, v0}, Landroid/content/Context;->getDatabasePath(Ljava/lang/String;)Ljava/io/File; move-result-object v0 invoke-virtual {v0}, Ljava/io/File;->delete()Z .line 7 :try_start_1 invoke-super {p0}, Landroid/database/sqlite/SQLiteOpenHelper;->getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase; move-result-object v0 iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; invoke-static {v1}, Lcom/google/android/gms/internal/gtm/zzce;->zzg(Lcom/google/android/gms/internal/gtm/zzce;)Lcom/google/android/gms/internal/gtm/zzfo; move-result-object v1 .line 8 invoke-virtual {v1}, Lcom/google/android/gms/internal/gtm/zzfo;->zza()V :try_end_1 .catch Landroid/database/sqlite/SQLiteException; {:try_start_1 .. :try_end_1} :catch_1 return-object v0 :catch_1 move-exception v0 iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzcd;->zza:Lcom/google/android/gms/internal/gtm/zzce; const-string v2, "Failed to open freshly created database" .line 9 invoke-virtual {v1, v2, v0}, Lcom/google/android/gms/internal/gtm/zzbr;->zzK(Ljava/lang/String;Ljava/lang/Object;)V .line 10 throw v0 .line 11 :cond_0 new-instance v0, Landroid/database/sqlite/SQLiteException; const-string v1, "Database open failed" invoke-direct {v0, v1}, Landroid/database/sqlite/SQLiteException;->(Ljava/lang/String;)V throw v0 .end method .method public final onCreate(Landroid/database/sqlite/SQLiteDatabase;)V .locals 2 .line 1 invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->getPath()Ljava/lang/String; move-result-object p1 :try_start_0 sget-object v0, Landroid/os/Build$VERSION;->SDK:Ljava/lang/String; .line 2 invoke-static {v0}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I move-result v0 :try_end_0 .catch Ljava/lang/NumberFormatException; {:try_start_0 .. :try_end_0} :catch_0 const/16 v1, 0x9 if-ge v0, v1, :cond_0 return-void :cond_0 new-instance v0, Ljava/io/File; .line 3 invoke-direct {v0, p1}, Ljava/io/File;->(Ljava/lang/String;)V const/4 p1, 0x0 .line 4 invoke-virtual {v0, p1, p1}, Ljava/io/File;->setReadable(ZZ)Z .line 5 invoke-virtual {v0, p1, p1}, Ljava/io/File;->setWritable(ZZ)Z const/4 p1, 0x1 .line 6 invoke-virtual {v0, p1, p1}, Ljava/io/File;->setReadable(ZZ)Z .line 7 invoke-virtual {v0, p1, p1}, Ljava/io/File;->setWritable(ZZ)Z return-void :catch_0 sget-object p1, Landroid/os/Build$VERSION;->SDK:Ljava/lang/String; const-string v0, "Invalid version number" .line 8 invoke-static {v0, p1}, Lcom/google/android/gms/internal/gtm/zzfa;->zzb(Ljava/lang/String;Ljava/lang/Object;)V return-void .end method .method public final onDowngrade(Landroid/database/sqlite/SQLiteDatabase;II)V .locals 0 return-void .end method .method public final onOpen(Landroid/database/sqlite/SQLiteDatabase;)V .locals 9 const-string v0, "hits2" .line 1 invoke-direct {p0, p1, v0}, Lcom/google/android/gms/internal/gtm/zzcd;->zza(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Z move-result v1 const/4 v2, 0x0 if-nez v1, :cond_0 .line 2 invoke-static {}, Lcom/google/android/gms/internal/gtm/zzce;->zzi()Ljava/lang/String; move-result-object v0 invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V goto :goto_2 .line 3 :cond_0 invoke-static {p1, v0}, Lcom/google/android/gms/internal/gtm/zzcd;->zzb(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Ljava/util/Set; move-result-object v0 const-string v1, "hit_id" const-string v3, "hit_string" const-string v4, "hit_time" const-string v5, "hit_url" filled-new-array {v1, v3, v4, v5}, [Ljava/lang/String; move-result-object v1 move v3, v2 :goto_0 const/4 v4, 0x4 if-ge v3, v4, :cond_3 .line 4 aget-object v4, v1, v3 .line 5 invoke-interface {v0, v4}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z move-result v5 if-nez v5, :cond_2 .line 6 new-instance p1, Landroid/database/sqlite/SQLiteException; invoke-static {v4}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v0 const-string v1, "Database hits2 is missing required column: " invoke-virtual {v0}, Ljava/lang/String;->length()I move-result v2 if-eqz v2, :cond_1 invoke-virtual {v1, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 goto :goto_1 .line 7 :cond_1 new-instance v0, Ljava/lang/String; .line 8 invoke-direct {v0, v1}, Ljava/lang/String;->(Ljava/lang/String;)V :goto_1 invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;->(Ljava/lang/String;)V throw p1 :cond_2 add-int/lit8 v3, v3, 0x1 goto :goto_0 :cond_3 const-string v1, "hit_app_id" .line 9 invoke-interface {v0, v1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z move-result v1 xor-int/lit8 v1, v1, 0x1 .line 10 invoke-interface {v0}, Ljava/util/Set;->isEmpty()Z move-result v0 if-eqz v0, :cond_a if-eqz v1, :cond_4 const-string v0, "ALTER TABLE hits2 ADD COLUMN hit_app_id INTEGER" .line 11 invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V :cond_4 :goto_2 const-string v0, "properties" .line 12 invoke-direct {p0, p1, v0}, Lcom/google/android/gms/internal/gtm/zzcd;->zza(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Z move-result v1 if-eqz v1, :cond_9 .line 13 invoke-static {p1, v0}, Lcom/google/android/gms/internal/gtm/zzcd;->zzb(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Ljava/util/Set; move-result-object p1 const-string v3, "app_uid" const-string v4, "cid" const-string v5, "tid" const-string v6, "params" const-string v7, "adid" const-string v8, "hits_count" filled-new-array/range {v3 .. v8}, [Ljava/lang/String; move-result-object v0 :goto_3 const/4 v1, 0x6 if-ge v2, v1, :cond_7 .line 14 aget-object v1, v0, v2 .line 15 invoke-interface {p1, v1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z move-result v3 if-nez v3, :cond_6 .line 16 new-instance p1, Landroid/database/sqlite/SQLiteException; invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v0 const-string v1, "Database properties is missing required column: " invoke-virtual {v0}, Ljava/lang/String;->length()I move-result v2 if-eqz v2, :cond_5 invoke-virtual {v1, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 goto :goto_4 .line 17 :cond_5 new-instance v0, Ljava/lang/String; .line 18 invoke-direct {v0, v1}, Ljava/lang/String;->(Ljava/lang/String;)V :goto_4 invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;->(Ljava/lang/String;)V throw p1 :cond_6 add-int/lit8 v2, v2, 0x1 goto :goto_3 .line 19 :cond_7 invoke-interface {p1}, Ljava/util/Set;->isEmpty()Z move-result p1 if-eqz p1, :cond_8 return-void .line 20 :cond_8 new-instance p1, Landroid/database/sqlite/SQLiteException; const-string v0, "Database properties table has extra columns" invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;->(Ljava/lang/String;)V throw p1 :cond_9 const-string v0, "CREATE TABLE IF NOT EXISTS properties ( app_uid INTEGER NOT NULL, cid TEXT NOT NULL, tid TEXT NOT NULL, params TEXT NOT NULL, adid INTEGER NOT NULL, hits_count INTEGER NOT NULL, PRIMARY KEY (app_uid, cid, tid)) ;" .line 21 invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V return-void .line 22 :cond_a new-instance p1, Landroid/database/sqlite/SQLiteException; const-string v0, "Database hits2 has extra columns" invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;->(Ljava/lang/String;)V throw p1 .end method .method public final onUpgrade(Landroid/database/sqlite/SQLiteDatabase;II)V .locals 0 return-void .end method