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