AttributionHandler.smali
.class public Lcom/adjust/sdk/AttributionHandler;
.super Ljava/lang/Object;
.source "AttributionHandler.java"
# interfaces
.implements Lcom/adjust/sdk/IAttributionHandler;
# static fields
.field private static final ATTRIBUTION_TIMER_NAME:Ljava/lang/String; = "Attribution timer"
# instance fields
.field private activityHandler:Lcom/adjust/sdk/IActivityHandler;
.field private attributionPackage:Lcom/adjust/sdk/ActivityPackage;
.field private hasListener:Z
.field public lastUrlUsed:Ljava/net/URL;
.field private logger:Lcom/adjust/sdk/ILogger;
.field private paused:Z
.field private scheduler:Ljava/util/concurrent/ScheduledExecutorService;
.field private timer:Lcom/adjust/sdk/TimerOnce;
# direct methods
.method public constructor <init>(Lcom/adjust/sdk/IActivityHandler;Lcom/adjust/sdk/ActivityPackage;ZZ)V
.registers 9
.line 33
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 34
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
iput-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
.line 35
invoke-static {}, Lcom/adjust/sdk/AdjustFactory;->getLogger()Lcom/adjust/sdk/ILogger;
move-result-object v0
iput-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->logger:Lcom/adjust/sdk/ILogger;
.line 37
iget-object v1, p0, Lcom/adjust/sdk/AttributionHandler;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
if-eqz v1, :cond_22
.line 38
new-instance v0, Lcom/adjust/sdk/TimerOnce;
new-instance v2, Lcom/adjust/sdk/AttributionHandler$1;
invoke-direct {v2, p0}, Lcom/adjust/sdk/AttributionHandler$1;-><init>(Lcom/adjust/sdk/AttributionHandler;)V
const-string v3, "Attribution timer"
invoke-direct {v0, v1, v2, v3}, Lcom/adjust/sdk/TimerOnce;-><init>(Ljava/util/concurrent/ScheduledExecutorService;Ljava/lang/Runnable;Ljava/lang/String;)V
iput-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->timer:Lcom/adjust/sdk/TimerOnce;
goto :goto_2a
:cond_22
const/4 v1, 0x0
new-array v1, v1, [Ljava/lang/Object;
const-string v2, "Timer not initialized, attribution handler is disabled"
.line 45
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->error(Ljava/lang/String;[Ljava/lang/Object;)V
.line 48
:goto_2a
invoke-virtual {p0, p1, p2, p3, p4}, Lcom/adjust/sdk/AttributionHandler;->init(Lcom/adjust/sdk/IActivityHandler;Lcom/adjust/sdk/ActivityPackage;ZZ)V
return-void
.end method
.method static synthetic access$000(Lcom/adjust/sdk/AttributionHandler;)V
.registers 1
.line 17
invoke-direct {p0}, Lcom/adjust/sdk/AttributionHandler;->getAttributionInternal()V
return-void
.end method
.method static synthetic access$100(Lcom/adjust/sdk/AttributionHandler;Lcom/adjust/sdk/SessionResponseData;)V
.registers 2
.line 17
invoke-direct {p0, p1}, Lcom/adjust/sdk/AttributionHandler;->checkSessionResponseInternal(Lcom/adjust/sdk/SessionResponseData;)V
return-void
.end method
.method static synthetic access$200(Lcom/adjust/sdk/AttributionHandler;Lcom/adjust/sdk/AttributionResponseData;)V
.registers 2
.line 17
invoke-direct {p0, p1}, Lcom/adjust/sdk/AttributionHandler;->checkAttributionResponseInternal(Lcom/adjust/sdk/AttributionResponseData;)V
return-void
.end method
.method private buildUri(Ljava/lang/String;Ljava/util/Map;)Landroid/net/Uri;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)",
"Landroid/net/Uri;"
}
.end annotation
.line 178
new-instance v0, Landroid/net/Uri$Builder;
invoke-direct {v0}, Landroid/net/Uri$Builder;-><init>()V
const-string v1, "https"
.line 180
invoke-virtual {v0, v1}, Landroid/net/Uri$Builder;->scheme(Ljava/lang/String;)Landroid/net/Uri$Builder;
const-string v1, "app.adjust.com"
.line 181
invoke-virtual {v0, v1}, Landroid/net/Uri$Builder;->authority(Ljava/lang/String;)Landroid/net/Uri$Builder;
.line 182
invoke-virtual {v0, p1}, Landroid/net/Uri$Builder;->appendPath(Ljava/lang/String;)Landroid/net/Uri$Builder;
.line 184
invoke-interface {p2}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object p1
invoke-interface {p1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_1a
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result p2
if-eqz p2, :cond_36
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/util/Map$Entry;
.line 185
invoke-interface {p2}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-interface {p2}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
invoke-virtual {v0, v1, p2}, Landroid/net/Uri$Builder;->appendQueryParameter(Ljava/lang/String;Ljava/lang/String;)Landroid/net/Uri$Builder;
goto :goto_1a
.line 188
:cond_36
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide p1
.line 189
invoke-static {p1, p2}, Lcom/adjust/sdk/Util;->dateFormat(J)Ljava/lang/String;
move-result-object p1
const-string p2, "sent_at"
.line 191
invoke-virtual {v0, p2, p1}, Landroid/net/Uri$Builder;->appendQueryParameter(Ljava/lang/String;Ljava/lang/String;)Landroid/net/Uri$Builder;
.line 193
invoke-virtual {v0}, Landroid/net/Uri$Builder;->build()Landroid/net/Uri;
move-result-object p1
return-object p1
.end method
.method private checkAttributionInternal(Lcom/adjust/sdk/ResponseData;)V
.registers 7
.line 115
iget-object v0, p1, Lcom/adjust/sdk/ResponseData;->jsonResponse:Lorg/json/JSONObject;
if-nez v0, :cond_5
return-void
.line 119
:cond_5
iget-object v0, p1, Lcom/adjust/sdk/ResponseData;->jsonResponse:Lorg/json/JSONObject;
const-wide/16 v1, -0x1
const-string v3, "ask_in"
invoke-virtual {v0, v3, v1, v2}, Lorg/json/JSONObject;->optLong(Ljava/lang/String;J)J
move-result-wide v0
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-ltz v4, :cond_1f
.line 122
iget-object p1, p0, Lcom/adjust/sdk/AttributionHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
const/4 v2, 0x1
invoke-interface {p1, v2}, Lcom/adjust/sdk/IActivityHandler;->setAskingAttribution(Z)V
.line 124
invoke-direct {p0, v0, v1}, Lcom/adjust/sdk/AttributionHandler;->getAttribution(J)V
return-void
.line 128
:cond_1f
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
const/4 v1, 0x0
invoke-interface {v0, v1}, Lcom/adjust/sdk/IActivityHandler;->setAskingAttribution(Z)V
.line 130
iget-object v0, p1, Lcom/adjust/sdk/ResponseData;->jsonResponse:Lorg/json/JSONObject;
const-string v1, "attribution"
invoke-virtual {v0, v1}, Lorg/json/JSONObject;->optJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v0
.line 131
invoke-static {v0}, Lcom/adjust/sdk/AdjustAttribution;->fromJson(Lorg/json/JSONObject;)Lcom/adjust/sdk/AdjustAttribution;
move-result-object v0
iput-object v0, p1, Lcom/adjust/sdk/ResponseData;->attribution:Lcom/adjust/sdk/AdjustAttribution;
return-void
.end method
.method private checkAttributionResponse(Lcom/adjust/sdk/AttributionResponseData;)V
.registers 4
.line 78
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
new-instance v1, Lcom/adjust/sdk/AttributionHandler$3;
invoke-direct {v1, p0, p1}, Lcom/adjust/sdk/AttributionHandler$3;-><init>(Lcom/adjust/sdk/AttributionHandler;Lcom/adjust/sdk/AttributionResponseData;)V
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledExecutorService;->submit(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
return-void
.end method
.method private checkAttributionResponseInternal(Lcom/adjust/sdk/AttributionResponseData;)V
.registers 3
.line 141
invoke-direct {p0, p1}, Lcom/adjust/sdk/AttributionHandler;->checkAttributionInternal(Lcom/adjust/sdk/ResponseData;)V
.line 143
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
invoke-interface {v0, p1}, Lcom/adjust/sdk/IActivityHandler;->launchAttributionResponseTasks(Lcom/adjust/sdk/AttributionResponseData;)V
return-void
.end method
.method private checkSessionResponseInternal(Lcom/adjust/sdk/SessionResponseData;)V
.registers 3
.line 135
invoke-direct {p0, p1}, Lcom/adjust/sdk/AttributionHandler;->checkAttributionInternal(Lcom/adjust/sdk/ResponseData;)V
.line 137
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
invoke-interface {v0, p1}, Lcom/adjust/sdk/IActivityHandler;->launchSessionResponseTasks(Lcom/adjust/sdk/SessionResponseData;)V
return-void
.end method
.method private getAttribution(J)V
.registers 7
.line 99
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->timer:Lcom/adjust/sdk/TimerOnce;
invoke-virtual {v0}, Lcom/adjust/sdk/TimerOnce;->getFireIn()J
move-result-wide v0
cmp-long v2, v0, p1
if-lez v2, :cond_b
return-void
:cond_b
const-wide/16 v0, 0x0
cmp-long v2, p1, v0
if-eqz v2, :cond_2b
long-to-double v0, p1
const-wide v2, 0x408f400000000000L # 1000.0
div-double/2addr v0, v2
.line 105
sget-object v2, Lcom/adjust/sdk/Util;->SecondsDisplayFormat:Ljava/text/DecimalFormat;
invoke-virtual {v2, v0, v1}, Ljava/text/DecimalFormat;->format(D)Ljava/lang/String;
move-result-object v0
.line 107
iget-object v1, p0, Lcom/adjust/sdk/AttributionHandler;->logger:Lcom/adjust/sdk/ILogger;
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
aput-object v0, v2, v3
const-string v0, "Waiting to query attribution in %s seconds"
invoke-interface {v1, v0, v2}, Lcom/adjust/sdk/ILogger;->debug(Ljava/lang/String;[Ljava/lang/Object;)V
.line 111
:cond_2b
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->timer:Lcom/adjust/sdk/TimerOnce;
invoke-virtual {v0, p1, p2}, Lcom/adjust/sdk/TimerOnce;->startIn(J)V
return-void
.end method
.method private getAttributionInternal()V
.registers 6
.line 147
iget-boolean v0, p0, Lcom/adjust/sdk/AttributionHandler;->hasListener:Z
if-nez v0, :cond_5
return-void
.line 151
:cond_5
iget-boolean v0, p0, Lcom/adjust/sdk/AttributionHandler;->paused:Z
const/4 v1, 0x0
if-eqz v0, :cond_14
.line 152
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v1, [Ljava/lang/Object;
const-string v2, "Attribution handler is paused"
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->debug(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 156
:cond_14
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->logger:Lcom/adjust/sdk/ILogger;
const/4 v2, 0x1
new-array v3, v2, [Ljava/lang/Object;
iget-object v4, p0, Lcom/adjust/sdk/AttributionHandler;->attributionPackage:Lcom/adjust/sdk/ActivityPackage;
invoke-virtual {v4}, Lcom/adjust/sdk/ActivityPackage;->getExtendedString()Ljava/lang/String;
move-result-object v4
aput-object v4, v3, v1
const-string v4, "%s"
invoke-interface {v0, v4, v3}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
.line 159
:try_start_26
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->attributionPackage:Lcom/adjust/sdk/ActivityPackage;
.line 160
invoke-virtual {v0}, Lcom/adjust/sdk/ActivityPackage;->getPath()Ljava/lang/String;
move-result-object v0
iget-object v3, p0, Lcom/adjust/sdk/AttributionHandler;->attributionPackage:Lcom/adjust/sdk/ActivityPackage;
invoke-virtual {v3}, Lcom/adjust/sdk/ActivityPackage;->getParameters()Ljava/util/Map;
move-result-object v3
invoke-direct {p0, v0, v3}, Lcom/adjust/sdk/AttributionHandler;->buildUri(Ljava/lang/String;Ljava/util/Map;)Landroid/net/Uri;
move-result-object v0
invoke-virtual {v0}, Landroid/net/Uri;->toString()Ljava/lang/String;
move-result-object v0
iget-object v3, p0, Lcom/adjust/sdk/AttributionHandler;->attributionPackage:Lcom/adjust/sdk/ActivityPackage;
.line 161
invoke-virtual {v3}, Lcom/adjust/sdk/ActivityPackage;->getClientSdk()Ljava/lang/String;
move-result-object v3
.line 159
invoke-static {v0, v3}, Lcom/adjust/sdk/Util;->createGETHttpsURLConnection(Ljava/lang/String;Ljava/lang/String;)Lcom/adjust/sdk/AdjustFactory$URLGetConnection;
move-result-object v0
.line 163
iget-object v3, v0, Lcom/adjust/sdk/AdjustFactory$URLGetConnection;->httpsURLConnection:Ljavax/net/ssl/HttpsURLConnection;
iget-object v4, p0, Lcom/adjust/sdk/AttributionHandler;->attributionPackage:Lcom/adjust/sdk/ActivityPackage;
invoke-static {v3, v4}, Lcom/adjust/sdk/Util;->readHttpResponse(Ljavax/net/ssl/HttpsURLConnection;Lcom/adjust/sdk/ActivityPackage;)Lcom/adjust/sdk/ResponseData;
move-result-object v3
.line 164
iget-object v0, v0, Lcom/adjust/sdk/AdjustFactory$URLGetConnection;->url:Ljava/net/URL;
iput-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->lastUrlUsed:Ljava/net/URL;
.line 166
instance-of v0, v3, Lcom/adjust/sdk/AttributionResponseData;
if-nez v0, :cond_55
return-void
.line 170
:cond_55
check-cast v3, Lcom/adjust/sdk/AttributionResponseData;
invoke-direct {p0, v3}, Lcom/adjust/sdk/AttributionHandler;->checkAttributionResponse(Lcom/adjust/sdk/AttributionResponseData;)V
:try_end_5a
.catch Ljava/lang/Exception; {:try_start_26 .. :try_end_5a} :catch_5b
return-void
:catch_5b
move-exception v0
.line 172
iget-object v3, p0, Lcom/adjust/sdk/AttributionHandler;->logger:Lcom/adjust/sdk/ILogger;
new-array v2, v2, [Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
aput-object v0, v2, v1
const-string v0, "Failed to get attribution (%s)"
invoke-interface {v3, v0, v2}, Lcom/adjust/sdk/ILogger;->error(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
# virtual methods
.method public checkSessionResponse(Lcom/adjust/sdk/SessionResponseData;)V
.registers 4
.line 69
iget-object v0, p0, Lcom/adjust/sdk/AttributionHandler;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
new-instance v1, Lcom/adjust/sdk/AttributionHandler$2;
invoke-direct {v1, p0, p1}, Lcom/adjust/sdk/AttributionHandler$2;-><init>(Lcom/adjust/sdk/AttributionHandler;Lcom/adjust/sdk/SessionResponseData;)V
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledExecutorService;->submit(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
return-void
.end method
.method public getAttribution()V
.registers 3
const-wide/16 v0, 0x0
.line 64
invoke-direct {p0, v0, v1}, Lcom/adjust/sdk/AttributionHandler;->getAttribution(J)V
return-void
.end method
.method public init(Lcom/adjust/sdk/IActivityHandler;Lcom/adjust/sdk/ActivityPackage;ZZ)V
.registers 5
.line 56
iput-object p1, p0, Lcom/adjust/sdk/AttributionHandler;->activityHandler:Lcom/adjust/sdk/IActivityHandler;
.line 57
iput-object p2, p0, Lcom/adjust/sdk/AttributionHandler;->attributionPackage:Lcom/adjust/sdk/ActivityPackage;
xor-int/lit8 p1, p3, 0x1
.line 58
iput-boolean p1, p0, Lcom/adjust/sdk/AttributionHandler;->paused:Z
.line 59
iput-boolean p4, p0, Lcom/adjust/sdk/AttributionHandler;->hasListener:Z
return-void
.end method
.method public pauseSending()V
.registers 2
const/4 v0, 0x1
.line 89
iput-boolean v0, p0, Lcom/adjust/sdk/AttributionHandler;->paused:Z
return-void
.end method
.method public resumeSending()V
.registers 2
const/4 v0, 0x0
.line 94
iput-boolean v0, p0, Lcom/adjust/sdk/AttributionHandler;->paused:Z
return-void
.end method