SdkClickHandler.smali
.class public Lcom/adjust/sdk/SdkClickHandler;
.super Landroid/os/HandlerThread;
.source "SdkClickHandler.java"
# interfaces
.implements Lcom/adjust/sdk/ISdkClickHandler;
# instance fields
.field private backoffStrategy:Lcom/adjust/sdk/BackoffStrategy;
.field private internalHandler:Landroid/os/Handler;
.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
# direct methods
.method public constructor <init>(Z)V
.registers 4
const-string v0, "Adjust"
const/4 v1, 0x1
.line 28
invoke-direct {p0, v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;I)V
.line 29
invoke-virtual {p0, v1}, Lcom/adjust/sdk/SdkClickHandler;->setDaemon(Z)V
.line 30
invoke-virtual {p0}, Lcom/adjust/sdk/SdkClickHandler;->start()V
.line 32
invoke-virtual {p0, p1}, Lcom/adjust/sdk/SdkClickHandler;->init(Z)V
.line 33
invoke-static {}, Lcom/adjust/sdk/AdjustFactory;->getLogger()Lcom/adjust/sdk/ILogger;
move-result-object p1
iput-object p1, p0, Lcom/adjust/sdk/SdkClickHandler;->logger:Lcom/adjust/sdk/ILogger;
.line 34
new-instance p1, Landroid/os/Handler;
invoke-virtual {p0}, Lcom/adjust/sdk/SdkClickHandler;->getLooper()Landroid/os/Looper;
move-result-object v0
invoke-direct {p1, v0}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
iput-object p1, p0, Lcom/adjust/sdk/SdkClickHandler;->internalHandler:Landroid/os/Handler;
.line 35
invoke-static {}, Lcom/adjust/sdk/AdjustFactory;->getSdkClickBackoffStrategy()Lcom/adjust/sdk/BackoffStrategy;
move-result-object p1
iput-object p1, p0, Lcom/adjust/sdk/SdkClickHandler;->backoffStrategy:Lcom/adjust/sdk/BackoffStrategy;
return-void
.end method
.method static synthetic access$000(Lcom/adjust/sdk/SdkClickHandler;)Ljava/util/List;
.registers 1
.line 20
iget-object p0, p0, Lcom/adjust/sdk/SdkClickHandler;->packageQueue:Ljava/util/List;
return-object p0
.end method
.method static synthetic access$100(Lcom/adjust/sdk/SdkClickHandler;)Lcom/adjust/sdk/ILogger;
.registers 1
.line 20
iget-object p0, p0, Lcom/adjust/sdk/SdkClickHandler;->logger:Lcom/adjust/sdk/ILogger;
return-object p0
.end method
.method static synthetic access$200(Lcom/adjust/sdk/SdkClickHandler;)V
.registers 1
.line 20
invoke-direct {p0}, Lcom/adjust/sdk/SdkClickHandler;->sendNextSdkClick()V
return-void
.end method
.method static synthetic access$300(Lcom/adjust/sdk/SdkClickHandler;)Z
.registers 1
.line 20
iget-boolean p0, p0, Lcom/adjust/sdk/SdkClickHandler;->paused:Z
return p0
.end method
.method static synthetic access$400(Lcom/adjust/sdk/SdkClickHandler;)Lcom/adjust/sdk/BackoffStrategy;
.registers 1
.line 20
iget-object p0, p0, Lcom/adjust/sdk/SdkClickHandler;->backoffStrategy:Lcom/adjust/sdk/BackoffStrategy;
return-object p0
.end method
.method static synthetic access$500(Lcom/adjust/sdk/SdkClickHandler;Lcom/adjust/sdk/ActivityPackage;)V
.registers 2
.line 20
invoke-direct {p0, p1}, Lcom/adjust/sdk/SdkClickHandler;->sendSdkClickInternal(Lcom/adjust/sdk/ActivityPackage;)V
return-void
.end method
.method private logErrorMessage(Lcom/adjust/sdk/ActivityPackage;Ljava/lang/String;Ljava/lang/Throwable;)V
.registers 5
.line 139
invoke-virtual {p1}, Lcom/adjust/sdk/ActivityPackage;->getFailureMessage()Ljava/lang/String;
move-result-object p1
.line 140
invoke-static {p2, p3}, Lcom/adjust/sdk/Util;->getReasonString(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/lang/String;
move-result-object p2
const/4 p3, 0x2
new-array p3, p3, [Ljava/lang/Object;
const/4 v0, 0x0
aput-object p1, p3, v0
const/4 p1, 0x1
aput-object p2, p3, p1
const-string p1, "%s. (%s)"
.line 141
invoke-static {p1, p3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
.line 142
iget-object p2, p0, Lcom/adjust/sdk/SdkClickHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array p3, v0, [Ljava/lang/Object;
invoke-interface {p2, p1, p3}, Lcom/adjust/sdk/ILogger;->error(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
.method private retrySending(Lcom/adjust/sdk/ActivityPackage;)V
.registers 6
.line 132
invoke-virtual {p1}, Lcom/adjust/sdk/ActivityPackage;->increaseRetries()I
move-result v0
.line 134
iget-object v1, p0, Lcom/adjust/sdk/SdkClickHandler;->logger:Lcom/adjust/sdk/ILogger;
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
const/4 v3, 0x0
aput-object v0, v2, v3
const-string v0, "Retrying sdk_click package for the %d time"
invoke-interface {v1, v0, v2}, Lcom/adjust/sdk/ILogger;->error(Ljava/lang/String;[Ljava/lang/Object;)V
.line 135
invoke-virtual {p0, p1}, Lcom/adjust/sdk/SdkClickHandler;->sendSdkClick(Lcom/adjust/sdk/ActivityPackage;)V
return-void
.end method
.method private sendNextSdkClick()V
.registers 3
.line 70
iget-object v0, p0, Lcom/adjust/sdk/SdkClickHandler;->internalHandler:Landroid/os/Handler;
new-instance v1, Lcom/adjust/sdk/SdkClickHandler$2;
invoke-direct {v1, p0}, Lcom/adjust/sdk/SdkClickHandler$2;-><init>(Lcom/adjust/sdk/SdkClickHandler;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method private sendSdkClickInternal(Lcom/adjust/sdk/ActivityPackage;)V
.registers 6
.line 104
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "https://app.adjust.com"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lcom/adjust/sdk/ActivityPackage;->getPath()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 109
:try_start_15
invoke-virtual {p1}, Lcom/adjust/sdk/ActivityPackage;->getClientSdk()Ljava/lang/String;
move-result-object v1
.line 110
invoke-virtual {p1}, Lcom/adjust/sdk/ActivityPackage;->getParameters()Ljava/util/Map;
move-result-object v2
iget-object v3, p0, Lcom/adjust/sdk/SdkClickHandler;->packageQueue:Ljava/util/List;
.line 111
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v3
add-int/lit8 v3, v3, -0x1
.line 107
invoke-static {v0, v1, v2, v3}, Lcom/adjust/sdk/Util;->createPOSTHttpsURLConnection(Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;I)Ljavax/net/ssl/HttpsURLConnection;
move-result-object v0
.line 113
invoke-static {v0, p1}, Lcom/adjust/sdk/Util;->readHttpResponse(Ljavax/net/ssl/HttpsURLConnection;Lcom/adjust/sdk/ActivityPackage;)Lcom/adjust/sdk/ResponseData;
move-result-object v0
.line 115
iget-object v0, v0, Lcom/adjust/sdk/ResponseData;->jsonResponse:Lorg/json/JSONObject;
if-nez v0, :cond_56
.line 116
invoke-direct {p0, p1}, Lcom/adjust/sdk/SdkClickHandler;->retrySending(Lcom/adjust/sdk/ActivityPackage;)V
:try_end_34
.catch Ljava/io/UnsupportedEncodingException; {:try_start_15 .. :try_end_34} :catch_50
.catch Ljava/net/SocketTimeoutException; {:try_start_15 .. :try_end_34} :catch_46
.catch Ljava/io/IOException; {:try_start_15 .. :try_end_34} :catch_3c
.catchall {:try_start_15 .. :try_end_34} :catchall_35
goto :goto_56
:catchall_35
move-exception v0
const-string v1, "Sdk_click runtime exception"
.line 127
invoke-direct {p0, p1, v1, v0}, Lcom/adjust/sdk/SdkClickHandler;->logErrorMessage(Lcom/adjust/sdk/ActivityPackage;Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_56
:catch_3c
move-exception v0
const-string v1, "Sdk_click request failed. Will retry later"
.line 124
invoke-direct {p0, p1, v1, v0}, Lcom/adjust/sdk/SdkClickHandler;->logErrorMessage(Lcom/adjust/sdk/ActivityPackage;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 125
invoke-direct {p0, p1}, Lcom/adjust/sdk/SdkClickHandler;->retrySending(Lcom/adjust/sdk/ActivityPackage;)V
goto :goto_56
:catch_46
move-exception v0
const-string v1, "Sdk_click request timed out. Will retry later"
.line 121
invoke-direct {p0, p1, v1, v0}, Lcom/adjust/sdk/SdkClickHandler;->logErrorMessage(Lcom/adjust/sdk/ActivityPackage;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 122
invoke-direct {p0, p1}, Lcom/adjust/sdk/SdkClickHandler;->retrySending(Lcom/adjust/sdk/ActivityPackage;)V
goto :goto_56
:catch_50
move-exception v0
const-string v1, "Sdk_click failed to encode parameters"
.line 119
invoke-direct {p0, p1, v1, v0}, Lcom/adjust/sdk/SdkClickHandler;->logErrorMessage(Lcom/adjust/sdk/ActivityPackage;Ljava/lang/String;Ljava/lang/Throwable;)V
:cond_56
:goto_56
return-void
.end method
# virtual methods
.method public init(Z)V
.registers 2
xor-int/lit8 p1, p1, 0x1
.line 40
iput-boolean p1, p0, Lcom/adjust/sdk/SdkClickHandler;->paused:Z
.line 41
new-instance p1, Ljava/util/ArrayList;
invoke-direct {p1}, Ljava/util/ArrayList;-><init>()V
iput-object p1, p0, Lcom/adjust/sdk/SdkClickHandler;->packageQueue:Ljava/util/List;
return-void
.end method
.method public pauseSending()V
.registers 2
const/4 v0, 0x1
.line 46
iput-boolean v0, p0, Lcom/adjust/sdk/SdkClickHandler;->paused:Z
return-void
.end method
.method public resumeSending()V
.registers 2
const/4 v0, 0x0
.line 51
iput-boolean v0, p0, Lcom/adjust/sdk/SdkClickHandler;->paused:Z
.line 53
invoke-direct {p0}, Lcom/adjust/sdk/SdkClickHandler;->sendNextSdkClick()V
return-void
.end method
.method public sendSdkClick(Lcom/adjust/sdk/ActivityPackage;)V
.registers 4
.line 58
iget-object v0, p0, Lcom/adjust/sdk/SdkClickHandler;->internalHandler:Landroid/os/Handler;
new-instance v1, Lcom/adjust/sdk/SdkClickHandler$1;
invoke-direct {v1, p0, p1}, Lcom/adjust/sdk/SdkClickHandler$1;-><init>(Lcom/adjust/sdk/SdkClickHandler;Lcom/adjust/sdk/ActivityPackage;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method