DTBMetricsConfiguration.smali
.class public Lcom/amazon/device/ads/DTBMetricsConfiguration;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field static final CONFIG_DIR:Ljava/lang/String; = "config"
.field static final CONFIG_WITH_JSON:Ljava/lang/String; = "aps_mobile_client_config.json"
.field static final SAMPLE_RATES_KEY_NAME:Ljava/lang/String; = "sample_rates"
.field static final WRAPPING_PIXEL_DEFAULT_VALUE:Ljava/lang/Integer;
.field static final WRAPPING_PIXEL_SAMPLE_RATE_KEY_NAME:Ljava/lang/String; = "wrapping_pixel"
.field private static theInstance:Lcom/amazon/device/ads/DTBMetricsConfiguration;
# instance fields
.field private configuration:Lorg/json/JSONObject;
# direct methods
.method static constructor <clinit>()V
.registers 1
const/4 v0, 0x5
.line 15
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
sput-object v0, Lcom/amazon/device/ads/DTBMetricsConfiguration;->WRAPPING_PIXEL_DEFAULT_VALUE:Ljava/lang/Integer;
return-void
.end method
.method private constructor <init>()V
.registers 3
.line 19
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-string v0, "config"
.line 20
invoke-static {v0}, Lcom/amazon/device/ads/DTBAdUtil;->createDirIfDoesNotExist(Ljava/lang/String;)V
.line 21
invoke-virtual {p0}, Lcom/amazon/device/ads/DTBMetricsConfiguration;->loadConfiguration()V
.line 22
invoke-static {}, Lcom/amazon/device/ads/DtbThreadService;->getInstance()Lcom/amazon/device/ads/DtbThreadService;
move-result-object v0
new-instance v1, Lcom/amazon/device/ads/-$$Lambda$DTBMetricsConfiguration$b35VWcZDw2HOX8Qi8k4yOlmxyjA;
invoke-direct {v1, p0}, Lcom/amazon/device/ads/-$$Lambda$DTBMetricsConfiguration$b35VWcZDw2HOX8Qi8k4yOlmxyjA;-><init>(Lcom/amazon/device/ads/DTBMetricsConfiguration;)V
invoke-virtual {v0, v1}, Lcom/amazon/device/ads/DtbThreadService;->execute(Ljava/lang/Runnable;)V
return-void
.end method
.method public static declared-synchronized getInstance()Lcom/amazon/device/ads/DTBMetricsConfiguration;
.registers 2
const-class v0, Lcom/amazon/device/ads/DTBMetricsConfiguration;
monitor-enter v0
.line 29
:try_start_3
sget-object v1, Lcom/amazon/device/ads/DTBMetricsConfiguration;->theInstance:Lcom/amazon/device/ads/DTBMetricsConfiguration;
if-nez v1, :cond_e
.line 30
new-instance v1, Lcom/amazon/device/ads/DTBMetricsConfiguration;
invoke-direct {v1}, Lcom/amazon/device/ads/DTBMetricsConfiguration;-><init>()V
sput-object v1, Lcom/amazon/device/ads/DTBMetricsConfiguration;->theInstance:Lcom/amazon/device/ads/DTBMetricsConfiguration;
.line 32
:cond_e
sget-object v1, Lcom/amazon/device/ads/DTBMetricsConfiguration;->theInstance:Lcom/amazon/device/ads/DTBMetricsConfiguration;
:try_end_10
.catchall {:try_start_3 .. :try_end_10} :catchall_12
monitor-exit v0
return-object v1
:catchall_12
move-exception v1
monitor-exit v0
throw v1
.end method
.method public static getSampleRateForWrappingPixel()Ljava/lang/Integer;
.registers 2
.line 38
invoke-static {}, Lcom/amazon/device/ads/DTBMetricsConfiguration;->getInstance()Lcom/amazon/device/ads/DTBMetricsConfiguration;
move-result-object v0
.line 39
invoke-direct {v0}, Lcom/amazon/device/ads/DTBMetricsConfiguration;->getSampleRates()Lorg/json/JSONObject;
move-result-object v0
if-eqz v0, :cond_1a
:try_start_a
const-string v1, "wrapping_pixel"
.line 42
invoke-virtual {v0, v1}, Lorg/json/JSONObject;->getInt(Ljava/lang/String;)I
move-result v0
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
:try_end_14
.catch Ljava/lang/Exception; {:try_start_a .. :try_end_14} :catch_15
return-object v0
:catch_15
const-string v0, "Unable to get sample rates for wrapping pixel from configuration. Using default value"
.line 44
invoke-static {v0}, Lcom/amazon/device/ads/DtbLog;->warn(Ljava/lang/String;)V
.line 48
:cond_1a
sget-object v0, Lcom/amazon/device/ads/DTBMetricsConfiguration;->WRAPPING_PIXEL_DEFAULT_VALUE:Ljava/lang/Integer;
return-object v0
.end method
.method private getSampleRates()Lorg/json/JSONObject;
.registers 3
.line 122
iget-object v0, p0, Lcom/amazon/device/ads/DTBMetricsConfiguration;->configuration:Lorg/json/JSONObject;
if-eqz v0, :cond_18
const-string v1, "sample_rates"
invoke-virtual {v0, v1}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_18
.line 124
:try_start_c
iget-object v0, p0, Lcom/amazon/device/ads/DTBMetricsConfiguration;->configuration:Lorg/json/JSONObject;
invoke-virtual {v0, v1}, Lorg/json/JSONObject;->getJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v0
:try_end_12
.catch Lorg/json/JSONException; {:try_start_c .. :try_end_12} :catch_13
return-object v0
:catch_13
const-string v0, "Unable to get sample rates from configuration"
.line 126
invoke-static {v0}, Lcom/amazon/device/ads/DtbLog;->error(Ljava/lang/String;)V
:cond_18
const/4 v0, 0x0
return-object v0
.end method
.method private getWorkingDirContent()Ljava/lang/String;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const-string v0, "aps_mobile_client_config.json"
const-string v1, "config"
.line 133
invoke-static {v0, v1}, Lcom/amazon/device/ads/DTBAdUtil;->loadFile(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method private loadConfigurationFromWeb()V
.registers 5
.line 72
:try_start_0
new-instance v0, Lcom/amazon/device/ads/DtbHttpClient;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-static {}, Lcom/amazon/device/ads/WebResourceOptions;->getCDNHost()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "aps_mobile_client_config.json"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Lcom/amazon/device/ads/DtbHttpClient;-><init>(Ljava/lang/String;)V
const/4 v1, 0x1
.line 73
invoke-static {v1}, Lcom/amazon/device/ads/DtbDebugProperties;->getIsSecure(Z)Z
move-result v1
invoke-virtual {v0, v1}, Lcom/amazon/device/ads/DtbHttpClient;->setUseSecure(Z)V
.line 75
invoke-virtual {v0}, Lcom/amazon/device/ads/DtbHttpClient;->executeGET()V
.line 77
invoke-virtual {v0}, Lcom/amazon/device/ads/DtbHttpClient;->getResponseCode()I
move-result v1
const/16 v2, 0xc8
if-ne v1, v2, :cond_7e
.line 80
invoke-virtual {v0}, Lcom/amazon/device/ads/DtbHttpClient;->getResponse()Ljava/lang/String;
move-result-object v0
.line 82
invoke-static {}, Lcom/amazon/device/ads/AdRegistration;->getContext()Landroid/content/Context;
move-result-object v1
invoke-virtual {v1}, Landroid/content/Context;->getFilesDir()Ljava/io/File;
move-result-object v1
const-string v2, "temp"
const-string v3, "json"
.line 84
invoke-static {v2, v3, v1}, Ljava/io/File;->createTempFile(Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)Ljava/io/File;
move-result-object v2
.line 86
new-instance v3, Ljava/io/FileWriter;
invoke-direct {v3, v2}, Ljava/io/FileWriter;-><init>(Ljava/io/File;)V
.line 87
invoke-virtual {v3, v0}, Ljava/io/FileWriter;->write(Ljava/lang/String;)V
.line 88
invoke-virtual {v3}, Ljava/io/FileWriter;->close()V
.line 90
new-instance v0, Ljava/io/File;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "/config/aps_mobile_client_config.json"
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 91
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_6f
.line 92
invoke-virtual {v0}, Ljava/io/File;->delete()Z
.line 94
:cond_6f
invoke-virtual {v2, v0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
move-result v0
if-nez v0, :cond_7a
const-string v0, "Rename failed"
.line 97
invoke-static {v0}, Lcom/amazon/device/ads/DtbLog;->error(Ljava/lang/String;)V
.line 99
:cond_7a
invoke-virtual {p0}, Lcom/amazon/device/ads/DTBMetricsConfiguration;->loadConfiguration()V
return-void
.line 78
:cond_7e
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "resource aps_mobile_client_config.json not available"
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_86
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_86} :catch_86
:catch_86
move-exception v0
.line 102
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Error loading configuration:"
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Exception;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/amazon/device/ads/DtbLog;->error(Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method declared-synchronized isTypeEnabled(Ljava/lang/String;)Z
.registers 4
monitor-enter p0
.line 108
:try_start_1
iget-object v0, p0, Lcom/amazon/device/ads/DTBMetricsConfiguration;->configuration:Lorg/json/JSONObject;
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_21
if-eqz v0, :cond_1e
.line 110
:try_start_5
iget-object v0, p0, Lcom/amazon/device/ads/DTBMetricsConfiguration;->configuration:Lorg/json/JSONObject;
const-string v1, "metrics"
invoke-virtual {v0, v1}, Lorg/json/JSONObject;->getJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v0
.line 111
invoke-virtual {v0, p1}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_1e
.line 112
invoke-virtual {v0, p1}, Lorg/json/JSONObject;->getBoolean(Ljava/lang/String;)Z
move-result p1
:try_end_17
.catch Lorg/json/JSONException; {:try_start_5 .. :try_end_17} :catch_19
.catchall {:try_start_5 .. :try_end_17} :catchall_21
monitor-exit p0
return p1
:catch_19
:try_start_19
const-string p1, "Unable to get metrics from configuration"
.line 115
invoke-static {p1}, Lcom/amazon/device/ads/DtbLog;->error(Ljava/lang/String;)V
:try_end_1e
.catchall {:try_start_19 .. :try_end_1e} :catchall_21
:cond_1e
const/4 p1, 0x0
.line 118
monitor-exit p0
return p1
:catchall_21
move-exception p1
monitor-exit p0
throw p1
.end method
.method public synthetic lambda$new$0$DTBMetricsConfiguration()V
.registers 1
.line 23
invoke-direct {p0}, Lcom/amazon/device/ads/DTBMetricsConfiguration;->loadConfigurationFromWeb()V
return-void
.end method
.method declared-synchronized loadConfiguration()V
.registers 3
monitor-enter p0
.line 53
:try_start_1
invoke-direct {p0}, Lcom/amazon/device/ads/DTBMetricsConfiguration;->getWorkingDirContent()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_d
const-string v0, "aps_mobile_client_config.json"
.line 55
invoke-static {v0}, Lcom/amazon/device/ads/DTBAdUtil;->loadFromAssets(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 58
:cond_d
new-instance v1, Lorg/json/JSONObject;
invoke-direct {v1, v0}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V
iput-object v1, p0, Lcom/amazon/device/ads/DTBMetricsConfiguration;->configuration:Lorg/json/JSONObject;
:try_end_14
.catch Ljava/io/IOException; {:try_start_1 .. :try_end_14} :catch_21
.catch Lorg/json/JSONException; {:try_start_1 .. :try_end_14} :catch_18
.catchall {:try_start_1 .. :try_end_14} :catchall_16
.line 65
monitor-exit p0
return-void
:catchall_16
move-exception v0
goto :goto_1f
:catch_18
:try_start_18
const-string v0, "Invalid configuration"
.line 64
invoke-static {v0}, Lcom/amazon/device/ads/DtbLog;->error(Ljava/lang/String;)V
:try_end_1d
.catchall {:try_start_18 .. :try_end_1d} :catchall_16
.line 67
monitor-exit p0
return-void
:goto_1f
monitor-exit p0
throw v0
.line 65
:catch_21
monitor-exit p0
return-void
.end method