d.smali
.class public final Lcom/proxy/ad/impl/video/a/d;
.super Ljava/lang/Object;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/proxy/ad/impl/video/a/d$a;,
Lcom/proxy/ad/impl/video/a/d$b;
}
.end annotation
# instance fields
.field final a:Ljava/util/concurrent/ExecutorService;
.field b:Ljava/net/ServerSocket;
.field public c:I
.field public d:Lcom/proxy/ad/impl/video/a/h;
.field private final e:Ljava/lang/Object;
.field private final f:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Lcom/proxy/ad/impl/video/a/e;",
">;"
}
.end annotation
.end field
.field private g:Ljava/lang/Thread;
# direct methods
.method public constructor <init>()V
.registers 9
const-string v0, "ads-proxycache"
const-string v1, "127.0.0.1"
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v2, Ljava/lang/Object;
invoke-direct {v2}, Ljava/lang/Object;-><init>()V
iput-object v2, p0, Lcom/proxy/ad/impl/video/a/d;->e:Ljava/lang/Object;
const/16 v2, 0x8
invoke-static {v2}, Ljava/util/concurrent/Executors;->newFixedThreadPool(I)Ljava/util/concurrent/ExecutorService;
move-result-object v3
iput-object v3, p0, Lcom/proxy/ad/impl/video/a/d;->a:Ljava/util/concurrent/ExecutorService;
new-instance v3, Ljava/util/concurrent/ConcurrentHashMap;
invoke-direct {v3}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V
iput-object v3, p0, Lcom/proxy/ad/impl/video/a/d;->f:Ljava/util/Map;
:try_start_1d
invoke-static {v1}, Ljava/net/InetAddress;->getByName(Ljava/lang/String;)Ljava/net/InetAddress;
move-result-object v3
new-instance v4, Ljava/net/ServerSocket;
const/4 v5, 0x0
invoke-direct {v4, v5, v2, v3}, Ljava/net/ServerSocket;-><init>(IILjava/net/InetAddress;)V
iput-object v4, p0, Lcom/proxy/ad/impl/video/a/d;->b:Ljava/net/ServerSocket;
invoke-virtual {v4}, Ljava/net/ServerSocket;->getLocalPort()I
move-result v2
iput v2, p0, Lcom/proxy/ad/impl/video/a/d;->c:I
invoke-static {v1, v2}, Lcom/proxy/ad/impl/video/a/f;->a(Ljava/lang/String;I)V
new-instance v2, Ljava/util/concurrent/CountDownLatch;
const/4 v3, 0x1
invoke-direct {v2, v3}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V
new-instance v3, Ljava/lang/Thread;
new-instance v4, Lcom/proxy/ad/impl/video/a/d$b;
invoke-direct {v4, p0, v2}, Lcom/proxy/ad/impl/video/a/d$b;-><init>(Lcom/proxy/ad/impl/video/a/d;Ljava/util/concurrent/CountDownLatch;)V
invoke-direct {v3, v4}, Ljava/lang/Thread;-><init>(Ljava/lang/Runnable;)V
iput-object v3, p0, Lcom/proxy/ad/impl/video/a/d;->g:Ljava/lang/Thread;
invoke-virtual {v3}, Ljava/lang/Thread;->start()V
invoke-virtual {v2}, Ljava/util/concurrent/CountDownLatch;->await()V
new-instance v2, Lcom/proxy/ad/impl/video/a/h;
iget v3, p0, Lcom/proxy/ad/impl/video/a/d;->c:I
invoke-direct {v2, v1, v3}, Lcom/proxy/ad/impl/video/a/h;-><init>(Ljava/lang/String;I)V
iput-object v2, p0, Lcom/proxy/ad/impl/video/a/d;->d:Lcom/proxy/ad/impl/video/a/h;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Proxy cache server started. Is it alive? "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v2, p0, Lcom/proxy/ad/impl/video/a/d;->d:Lcom/proxy/ad/impl/video/a/h;
invoke-virtual {v2}, Lcom/proxy/ad/impl/video/a/h;->a()Z
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcom/proxy/ad/log/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
:try_end_6a
.catch Ljava/io/IOException; {:try_start_1d .. :try_end_6a} :catch_6d
.catch Ljava/lang/InterruptedException; {:try_start_1d .. :try_end_6a} :catch_6b
return-void
:catch_6b
move-exception v1
goto :goto_6e
:catch_6d
move-exception v1
:goto_6e
iget-object v2, p0, Lcom/proxy/ad/impl/video/a/d;->a:Ljava/util/concurrent/ExecutorService;
invoke-interface {v2}, Ljava/util/concurrent/ExecutorService;->shutdown()V
new-instance v2, Lcom/proxy/ad/adsdk/AdError;
const/16 v3, 0x3f3
const/16 v4, 0x2b05
new-instance v5, Ljava/lang/StringBuilder;
const-string v6, "Error starting local proxy server, error message is : "
invoke-direct {v5, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->toString()Ljava/lang/String;
move-result-object v7
invoke-virtual {v5, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-direct {v2, v3, v4, v5}, Lcom/proxy/ad/adsdk/AdError;-><init>(IILjava/lang/String;)V
const/4 v3, 0x0
invoke-static {v3, v2, v3}, Lcom/proxy/ad/adbusiness/b/c;->a(Lcom/proxy/ad/adbusiness/h/a;Lcom/proxy/ad/adsdk/AdError;Ljava/util/HashMap;)V
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->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
invoke-static {v0, v1}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method static a(Ljava/net/Socket;)V
.registers 5
const-string v0, "ads-proxycache"
:try_start_2
invoke-virtual {p0}, Ljava/net/Socket;->isInputShutdown()Z
move-result v1
if-nez v1, :cond_25
invoke-virtual {p0}, Ljava/net/Socket;->shutdownInput()V
:try_end_b
.catch Ljava/net/SocketException; {:try_start_2 .. :try_end_b} :catch_20
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_b} :catch_c
goto :goto_25
:catch_c
move-exception v1
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Error closing socket input stream, error message is "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/io/IOException;->getMessage()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
goto :goto_22
:catch_20
const-string v1, "Releasing input stream\u2026 Socket is closed by client."
:goto_22
invoke-static {v0, v1}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
:cond_25
:goto_25
:try_start_25
invoke-virtual {p0}, Ljava/net/Socket;->isOutputShutdown()Z
move-result v1
if-nez v1, :cond_45
invoke-virtual {p0}, Ljava/net/Socket;->shutdownOutput()V
:try_end_2e
.catch Ljava/io/IOException; {:try_start_25 .. :try_end_2e} :catch_2f
goto :goto_45
:catch_2f
move-exception v1
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Failed to close socket on proxy side: {}. It seems client have already closed connection."
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/io/IOException;->getMessage()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
invoke-static {v0, v1}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
:cond_45
:goto_45
:try_start_45
invoke-virtual {p0}, Ljava/net/Socket;->isClosed()Z
move-result v1
if-nez v1, :cond_4e
invoke-virtual {p0}, Ljava/net/Socket;->close()V
:try_end_4e
.catch Ljava/io/IOException; {:try_start_45 .. :try_end_4e} :catch_4f
:cond_4e
return-void
:catch_4f
move-exception p0
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Error closing socket"
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p0}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object p0
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-static {v0, p0}, Lcom/proxy/ad/log/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method final a()I
.registers 5
iget-object v0, p0, Lcom/proxy/ad/impl/video/a/d;->e:Ljava/lang/Object;
monitor-enter v0
const/4 v1, 0x0
:try_start_4
iget-object v2, p0, Lcom/proxy/ad/impl/video/a/d;->f:Ljava/util/Map;
invoke-interface {v2}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v2
invoke-interface {v2}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_e
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v3
if-eqz v3, :cond_22
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/proxy/ad/impl/video/a/e;
iget-object v3, v3, Lcom/proxy/ad/impl/video/a/e;->a:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v3}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I
move-result v3
add-int/2addr v1, v3
goto :goto_e
:cond_22
monitor-exit v0
return v1
:catchall_24
move-exception v1
monitor-exit v0
:try_end_26
.catchall {:try_start_4 .. :try_end_26} :catchall_24
goto :goto_28
:goto_27
throw v1
:goto_28
goto :goto_27
.end method
.method final a(Ljava/lang/String;)Lcom/proxy/ad/impl/video/a/e;
.registers 5
iget-object v0, p0, Lcom/proxy/ad/impl/video/a/d;->e:Ljava/lang/Object;
monitor-enter v0
:try_start_3
iget-object v1, p0, Lcom/proxy/ad/impl/video/a/d;->f:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/proxy/ad/impl/video/a/e;
if-nez v1, :cond_17
new-instance v1, Lcom/proxy/ad/impl/video/a/e;
invoke-direct {v1, p1}, Lcom/proxy/ad/impl/video/a/e;-><init>(Ljava/lang/String;)V
iget-object v2, p0, Lcom/proxy/ad/impl/video/a/d;->f:Ljava/util/Map;
invoke-interface {v2, p1, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_17
monitor-exit v0
return-object v1
:catchall_19
move-exception p1
monitor-exit v0
:try_end_1b
.catchall {:try_start_3 .. :try_end_1b} :catchall_19
throw p1
.end method