EventQueue.smali

.class public Lcom/taboola/android/global_components/eventsmanager/EventQueue;
.super Ljava/util/LinkedList;
.source "EventQueue.java"


# annotations
.annotation system Ldalvik/annotation/Signature;
    value = {
        "Ljava/util/LinkedList<",
        "Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;",
        ">;"
    }
.end annotation


# static fields
.field private static final EVENT_TYPE_MOBILE_EVENT:Ljava/lang/String; = "mobile"

.field private static final JSON_KEY_EVENT_TYPE:Ljava/lang/String; = "eventType"

.field private static final TAG:Ljava/lang/String;

.field private static sQueueMaxSize:I


# instance fields
.field private mContext:Landroid/content/Context;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .line 28
    const-class v0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;

    invoke-virtual {v0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;

    move-result-object v0

    sput-object v0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->TAG:Ljava/lang/String;

    const/16 v0, 0x64

    .line 31
    sput v0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->sQueueMaxSize:I

    return-void
.end method

.method public constructor <init>(Landroid/content/Context;)V
    .registers 2

    .line 34
    invoke-direct {p0}, Ljava/util/LinkedList;-><init>()V

    .line 35
    iput-object p1, p0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->mContext:Landroid/content/Context;

    return-void
.end method

.method private makeRoomIfNeeded([Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;)V
    .registers 6

    .line 56
    array-length p1, p1

    .line 57
    invoke-virtual {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->size()I

    move-result v0

    sget v1, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->sQueueMaxSize:I

    sub-int/2addr v1, p1

    if-le v0, v1, :cond_31

    const/4 v0, 0x0

    :goto_b
    if-ge v0, p1, :cond_31

    .line 60
    :try_start_d
    invoke-virtual {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->pop()Ljava/lang/Object;
    :try_end_10
    .catch Ljava/util/NoSuchElementException; {:try_start_d .. :try_end_10} :catch_11

    goto :goto_2e

    .line 62
    :catch_11
    sget-object v1, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->TAG:Ljava/lang/String;

    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "EventsQueue reached max size ("

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget v3, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->sQueueMaxSize:I

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v3, ") but can\'t remove oldest event."

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-static {v1, v2}, Lcom/taboola/android/utils/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V

    :goto_2e
    add-int/lit8 v0, v0, 0x1

    goto :goto_b

    :cond_31
    return-void
.end method

.method private saveQueue()V
    .registers 4

    .line 94
    invoke-virtual {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->toString()Ljava/lang/String;

    move-result-object v0

    .line 95
    invoke-virtual {v0}, Ljava/lang/String;->length()I

    move-result v1

    const v2, 0x7fffffff

    if-ge v1, v2, :cond_13

    .line 96
    iget-object v1, p0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->mContext:Landroid/content/Context;

    invoke-static {v1, v0}, Lcom/taboola/android/utils/SharedPrefUtil;->saveEventsQueue(Landroid/content/Context;Ljava/lang/String;)V

    goto :goto_1a

    .line 98
    :cond_13
    sget-object v0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->TAG:Ljava/lang/String;

    const-string v1, "Warning: Taboola events queue is fully, not persisting new events (they still exist in memory)."

    invoke-static {v0, v1}, Lcom/taboola/android/utils/Logger;->w(Ljava/lang/String;Ljava/lang/String;)V

    :goto_1a
    return-void
.end method


# virtual methods
.method public varargs declared-synchronized addEvent([Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;)V
    .registers 5

    monitor-enter p0

    .line 40
    :try_start_1
    invoke-direct {p0, p1}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->makeRoomIfNeeded([Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;)V

    .line 43
    array-length v0, p1

    const/4 v1, 0x0

    :goto_6
    if-ge v1, v0, :cond_10

    aget-object v2, p1, v1

    .line 44
    invoke-virtual {p0, v2}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->addLast(Ljava/lang/Object;)V

    add-int/lit8 v1, v1, 0x1

    goto :goto_6

    .line 48
    :cond_10
    invoke-direct {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->saveQueue()V
    :try_end_13
    .catchall {:try_start_1 .. :try_end_13} :catchall_15

    .line 49
    monitor-exit p0

    return-void

    :catchall_15
    move-exception p1

    monitor-exit p0

    throw p1
.end method

.method public getMaxSize()I
    .registers 2

    .line 136
    sget v0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->sQueueMaxSize:I

    return v0
.end method

.method public loadQueue()V
    .registers 9

    .line 107
    iget-object v0, p0, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->mContext:Landroid/content/Context;

    invoke-static {v0}, Lcom/taboola/android/utils/SharedPrefUtil;->loadEventsQueue(Landroid/content/Context;)Ljava/lang/String;

    move-result-object v0

    .line 109
    invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v1

    if-nez v1, :cond_85

    .line 111
    :try_start_c
    new-instance v1, Lorg/json/JSONArray;

    invoke-direct {v1, v0}, Lorg/json/JSONArray;-><init>(Ljava/lang/String;)V

    const/4 v0, 0x0

    const/4 v2, 0x0

    .line 112
    :goto_13
    invoke-virtual {v1}, Lorg/json/JSONArray;->length()I

    move-result v3

    if-ge v2, v3, :cond_85

    .line 113
    invoke-virtual {v1, v2}, Lorg/json/JSONArray;->getJSONObject(I)Lorg/json/JSONObject;

    move-result-object v3

    const-string v4, "eventType"

    .line 114
    invoke-virtual {v3, v4}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v4

    const/4 v5, -0x1

    .line 116
    invoke-virtual {v4}, Ljava/lang/String;->hashCode()I

    move-result v6

    const v7, -0x3fb56f5e

    if-eq v6, v7, :cond_2e

    goto :goto_37

    :cond_2e
    const-string v6, "mobile"

    invoke-virtual {v4, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v6

    if-eqz v6, :cond_37

    const/4 v5, 0x0

    :cond_37
    :goto_37
    if-eqz v5, :cond_55

    .line 121
    sget-object v3, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->TAG:Ljava/lang/String;

    new-instance v5, Ljava/lang/StringBuilder;

    invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V

    const-string v6, "Issue loading queue, event type unrecognizable ("

    invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v4, ")."

    invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v4

    invoke-static {v3, v4}, Lcom/taboola/android/utils/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_67

    :cond_55
    const/4 v4, 0x1

    new-array v4, v4, [Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;

    .line 118
    new-instance v5, Lcom/taboola/android/global_components/eventsmanager/events/TaboolaMobileEvent;

    const/4 v6, 0x0

    invoke-direct {v5, v6}, Lcom/taboola/android/global_components/eventsmanager/events/TaboolaMobileEvent;-><init>(Ljava/util/Map;)V

    invoke-virtual {v5, v3}, Lcom/taboola/android/global_components/eventsmanager/events/TaboolaMobileEvent;->fromJson(Lorg/json/JSONObject;)Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;

    move-result-object v3

    aput-object v3, v4, v0

    invoke-virtual {p0, v4}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->addEvent([Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;)V
    :try_end_67
    .catch Lorg/json/JSONException; {:try_start_c .. :try_end_67} :catch_6a

    :goto_67
    add-int/lit8 v2, v2, 0x1

    goto :goto_13

    :catch_6a
    move-exception v0

    .line 126
    sget-object v1, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->TAG:Ljava/lang/String;

    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "Failed loading queue, exception: "

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Lorg/json/JSONException;->getLocalizedMessage()Ljava/lang/String;

    move-result-object v0

    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 {v1, v0}, Lcom/taboola/android/utils/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V

    :cond_85
    return-void
.end method

.method public declared-synchronized popFirstEvent()Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;
    .registers 3

    monitor-enter p0

    const/4 v0, 0x0

    .line 78
    :try_start_2
    invoke-virtual {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->pop()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;
    :try_end_8
    .catch Ljava/util/NoSuchElementException; {:try_start_2 .. :try_end_8} :catch_11
    .catchall {:try_start_2 .. :try_end_8} :catchall_e

    .line 79
    :try_start_8
    invoke-direct {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->saveQueue()V
    :try_end_b
    .catch Ljava/util/NoSuchElementException; {:try_start_8 .. :try_end_b} :catch_c
    .catchall {:try_start_8 .. :try_end_b} :catchall_e

    goto :goto_12

    :catch_c
    move-object v0, v1

    goto :goto_11

    :catchall_e
    move-exception v0

    monitor-exit p0

    throw v0

    :catch_11
    :goto_11
    move-object v1, v0

    .line 84
    :goto_12
    monitor-exit p0

    return-object v1
.end method

.method public setMaxSize(I)V
    .registers 2

    .line 132
    sput p1, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->sQueueMaxSize:I

    return-void
.end method

.method public declared-synchronized toString()Ljava/lang/String;
    .registers 7

    monitor-enter p0

    :try_start_1
    const-string v0, ""
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_41

    .line 149
    :try_start_3
    invoke-virtual {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->isEmpty()Z

    move-result v1
    :try_end_7
    .catch Ljava/lang/OutOfMemoryError; {:try_start_3 .. :try_end_7} :catch_3f
    .catch Ljava/lang/StringIndexOutOfBoundsException; {:try_start_3 .. :try_end_7} :catch_3f
    .catchall {:try_start_3 .. :try_end_7} :catchall_41

    if-eqz v1, :cond_b

    .line 150
    monitor-exit p0

    return-object v0

    .line 154
    :cond_b
    :try_start_b
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "["

    invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    .line 155
    invoke-virtual {p0}, Lcom/taboola/android/global_components/eventsmanager/EventQueue;->iterator()Ljava/util/Iterator;

    move-result-object v2

    :goto_16
    invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z

    move-result v3

    if-eqz v3, :cond_36

    invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v3

    check-cast v3, Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;

    .line 156
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->length()I

    move-result v4

    const/4 v5, 0x1

    if-le v4, v5, :cond_2e

    const-string v4, ", "

    .line 157
    invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 161
    :cond_2e
    invoke-virtual {v3}, Lcom/taboola/android/global_components/eventsmanager/events/TaboolaEvent;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    goto :goto_16

    :cond_36
    const-string v2, "]"

    .line 165
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 167
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0
    :try_end_3f
    .catch Ljava/lang/OutOfMemoryError; {:try_start_b .. :try_end_3f} :catch_3f
    .catch Ljava/lang/StringIndexOutOfBoundsException; {:try_start_b .. :try_end_3f} :catch_3f
    .catchall {:try_start_b .. :try_end_3f} :catchall_41

    .line 174
    :catch_3f
    monitor-exit p0

    return-object v0

    :catchall_41
    move-exception v0

    monitor-exit p0

    throw v0
.end method