zzey.smali
.class final Lcom/google/android/gms/internal/gtm/zzey;
.super Ljava/lang/Object;
# interfaces
.implements Lcom/google/android/gms/internal/gtm/zzem;
# static fields
.field private static final i:Ljava/lang/String;
.field private static final j:Ljava/lang/String;
.field private static final k:Ljava/lang/String;
.field private static final l:Ljava/lang/String;
# instance fields
.field private final a:Lcom/google/android/gms/internal/gtm/zzfa;
.field private volatile b:Lcom/google/android/gms/internal/gtm/zzed;
.field private final c:Lcom/google/android/gms/internal/gtm/zzen;
.field private final d:Landroid/content/Context;
.field private final e:Ljava/lang/String;
.field private f:J
.field private g:Lcom/google/android/gms/common/util/Clock;
.field private final h:I
# direct methods
.method 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);"
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/zzey;->i: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);"
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/zzey;->j: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;"
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/zzey;->k: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;"
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/zzey;->l:Ljava/lang/String;
return-void
.end method
.method constructor <init>(Lcom/google/android/gms/internal/gtm/zzen;Landroid/content/Context;)V
.registers 5
const-string v0, "gtm_urls.db"
const/16 v1, 0x7d0
invoke-direct {p0, p1, p2, v0, v1}, Lcom/google/android/gms/internal/gtm/zzey;-><init>(Lcom/google/android/gms/internal/gtm/zzen;Landroid/content/Context;Ljava/lang/String;I)V
return-void
.end method
.method private constructor <init>(Lcom/google/android/gms/internal/gtm/zzen;Landroid/content/Context;Ljava/lang/String;I)V
.registers 5
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
invoke-virtual {p2}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object p2
iput-object p2, p0, Lcom/google/android/gms/internal/gtm/zzey;->d:Landroid/content/Context;
iput-object p3, p0, Lcom/google/android/gms/internal/gtm/zzey;->e:Ljava/lang/String;
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzey;->c:Lcom/google/android/gms/internal/gtm/zzen;
invoke-static {}, Lcom/google/android/gms/common/util/DefaultClock;->d()Lcom/google/android/gms/common/util/Clock;
move-result-object p1
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzey;->g:Lcom/google/android/gms/common/util/Clock;
new-instance p1, Lcom/google/android/gms/internal/gtm/zzfa;
iget-object p2, p0, Lcom/google/android/gms/internal/gtm/zzey;->d:Landroid/content/Context;
iget-object p3, p0, Lcom/google/android/gms/internal/gtm/zzey;->e:Ljava/lang/String;
invoke-direct {p1, p0, p2, p3}, Lcom/google/android/gms/internal/gtm/zzfa;-><init>(Lcom/google/android/gms/internal/gtm/zzey;Landroid/content/Context;Ljava/lang/String;)V
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzey;->a:Lcom/google/android/gms/internal/gtm/zzfa;
new-instance p1, Lcom/google/android/gms/internal/gtm/zzfu;
iget-object p2, p0, Lcom/google/android/gms/internal/gtm/zzey;->d:Landroid/content/Context;
new-instance p3, Lcom/google/android/gms/internal/gtm/zzez;
invoke-direct {p3, p0}, Lcom/google/android/gms/internal/gtm/zzez;-><init>(Lcom/google/android/gms/internal/gtm/zzey;)V
invoke-direct {p1, p2, p3}, Lcom/google/android/gms/internal/gtm/zzfu;-><init>(Landroid/content/Context;Lcom/google/android/gms/internal/gtm/zzfw;)V
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzey;->b:Lcom/google/android/gms/internal/gtm/zzed;
const-wide/16 p1, 0x0
iput-wide p1, p0, Lcom/google/android/gms/internal/gtm/zzey;->f:J
const/16 p1, 0x7d0
iput p1, p0, Lcom/google/android/gms/internal/gtm/zzey;->h:I
return-void
.end method
.method static synthetic b(Lcom/google/android/gms/internal/gtm/zzey;)Lcom/google/android/gms/common/util/Clock;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/internal/gtm/zzey;->g:Lcom/google/android/gms/common/util/Clock;
return-object p0
.end method
.method static synthetic c(Lcom/google/android/gms/internal/gtm/zzey;J)V
.registers 3
invoke-direct {p0, p1, p2}, Lcom/google/android/gms/internal/gtm/zzey;->l(J)V
return-void
.end method
.method static synthetic d(Lcom/google/android/gms/internal/gtm/zzey;JJ)V
.registers 5
invoke-direct {p0, p1, p2, p3, p4}, Lcom/google/android/gms/internal/gtm/zzey;->i(JJ)V
return-void
.end method
.method private final e([Ljava/lang/String;)V
.registers 8
const-string v0, "gtm_hits"
if-eqz p1, :cond_59
array-length v1, p1
if-nez v1, :cond_8
goto :goto_59
:cond_8
const-string v1, "Error opening database for deleteHits."
invoke-direct {p0, v1}, Lcom/google/android/gms/internal/gtm/zzey;->g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v1
if-nez v1, :cond_11
return-void
:cond_11
const/4 v2, 0x1
new-array v3, v2, [Ljava/lang/Object;
array-length v4, p1
const-string v5, "?"
invoke-static {v4, v5}, Ljava/util/Collections;->nCopies(ILjava/lang/Object;)Ljava/util/List;
move-result-object v4
const-string v5, ","
invoke-static {v5, v4}, Landroid/text/TextUtils;->join(Ljava/lang/CharSequence;Ljava/lang/Iterable;)Ljava/lang/String;
move-result-object v4
const/4 v5, 0x0
aput-object v4, v3, v5
const-string v4, "HIT_ID in (%s)"
invoke-static {v4, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
:try_start_2a
invoke-virtual {v1, v0, v3, 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/zzey;->c:Lcom/google/android/gms/internal/gtm/zzen;
invoke-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzey;->j(Ljava/lang/String;)I
move-result v0
if-nez v0, :cond_36
goto :goto_37
:cond_36
const/4 v2, 0x0
:goto_37
invoke-interface {p1, v2}, Lcom/google/android/gms/internal/gtm/zzen;->a(Z)V
:try_end_3a
.catch Landroid/database/sqlite/SQLiteException; {:try_start_2a .. :try_end_3a} :catch_3b
return-void
:catch_3b
move-exception p1
const-string v0, "Error deleting hits: "
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteException;->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 v1
if-eqz v1, :cond_51
invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_56
:cond_51
new-instance p1, Ljava/lang/String;
invoke-direct {p1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_56
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
:cond_59
:goto_59
return-void
.end method
.method private final f(I)Ljava/util/List;
.registers 26
.annotation system Ldalvik/annotation/Signature;
value = {
"(I)",
"Ljava/util/List<",
"Lcom/google/android/gms/internal/gtm/zzeh;",
">;"
}
.end annotation
const-string v0, "%s ASC"
const-string v1, "hit_id"
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
const-string v3, "Error opening database for peekHits"
move-object/from16 v4, p0
invoke-direct {v4, v3}, Lcom/google/android/gms/internal/gtm/zzey;->g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v3
if-nez v3, :cond_14
return-object v2
:cond_14
:try_start_14
const-string v6, "gtm_hits"
const-string v5, "hit_time"
const-string v7, "hit_first_send_time"
filled-new-array {v1, v5, v7}, [Ljava/lang/String;
move-result-object v7
const/4 v8, 0x0
const/4 v9, 0x0
const/4 v10, 0x0
const/4 v11, 0x0
const/4 v15, 0x1
new-array v5, v15, [Ljava/lang/Object;
const/4 v13, 0x0
aput-object v1, v5, v13
invoke-static {v0, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v12
const/16 v16, 0x28
invoke-static/range {v16 .. v16}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v17
move-object v5, v3
const/4 v14, 0x0
move-object/from16 v13, v17
invoke-virtual/range {v5 .. v13}, 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 v13
:try_end_3a
.catch Landroid/database/sqlite/SQLiteException; {:try_start_14 .. :try_end_3a} :catch_1cd
.catchall {:try_start_14 .. :try_end_3a} :catchall_1ca
:try_start_3a
new-instance v12, Ljava/util/ArrayList;
invoke-direct {v12}, Ljava/util/ArrayList;-><init>()V
:try_end_3f
.catch Landroid/database/sqlite/SQLiteException; {:try_start_3a .. :try_end_3f} :catch_1c4
.catchall {:try_start_3a .. :try_end_3f} :catchall_1be
:try_start_3f
invoke-interface {v13}, Landroid/database/Cursor;->moveToFirst()Z
move-result v2
:try_end_43
.catch Landroid/database/sqlite/SQLiteException; {:try_start_3f .. :try_end_43} :catch_1bb
.catchall {:try_start_3f .. :try_end_43} :catchall_1be
const/4 v11, 0x2
if-eqz v2, :cond_6c
:cond_46
:try_start_46
new-instance v2, Lcom/google/android/gms/internal/gtm/zzeh;
invoke-interface {v13, v14}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v18
invoke-interface {v13, v15}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v20
invoke-interface {v13, v11}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v22
move-object/from16 v17, v2
invoke-direct/range {v17 .. v23}, Lcom/google/android/gms/internal/gtm/zzeh;-><init>(JJJ)V
invoke-interface {v12, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
invoke-interface {v13}, Landroid/database/Cursor;->moveToNext()Z
move-result v2
:try_end_60
.catch Landroid/database/sqlite/SQLiteException; {:try_start_46 .. :try_end_60} :catch_67
.catchall {:try_start_46 .. :try_end_60} :catchall_63
if-nez v2, :cond_46
goto :goto_6c
:catchall_63
move-exception v0
move-object v14, v13
goto/16 :goto_1f3
:catch_67
move-exception v0
move-object v2, v12
move-object v14, v13
goto/16 :goto_1cf
:cond_6c
:goto_6c
if-eqz v13, :cond_71
invoke-interface {v13}, Landroid/database/Cursor;->close()V
:cond_71
:try_start_71
const-string v6, "gtm_hits"
const-string v2, "hit_url"
const-string v5, "hit_method"
const-string v7, "hit_headers"
const-string v8, "hit_body"
filled-new-array {v1, v2, v5, v7, v8}, [Ljava/lang/String;
move-result-object v7
const/4 v8, 0x0
const/4 v9, 0x0
const/4 v10, 0x0
const/4 v2, 0x0
new-array v5, v15, [Ljava/lang/Object;
aput-object v1, v5, v14
invoke-static {v0, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-static/range {v16 .. v16}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v1
:try_end_8f
.catch Landroid/database/sqlite/SQLiteException; {:try_start_71 .. :try_end_8f} :catch_168
.catchall {:try_start_71 .. :try_end_8f} :catchall_164
move-object v5, v3
const/4 v3, 0x2
move-object v11, v2
move-object v2, v12
move-object v12, v0
move-object/from16 v16, v13
move-object v13, v1
:try_start_97
invoke-virtual/range {v5 .. v13}, 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 v13
:try_end_9b
.catch Landroid/database/sqlite/SQLiteException; {:try_start_97 .. :try_end_9b} :catch_160
.catchall {:try_start_97 .. :try_end_9b} :catchall_15c
:try_start_9b
invoke-interface {v13}, Landroid/database/Cursor;->moveToFirst()Z
move-result v0
if-eqz v0, :cond_154
const/4 v1, 0x0
:cond_a2
move-object v0, v13
check-cast v0, Landroid/database/sqlite/SQLiteCursor;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteCursor;->getWindow()Landroid/database/CursorWindow;
move-result-object v0
invoke-virtual {v0}, Landroid/database/CursorWindow;->getNumRows()I
move-result v0
if-lez v0, :cond_131
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzeh;
invoke-interface {v13, v15}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v5
invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/gtm/zzeh;->a(Ljava/lang/String;)V
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzeh;
invoke-interface {v13, v3}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v5
invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/gtm/zzeh;->b(Ljava/lang/String;)V
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzeh;
const/4 v5, 0x4
invoke-interface {v13, v5}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v5
invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/gtm/zzeh;->c(Ljava/lang/String;)V
:try_end_d7
.catch Landroid/database/sqlite/SQLiteException; {:try_start_9b .. :try_end_d7} :catch_15a
.catchall {:try_start_9b .. :try_end_d7} :catchall_1b4
const/4 v0, 0x3
:try_start_d8
invoke-interface {v13, v0}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_103
new-instance v5, Lorg/json/JSONObject;
invoke-direct {v5, v0}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V
invoke-virtual {v5}, Lorg/json/JSONObject;->names()Lorg/json/JSONArray;
move-result-object v0
new-instance v6, Ljava/util/HashMap;
invoke-direct {v6}, Ljava/util/HashMap;-><init>()V
const/4 v7, 0x0
:goto_ed
invoke-virtual {v0}, Lorg/json/JSONArray;->length()I
move-result v8
if-ge v7, v8, :cond_104
invoke-virtual {v0, v7}, Lorg/json/JSONArray;->getString(I)Ljava/lang/String;
move-result-object v8
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-interface {v6, v8, v9}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_100
.catch Lorg/json/JSONException; {:try_start_d8 .. :try_end_100} :catch_10e
.catch Landroid/database/sqlite/SQLiteException; {:try_start_d8 .. :try_end_100} :catch_15a
.catchall {:try_start_d8 .. :try_end_100} :catchall_1b4
add-int/lit8 v7, v7, 0x1
goto :goto_ed
:cond_103
const/4 v6, 0x0
:cond_104
:try_start_104
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/internal/gtm/zzeh;
invoke-virtual {v0, v6}, Lcom/google/android/gms/internal/gtm/zzeh;->d(Ljava/util/Map;)V
goto :goto_14c
:catch_10e
move-exception v0
const-string v5, "Failed to read headers for hitId %d: %s"
new-array v6, v3, [Ljava/lang/Object;
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v7
check-cast v7, Lcom/google/android/gms/internal/gtm/zzeh;
invoke-virtual {v7}, Lcom/google/android/gms/internal/gtm/zzeh;->e()J
move-result-wide v7
invoke-static {v7, v8}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v7
aput-object v7, v6, v14
invoke-virtual {v0}, Lorg/json/JSONException;->getMessage()Ljava/lang/String;
move-result-object v0
aput-object v0, v6, v15
invoke-static {v5, v6}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
goto :goto_14e
:cond_131
const-string v0, "HitString for hitId %d too large. Hit will be deleted."
new-array v5, v15, [Ljava/lang/Object;
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v6
check-cast v6, Lcom/google/android/gms/internal/gtm/zzeh;
invoke-virtual {v6}, Lcom/google/android/gms/internal/gtm/zzeh;->e()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-static {v0, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
:goto_14c
add-int/lit8 v1, v1, 0x1
:goto_14e
invoke-interface {v13}, Landroid/database/Cursor;->moveToNext()Z
move-result v0
:try_end_152
.catch Landroid/database/sqlite/SQLiteException; {:try_start_104 .. :try_end_152} :catch_15a
.catchall {:try_start_104 .. :try_end_152} :catchall_1b4
if-nez v0, :cond_a2
:cond_154
if-eqz v13, :cond_159
invoke-interface {v13}, Landroid/database/Cursor;->close()V
:cond_159
return-object v2
:catch_15a
move-exception v0
goto :goto_16c
:catchall_15c
move-exception v0
move-object/from16 v13, v16
goto :goto_1b5
:catch_160
move-exception v0
move-object/from16 v13, v16
goto :goto_16c
:catchall_164
move-exception v0
move-object/from16 v16, v13
goto :goto_1b5
:catch_168
move-exception v0
move-object v2, v12
move-object/from16 v16, v13
:goto_16c
:try_start_16c
const-string v1, "Error in peekHits fetching hit url: "
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteException;->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 v3
if-eqz v3, :cond_181
invoke-virtual {v1, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_186
:cond_181
new-instance v0, Ljava/lang/String;
invoke-direct {v0, v1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_186
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
invoke-virtual {v2}, Ljava/util/ArrayList;->size()I
move-result v1
const/4 v3, 0x0
:goto_193
if-ge v14, v1, :cond_1ae
invoke-virtual {v2, v14}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v5
add-int/lit8 v14, v14, 0x1
check-cast v5, Lcom/google/android/gms/internal/gtm/zzeh;
invoke-virtual {v5}, Lcom/google/android/gms/internal/gtm/zzeh;->g()Ljava/lang/String;
move-result-object v6
invoke-static {v6}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v6
if-eqz v6, :cond_1aa
if-nez v3, :cond_1ae
const/4 v3, 0x1
:cond_1aa
invoke-interface {v0, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:try_end_1ad
.catchall {:try_start_16c .. :try_end_1ad} :catchall_1b4
goto :goto_193
:cond_1ae
if-eqz v13, :cond_1b3
invoke-interface {v13}, Landroid/database/Cursor;->close()V
:cond_1b3
return-object v0
:catchall_1b4
move-exception v0
:goto_1b5
if-eqz v13, :cond_1ba
invoke-interface {v13}, Landroid/database/Cursor;->close()V
:cond_1ba
throw v0
:catch_1bb
move-exception v0
move-object v2, v12
goto :goto_1c5
:catchall_1be
move-exception v0
move-object/from16 v16, v13
move-object/from16 v14, v16
goto :goto_1f3
:catch_1c4
move-exception v0
:goto_1c5
move-object/from16 v16, v13
move-object/from16 v14, v16
goto :goto_1cf
:catchall_1ca
move-exception v0
const/4 v14, 0x0
goto :goto_1f3
:catch_1cd
move-exception v0
const/4 v14, 0x0
:goto_1cf
:try_start_1cf
const-string v1, "Error in peekHits fetching hitIds: "
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteException;->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 v3
if-eqz v3, :cond_1e4
invoke-virtual {v1, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_1e9
:cond_1e4
new-instance v0, Ljava/lang/String;
invoke-direct {v0, v1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_1e9
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
:try_end_1ec
.catchall {:try_start_1cf .. :try_end_1ec} :catchall_1f2
if-eqz v14, :cond_1f1
invoke-interface {v14}, Landroid/database/Cursor;->close()V
:cond_1f1
return-object v2
:catchall_1f2
move-exception v0
:goto_1f3
if-eqz v14, :cond_1f8
invoke-interface {v14}, Landroid/database/Cursor;->close()V
:cond_1f8
throw v0
.end method
.method private final g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
.registers 4
:try_start_0
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzey;->a:Lcom/google/android/gms/internal/gtm/zzfa;
invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzfa;->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/zzey;->d:Landroid/content/Context;
invoke-static {p1, v0}, Lcom/google/android/gms/internal/gtm/zzev;->g(Ljava/lang/String;Ljava/lang/Throwable;)V
invoke-static {v1, v0}, Lcom/google/android/gms/common/util/CrashUtils;->a(Landroid/content/Context;Ljava/lang/Throwable;)Z
move-result p1
if-eqz p1, :cond_19
const-string p1, "Crash reported successfully."
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
goto :goto_1e
:cond_19
const-string p1, "Failed to report crash"
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
:goto_1e
const/4 p1, 0x0
return-object p1
.end method
.method static synthetic h(Lcom/google/android/gms/internal/gtm/zzey;)Ljava/lang/String;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/internal/gtm/zzey;->e:Ljava/lang/String;
return-object p0
.end method
.method private final i(JJ)V
.registers 10
const-string v0, "Error opening database for getNumStoredHits."
invoke-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzey;->g(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;
invoke-direct {v1}, Landroid/content/ContentValues;-><init>()V
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
:try_start_17
const-string p3, "gtm_hits"
const-string p4, "hit_id=?"
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/String;
const/4 v3, 0x0
invoke-static {p1, p2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v4
aput-object v4, v2, v3
invoke-virtual {v0, p3, v1, p4, v2}, 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_17 .. :try_end_28} :catch_29
return-void
:catch_29
move-exception p3
invoke-virtual {p3}, Landroid/database/sqlite/SQLiteException;->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
add-int/lit8 p4, p4, 0x46
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0, p4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p4, "Error setting HIT_FIRST_DISPATCH_TIME for hitId "
invoke-virtual {v0, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1, p2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string p4, ": "
invoke-virtual {v0, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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/zzev;->d(Ljava/lang/String;)V
invoke-direct {p0, p1, p2}, Lcom/google/android/gms/internal/gtm/zzey;->l(J)V
return-void
.end method
.method private final j(Ljava/lang/String;)I
.registers 7
const-string v0, "Error opening database for getNumRecords."
invoke-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzey;->g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
const/4 v1, 0x0
if-nez v0, :cond_a
return v1
:cond_a
const/4 v2, 0x0
:try_start_b
const-string v3, "SELECT COUNT(*) from "
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 v4
if-eqz v4, :cond_1c
invoke-virtual {v3, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_21
:cond_1c
new-instance p1, Ljava/lang/String;
invoke-direct {p1, v3}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_21
invoke-virtual {v0, p1, v2}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v2
invoke-interface {v2}, Landroid/database/Cursor;->moveToFirst()Z
move-result p1
if-eqz p1, :cond_30
invoke-interface {v2, v1}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v0
:try_end_2f
.catch Landroid/database/sqlite/SQLiteException; {:try_start_b .. :try_end_2f} :catch_38
.catchall {:try_start_b .. :try_end_2f} :catchall_36
long-to-int v1, v0
:cond_30
if-eqz v2, :cond_5b
invoke-interface {v2}, Landroid/database/Cursor;->close()V
goto :goto_5b
:catchall_36
move-exception p1
goto :goto_5c
:catch_38
move-exception p1
:try_start_39
const-string v0, "Error getting numStoredRecords: "
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteException;->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_4e
invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_53
:cond_4e
new-instance p1, Ljava/lang/String;
invoke-direct {p1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_53
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
:try_end_56
.catchall {:try_start_39 .. :try_end_56} :catchall_36
if-eqz v2, :cond_5b
invoke-interface {v2}, Landroid/database/Cursor;->close()V
:cond_5b
:goto_5b
return v1
:goto_5c
if-eqz v2, :cond_61
invoke-interface {v2}, Landroid/database/Cursor;->close()V
:cond_61
throw p1
.end method
.method static synthetic k(Lcom/google/android/gms/internal/gtm/zzey;)Landroid/content/Context;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/internal/gtm/zzey;->d:Landroid/content/Context;
return-object p0
.end method
.method private final l(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-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzey;->e([Ljava/lang/String;)V
return-void
.end method
.method private final m()I
.registers 11
const-string v0, "Error opening database for getNumStoredHits."
invoke-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzey;->g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v1
const/4 v0, 0x0
if-nez v1, :cond_a
return v0
:cond_a
const/4 v9, 0x0
:try_start_b
const-string v2, "gtm_hits"
const-string v3, "hit_id"
const-string v4, "hit_first_send_time"
filled-new-array {v3, v4}, [Ljava/lang/String;
move-result-object v3
const-string v4, "hit_first_send_time=0"
const/4 v5, 0x0
const/4 v6, 0x0
const/4 v7, 0x0
const/4 v8, 0x0
invoke-virtual/range {v1 .. v8}, 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 v9
invoke-interface {v9}, Landroid/database/Cursor;->getCount()I
move-result v0
:try_end_23
.catch Landroid/database/sqlite/SQLiteException; {:try_start_b .. :try_end_23} :catch_2b
.catchall {:try_start_b .. :try_end_23} :catchall_29
if-eqz v9, :cond_4e
invoke-interface {v9}, Landroid/database/Cursor;->close()V
goto :goto_4e
:catchall_29
move-exception v0
goto :goto_4f
:catch_2b
move-exception v1
:try_start_2c
const-string v2, "Error getting num untried hits: "
invoke-virtual {v1}, Landroid/database/sqlite/SQLiteException;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v3
if-eqz v3, :cond_41
invoke-virtual {v2, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
goto :goto_46
:cond_41
new-instance v1, Ljava/lang/String;
invoke-direct {v1, v2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_46
invoke-static {v1}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
:try_end_49
.catchall {:try_start_2c .. :try_end_49} :catchall_29
if-eqz v9, :cond_4e
invoke-interface {v9}, Landroid/database/Cursor;->close()V
:cond_4e
:goto_4e
return v0
:goto_4f
if-eqz v9, :cond_54
invoke-interface {v9}, Landroid/database/Cursor;->close()V
:cond_54
throw v0
.end method
.method static synthetic n()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzey;->i:Ljava/lang/String;
return-object v0
.end method
.method static synthetic o()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzey;->j:Ljava/lang/String;
return-object v0
.end method
.method static synthetic p()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzey;->k:Ljava/lang/String;
return-object v0
.end method
.method static synthetic q()Ljava/lang/String;
.registers 1
sget-object v0, Lcom/google/android/gms/internal/gtm/zzey;->l:Ljava/lang/String;
return-object v0
.end method
.method private final r(I)Ljava/util/List;
.registers 15
.annotation system Ldalvik/annotation/Signature;
value = {
"(I)",
"Ljava/util/List<",
"Ljava/lang/String;",
">;"
}
.end annotation
const-string v0, "hit_id"
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
if-gtz p1, :cond_f
const-string p1, "Invalid maxHits specified. Skipping"
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
return-object v1
:cond_f
const-string v2, "Error opening database for peekHitIds."
invoke-direct {p0, v2}, Lcom/google/android/gms/internal/gtm/zzey;->g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v3
if-nez v3, :cond_18
return-object v1
:cond_18
const/4 v2, 0x0
:try_start_19
const-string v4, "gtm_hits"
filled-new-array {v0}, [Ljava/lang/String;
move-result-object v5
const/4 v6, 0x0
const/4 v7, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
const-string v10, "%s ASC"
const/4 v11, 0x1
new-array v11, v11, [Ljava/lang/Object;
const/4 v12, 0x0
aput-object v0, v11, v12
invoke-static {v10, v11}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v10
invoke-static {p1}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v11
invoke-virtual/range {v3 .. v11}, 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 v2
invoke-interface {v2}, Landroid/database/Cursor;->moveToFirst()Z
move-result p1
if-eqz p1, :cond_4e
:cond_3d
invoke-interface {v2, v12}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v3
invoke-static {v3, v4}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object p1
invoke-interface {v1, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
invoke-interface {v2}, Landroid/database/Cursor;->moveToNext()Z
move-result p1
:try_end_4c
.catch Landroid/database/sqlite/SQLiteException; {:try_start_19 .. :try_end_4c} :catch_56
.catchall {:try_start_19 .. :try_end_4c} :catchall_54
if-nez p1, :cond_3d
:cond_4e
if-eqz v2, :cond_79
invoke-interface {v2}, Landroid/database/Cursor;->close()V
goto :goto_79
:catchall_54
move-exception p1
goto :goto_7a
:catch_56
move-exception p1
:try_start_57
const-string v0, "Error in peekHits fetching hitIds: "
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteException;->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_6c
invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_71
:cond_6c
new-instance p1, Ljava/lang/String;
invoke-direct {p1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_71
invoke-static {p1}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
:try_end_74
.catchall {:try_start_57 .. :try_end_74} :catchall_54
if-eqz v2, :cond_79
invoke-interface {v2}, Landroid/database/Cursor;->close()V
:cond_79
:goto_79
return-object v1
:goto_7a
if-eqz v2, :cond_7f
invoke-interface {v2}, Landroid/database/Cursor;->close()V
:cond_7f
throw p1
.end method
# virtual methods
.method public final a(JLjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Ljava/lang/String;)V
.registers 20
.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 v1, p0
move-object v0, p3
move-object/from16 v2, p6
iget-object v3, v1, Lcom/google/android/gms/internal/gtm/zzey;->g:Lcom/google/android/gms/common/util/Clock;
invoke-interface {v3}, Lcom/google/android/gms/common/util/Clock;->b()J
move-result-wide v3
iget-wide v5, v1, Lcom/google/android/gms/internal/gtm/zzey;->f:J
const-wide/32 v7, 0x5265c00
add-long/2addr v5, v7
const/4 v7, 0x1
const-string v8, "gtm_hits"
const/4 v9, 0x0
cmp-long v10, v3, v5
if-gtz v10, :cond_19
goto :goto_67
:cond_19
iput-wide v3, v1, Lcom/google/android/gms/internal/gtm/zzey;->f:J
const-string v3, "Error opening database for deleteStaleHits."
invoke-direct {p0, v3}, Lcom/google/android/gms/internal/gtm/zzey;->g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v3
if-nez v3, :cond_24
goto :goto_67
:cond_24
iget-object v4, v1, Lcom/google/android/gms/internal/gtm/zzey;->g:Lcom/google/android/gms/common/util/Clock;
invoke-interface {v4}, Lcom/google/android/gms/common/util/Clock;->b()J
move-result-wide v4
const-wide v10, 0x9a7ec800L
sub-long/2addr v4, v10
new-array v6, v7, [Ljava/lang/String;
invoke-static {v4, v5}, Ljava/lang/Long;->toString(J)Ljava/lang/String;
move-result-object v4
aput-object v4, v6, v9
const-string v4, "HIT_TIME < ?"
invoke-virtual {v3, v8, v4, v6}, Landroid/database/sqlite/SQLiteDatabase;->delete(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)I
move-result v3
const/16 v4, 0x1f
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5, v4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v4, "Removed "
invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, " stale hits."
invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v3}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
iget-object v3, v1, Lcom/google/android/gms/internal/gtm/zzey;->c:Lcom/google/android/gms/internal/gtm/zzen;
invoke-direct {p0, v8}, Lcom/google/android/gms/internal/gtm/zzey;->j(Ljava/lang/String;)I
move-result v4
if-nez v4, :cond_63
const/4 v4, 0x1
goto :goto_64
:cond_63
const/4 v4, 0x0
:goto_64
invoke-interface {v3, v4}, Lcom/google/android/gms/internal/gtm/zzen;->a(Z)V
:goto_67
invoke-direct {p0, v8}, Lcom/google/android/gms/internal/gtm/zzey;->j(Ljava/lang/String;)I
move-result v3
iget v4, v1, Lcom/google/android/gms/internal/gtm/zzey;->h:I
sub-int/2addr v3, v4
add-int/2addr v3, v7
if-lez v3, :cond_9f
invoke-direct {p0, v3}, Lcom/google/android/gms/internal/gtm/zzey;->r(I)Ljava/util/List;
move-result-object v3
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v4
const/16 v5, 0x33
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6, v5}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v5, "Store full, deleting "
invoke-virtual {v6, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v4, " hits to make room."
invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v4}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
new-array v4, v9, [Ljava/lang/String;
invoke-interface {v3, v4}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v3
check-cast v3, [Ljava/lang/String;
invoke-direct {p0, v3}, Lcom/google/android/gms/internal/gtm/zzey;->e([Ljava/lang/String;)V
:cond_9f
const-string v3, "Error opening database for putHit"
invoke-direct {p0, v3}, Lcom/google/android/gms/internal/gtm/zzey;->g(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v3
if-eqz v3, :cond_157
new-instance v4, Landroid/content/ContentValues;
invoke-direct {v4}, Landroid/content/ContentValues;-><init>()V
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
const-string v6, "hit_time"
invoke-virtual {v4, v6, v5}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/Long;)V
const-string v5, "hit_url"
invoke-virtual {v4, v5, p3}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
invoke-static {v9}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v5
const-string v6, "hit_first_send_time"
invoke-virtual {v4, v6, v5}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/Integer;)V
if-nez p4, :cond_c8
const-string v5, "GET"
goto :goto_ca
:cond_c8
move-object/from16 v5, p4
:goto_ca
const-string v6, "hit_method"
invoke-virtual {v4, v6, v5}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const-string v5, "hit_unique_id"
move-object/from16 v6, p5
invoke-virtual {v4, v5, v6}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const/4 v5, 0x0
if-nez v2, :cond_db
move-object v2, v5
goto :goto_e4
:cond_db
new-instance v6, Lorg/json/JSONObject;
invoke-direct {v6, v2}, Lorg/json/JSONObject;-><init>(Ljava/util/Map;)V
invoke-virtual {v6}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
move-result-object v2
:goto_e4
const-string v6, "hit_headers"
invoke-virtual {v4, v6, v2}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const-string v2, "hit_body"
move-object/from16 v6, p7
invoke-virtual {v4, v2, v6}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
:try_start_f0
invoke-virtual {v3, v8, v5, v4}, Landroid/database/sqlite/SQLiteDatabase;->insertOrThrow(Ljava/lang/String;Ljava/lang/String;Landroid/content/ContentValues;)J
invoke-static {p3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v2
add-int/lit8 v2, v2, 0x13
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3, v2}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v2, "Hit stored (url = "
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, ")"
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/zzev;->c(Ljava/lang/String;)V
iget-object v2, v1, Lcom/google/android/gms/internal/gtm/zzey;->c:Lcom/google/android/gms/internal/gtm/zzen;
invoke-interface {v2, v9}, Lcom/google/android/gms/internal/gtm/zzen;->a(Z)V
:try_end_11b
.catch Landroid/database/sqlite/SQLiteConstraintException; {:try_start_f0 .. :try_end_11b} :catch_11e
.catch Landroid/database/sqlite/SQLiteException; {:try_start_f0 .. :try_end_11b} :catch_11c
goto :goto_157
:catch_11c
move-exception v0
goto :goto_120
:catch_11e
nop
goto :goto_13e
:goto_120
const-string v2, "Error storing hit: "
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteException;->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 v3
if-eqz v3, :cond_135
invoke-virtual {v2, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_13a
:cond_135
new-instance v0, Ljava/lang/String;
invoke-direct {v0, v2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_13a
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->d(Ljava/lang/String;)V
goto :goto_157
:goto_13e
const-string v2, "Hit has already been sent: "
invoke-static {p3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v3
if-eqz v3, :cond_14f
invoke-virtual {v2, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_154
:cond_14f
new-instance v0, Ljava/lang/String;
invoke-direct {v0, v2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_154
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
:cond_157
:goto_157
invoke-static {}, Lcom/google/android/gms/internal/gtm/zzfd;->e()Lcom/google/android/gms/internal/gtm/zzfd;
move-result-object v0
invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzfd;->b()Z
move-result v0
if-eqz v0, :cond_169
const-string v0, "Sending hits immediately under preview."
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
invoke-virtual {p0}, Lcom/google/android/gms/internal/gtm/zzey;->w()V
:cond_169
return-void
.end method
.method public final w()V
.registers 3
const-string v0, "GTM Dispatch running..."
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzey;->b:Lcom/google/android/gms/internal/gtm/zzed;
invoke-interface {v0}, Lcom/google/android/gms/internal/gtm/zzed;->a()Z
move-result v0
if-nez v0, :cond_e
return-void
:cond_e
const/16 v0, 0x28
invoke-direct {p0, v0}, Lcom/google/android/gms/internal/gtm/zzey;->f(I)Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v1
if-eqz v1, :cond_26
const-string v0, "...nothing to dispatch"
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzev;->c(Ljava/lang/String;)V
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzey;->c:Lcom/google/android/gms/internal/gtm/zzen;
const/4 v1, 0x1
invoke-interface {v0, v1}, Lcom/google/android/gms/internal/gtm/zzen;->a(Z)V
return-void
:cond_26
iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzey;->b:Lcom/google/android/gms/internal/gtm/zzed;
invoke-interface {v1, v0}, Lcom/google/android/gms/internal/gtm/zzed;->H(Ljava/util/List;)V
invoke-direct {p0}, Lcom/google/android/gms/internal/gtm/zzey;->m()I
move-result v0
if-lez v0, :cond_38
invoke-static {}, Lcom/google/android/gms/internal/gtm/zzfo;->n()Lcom/google/android/gms/internal/gtm/zzfo;
move-result-object v0
invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzfo;->c()V
:cond_38
return-void
.end method