PackageHandler.smali
.class public Lcom/adjust/sdk/PackageHandler;
.super Landroid/os/HandlerThread;
.source "PackageHandler.java"
# interfaces
.implements Lcom/adjust/sdk/IPackageHandler;
# static fields
.field private static final PACKAGE_QUEUE_FILENAME:Ljava/lang/String; = "AdjustIoPackageQueue"
.field private static final PACKAGE_QUEUE_NAME:Ljava/lang/String; = "Package queue"
# instance fields
.field private activityHandler:Lcom/adjust/sdk/IActivityHandler;
.field private backoffStrategy:Lcom/adjust/sdk/BackoffStrategy;
.field private context:Landroid/content/Context;
.field private internalHandler:Landroid/os/Handler;
.field private isSending:Ljava/util/concurrent/atomic/AtomicBoolean;
.field private logger:Lcom/adjust/sdk/ILogger;
.field private packageQueue:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/adjust/sdk/ActivityPackage;",
">;"
}
.end annotation
.end field
.field private paused:Z
.field private requestHandler:Lcom/adjust/sdk/IRequestHandler;
# direct methods
.method public constructor <init>(Lcom/adjust/sdk/IActivityHandler;Landroid/content/Context;Z)V
.registers 6
const-string v0, "Adjust"
const/4 v1, 0x1
.line 45
invoke-direct {p0, v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;I)V
.line 46
invoke-virtual {p0, v1}, Lcom/adjust/sdk/PackageHandler;->setDaemon(Z)V
.line 47
invoke-virtual {p0}, Lcom/adjust/sdk/PackageHandler;->start()V
.line 48
new-instance v0, Landroid/os/Handler;
invoke-virtual {p0}, Lcom/adjust/sdk/PackageHandler;->getLooper()Landroid/os/Looper;
move-result-object v1
invoke-direct {v0, v1}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
iput-object v0, p0, Lcom/adjust/sdk/PackageHandler;->internalHandler:Landroid/os/Handler;
.line 49
invoke-static {}, Lcom/adjust/sdk/AdjustFactory;->getLogger()Lcom/adjust/sdk/ILogger;
move-result-object v0
iput-object v0, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
.line 50
invoke-static {}, Lcom/adjust/sdk/AdjustFactory;->getPackageHandlerBackoffStrategy()Lcom/adjust/sdk/BackoffStrategy;
move-result-object v0
iput-object v0, p0, Lcom/adjust/sdk/PackageHandler;->backoffStrategy:Lcom/adjust/sdk/BackoffStrategy;
.line 52
invoke-virtual {p0, p1, p2, p3}, Lcom/adjust/sdk/PackageHandler;->init(Lcom/adjust/sdk/IActivityHandler;Landroid/content/Context;Z)V
.line 54
iget-object p1, p0, Lcom/adjust/sdk/PackageHandler;->internalHandler:Landroid/os/Handler;
new-instance p2, Lcom/adjust/sdk/PackageHandler$1;
invoke-direct {p2, p0}, Lcom/adjust/sdk/PackageHandler$1;-><init>(Lcom/adjust/sdk/PackageHandler;)V
invoke-virtual {p1, p2}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method static synthetic access$000(Lcom/adjust/sdk/PackageHandler;)V
.registers 1
.line 28
invoke-direct {p0}, Lcom/adjust/sdk/PackageHandler;->initInternal()V
return-void
.end method
.method static synthetic access$100(Lcom/adjust/sdk/PackageHandler;Lcom/adjust/sdk/ActivityPackage;)V
.registers 2
.line 28
invoke-direct {p0, p1}, Lcom/adjust/sdk/PackageHandler;->addInternal(Lcom/adjust/sdk/ActivityPackage;)V
return-void
.end method
.method static synthetic access$200(Lcom/adjust/sdk/PackageHandler;)V
.registers 1
.line 28
invoke-direct {p0}, Lcom/adjust/sdk/PackageHandler;->sendFirstInternal()V
return-void
.end method
.method static synthetic access$300(Lcom/adjust/sdk/PackageHandler;)V
.registers 1
.line 28
invoke-direct {p0}, Lcom/adjust/sdk/PackageHandler;->sendNextInternal()V
return-void
.end method
.method private addInternal(Lcom/adjust/sdk/ActivityPackage;)V
.registers 7
.line 153
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
invoke-interface {v0, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 154
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
const/4 v1, 0x2
new-array v1, v1, [Ljava/lang/Object;
iget-object v2, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
const/4 v3, 0x0
aput-object v2, v1, v3
const/4 v2, 0x1
aput-object p1, v1, v2
const-string v4, "Added package %d (%s)"
invoke-interface {v0, v4, v1}, Lcom/adjust/sdk/ILogger;->debug(Ljava/lang/String;[Ljava/lang/Object;)V
.line 155
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v2, [Ljava/lang/Object;
invoke-virtual {p1}, Lcom/adjust/sdk/ActivityPackage;->getExtendedString()Ljava/lang/String;
move-result-object p1
aput-object p1, v1, v3
const-string p1, "%s"
invoke-interface {v0, p1, v1}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
.line 157
invoke-direct {p0}, Lcom/adjust/sdk/PackageHandler;->writePackageQueue()V
return-void
.end method
.method public static deletePackageQueue(Landroid/content/Context;)Ljava/lang/Boolean;
.registers 2
const-string v0, "AdjustIoPackageQueue"
.line 207
invoke-virtual {p0, v0}, Landroid/content/Context;->deleteFile(Ljava/lang/String;)Z
move-result p0
invoke-static {p0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object p0
return-object p0
.end method
.method private initInternal()V
.registers 2
.line 145
invoke-static {p0}, Lcom/adjust/sdk/AdjustFactory;->getRequestHandler(Lcom/adjust/sdk/IPackageHandler;)Lcom/adjust/sdk/IRequestHandler;
move-result-object v0
iput-object v0, p0, Lcom/adjust/sdk/PackageHandler;->requestHandler:Lcom/adjust/sdk/IRequestHandler;
.line 147
new-instance v0, Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicBoolean;-><init>()V
iput-object v0, p0, Lcom/adjust/sdk/PackageHandler;->isSending:Ljava/util/concurrent/atomic/AtomicBoolean;
.line 149
invoke-direct {p0}, Lcom/adjust/sdk/PackageHandler;->readPackageQueue()V
return-void
.end method
.method private readPackageQueue()V
.registers 7
const-string v0, "Package queue"
const/4 v1, 0x1
const/4 v2, 0x0
.line 188
:try_start_4
iget-object v3, p0, Lcom/adjust/sdk/PackageHandler;->context:Landroid/content/Context;
const-string v4, "AdjustIoPackageQueue"
const-class v5, Ljava/util/List;
invoke-static {v3, v4, v0, v5}, Lcom/adjust/sdk/Util;->readObject(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/util/List;
iput-object v3, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
:try_end_12
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_12} :catch_13
goto :goto_29
:catch_13
move-exception v3
.line 190
iget-object v4, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
const/4 v5, 0x2
new-array v5, v5, [Ljava/lang/Object;
aput-object v0, v5, v2
invoke-virtual {v3}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
aput-object v0, v5, v1
const-string v0, "Failed to read %s file (%s)"
invoke-interface {v4, v0, v5}, Lcom/adjust/sdk/ILogger;->error(Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v0, 0x0
.line 191
iput-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
.line 194
:goto_29
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
if-eqz v0, :cond_41
.line 195
iget-object v3, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v1, [Ljava/lang/Object;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
aput-object v0, v1, v2
const-string v0, "Package handler read %d packages"
invoke-interface {v3, v0, v1}, Lcom/adjust/sdk/ILogger;->debug(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_48
.line 197
:cond_41
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
:goto_48
return-void
.end method
.method private sendFirstInternal()V
.registers 5
.line 161
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-eqz v0, :cond_9
return-void
.line 165
:cond_9
iget-boolean v0, p0, Lcom/adjust/sdk/PackageHandler;->paused:Z
const/4 v1, 0x0
if-eqz v0, :cond_18
.line 166
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v1, [Ljava/lang/Object;
const-string v2, "Package handler is paused"
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->debug(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 169
:cond_18
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->isSending:Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v2, 0x1
invoke-virtual {v0, v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->getAndSet(Z)Z
move-result v0
if-eqz v0, :cond_2b
.line 170
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v1, [Ljava/lang/Object;
const-string v2, "Package handler is already sending"
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 174
:cond_2b
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/adjust/sdk/ActivityPackage;
.line 175
iget-object v1, p0, Lcom/adjust/sdk/PackageHandler;->requestHandler:Lcom/adjust/sdk/IRequestHandler;
iget-object v3, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v3
sub-int/2addr v3, v2
invoke-interface {v1, v0, v3}, Lcom/adjust/sdk/IRequestHandler;->sendPackage(Lcom/adjust/sdk/ActivityPackage;I)V
return-void
.end method
.method private sendNextInternal()V
.registers 4
.line 179
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
const/4 v1, 0x0
invoke-interface {v0, v1}, Ljava/util/List;->remove(I)Ljava/lang/Object;
.line 180
invoke-direct {p0}, Lcom/adjust/sdk/PackageHandler;->writePackageQueue()V
.line 181
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->isSending:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v0, v1}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
.line 182
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v1, [Ljava/lang/Object;
const-string v2, "Package handler can send"
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
.line 183
invoke-direct {p0}, Lcom/adjust/sdk/PackageHandler;->sendFirstInternal()V
return-void
.end method
.method private writePackageQueue()V
.registers 5
.line 202
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
iget-object v1, p0, Lcom/adjust/sdk/PackageHandler;->context:Landroid/content/Context;
const-string v2, "AdjustIoPackageQueue"
const-string v3, "Package queue"
invoke-static {v0, v1, v2, v3}, Lcom/adjust/sdk/Util;->writeObject(Ljava/lang/Object;Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V
.line 203
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
iget-object v2, p0, Lcom/adjust/sdk/PackageHandler;->packageQueue:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
const/4 v3, 0x0
aput-object v2, v1, v3
const-string v2, "Package handler wrote %d packages"
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->debug(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
# virtual methods
.method public addPackage(Lcom/adjust/sdk/ActivityPackage;)V
.registers 4
.line 72
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->internalHandler:Landroid/os/Handler;
new-instance v1, Lcom/adjust/sdk/PackageHandler$2;
invoke-direct {v1, p0, p1}, Lcom/adjust/sdk/PackageHandler$2;-><init>(Lcom/adjust/sdk/PackageHandler;Lcom/adjust/sdk/ActivityPackage;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method public closeFirstPackage(Lcom/adjust/sdk/ResponseData;Lcom/adjust/sdk/ActivityPackage;)V
.registers 10
const/4 v0, 0x1
.line 108
iput-boolean v0, p1, Lcom/adjust/sdk/ResponseData;->willRetry:Z
.line 109
iget-object v1, p0, Lcom/adjust/sdk/PackageHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
invoke-interface {v1, p1}, Lcom/adjust/sdk/IActivityHandler;->finishedTrackingActivity(Lcom/adjust/sdk/ResponseData;)V
const/4 p1, 0x0
if-eqz p2, :cond_37
.line 112
invoke-virtual {p2}, Lcom/adjust/sdk/ActivityPackage;->increaseRetries()I
move-result p2
.line 114
iget-object v1, p0, Lcom/adjust/sdk/PackageHandler;->backoffStrategy:Lcom/adjust/sdk/BackoffStrategy;
invoke-static {p2, v1}, Lcom/adjust/sdk/Util;->getWaitingTime(ILcom/adjust/sdk/BackoffStrategy;)J
move-result-wide v1
long-to-double v3, v1
const-wide v5, 0x408f400000000000L # 1000.0
div-double/2addr v3, v5
.line 117
sget-object v5, Lcom/adjust/sdk/Util;->SecondsDisplayFormat:Ljava/text/DecimalFormat;
invoke-virtual {v5, v3, v4}, Ljava/text/DecimalFormat;->format(D)Ljava/lang/String;
move-result-object v3
.line 119
iget-object v4, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
const/4 v5, 0x2
new-array v5, v5, [Ljava/lang/Object;
aput-object v3, v5, p1
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
aput-object p2, v5, v0
const-string p2, "Sleeping for %s seconds before retrying the %d time"
invoke-interface {v4, p2, v5}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
.line 120
invoke-static {v1, v2}, Landroid/os/SystemClock;->sleep(J)V
.line 123
:cond_37
iget-object p2, p0, Lcom/adjust/sdk/PackageHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v0, p1, [Ljava/lang/Object;
const-string v1, "Package handler can send"
invoke-interface {p2, v1, v0}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
.line 124
iget-object p2, p0, Lcom/adjust/sdk/PackageHandler;->isSending:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {p2, p1}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
.line 127
invoke-virtual {p0}, Lcom/adjust/sdk/PackageHandler;->sendFirstPackage()V
return-void
.end method
.method public init(Lcom/adjust/sdk/IActivityHandler;Landroid/content/Context;Z)V
.registers 4
.line 64
iput-object p1, p0, Lcom/adjust/sdk/PackageHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
.line 65
iput-object p2, p0, Lcom/adjust/sdk/PackageHandler;->context:Landroid/content/Context;
xor-int/lit8 p1, p3, 0x1
.line 66
iput-boolean p1, p0, Lcom/adjust/sdk/PackageHandler;->paused:Z
return-void
.end method
.method public pauseSending()V
.registers 2
const/4 v0, 0x1
.line 133
iput-boolean v0, p0, Lcom/adjust/sdk/PackageHandler;->paused:Z
return-void
.end method
.method public resumeSending()V
.registers 2
const/4 v0, 0x0
.line 139
iput-boolean v0, p0, Lcom/adjust/sdk/PackageHandler;->paused:Z
return-void
.end method
.method public sendFirstPackage()V
.registers 3
.line 83
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->internalHandler:Landroid/os/Handler;
new-instance v1, Lcom/adjust/sdk/PackageHandler$3;
invoke-direct {v1, p0}, Lcom/adjust/sdk/PackageHandler$3;-><init>(Lcom/adjust/sdk/PackageHandler;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method public sendNextPackage(Lcom/adjust/sdk/ResponseData;)V
.registers 4
.line 95
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->internalHandler:Landroid/os/Handler;
new-instance v1, Lcom/adjust/sdk/PackageHandler$4;
invoke-direct {v1, p0}, Lcom/adjust/sdk/PackageHandler$4;-><init>(Lcom/adjust/sdk/PackageHandler;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
.line 102
iget-object v0, p0, Lcom/adjust/sdk/PackageHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
invoke-interface {v0, p1}, Lcom/adjust/sdk/IActivityHandler;->finishedTrackingActivity(Lcom/adjust/sdk/ResponseData;)V
return-void
.end method