h.smali
.class public final Lcom/proxy/ad/impl/video/a/h;
.super Ljava/lang/Object;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/proxy/ad/impl/video/a/h$a;
}
.end annotation
# instance fields
.field private final a:Ljava/util/concurrent/ExecutorService;
.field private final b:Ljava/lang/String;
.field private final c:I
# direct methods
.method constructor <init>(Ljava/lang/String;I)V
.registers 4
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadExecutor()Ljava/util/concurrent/ExecutorService;
move-result-object v0
iput-object v0, p0, Lcom/proxy/ad/impl/video/a/h;->a:Ljava/util/concurrent/ExecutorService;
invoke-static {p1}, Lcom/proxy/ad/impl/video/a/i;->a(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/lang/String;
iput-object p1, p0, Lcom/proxy/ad/impl/video/a/h;->b:Ljava/lang/String;
iput p2, p0, Lcom/proxy/ad/impl/video/a/h;->c:I
return-void
.end method
.method private c()Ljava/util/List;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Ljava/net/Proxy;",
">;"
}
.end annotation
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
:try_start_5
invoke-static {}, Ljava/net/ProxySelector;->getDefault()Ljava/net/ProxySelector;
move-result-object v1
new-instance v2, Ljava/net/URI;
invoke-direct {p0}, Lcom/proxy/ad/impl/video/a/h;->d()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v3}, Ljava/net/URI;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, v2}, Ljava/net/ProxySelector;->select(Ljava/net/URI;)Ljava/util/List;
move-result-object v0
:try_end_16
.catch Ljava/net/URISyntaxException; {:try_start_5 .. :try_end_16} :catch_17
goto :goto_2f
:catch_17
move-exception v1
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Pinger#getDefaultProxies, error message is : "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/net/URISyntaxException;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
const-string v2, "ads-proxycache"
invoke-static {v2, v1}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
:goto_2f
return-object v0
.end method
.method private d()Ljava/lang/String;
.registers 5
sget-object v0, Ljava/util/Locale;->US:Ljava/util/Locale;
const/4 v1, 0x3
new-array v1, v1, [Ljava/lang/Object;
iget-object v2, p0, Lcom/proxy/ad/impl/video/a/h;->b:Ljava/lang/String;
const/4 v3, 0x0
aput-object v2, v1, v3
iget v2, p0, Lcom/proxy/ad/impl/video/a/h;->c:I
invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
const/4 v3, 0x1
aput-object v2, v1, v3
const/4 v2, 0x2
const-string v3, "ping"
aput-object v3, v1, v2
const-string v2, "http://%s:%d/%s"
invoke-static {v0, v2, v1}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
# virtual methods
.method public final a()Z
.registers 10
const/4 v0, 0x0
const/16 v1, 0x46
const/4 v2, 0x0
:goto_4
const/4 v3, 0x3
const-string v4, "ads-proxycache"
const/4 v5, 0x1
if-ge v2, v3, :cond_4b
:try_start_a
iget-object v3, p0, Lcom/proxy/ad/impl/video/a/h;->a:Ljava/util/concurrent/ExecutorService;
new-instance v6, Lcom/proxy/ad/impl/video/a/h$a;
invoke-direct {v6, p0, v0}, Lcom/proxy/ad/impl/video/a/h$a;-><init>(Lcom/proxy/ad/impl/video/a/h;B)V
invoke-interface {v3, v6}, Ljava/util/concurrent/ExecutorService;->submit(Ljava/util/concurrent/Callable;)Ljava/util/concurrent/Future;
move-result-object v3
int-to-long v6, v1
sget-object v8, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v3, v6, v7, v8}, Ljava/util/concurrent/Future;->get(JLjava/util/concurrent/TimeUnit;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/Boolean;
invoke-virtual {v3}, Ljava/lang/Boolean;->booleanValue()Z
move-result v3
:try_end_22
.catch Ljava/util/concurrent/TimeoutException; {:try_start_a .. :try_end_22} :catch_28
.catch Ljava/lang/InterruptedException; {:try_start_a .. :try_end_22} :catch_25
.catch Ljava/util/concurrent/ExecutionException; {:try_start_a .. :try_end_22} :catch_25
if-eqz v3, :cond_46
return v5
:catch_25
const-string v3, "Error pinging server due to unexpected error"
goto :goto_43
:catch_28
new-instance v3, Ljava/lang/StringBuilder;
const-string v5, "Error pinging server (attempt: "
invoke-direct {v3, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v5, ", timeout: "
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v5, "). "
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
:goto_43
invoke-static {v4, v3}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
:cond_46
add-int/lit8 v2, v2, 0x1
mul-int/lit8 v1, v1, 0x2
goto :goto_4
:cond_4b
sget-object v6, Ljava/util/Locale;->US:Ljava/util/Locale;
new-array v3, v3, [Ljava/lang/Object;
invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
aput-object v2, v3, v0
const/4 v2, 0x2
div-int/2addr v1, v2
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
aput-object v1, v3, v5
invoke-direct {p0}, Lcom/proxy/ad/impl/video/a/h;->c()Ljava/util/List;
move-result-object v1
aput-object v1, v3, v2
const-string v1, "Error pinging server (attempts: %d, max timeout: %d). If you see this message, please, report at https://github.com/danikula/AndroidVideoCache/issues/134. Default proxies are: %s"
invoke-static {v6, v1, v3}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-static {v4, v1}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
return v0
.end method
.method final b()Z
.registers 7
const-string v0, "ads-proxycache"
invoke-direct {p0}, Lcom/proxy/ad/impl/video/a/h;->d()Ljava/lang/String;
move-result-object v1
new-instance v2, Lcom/proxy/ad/impl/video/a/g;
invoke-direct {v2, v1}, Lcom/proxy/ad/impl/video/a/g;-><init>(Ljava/lang/String;)V
:try_start_b
const-string v1, "ping ok"
invoke-virtual {v1}, Ljava/lang/String;->getBytes()[B
move-result-object v1
:try_end_11
.catchall {:try_start_b .. :try_end_11} :catchall_77
:try_start_11
invoke-virtual {v2}, Lcom/proxy/ad/impl/video/a/g;->b()Ljava/net/HttpURLConnection;
move-result-object v3
iput-object v3, v2, Lcom/proxy/ad/impl/video/a/g;->a:Ljava/net/HttpURLConnection;
iget-object v3, v2, Lcom/proxy/ad/impl/video/a/g;->a:Ljava/net/HttpURLConnection;
if-eqz v3, :cond_4b
new-instance v3, Ljava/io/BufferedInputStream;
iget-object v4, v2, Lcom/proxy/ad/impl/video/a/g;->a:Ljava/net/HttpURLConnection;
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v4
const/16 v5, 0x2000
invoke-direct {v3, v4, v5}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;I)V
iput-object v3, v2, Lcom/proxy/ad/impl/video/a/g;->b:Ljava/io/InputStream;
:try_end_2a
.catch Ljava/io/IOException; {:try_start_11 .. :try_end_2a} :catch_2b
.catchall {:try_start_11 .. :try_end_2a} :catchall_77
goto :goto_4b
:catch_2b
move-exception v3
:try_start_2c
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "Error opening connection for "
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v5, v2, Lcom/proxy/ad/impl/video/a/g;->c:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, " with offset 0, error message is : "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/io/IOException;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v0, v3}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
:cond_4b
:goto_4b
array-length v3, v1
new-array v3, v3, [B
invoke-virtual {v2, v3}, Lcom/proxy/ad/impl/video/a/g;->a([B)I
invoke-static {v1, v3}, Ljava/util/Arrays;->equals([B[B)Z
move-result v1
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "Ping response: `"
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
new-instance v5, Ljava/lang/String;
invoke-direct {v5, v3}, Ljava/lang/String;-><init>([B)V
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "`, pinged? "
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v0, v3}, Lcom/proxy/ad/log/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
:try_end_73
.catchall {:try_start_2c .. :try_end_73} :catchall_77
invoke-virtual {v2}, Lcom/proxy/ad/impl/video/a/g;->a()V
return v1
:catchall_77
move-exception v0
invoke-virtual {v2}, Lcom/proxy/ad/impl/video/a/g;->a()V
throw v0
.end method