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