zzhp.smali
.class final Lcom/google/android/gms/internal/gtm/zzhp;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/google/android/gms/internal/gtm/zzhd;
# annotations
.annotation build Lcom/google/android/gms/common/util/VisibleForTesting;
.end annotation
# static fields
.field private static final zza:Ljava/lang/String;
.field private static final zzb:Ljava/lang/String;
.field private static final zzc:Ljava/lang/String;
.field private static final zzd:Ljava/lang/String;
# instance fields
.field private final zze:Lcom/google/android/gms/internal/gtm/zzho;
.field private volatile zzf:Lcom/google/android/gms/internal/gtm/zzgw;
.field private final zzg:Landroid/content/Context;
.field private final zzh:Ljava/lang/String;
.field private zzi:J
.field private final zzj:Lcom/google/android/gms/common/util/Clock;
.field private final zzk:I
.field private final zzl:Lcom/google/android/gms/internal/gtm/zzie;
# direct methods
.method public static constructor <clinit>()V
.registers 13
const/4 v0, 0x2
new-array v1, v0, [Ljava/lang/Object;
const/4 v2, 0x0
const-string v3, "gtm_hit_unique_ids"
aput-object v3, v1, v2
const/4 v4, 0x1
const-string v5, "hit_unique_id"
aput-object v5, v1, v4
const-string v6, "CREATE TABLE IF NOT EXISTS %s (\'%s\' TEXT UNIQUE);"
.line 1
invoke-static {v6, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
sput-object v1, Lcom/google/android/gms/internal/gtm/zzhp;->zza:Ljava/lang/String;
const/16 v1, 0x9
new-array v1, v1, [Ljava/lang/Object;
const-string v6, "gtm_hits"
aput-object v6, v1, v2
const-string v7, "hit_id"
aput-object v7, v1, v4
const-string v7, "hit_time"
aput-object v7, v1, v0
const-string v7, "hit_url"
const/4 v8, 0x3
aput-object v7, v1, v8
const-string v7, "hit_first_send_time"
const/4 v9, 0x4
aput-object v7, v1, v9
const-string v7, "hit_method"
const/4 v10, 0x5
aput-object v7, v1, v10
const/4 v7, 0x6
aput-object v5, v1, v7
const/4 v11, 0x7
const-string v12, "hit_headers"
aput-object v12, v1, v11
const/16 v11, 0x8
const-string v12, "hit_body"
aput-object v12, v1, v11
const-string v11, "CREATE TABLE IF NOT EXISTS %s ( \'%s\' INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, \'%s\' INTEGER NOT NULL, \'%s\' TEXT NOT NULL, \'%s\' INTEGER NOT NULL, \'%s\' TEXT NOT NULL, \'%s\' TEXT UNIQUE, \'%s\' TEXT, \'%s\' TEXT);"
.line 2
invoke-static {v11, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
sput-object v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzb:Ljava/lang/String;
new-array v1, v7, [Ljava/lang/Object;
const-string v11, "save_unique_on_delete"
aput-object v11, v1, v2
aput-object v6, v1, v4
aput-object v5, v1, v0
aput-object v3, v1, v8
aput-object v5, v1, v9
aput-object v5, v1, v10
const-string v11, "CREATE TRIGGER IF NOT EXISTS %s DELETE ON %s FOR EACH ROW WHEN OLD.%s NOTNULL BEGIN INSERT OR IGNORE INTO %s (%s) VALUES (OLD.%s); END;"
.line 3
invoke-static {v11, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
sput-object v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzc:Ljava/lang/String;
new-array v1, v7, [Ljava/lang/Object;
const-string v7, "check_unique_on_insert"
aput-object v7, v1, v2
aput-object v6, v1, v4
aput-object v5, v1, v0
aput-object v3, v1, v8
aput-object v5, v1, v9
aput-object v5, v1, v10
const-string v0, "CREATE TRIGGER IF NOT EXISTS %s BEFORE INSERT ON %s FOR EACH ROW WHEN NEW.%s NOT NULL BEGIN SELECT RAISE(ABORT, \'Duplicate unique ID.\') WHERE EXISTS (SELECT 1 FROM %s WHERE %s = NEW.%s); END;"
.line 4
invoke-static {v0, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/google/android/gms/internal/gtm/zzhp;->zzd:Ljava/lang/String;
return-void
.end method
.method public constructor <init>(Lcom/google/android/gms/internal/gtm/zzie;Landroid/content/Context;[B)V
.registers 4
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 1
invoke-virtual {p2}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object p2
iput-object p2, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzg:Landroid/content/Context;
const-string p3, "gtm_urls.db"
iput-object p3, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzh:Ljava/lang/String;
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzl:Lcom/google/android/gms/internal/gtm/zzie;
.line 2
invoke-static {}, Lcom/google/android/gms/common/util/DefaultClock;->getInstance()Lcom/google/android/gms/common/util/Clock;
move-result-object p1
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzj:Lcom/google/android/gms/common/util/Clock;
new-instance p1, Lcom/google/android/gms/internal/gtm/zzho;
.line 3
invoke-direct {p1, p0, p2, p3}, Lcom/google/android/gms/internal/gtm/zzho;-><init>(Lcom/google/android/gms/internal/gtm/zzhp;Landroid/content/Context;Ljava/lang/String;)V
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zze:Lcom/google/android/gms/internal/gtm/zzho;
new-instance p1, Lcom/google/android/gms/internal/gtm/zzin;
new-instance p3, Lcom/google/android/gms/internal/gtm/zzhn;
.line 4
invoke-direct {p3, p0}, Lcom/google/android/gms/internal/gtm/zzhn;-><init>(Lcom/google/android/gms/internal/gtm/zzhp;)V
invoke-direct {p1, p2, p3}, Lcom/google/android/gms/internal/gtm/zzin;-><init>(Landroid/content/Context;Lcom/google/android/gms/internal/gtm/zzim;)V
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzf:Lcom/google/android/gms/internal/gtm/zzgw;
const-wide/16 p1, 0x0
iput-wide p1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzi:J
const/16 p1, 0x7d0
iput p1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzk:I
return-void
.end method
.method public static bridge synthetic zzd(Lcom/google/android/gms/internal/gtm/zzhp;)Landroid/content/Context;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzg:Landroid/content/Context;
return-object p0
.end method
.method public static bridge synthetic zze(Lcom/google/android/gms/internal/gtm/zzhp;)Lcom/google/android/gms/common/util/Clock;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzj:Lcom/google/android/gms/common/util/Clock;
return-object p0
.end method
.method public static bridge synthetic zzf(Lcom/google/android/gms/internal/gtm/zzhp;)Ljava/lang/String;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzh:Ljava/lang/String;
return-object p0
.end method
.method public static bridge synthetic zzg()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzhp;->zzd:Ljava/lang/String;
return-object v0
.end method
.method public static bridge synthetic zzh()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzhp;->zzb:Ljava/lang/String;
return-object v0
.end method
.method public static bridge synthetic zzi()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzhp;->zza:Ljava/lang/String;
return-object v0
.end method
.method public static bridge synthetic zzj()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzhp;->zzc:Ljava/lang/String;
return-object v0
.end method
.method public static bridge synthetic zzk(Lcom/google/android/gms/internal/gtm/zzhp;J)V
.registers 3
invoke-direct {p0, p1, p2}, Lcom/google/android/gms/internal/gtm/zzhp;->zzo(J)V
return-void
.end method
.method public static bridge synthetic zzl(Lcom/google/android/gms/internal/gtm/zzhp;JJ)V
.registers 8
const-string v0, "Error opening database for getNumStoredHits."
.line 1
invoke-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
if-nez v0, :cond_9
return-void
:cond_9
new-instance v1, Landroid/content/ContentValues;
.line 2
invoke-direct {v1}, Landroid/content/ContentValues;-><init>()V
.line 3
invoke-static {p3, p4}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object p3
const-string p4, "hit_first_send_time"
invoke-virtual {v1, p4, p3}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/Long;)V
const/4 p3, 0x1
:try_start_18
new-array p3, p3, [Ljava/lang/String;
const/4 p4, 0x0
.line 4
invoke-static {p1, p2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v2
aput-object v2, p3, p4
const-string p4, "gtm_hits"
const-string v2, "hit_id=?"
invoke-virtual {v0, p4, v1, v2, p3}, Landroid/database/sqlite/SQLiteDatabase;->update(Ljava/lang/String;Landroid/content/ContentValues;Ljava/lang/String;[Ljava/lang/String;)I
:try_end_28
.catch Landroid/database/sqlite/SQLiteException; {:try_start_18 .. :try_end_28} :catch_29
return-void
:catch_29
move-exception p3
.line 5
invoke-virtual {p3}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p3
invoke-static {p3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p4
invoke-virtual {p4}, Ljava/lang/String;->length()I
move-result p4
new-instance v0, Ljava/lang/StringBuilder;
add-int/lit8 p4, p4, 0x46
invoke-direct {v0, p4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p4, "Error setting HIT_FIRST_DISPATCH_TIME for hitId "
const-string v1, ": "
.line 6
invoke-static {v0, p4, p1, p2, v1}, Landroidx/appcompat/k;->i(Ljava/lang/StringBuilder;Ljava/lang/String;JLjava/lang/String;)V
.line 7
invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p3
invoke-static {p3}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
.line 8
invoke-direct {p0, p1, p2}, Lcom/google/android/gms/internal/gtm/zzhp;->zzo(J)V
return-void
.end method
.method private final zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
.registers 4
:try_start_0
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zze:Lcom/google/android/gms/internal/gtm/zzho;
.line 1
invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzho;->getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase;
move-result-object p1
:try_end_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_0 .. :try_end_6} :catch_7
return-object p1
:catch_7
move-exception v0
iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzg:Landroid/content/Context;
.line 2
invoke-static {p1, v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zzf(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 3
invoke-static {v1, v0}, Lcom/google/android/gms/common/util/CrashUtils;->addDynamiteErrorToDropBox(Landroid/content/Context;Ljava/lang/Throwable;)Z
move-result p1
if-eqz p1, :cond_19
const-string p1, "Crash reported successfully."
.line 4
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
goto :goto_1e
:cond_19
const-string p1, "Failed to report crash"
.line 5
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
:goto_1e
const/4 p1, 0x0
return-object p1
.end method
.method private final zzo(J)V
.registers 4
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/String;
invoke-static {p1, p2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object p1
const/4 p2, 0x0
aput-object p1, v0, p2
invoke-virtual {p0, v0}, Lcom/google/android/gms/internal/gtm/zzhp;->zzm([Ljava/lang/String;)V
return-void
.end method
.method private final zzp(JLjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Ljava/lang/String;)V
.registers 11
.annotation system Ldalvik/annotation/Signature;
value = {
"(J",
"Ljava/lang/String;",
"Ljava/lang/String;",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;",
"Ljava/lang/String;",
")V"
}
.end annotation
const-string v0, "Error opening database for putHit"
.line 1
invoke-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
if-nez v0, :cond_9
return-void
:cond_9
new-instance v1, Landroid/content/ContentValues;
.line 2
invoke-direct {v1}, Landroid/content/ContentValues;-><init>()V
.line 3
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object p1
const-string p2, "hit_time"
invoke-virtual {v1, p2, p1}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/Long;)V
const-string p1, "hit_url"
.line 4
invoke-virtual {v1, p1, p3}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const/4 p1, 0x0
.line 5
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
const-string v2, "hit_first_send_time"
invoke-virtual {v1, v2, p2}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/Integer;)V
if-nez p4, :cond_2a
const-string p4, "GET"
:cond_2a
const-string p2, "hit_method"
.line 6
invoke-virtual {v1, p2, p4}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const-string p2, "hit_unique_id"
.line 7
invoke-virtual {v1, p2, p5}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const/4 p2, 0x0
if-nez p6, :cond_39
move-object p4, p2
goto :goto_42
.line 8
:cond_39
new-instance p4, Lorg/json/JSONObject;
invoke-direct {p4, p6}, Lorg/json/JSONObject;-><init>(Ljava/util/Map;)V
invoke-virtual {p4}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
move-result-object p4
:goto_42
const-string p5, "hit_headers"
invoke-virtual {v1, p5, p4}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const-string p4, "hit_body"
.line 9
invoke-virtual {v1, p4, p7}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
:try_start_4c
const-string p4, "gtm_hits"
.line 10
invoke-virtual {v0, p4, p2, v1}, Landroid/database/sqlite/SQLiteDatabase;->insertOrThrow(Ljava/lang/String;Ljava/lang/String;Landroid/content/ContentValues;)J
.line 11
invoke-static {p3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p2
invoke-virtual {p2}, Ljava/lang/String;->length()I
move-result p2
add-int/lit8 p2, p2, 0x13
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4, p2}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p2, "Hit stored (url = "
invoke-virtual {p4, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p2, ")"
invoke-virtual {p4, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {p2}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
iget-object p2, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzl:Lcom/google/android/gms/internal/gtm/zzie;
.line 12
invoke-virtual {p2, p1}, Lcom/google/android/gms/internal/gtm/zzie;->zza(Z)V
:try_end_79
.catch Landroid/database/sqlite/SQLiteConstraintException; {:try_start_4c .. :try_end_79} :catch_99
.catch Landroid/database/sqlite/SQLiteException; {:try_start_4c .. :try_end_79} :catch_7a
return-void
:catch_7a
move-exception p1
.line 13
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string p2, "Error storing hit: "
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result p3
if-eqz p3, :cond_90
invoke-virtual {p2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_95
.line 14
:cond_90
new-instance p1, Ljava/lang/String;
.line 15
invoke-direct {p1, p2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_95
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
return-void
:catch_99
nop
.line 16
invoke-static {p3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string p2, "Hit has already been sent: "
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result p3
if-eqz p3, :cond_ab
invoke-virtual {p2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_b0
.line 17
:cond_ab
new-instance p1, Ljava/lang/String;
.line 18
invoke-direct {p1, p2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_b0
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method public final zza()V
.registers 27
move-object/from16 v1, p0
const-string v0, "%s ASC"
const-string v2, "GTM Dispatch running..."
.line 1
invoke-static {v2}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
iget-object v2, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzf:Lcom/google/android/gms/internal/gtm/zzgw;
.line 2
invoke-interface {v2}, Lcom/google/android/gms/internal/gtm/zzgw;->zzb()Z
move-result v2
if-eqz v2, :cond_283
new-instance v2, Ljava/util/ArrayList;
.line 3
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
const-string v3, "Error opening database for peekHits"
.line 4
invoke-direct {v1, v3}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v3
const-string v13, "hit_first_send_time"
const-string v15, "hit_id"
const/4 v12, 0x0
const/4 v11, 0x1
if-nez v3, :cond_27
const/4 v14, 0x0
goto/16 :goto_206
:cond_27
:try_start_27
const-string v4, "hit_time"
.line 5
filled-new-array {v15, v4, v13}, [Ljava/lang/String;
move-result-object v6
new-array v4, v11, [Ljava/lang/Object;
aput-object v15, v4, v12
const-string v5, "gtm_hits"
const/4 v7, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
const/4 v10, 0x0
.line 6
invoke-static {v0, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v16
const/16 v17, 0x28
.line 7
invoke-static/range {v17 .. v17}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v18
:try_end_41
.catch Landroid/database/sqlite/SQLiteException; {:try_start_27 .. :try_end_41} :catch_1e1
.catchall {:try_start_27 .. :try_end_41} :catchall_1dd
move-object v4, v3
const/4 v14, 0x1
move-object/from16 v11, v16
const/4 v14, 0x0
move-object/from16 v12, v18
.line 8
:try_start_48
invoke-virtual/range {v4 .. v12}, 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;Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v12
:try_end_4c
.catch Landroid/database/sqlite/SQLiteException; {:try_start_48 .. :try_end_4c} :catch_1db
.catchall {:try_start_48 .. :try_end_4c} :catchall_1dd
:try_start_4c
new-instance v11, Ljava/util/ArrayList;
.line 9
invoke-direct {v11}, Ljava/util/ArrayList;-><init>()V
:try_end_51
.catch Landroid/database/sqlite/SQLiteException; {:try_start_4c .. :try_end_51} :catch_1d5
.catchall {:try_start_4c .. :try_end_51} :catchall_1ce
.line 10
:try_start_51
invoke-interface {v12}, Landroid/database/Cursor;->moveToFirst()Z
move-result v2
const/4 v10, 0x2
if-eqz v2, :cond_75
:cond_58
new-instance v2, Lcom/google/android/gms/internal/gtm/zzgz;
.line 11
invoke-interface {v12, v14}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v20
const/4 v4, 0x1
invoke-interface {v12, v4}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v22
invoke-interface {v12, v10}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v24
move-object/from16 v19, v2
invoke-direct/range {v19 .. v25}, Lcom/google/android/gms/internal/gtm/zzgz;-><init>(JJJ)V
.line 12
invoke-virtual {v11, v2}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 13
invoke-interface {v12}, Landroid/database/Cursor;->moveToNext()Z
move-result v2
:try_end_73
.catch Landroid/database/sqlite/SQLiteException; {:try_start_51 .. :try_end_73} :catch_1cb
.catchall {:try_start_51 .. :try_end_73} :catchall_1ce
if-nez v2, :cond_58
.line 14
:cond_75
invoke-interface {v12}, Landroid/database/Cursor;->close()V
:try_start_78
const-string v2, "hit_url"
const-string v4, "hit_method"
const-string v5, "hit_headers"
const-string v6, "hit_body"
filled-new-array {v15, v2, v4, v5, v6}, [Ljava/lang/String;
move-result-object v6
const/4 v2, 0x1
new-array v4, v2, [Ljava/lang/Object;
aput-object v15, v4, v14
const-string v5, "gtm_hits"
const/4 v7, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
const/4 v2, 0x0
.line 15
invoke-static {v0, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
.line 16
invoke-static/range {v17 .. v17}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v17
:try_end_97
.catch Landroid/database/sqlite/SQLiteException; {:try_start_78 .. :try_end_97} :catch_173
.catchall {:try_start_78 .. :try_end_97} :catchall_16d
move-object v4, v3
const/4 v3, 0x2
move-object v10, v2
move-object v2, v11
move-object v11, v0
move-object/from16 v18, v12
move-object/from16 v12, v17
.line 17
:try_start_a0
invoke-virtual/range {v4 .. v12}, 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;Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v12
:try_end_a4
.catch Landroid/database/sqlite/SQLiteException; {:try_start_a0 .. :try_end_a4} :catch_16b
.catchall {:try_start_a0 .. :try_end_a4} :catchall_169
.line 18
:try_start_a4
invoke-interface {v12}, Landroid/database/Cursor;->moveToFirst()Z
move-result v0
if-eqz v0, :cond_160
const/4 v4, 0x0
.line 19
:cond_ab
move-object v0, v12
check-cast v0, Landroid/database/sqlite/SQLiteCursor;
invoke-virtual {v0}, Landroid/database/AbstractCursor;->getWindow()Landroid/database/CursorWindow;
move-result-object v0
.line 20
invoke-virtual {v0}, Landroid/database/CursorWindow;->getNumRows()I
move-result v0
if-lez v0, :cond_13c
.line 21
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzgz;
const/4 v5, 0x1
invoke-interface {v12, v5}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v6
invoke-virtual {v0, v6}, Lcom/google/android/gms/internal/gtm/zzgz;->zzj(Ljava/lang/String;)V
.line 22
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzgz;
invoke-interface {v12, v3}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v5
invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/gtm/zzgz;->zzi(Ljava/lang/String;)V
.line 23
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzgz;
const/4 v5, 0x4
invoke-interface {v12, v5}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v5
invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/gtm/zzgz;->zzg(Ljava/lang/String;)V
:try_end_e1
.catch Landroid/database/sqlite/SQLiteException; {:try_start_a4 .. :try_end_e1} :catch_167
.catchall {:try_start_a4 .. :try_end_e1} :catchall_165
const/4 v0, 0x3
.line 24
:try_start_e2
invoke-interface {v12, v0}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_10d
.line 25
new-instance v5, Lorg/json/JSONObject;
invoke-direct {v5, v0}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V
.line 26
invoke-virtual {v5}, Lorg/json/JSONObject;->names()Lorg/json/JSONArray;
move-result-object v0
new-instance v6, Ljava/util/HashMap;
.line 27
invoke-direct {v6}, Ljava/util/HashMap;-><init>()V
const/4 v7, 0x0
.line 28
:goto_f7
invoke-virtual {v0}, Lorg/json/JSONArray;->length()I
move-result v8
if-ge v7, v8, :cond_10e
.line 29
invoke-virtual {v0, v7}, Lorg/json/JSONArray;->getString(I)Ljava/lang/String;
move-result-object v8
.line 30
invoke-virtual {v5, v8}, Lorg/json/JSONObject;->opt(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v9
check-cast v9, Ljava/lang/String;
invoke-virtual {v6, v8, v9}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_10a
.catch Lorg/json/JSONException; {:try_start_e2 .. :try_end_10a} :catch_118
.catch Landroid/database/sqlite/SQLiteException; {:try_start_e2 .. :try_end_10a} :catch_167
.catchall {:try_start_e2 .. :try_end_10a} :catchall_165
add-int/lit8 v7, v7, 0x1
goto :goto_f7
:cond_10d
const/4 v6, 0x0
.line 31
:cond_10e
:try_start_10e
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzgz;
invoke-virtual {v0, v6}, Lcom/google/android/gms/internal/gtm/zzgz;->zzh(Ljava/util/Map;)V
goto :goto_158
:catch_118
move-exception v0
new-array v5, v3, [Ljava/lang/Object;
.line 32
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v6
check-cast v6, Lcom/google/android/gms/internal/gtm/zzgz;
invoke-virtual {v6}, Lcom/google/android/gms/internal/gtm/zzgz;->zzb()J
move-result-wide v6
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v6
aput-object v6, v5, v14
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
const/4 v6, 0x1
aput-object v0, v5, v6
const-string v0, "Failed to read headers for hitId %d: %s"
.line 33
invoke-static {v0, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
.line 34
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
goto :goto_15a
:cond_13c
const/4 v5, 0x1
new-array v0, v5, [Ljava/lang/Object;
.line 35
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Lcom/google/android/gms/internal/gtm/zzgz;
invoke-virtual {v5}, Lcom/google/android/gms/internal/gtm/zzgz;->zzb()J
move-result-wide v5
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
aput-object v5, v0, v14
const-string v5, "HitString for hitId %d too large. Hit will be deleted."
.line 36
invoke-static {v5, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
.line 37
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
:goto_158
add-int/lit8 v4, v4, 0x1
.line 38
:goto_15a
invoke-interface {v12}, Landroid/database/Cursor;->moveToNext()Z
move-result v0
:try_end_15e
.catch Landroid/database/sqlite/SQLiteException; {:try_start_10e .. :try_end_15e} :catch_167
.catchall {:try_start_10e .. :try_end_15e} :catchall_165
if-nez v0, :cond_ab
.line 39
:cond_160
invoke-interface {v12}, Landroid/database/Cursor;->close()V
goto/16 :goto_206
:catchall_165
move-exception v0
goto :goto_1c5
:catch_167
move-exception v0
goto :goto_179
:catchall_169
move-exception v0
goto :goto_170
:catch_16b
move-exception v0
goto :goto_177
:catchall_16d
move-exception v0
move-object/from16 v18, v12
:goto_170
move-object/from16 v12, v18
goto :goto_1c5
:catch_173
move-exception v0
move-object v2, v11
move-object/from16 v18, v12
:goto_177
move-object/from16 v12, v18
:goto_179
:try_start_179
const-string v3, "Error in peekHits fetching hit url: "
.line 40
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_18e
invoke-virtual {v3, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_193
.line 41
:cond_18e
new-instance v0, Ljava/lang/String;
.line 42
invoke-direct {v0, v3}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_193
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
new-instance v0, Ljava/util/ArrayList;
.line 43
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 44
invoke-virtual {v2}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v2
const/4 v3, 0x0
:goto_1a0
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_1be
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/google/android/gms/internal/gtm/zzgz;
.line 45
invoke-virtual {v4}, Lcom/google/android/gms/internal/gtm/zzgz;->zze()Ljava/lang/String;
move-result-object v5
invoke-static {v5}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v5
if-eqz v5, :cond_1ba
if-eqz v3, :cond_1b9
goto :goto_1be
:cond_1b9
const/4 v3, 0x1
.line 46
:cond_1ba
invoke-virtual {v0, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
:try_end_1bd
.catchall {:try_start_179 .. :try_end_1bd} :catchall_165
goto :goto_1a0
:cond_1be
:goto_1be
if-eqz v12, :cond_1c3
.line 47
invoke-interface {v12}, Landroid/database/Cursor;->close()V
:cond_1c3
move-object v2, v0
goto :goto_206
:goto_1c5
if-eqz v12, :cond_1ca
invoke-interface {v12}, Landroid/database/Cursor;->close()V
.line 48
:cond_1ca
throw v0
:catch_1cb
move-exception v0
move-object v2, v11
goto :goto_1d6
:catchall_1ce
move-exception v0
move-object/from16 v18, v12
move-object/from16 v14, v18
goto/16 :goto_27d
:catch_1d5
move-exception v0
:goto_1d6
move-object/from16 v18, v12
move-object/from16 v12, v18
goto :goto_1e4
:catch_1db
move-exception v0
goto :goto_1e3
:catchall_1dd
move-exception v0
const/4 v14, 0x0
goto/16 :goto_27d
:catch_1e1
move-exception v0
const/4 v14, 0x0
:goto_1e3
const/4 v12, 0x0
:goto_1e4
:try_start_1e4
const-string v3, "Error in peekHits fetching hitIds: "
.line 49
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_1f9
invoke-virtual {v3, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_1fe
.line 50
:cond_1f9
new-instance v0, Ljava/lang/String;
.line 51
invoke-direct {v0, v3}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_1fe
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
:try_end_201
.catchall {:try_start_1e4 .. :try_end_201} :catchall_27b
if-eqz v12, :cond_206
.line 52
invoke-interface {v12}, Landroid/database/Cursor;->close()V
.line 53
:cond_206
:goto_206
invoke-interface {v2}, Ljava/util/List;->isEmpty()Z
move-result v0
if-eqz v0, :cond_218
const-string v0, "...nothing to dispatch"
.line 54
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
iget-object v0, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzl:Lcom/google/android/gms/internal/gtm/zzie;
const/4 v2, 0x1
.line 55
invoke-virtual {v0, v2}, Lcom/google/android/gms/internal/gtm/zzie;->zza(Z)V
return-void
:cond_218
iget-object v0, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzf:Lcom/google/android/gms/internal/gtm/zzgw;
.line 56
invoke-interface {v0, v2}, Lcom/google/android/gms/internal/gtm/zzgw;->zza(Ljava/util/List;)V
const-string v0, "Error opening database for getNumStoredHits."
.line 57
invoke-direct {v1, v0}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v2
if-nez v2, :cond_226
goto :goto_26e
:cond_226
:try_start_226
filled-new-array {v15, v13}, [Ljava/lang/String;
move-result-object v4
const-string v3, "gtm_hits"
const-string v5, "hit_first_send_time=0"
const/4 v6, 0x0
const/4 v7, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
.line 58
invoke-virtual/range {v2 .. v9}, 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 v2
:try_end_236
.catch Landroid/database/sqlite/SQLiteException; {:try_start_226 .. :try_end_236} :catch_243
.catchall {:try_start_226 .. :try_end_236} :catchall_240
.line 59
:try_start_236
invoke-interface {v2}, Landroid/database/Cursor;->getCount()I
move-result v12
:try_end_23a
.catch Landroid/database/sqlite/SQLiteException; {:try_start_236 .. :try_end_23a} :catch_23e
.catchall {:try_start_236 .. :try_end_23a} :catchall_273
.line 60
invoke-interface {v2}, Landroid/database/Cursor;->close()V
goto :goto_265
:catch_23e
move-exception v0
goto :goto_245
:catchall_240
move-exception v0
const/4 v14, 0x0
goto :goto_275
:catch_243
move-exception v0
const/4 v2, 0x0
:goto_245
:try_start_245
const-string v3, "Error getting num untried hits: "
.line 61
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_25a
invoke-virtual {v3, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_25f
.line 62
:cond_25a
new-instance v0, Ljava/lang/String;
.line 63
invoke-direct {v0, v3}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_25f
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
:try_end_262
.catchall {:try_start_245 .. :try_end_262} :catchall_273
if-nez v2, :cond_26f
const/4 v12, 0x0
:goto_265
if-lez v12, :cond_26e
.line 64
invoke-static {}, Lcom/google/android/gms/internal/gtm/zzik;->zzf()Lcom/google/android/gms/internal/gtm/zzik;
move-result-object v0
invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzik;->zzi()V
:cond_26e
:goto_26e
return-void
.line 65
:cond_26f
invoke-interface {v2}, Landroid/database/Cursor;->close()V
return-void
:catchall_273
move-exception v0
move-object v14, v2
:goto_275
if-eqz v14, :cond_27a
invoke-interface {v14}, Landroid/database/Cursor;->close()V
.line 66
:cond_27a
throw v0
:catchall_27b
move-exception v0
move-object v14, v12
:goto_27d
if-eqz v14, :cond_282
.line 67
invoke-interface {v14}, Landroid/database/Cursor;->close()V
.line 68
:cond_282
throw v0
:cond_283
return-void
.end method
.method public final zzb(JLjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Ljava/lang/String;)V
.registers 26
.annotation system Ldalvik/annotation/Signature;
value = {
"(J",
"Ljava/lang/String;",
"Ljava/lang/String;",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;",
"Ljava/lang/String;",
")V"
}
.end annotation
move-object/from16 v1, p0
const-string v0, "hit_id"
iget-object v2, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzj:Lcom/google/android/gms/common/util/Clock;
.line 1
invoke-interface {v2}, Lcom/google/android/gms/common/util/Clock;->currentTimeMillis()J
move-result-wide v2
iget-wide v4, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzi:J
const-wide/32 v6, 0x5265c00
add-long/2addr v4, v6
const-string v6, "gtm_hits"
const/4 v7, 0x1
const/4 v8, 0x0
cmp-long v9, v2, v4
if-gtz v9, :cond_19
goto :goto_66
.line 2
:cond_19
iput-wide v2, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzi:J
const-string v2, "Error opening database for deleteStaleHits."
.line 3
invoke-direct {v1, v2}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v2
if-eqz v2, :cond_66
iget-object v3, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzj:Lcom/google/android/gms/common/util/Clock;
.line 4
invoke-interface {v3}, Lcom/google/android/gms/common/util/Clock;->currentTimeMillis()J
move-result-wide v3
new-array v5, v7, [Ljava/lang/String;
const-wide v9, -0x9a7ec800L
add-long/2addr v3, v9
.line 5
invoke-static {v3, v4}, Ljava/lang/Long;->toString(J)Ljava/lang/String;
move-result-object v3
aput-object v3, v5, v8
const-string v3, "HIT_TIME < ?"
invoke-virtual {v2, v6, v3, v5}, Landroid/database/sqlite/SQLiteDatabase;->delete(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)I
move-result v2
new-instance v3, Ljava/lang/StringBuilder;
const/16 v4, 0x1f
.line 6
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v4, "Removed "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, " stale hits."
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v2}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
iget-object v2, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzl:Lcom/google/android/gms/internal/gtm/zzie;
.line 7
invoke-virtual {v1, v6}, Lcom/google/android/gms/internal/gtm/zzhp;->zzc(Ljava/lang/String;)I
move-result v3
if-nez v3, :cond_62
const/4 v3, 0x1
goto :goto_63
:cond_62
const/4 v3, 0x0
.line 8
:goto_63
invoke-virtual {v2, v3}, Lcom/google/android/gms/internal/gtm/zzie;->zza(Z)V
.line 9
:cond_66
:goto_66
invoke-virtual {v1, v6}, Lcom/google/android/gms/internal/gtm/zzhp;->zzc(Ljava/lang/String;)I
move-result v2
iget v3, v1, Lcom/google/android/gms/internal/gtm/zzhp;->zzk:I
sub-int/2addr v2, v3
add-int/2addr v2, v7
if-lez v2, :cond_109
new-instance v3, Ljava/util/ArrayList;
.line 10
invoke-direct {v3}, Ljava/util/ArrayList;-><init>()V
const-string v4, "Error opening database for peekHitIds."
.line 11
invoke-direct {v1, v4}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v9
if-nez v9, :cond_7e
goto :goto_d8
:cond_7e
const/4 v4, 0x0
.line 12
:try_start_7f
filled-new-array {v0}, [Ljava/lang/String;
move-result-object v11
new-array v5, v7, [Ljava/lang/Object;
aput-object v0, v5, v8
const-string v10, "gtm_hits"
const/4 v12, 0x0
const/4 v13, 0x0
const/4 v14, 0x0
const/4 v15, 0x0
const-string v0, "%s ASC"
.line 13
invoke-static {v0, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v16
.line 14
invoke-static {v2}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v17
.line 15
invoke-virtual/range {v9 .. v17}, 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;Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v4
.line 16
invoke-interface {v4}, Landroid/database/Cursor;->moveToFirst()Z
move-result v0
if-eqz v0, :cond_d5
.line 17
:cond_a1
invoke-interface {v4, v8}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v5
invoke-static {v5, v6}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 18
invoke-interface {v4}, Landroid/database/Cursor;->moveToNext()Z
move-result v0
:try_end_b0
.catch Landroid/database/sqlite/SQLiteException; {:try_start_7f .. :try_end_b0} :catch_b5
.catchall {:try_start_7f .. :try_end_b0} :catchall_b3
if-nez v0, :cond_a1
goto :goto_d5
:catchall_b3
move-exception v0
goto :goto_103
:catch_b5
move-exception v0
:try_start_b6
const-string v2, "Error in peekHits fetching hitIds: "
.line 19
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v5
if-eqz v5, :cond_cb
invoke-virtual {v2, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_d0
.line 20
:cond_cb
new-instance v0, Ljava/lang/String;
.line 21
invoke-direct {v0, v2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_d0
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
:try_end_d3
.catchall {:try_start_b6 .. :try_end_d3} :catchall_b3
if-eqz v4, :cond_d8
.line 22
:cond_d5
:goto_d5
invoke-interface {v4}, Landroid/database/Cursor;->close()V
.line 23
:cond_d8
:goto_d8
invoke-virtual {v3}, Ljava/util/ArrayList;->size()I
move-result v0
new-instance v2, Ljava/lang/StringBuilder;
const/16 v4, 0x33
invoke-direct {v2, v4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v4, "Store full, deleting "
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v0, " hits to make room."
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
new-array v0, v8, [Ljava/lang/String;
.line 24
invoke-virtual {v3, v0}, Ljava/util/ArrayList;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v0
check-cast v0, [Ljava/lang/String;
invoke-virtual {v1, v0}, Lcom/google/android/gms/internal/gtm/zzhp;->zzm([Ljava/lang/String;)V
goto :goto_109
:goto_103
if-eqz v4, :cond_108
.line 25
invoke-interface {v4}, Landroid/database/Cursor;->close()V
.line 26
:cond_108
throw v0
.line 27
:cond_109
:goto_109
invoke-direct/range {p0 .. p7}, Lcom/google/android/gms/internal/gtm/zzhp;->zzp(JLjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Ljava/lang/String;)V
.line 28
invoke-static {}, Lcom/google/android/gms/internal/gtm/zzhs;->zza()Lcom/google/android/gms/internal/gtm/zzhs;
move-result-object v0
invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzhs;->zzd()Z
move-result v0
if-eqz v0, :cond_11e
const-string v0, "Sending hits immediately under preview."
.line 29
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzhl;->zzd(Ljava/lang/String;)V
.line 30
invoke-virtual/range {p0 .. p0}, Lcom/google/android/gms/internal/gtm/zzhp;->zza()V
:cond_11e
return-void
.end method
.method public final zzc(Ljava/lang/String;)I
.registers 6
const-string p1, "Error opening database for getNumRecords."
.line 1
invoke-direct {p0, p1}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object p1
const-string v0, "SELECT COUNT(*) from gtm_hits"
const/4 v1, 0x0
if-eqz p1, :cond_4c
const/4 v2, 0x0
.line 2
:try_start_c
invoke-virtual {p1, v0, v2}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v2
.line 3
invoke-interface {v2}, Landroid/database/Cursor;->moveToFirst()Z
move-result p1
if-eqz p1, :cond_1b
.line 4
invoke-interface {v2, v1}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v0
:try_end_1a
.catch Landroid/database/sqlite/SQLiteException; {:try_start_c .. :try_end_1a} :catch_21
.catchall {:try_start_c .. :try_end_1a} :catchall_1f
long-to-int v1, v0
.line 5
:cond_1b
invoke-interface {v2}, Landroid/database/Cursor;->close()V
return v1
:catchall_1f
move-exception p1
goto :goto_46
:catch_21
move-exception p1
:try_start_22
const-string v0, "Error getting numStoredRecords: "
.line 6
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v3
if-eqz v3, :cond_37
invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_3c
.line 7
:cond_37
new-instance p1, Ljava/lang/String;
.line 8
invoke-direct {p1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_3c
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
:try_end_3f
.catchall {:try_start_22 .. :try_end_3f} :catchall_1f
if-nez v2, :cond_42
return v1
.line 9
:cond_42
invoke-interface {v2}, Landroid/database/Cursor;->close()V
return v1
:goto_46
if-eqz v2, :cond_4b
invoke-interface {v2}, Landroid/database/Cursor;->close()V
.line 10
:cond_4b
throw p1
:cond_4c
return v1
.end method
.method public final zzm([Ljava/lang/String;)V
.registers 8
const-string v0, "gtm_hits"
if-eqz p1, :cond_58
array-length v1, p1
if-nez v1, :cond_8
goto :goto_58
:cond_8
const-string v2, "Error opening database for deleteHits."
.line 1
invoke-direct {p0, v2}, Lcom/google/android/gms/internal/gtm/zzhp;->zzn(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v2
if-nez v2, :cond_11
return-void
:cond_11
const/4 v3, 0x1
new-array v4, v3, [Ljava/lang/Object;
const-string v5, "?"
.line 2
invoke-static {v1, v5}, Ljava/util/Collections;->nCopies(ILjava/lang/Object;)Ljava/util/List;
move-result-object v1
const-string v5, ","
invoke-static {v5, v1}, Landroid/text/TextUtils;->join(Ljava/lang/CharSequence;Ljava/lang/Iterable;)Ljava/lang/String;
move-result-object v1
const/4 v5, 0x0
aput-object v1, v4, v5
const-string v1, "HIT_ID in (%s)"
.line 3
invoke-static {v1, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
.line 4
:try_start_29
invoke-virtual {v2, v0, v1, p1}, Landroid/database/sqlite/SQLiteDatabase;->delete(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)I
iget-object p1, p0, Lcom/google/android/gms/internal/gtm/zzhp;->zzl:Lcom/google/android/gms/internal/gtm/zzie;
.line 5
invoke-virtual {p0, v0}, Lcom/google/android/gms/internal/gtm/zzhp;->zzc(Ljava/lang/String;)I
move-result v0
if-nez v0, :cond_35
goto :goto_36
:cond_35
const/4 v3, 0x0
.line 6
:goto_36
invoke-virtual {p1, v3}, Lcom/google/android/gms/internal/gtm/zzie;->zza(Z)V
:try_end_39
.catch Landroid/database/sqlite/SQLiteException; {:try_start_29 .. :try_end_39} :catch_3a
return-void
:catch_3a
move-exception p1
.line 7
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string v0, "Error deleting hits: "
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v1
if-eqz v1, :cond_50
invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_55
:cond_50
new-instance p1, Ljava/lang/String;
invoke-direct {p1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_55
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzhl;->zze(Ljava/lang/String;)V
:cond_58
:goto_58
return-void
.end method