AssetDownloader.smali
.class public Lcom/vungle/warren/downloader/AssetDownloader;
.super Ljava/lang/Object;
.source "AssetDownloader.java"
# interfaces
.implements Lcom/vungle/warren/downloader/Downloader;
# annotations
.annotation build Landroid/annotation/SuppressLint;
value = {
"LogNotTimber"
}
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/vungle/warren/downloader/AssetDownloader$DownloadPriorityRunnable;,
Lcom/vungle/warren/downloader/AssetDownloader$NetworkType;
}
.end annotation
# static fields
.field private static final ACCEPT_ENCODING:Ljava/lang/String; = "Accept-Encoding"
.field private static final ACCEPT_RANGES:Ljava/lang/String; = "Accept-Ranges"
.field private static final BYTES:Ljava/lang/String; = "bytes"
.field private static final CONNECTION_RETRY_TIMEOUT:I = 0x12c
.field private static final CONTENT_ENCODING:Ljava/lang/String; = "Content-Encoding"
.field private static final CONTENT_RANGE:Ljava/lang/String; = "Content-Range"
.field private static final CONTENT_TYPE:Ljava/lang/String; = "Content-Type"
.field private static final DOWNLOAD_CHUNK_SIZE:I = 0x800
.field static final DOWNLOAD_COMPLETE:Ljava/lang/String; = "DOWNLOAD_COMPLETE"
.field static final DOWNLOAD_URL:Ljava/lang/String; = "Download_URL"
.field static final ETAG:Ljava/lang/String; = "ETag"
.field private static final GZIP:Ljava/lang/String; = "gzip"
.field private static final IDENTITY:Ljava/lang/String; = "identity"
.field private static final IF_MODIFIED_SINCE:Ljava/lang/String; = "If-Modified-Since"
.field private static final IF_NONE_MATCH:Ljava/lang/String; = "If-None-Match"
.field private static final IF_RANGE:Ljava/lang/String; = "If-Range"
.field static final LAST_CACHE_VERIFICATION:Ljava/lang/String; = "Last-Cache-Verification"
.field static final LAST_DOWNLOAD:Ljava/lang/String; = "Last-Download"
.field static final LAST_MODIFIED:Ljava/lang/String; = "Last-Modified"
.field private static final LOAD_CONTEXT:Ljava/lang/String; = "AssetDownloader#load; loadAd sequence"
.field private static final MAX_PERCENT:J = 0x64L
.field private static final MAX_RECONNECT_ATTEMPTS:I = 0xa
.field private static final META_POSTFIX_EXT:Ljava/lang/String; = ".vng_meta"
.field private static final PROGRESS_STEP:I = 0x5
.field private static final RANGE:Ljava/lang/String; = "Range"
.field private static final RANGE_NOT_SATISFIABLE:I = 0x1a0
.field private static final RETRY_COUNT_ON_CONNECTION_LOST:I = 0x5
.field private static final TAG:Ljava/lang/String;
.field private static final TIMEOUT:I = 0x1e
.field public static final VERIFICATION_WINDOW:J
# instance fields
.field private final addLock:Ljava/lang/Object;
.field private final cache:Lcom/vungle/warren/downloader/DownloaderCache;
.field private final downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
.field private isCacheEnabled:Z
.field maxReconnectAttempts:I
.field private mediators:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Lcom/vungle/warren/downloader/DownloadRequestMediator;",
">;"
}
.end annotation
.end field
.field private final networkListener:Lcom/vungle/warren/utility/NetworkProvider$NetworkListener;
.field private final networkProvider:Lcom/vungle/warren/utility/NetworkProvider;
.field private final okHttpClient:Lokhttp3/z;
.field private volatile progressStep:I
.field reconnectTimeout:I
.field retryCountOnConnectionLost:I
.field private final timeWindow:J
.field private transitioning:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/vungle/warren/downloader/DownloadRequest;",
">;"
}
.end annotation
.end field
.field private final uiExecutor:Ljava/util/concurrent/ExecutorService;
# direct methods
.method static constructor <clinit>()V
.registers 3
.line 1
sget-object v0, Ljava/util/concurrent/TimeUnit;->HOURS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v1, 0x18
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v0
sput-wide v0, Lcom/vungle/warren/downloader/AssetDownloader;->VERIFICATION_WINDOW:J
.line 2
const-class v0, Lcom/vungle/warren/downloader/AssetDownloader;
invoke-virtual {v0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
return-void
.end method
.method public constructor <init>(ILcom/vungle/warren/utility/NetworkProvider;Ljava/util/concurrent/ExecutorService;)V
.registers 11
const/4 v1, 0x0
const-wide/16 v2, 0x0
move-object v0, p0
move v4, p1
move-object v5, p2
move-object v6, p3
.line 1
invoke-direct/range {v0 .. v6}, Lcom/vungle/warren/downloader/AssetDownloader;-><init>(Lcom/vungle/warren/downloader/DownloaderCache;JILcom/vungle/warren/utility/NetworkProvider;Ljava/util/concurrent/ExecutorService;)V
return-void
.end method
.method public constructor <init>(Lcom/vungle/warren/downloader/DownloaderCache;JILcom/vungle/warren/utility/NetworkProvider;Ljava/util/concurrent/ExecutorService;)V
.registers 16
.line 2
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x5
.line 3
iput v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->retryCountOnConnectionLost:I
const/16 v1, 0xa
.line 4
iput v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->maxReconnectAttempts:I
const/16 v1, 0x12c
.line 5
iput v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->reconnectTimeout:I
.line 6
new-instance v1, Ljava/util/concurrent/ConcurrentHashMap;
invoke-direct {v1}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V
iput-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
.line 7
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
iput-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
.line 8
new-instance v1, Ljava/lang/Object;
invoke-direct {v1}, Ljava/lang/Object;-><init>()V
iput-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->addLock:Ljava/lang/Object;
.line 9
iput v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->progressStep:I
const/4 v0, 0x1
.line 10
iput-boolean v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->isCacheEnabled:Z
.line 11
new-instance v1, Lcom/vungle/warren/downloader/AssetDownloader$3;
invoke-direct {v1, p0}, Lcom/vungle/warren/downloader/AssetDownloader$3;-><init>(Lcom/vungle/warren/downloader/AssetDownloader;)V
iput-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->networkListener:Lcom/vungle/warren/utility/NetworkProvider$NetworkListener;
.line 12
iput-object p1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
.line 13
invoke-static {p4, v0}, Ljava/lang/Math;->max(II)I
move-result v4
.line 14
new-instance p1, Ljava/util/concurrent/ThreadPoolExecutor;
sget-object v7, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
new-instance v8, Ljava/util/concurrent/PriorityBlockingQueue;
invoke-direct {v8}, Ljava/util/concurrent/PriorityBlockingQueue;-><init>()V
const-wide/16 v5, 0x1
move-object v2, p1
move v3, v4
invoke-direct/range {v2 .. v8}, Ljava/util/concurrent/ThreadPoolExecutor;-><init>(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;)V
.line 15
invoke-virtual {p1, v0}, Ljava/util/concurrent/ThreadPoolExecutor;->allowCoreThreadTimeOut(Z)V
.line 16
iput-wide p2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->timeWindow:J
.line 17
iput-object p1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
.line 18
iput-object p5, p0, Lcom/vungle/warren/downloader/AssetDownloader;->networkProvider:Lcom/vungle/warren/utility/NetworkProvider;
.line 19
iput-object p6, p0, Lcom/vungle/warren/downloader/AssetDownloader;->uiExecutor:Ljava/util/concurrent/ExecutorService;
.line 20
new-instance p1, Lokhttp3/z$a;
invoke-direct {p1}, Lokhttp3/z$a;-><init>()V
sget-object p2, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 p3, 0x1e
.line 21
invoke-virtual {p1, p3, p4, p2}, Lokhttp3/z$a;->b(JLjava/util/concurrent/TimeUnit;)Lokhttp3/z$a;
sget-object p2, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
.line 22
invoke-virtual {p1, p3, p4, p2}, Lokhttp3/z$a;->a(JLjava/util/concurrent/TimeUnit;)Lokhttp3/z$a;
const/4 p2, 0x0
.line 23
invoke-virtual {p1, p2}, Lokhttp3/z$a;->a(Lokhttp3/e;)Lokhttp3/z$a;
.line 24
invoke-virtual {p1, v0}, Lokhttp3/z$a;->a(Z)Lokhttp3/z$a;
.line 25
invoke-virtual {p1, v0}, Lokhttp3/z$a;->b(Z)Lokhttp3/z$a;
.line 26
invoke-virtual {p1}, Lokhttp3/z$a;->a()Lokhttp3/z;
move-result-object p1
iput-object p1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->okHttpClient:Lokhttp3/z;
return-void
.end method
.method static synthetic access$000(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->launchRequest(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
return-void
.end method
.method static synthetic access$100()Ljava/lang/String;
.registers 1
.line 1
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
return-object v0
.end method
.method static synthetic access$1000(Lcom/vungle/warren/downloader/AssetDownloader;Lokhttp3/H;)J
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->getContentLength(Lokhttp3/H;)J
move-result-wide p0
return-wide p0
.end method
.method static synthetic access$1100(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/io/File;Lokhttp3/H;Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/util/HashMap;)Z
.registers 5
.line 1
invoke-direct {p0, p1, p2, p3, p4}, Lcom/vungle/warren/downloader/AssetDownloader;->notModified(Ljava/io/File;Lokhttp3/H;Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/util/HashMap;)Z
move-result p0
return p0
.end method
.method static synthetic access$1200(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/io/File;Ljava/util/Map;I)Z
.registers 5
.line 1
invoke-direct {p0, p1, p2, p3, p4}, Lcom/vungle/warren/downloader/AssetDownloader;->useCacheOnFail(Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/io/File;Ljava/util/Map;I)Z
move-result p0
return p0
.end method
.method static synthetic access$1300(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/io/File;Ljava/util/HashMap;)V
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->saveMeta(Ljava/io/File;Ljava/util/HashMap;)V
return-void
.end method
.method static synthetic access$1400(Lcom/vungle/warren/downloader/AssetDownloader;JILokhttp3/H;Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
.registers 6
.line 1
invoke-direct/range {p0 .. p5}, Lcom/vungle/warren/downloader/AssetDownloader;->partialMalformed(JILokhttp3/H;Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
move-result p0
return p0
.end method
.method static synthetic access$1500(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/io/File;Ljava/io/File;Z)V
.registers 4
.line 1
invoke-direct {p0, p1, p2, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->deleteFileAndMeta(Ljava/io/File;Ljava/io/File;Z)V
return-void
.end method
.method static synthetic access$1600(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/io/File;Ljava/io/File;Lokhttp3/u;)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-direct {p0, p1, p2, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->checkEncoding(Ljava/io/File;Ljava/io/File;Lokhttp3/u;)V
return-void
.end method
.method static synthetic access$1700(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/io/File;Lokhttp3/u;Ljava/lang/String;)Ljava/util/HashMap;
.registers 4
.line 1
invoke-direct {p0, p1, p2, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->makeMeta(Ljava/io/File;Lokhttp3/u;Ljava/lang/String;)Ljava/util/HashMap;
move-result-object p0
return-object p0
.end method
.method static synthetic access$1800(Lcom/vungle/warren/downloader/AssetDownloader;Lokhttp3/H;)Lokhttp3/J;
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->decodeGzipIfNeeded(Lokhttp3/H;)Lokhttp3/J;
move-result-object p0
return-object p0
.end method
.method static synthetic access$1900(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;)V
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->onProgressMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;)V
return-void
.end method
.method static synthetic access$200(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
.registers 4
.line 1
invoke-direct {p0, p1, p2, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
return-void
.end method
.method static synthetic access$2000(Lcom/vungle/warren/downloader/AssetDownloader;)I
.registers 1
.line 1
iget p0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->progressStep:I
return p0
.end method
.method static synthetic access$2100(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/lang/Throwable;Z)I
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->mapExceptionToReason(Ljava/lang/Throwable;Z)I
move-result p0
return p0
.end method
.method static synthetic access$2200(Lcom/vungle/warren/downloader/AssetDownloader;J)V
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->sleep(J)V
return-void
.end method
.method static synthetic access$2300(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)Z
.registers 4
.line 1
invoke-direct {p0, p1, p2, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->pause(Lcom/vungle/warren/downloader/DownloadRequestMediator;Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)Z
move-result p0
return p0
.end method
.method static synthetic access$2400(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/io/File;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->onSuccessMediator(Ljava/io/File;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
return-void
.end method
.method static synthetic access$2500(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->onErrorMediator(Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
return-void
.end method
.method static synthetic access$2600(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->onCancelledMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
return-void
.end method
.method static synthetic access$2700(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->removeMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
return-void
.end method
.method static synthetic access$2800(Lcom/vungle/warren/downloader/AssetDownloader;)V
.registers 1
.line 1
invoke-direct {p0}, Lcom/vungle/warren/downloader/AssetDownloader;->removeNetworkListener()V
return-void
.end method
.method static synthetic access$2900(Lcom/vungle/warren/downloader/AssetDownloader;I)V
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->onNetworkChanged(I)V
return-void
.end method
.method static synthetic access$300(Lcom/vungle/warren/downloader/AssetDownloader;)Lcom/vungle/warren/downloader/DownloaderCache;
.registers 1
.line 1
iget-object p0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
return-object p0
.end method
.method static synthetic access$400(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
move-result-object p0
return-object p0
.end method
.method static synthetic access$500(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->isAnyConnected(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
move-result p0
return p0
.end method
.method static synthetic access$600(Lcom/vungle/warren/downloader/AssetDownloader;Ljava/io/File;)Ljava/util/HashMap;
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->extractMeta(Ljava/io/File;)Ljava/util/HashMap;
move-result-object p0
return-object p0
.end method
.method static synthetic access$700(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/io/File;Ljava/util/Map;)Z
.registers 4
.line 1
invoke-direct {p0, p1, p2, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->useCacheWithoutVerification(Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/io/File;Ljava/util/Map;)Z
move-result p0
return p0
.end method
.method static synthetic access$800(Lcom/vungle/warren/downloader/AssetDownloader;JLjava/io/File;Ljava/util/HashMap;Lokhttp3/C$a;)V
.registers 6
.line 1
invoke-direct/range {p0 .. p5}, Lcom/vungle/warren/downloader/AssetDownloader;->appendHeaders(JLjava/io/File;Ljava/util/HashMap;Lokhttp3/C$a;)V
return-void
.end method
.method static synthetic access$900(Lcom/vungle/warren/downloader/AssetDownloader;)Lokhttp3/z;
.registers 1
.line 1
iget-object p0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->okHttpClient:Lokhttp3/z;
return-object p0
.end method
.method private addNetworkListener()V
.registers 3
.line 1
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v1, "Adding network listner"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 2
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->networkProvider:Lcom/vungle/warren/utility/NetworkProvider;
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->networkListener:Lcom/vungle/warren/utility/NetworkProvider$NetworkListener;
invoke-virtual {v0, v1}, Lcom/vungle/warren/utility/NetworkProvider;->addListener(Lcom/vungle/warren/utility/NetworkProvider$NetworkListener;)V
return-void
.end method
.method private appendHeaders(JLjava/io/File;Ljava/util/HashMap;Lokhttp3/C$a;)V
.registers 10
.annotation system Ldalvik/annotation/Signature;
value = {
"(J",
"Ljava/io/File;",
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;",
"Lokhttp3/C$a;",
")V"
}
.end annotation
const-string v0, "identity"
const-string v1, "Accept-Encoding"
.line 1
invoke-virtual {p5, v1, v0}, Lokhttp3/C$a;->a(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/C$a;
.line 2
invoke-virtual {p3}, Ljava/io/File;->exists()Z
move-result p3
if-eqz p3, :cond_a0
invoke-virtual {p4}, Ljava/util/HashMap;->isEmpty()Z
move-result p3
if-eqz p3, :cond_15
goto/16 :goto_a0
:cond_15
const-string p3, "ETag"
.line 3
invoke-virtual {p4, p3}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p3
check-cast p3, Ljava/lang/String;
const-string v1, "Last-Modified"
.line 4
invoke-virtual {p4, v1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
const-string v2, "DOWNLOAD_COMPLETE"
.line 5
invoke-virtual {p4, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
invoke-static {v2}, Ljava/lang/Boolean;->parseBoolean(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_4a
.line 6
invoke-static {p3}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p1
if-nez p1, :cond_3e
const-string p1, "If-None-Match"
.line 7
invoke-virtual {p5, p1, p3}, Lokhttp3/C$a;->a(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/C$a;
.line 8
:cond_3e
invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p1
if-nez p1, :cond_49
const-string p1, "If-Modified-Since"
.line 9
invoke-virtual {p5, p1, v1}, Lokhttp3/C$a;->a(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/C$a;
:cond_49
return-void
:cond_4a
const-string v2, "Accept-Ranges"
.line 10
invoke-virtual {p4, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
const-string v3, "bytes"
invoke-virtual {v3, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v2
if-nez v2, :cond_5b
return-void
:cond_5b
const-string v2, "Content-Encoding"
.line 11
invoke-virtual {p4, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
if-eqz v3, :cond_70
.line 12
invoke-virtual {p4, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p4
check-cast p4, Ljava/lang/String;
invoke-virtual {v0, p4}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result p4
if-nez p4, :cond_70
return-void
.line 13
:cond_70
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "bytes="
invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4, p1, p2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string p1, "-"
invoke-virtual {p4, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "Range"
invoke-virtual {p5, p2, p1}, Lokhttp3/C$a;->a(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/C$a;
.line 14
invoke-static {p3}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p1
const-string p2, "If-Range"
if-nez p1, :cond_97
.line 15
invoke-virtual {p5, p2, p3}, Lokhttp3/C$a;->a(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/C$a;
goto :goto_a0
.line 16
:cond_97
invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p1
if-nez p1, :cond_a0
.line 17
invoke-virtual {p5, p2, v1}, Lokhttp3/C$a;->a(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/C$a;
:cond_a0
:goto_a0
return-void
.end method
.method private checkEncoding(Ljava/io/File;Ljava/io/File;Lokhttp3/u;)V
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const-string v0, "Content-Encoding"
.line 1
invoke-virtual {p3, v0}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object p3
if-eqz p3, :cond_38
const-string v1, "gzip"
.line 2
invoke-virtual {v1, p3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v1
if-nez v1, :cond_38
const-string v1, "identity"
.line 3
invoke-virtual {v1, p3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_19
goto :goto_38
:cond_19
const/4 v1, 0x0
.line 4
invoke-direct {p0, p1, p2, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->deleteFileAndMeta(Ljava/io/File;Ljava/io/File;Z)V
const/4 p1, 0x2
.line 5
new-array p1, p1, [Ljava/lang/Object;
aput-object v0, p1, v1
const/4 p2, 0x1
aput-object p3, p1, p2
const-string p2, "unknown %1$s %2$s "
.line 6
invoke-static {p2, p1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string p2, "AssetDownloader#checkEncoding; loadAd sequence"
.line 7
invoke-static {p2, p1}, Lcom/vungle/warren/VungleLogger;->error(Ljava/lang/String;Ljava/lang/String;)V
.line 8
new-instance p1, Ljava/io/IOException;
const-string p2, "Unknown Content-Encoding"
invoke-direct {p1, p2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
:cond_38
:goto_38
return-void
.end method
.method private copyToDestination(Ljava/io/File;Ljava/io/File;Landroidx/core/f/c;)V
.registers 15
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/File;",
"Ljava/io/File;",
"Landroidx/core/f/c<",
"Lcom/vungle/warren/downloader/DownloadRequest;",
"Lcom/vungle/warren/downloader/AssetDownloadListener;",
">;)V"
}
.end annotation
const-string v0, " copying to "
.line 1
invoke-virtual {p2}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_b
.line 2
invoke-static {p2}, Lcom/vungle/warren/utility/FileUtility;->deleteAndLogIfFailed(Ljava/io/File;)V
.line 3
:cond_b
invoke-virtual {p2}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v1
if-eqz v1, :cond_22
invoke-virtual {p2}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v1
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v1
if-nez v1, :cond_22
.line 4
invoke-virtual {p2}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v1
invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z
:cond_22
const/4 v1, 0x0
.line 5
:try_start_23
new-instance v2, Ljava/io/FileInputStream;
invoke-direct {v2, p1}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
:try_end_28
.catch Ljava/io/IOException; {:try_start_23 .. :try_end_28} :catch_7b
.catchall {:try_start_23 .. :try_end_28} :catchall_77
.line 6
:try_start_28
new-instance v3, Ljava/io/FileOutputStream;
invoke-direct {v3, p2}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
:try_end_2d
.catch Ljava/io/IOException; {:try_start_28 .. :try_end_2d} :catch_72
.catchall {:try_start_28 .. :try_end_2d} :catchall_6e
.line 7
:try_start_2d
invoke-virtual {v2}, Ljava/io/FileInputStream;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v4
.line 8
invoke-virtual {v3}, Ljava/io/FileOutputStream;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v9
const-wide/16 v5, 0x0
.line 9
invoke-virtual {v4}, Ljava/nio/channels/FileChannel;->size()J
move-result-wide v7
invoke-virtual/range {v4 .. v9}, Ljava/nio/channels/FileChannel;->transferTo(JJLjava/nio/channels/WritableByteChannel;)J
.line 10
sget-object v1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Copying: finished "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p3, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v5, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object v5, v5, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v1, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:try_end_64
.catch Ljava/io/IOException; {:try_start_2d .. :try_end_64} :catch_6c
.catchall {:try_start_2d .. :try_end_64} :catchall_e0
.line 11
:goto_64
invoke-static {v2}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V
.line 12
invoke-static {v3}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V
goto/16 :goto_df
:catch_6c
move-exception v1
goto :goto_7f
:catchall_6e
move-exception p1
move-object v3, v1
goto/16 :goto_e1
:catch_72
move-exception v3
move-object v10, v3
move-object v3, v1
move-object v1, v10
goto :goto_7f
:catchall_77
move-exception p1
move-object v2, v1
move-object v3, v2
goto :goto_e1
:catch_7b
move-exception v2
move-object v3, v1
move-object v1, v2
move-object v2, v3
:goto_7f
:try_start_7f
const-string v4, "AssetDownloader#copyToDestination; loadAd sequence"
const-string v5, "cannot copy from %1$s(%2$s) to %3$s due to %4$s"
const/4 v6, 0x4
.line 13
new-array v6, v6, [Ljava/lang/Object;
const/4 v7, 0x0
.line 14
invoke-virtual {p1}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object p1
aput-object p1, v6, v7
const/4 p1, 0x1
iget-object v7, p3, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v7, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object v7, v7, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
aput-object v7, v6, p1
invoke-virtual {p2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object p1
const/4 v7, 0x2
aput-object p1, v6, v7
const/4 p1, 0x3
aput-object v1, v6, p1
.line 15
invoke-static {v5, v6}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
.line 16
invoke-static {v4, p1}, Lcom/vungle/warren/VungleLogger;->error(Ljava/lang/String;Ljava/lang/String;)V
.line 17
iget-object p1, p3, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast p1, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object v4, p3, Landroidx/core/f/c;->b:Ljava/lang/Object;
check-cast v4, Lcom/vungle/warren/downloader/AssetDownloadListener;
new-instance v5, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;
const/4 v6, -0x1
invoke-direct {v5, v6, v1, v7}, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;-><init>(ILjava/lang/Throwable;I)V
invoke-direct {p0, p1, v4, v5}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
.line 18
sget-object p1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Copying: error"
invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p3, p3, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast p3, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object p3, p3, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object p2
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {p1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:try_end_de
.catchall {:try_start_7f .. :try_end_de} :catchall_e0
goto :goto_64
:goto_df
return-void
:catchall_e0
move-exception p1
.line 19
:goto_e1
invoke-static {v2}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V
.line 20
invoke-static {v3}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V
.line 21
goto :goto_e9
:goto_e8
throw p1
:goto_e9
goto :goto_e8
.end method
.method private debugString(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
.registers 4
.line 3
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, ", single request url - "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ", path - "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->path:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ", th - "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 4
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "id "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->id:Ljava/lang/String;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private debugString(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
.registers 4
.line 1
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, ", mediator url - "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->url:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ", path - "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->filePath:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ", th - "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 2
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "id "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private decodeGzipIfNeeded(Lokhttp3/H;)Lokhttp3/J;
.registers 6
const-string v0, "Content-Encoding"
.line 1
invoke-virtual {p1, v0}, Lokhttp3/H;->a(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
const-string v1, "gzip"
invoke-virtual {v1, v0}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_39
.line 2
invoke-static {p1}, Lokhttp3/internal/http/e;->b(Lokhttp3/H;)Z
move-result v0
if-eqz v0, :cond_39
.line 3
invoke-virtual {p1}, Lokhttp3/H;->b()Lokhttp3/J;
move-result-object v0
if-eqz v0, :cond_39
.line 4
new-instance v0, Lokio/GzipSource;
invoke-virtual {p1}, Lokhttp3/H;->b()Lokhttp3/J;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/J;->source()Lokio/BufferedSource;
move-result-object v1
invoke-direct {v0, v1}, Lokio/GzipSource;-><init>(Lokio/Source;)V
const-string v1, "Content-Type"
.line 5
invoke-virtual {p1, v1}, Lokhttp3/H;->a(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 6
new-instance v1, Lokhttp3/internal/http/h;
const-wide/16 v2, -0x1
invoke-static {v0}, Lokio/Okio;->buffer(Lokio/Source;)Lokio/BufferedSource;
move-result-object v0
invoke-direct {v1, p1, v2, v3, v0}, Lokhttp3/internal/http/h;-><init>(Ljava/lang/String;JLokio/BufferedSource;)V
return-object v1
.line 7
:cond_39
invoke-virtual {p1}, Lokhttp3/H;->b()Lokhttp3/J;
move-result-object p1
return-object p1
.end method
.method private deleteFileAndMeta(Ljava/io/File;Ljava/io/File;Z)V
.registers 4
if-nez p1, :cond_3
return-void
.line 1
:cond_3
invoke-static {p1}, Lcom/vungle/warren/utility/FileUtility;->deleteAndLogIfFailed(Ljava/io/File;)V
if-eqz p2, :cond_b
.line 2
invoke-static {p2}, Lcom/vungle/warren/utility/FileUtility;->deleteAndLogIfFailed(Ljava/io/File;)V
.line 3
:cond_b
iget-object p2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
if-eqz p2, :cond_22
invoke-virtual {p0}, Lcom/vungle/warren/downloader/AssetDownloader;->isCacheEnabled()Z
move-result p2
if-eqz p2, :cond_22
if-eqz p3, :cond_1d
.line 4
iget-object p2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {p2, p1}, Lcom/vungle/warren/downloader/DownloaderCache;->deleteAndRemove(Ljava/io/File;)Z
goto :goto_22
.line 5
:cond_1d
iget-object p2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {p2, p1}, Lcom/vungle/warren/downloader/DownloaderCache;->deleteContents(Ljava/io/File;)Z
:cond_22
:goto_22
return-void
.end method
.method private deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
.registers 7
const/4 v0, 0x2
.line 1
new-array v0, v0, [Ljava/lang/Object;
const/4 v1, 0x0
aput-object p3, v0, v1
if-eqz p1, :cond_d
.line 2
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object v1
goto :goto_f
:cond_d
const-string v1, "null"
:goto_f
const/4 v2, 0x1
aput-object v1, v0, v2
const-string v1, "Delivering error %1$s; request %2$s"
.line 3
invoke-static {v1, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
const-string v1, "AssetDownloader#deliverError; loadAd sequence"
.line 4
invoke-static {v1, v0}, Lcom/vungle/warren/VungleLogger;->error(Ljava/lang/String;Ljava/lang/String;)V
if-eqz p2, :cond_29
.line 5
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->uiExecutor:Ljava/util/concurrent/ExecutorService;
new-instance v1, Lcom/vungle/warren/downloader/AssetDownloader$4;
invoke-direct {v1, p0, p2, p3, p1}, Lcom/vungle/warren/downloader/AssetDownloader$4;-><init>(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;Lcom/vungle/warren/downloader/DownloadRequest;)V
invoke-interface {v0, v1}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
:cond_29
return-void
.end method
.method private deliverProgress(Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
.registers 6
if-eqz p3, :cond_c
.line 1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->uiExecutor:Ljava/util/concurrent/ExecutorService;
new-instance v1, Lcom/vungle/warren/downloader/AssetDownloader$5;
invoke-direct {v1, p0, p2, p3, p1}, Lcom/vungle/warren/downloader/AssetDownloader$5;-><init>(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;)V
invoke-interface {v0, v1}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
:cond_c
return-void
.end method
.method private deliverSuccess(Landroidx/core/f/c;Ljava/io/File;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroidx/core/f/c<",
"Lcom/vungle/warren/downloader/DownloadRequest;",
"Lcom/vungle/warren/downloader/AssetDownloadListener;",
">;",
"Ljava/io/File;",
")V"
}
.end annotation
.line 1
iget-object v0, p1, Landroidx/core/f/c;->b:Ljava/lang/Object;
if-eqz v0, :cond_d
.line 2
check-cast v0, Lcom/vungle/warren/downloader/AssetDownloadListener;
iget-object p1, p1, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast p1, Lcom/vungle/warren/downloader/DownloadRequest;
invoke-interface {v0, p2, p1}, Lcom/vungle/warren/downloader/AssetDownloadListener;->onSuccess(Ljava/io/File;Lcom/vungle/warren/downloader/DownloadRequest;)V
:cond_d
return-void
.end method
.method private extractMeta(Ljava/io/File;)Ljava/util/HashMap;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/File;",
")",
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.line 1
invoke-virtual {p1}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Lcom/vungle/warren/utility/FileUtility;->readMap(Ljava/lang/String;)Ljava/util/HashMap;
move-result-object p1
return-object p1
.end method
.method private declared-synchronized findMediatorForCancellation(Lcom/vungle/warren/downloader/DownloadRequest;)Lcom/vungle/warren/downloader/DownloadRequestMediator;
.registers 6
monitor-enter p0
.line 1
:try_start_1
new-instance v0, Ljava/util/ArrayList;
const/4 v1, 0x2
invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(I)V
.line 2
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->getCacheableKey(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 3
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->getNonCacheableKey(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 4
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_25
:goto_25
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_50
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;
if-nez v1, :cond_34
goto :goto_25
.line 5
:cond_34
invoke-virtual {v1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->requests()Ljava/util/List;
move-result-object v2
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:cond_3c
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v3
if-eqz v3, :cond_25
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/vungle/warren/downloader/DownloadRequest;
.line 6
invoke-virtual {v3, p1}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v3
:try_end_4c
.catchall {:try_start_1 .. :try_end_4c} :catchall_53
if-eqz v3, :cond_3c
.line 7
monitor-exit p0
return-object v1
:cond_50
const/4 p1, 0x0
.line 8
monitor-exit p0
return-object p1
:catchall_53
move-exception p1
monitor-exit p0
goto :goto_57
:goto_56
throw p1
:goto_57
goto :goto_56
.end method
.method private getCacheableKey(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
.registers 2
.line 1
iget-object p1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
return-object p1
.end method
.method private getContentLength(Lokhttp3/H;)J
.registers 5
const-wide/16 v0, -0x1
if-nez p1, :cond_5
return-wide v0
.line 1
:cond_5
invoke-virtual {p1}, Lokhttp3/H;->o()Lokhttp3/u;
move-result-object p1
const-string v2, "Content-Length"
invoke-virtual {p1, v2}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 2
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_16
return-wide v0
.line 3
:cond_16
:try_start_16
invoke-static {p1}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v0
:try_end_1a
.catch Ljava/lang/Throwable; {:try_start_16 .. :try_end_1a} :catch_1a
:catch_1a
return-wide v0
.end method
.method private getNonCacheableKey(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
.registers 4
.line 1
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->path:Ljava/lang/String;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private isAnyConnected(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
.registers 4
.line 1
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->requests()Ljava/util/List;
move-result-object p1
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:cond_8
:goto_8
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_26
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/vungle/warren/downloader/DownloadRequest;
if-nez v0, :cond_1e
.line 2
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v1, "Request is null"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_8
.line 3
:cond_1e
invoke-direct {p0, v0}, Lcom/vungle/warren/downloader/AssetDownloader;->isConnected(Lcom/vungle/warren/downloader/DownloadRequest;)Z
move-result v0
if-eqz v0, :cond_8
const/4 p1, 0x1
return p1
:cond_26
const/4 p1, 0x0
return p1
.end method
.method private isConnected(Lcom/vungle/warren/downloader/DownloadRequest;)Z
.registers 7
.annotation build Landroid/annotation/TargetApi;
value = 0x15
.end annotation
.line 1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->networkProvider:Lcom/vungle/warren/utility/NetworkProvider;
invoke-virtual {v0}, Lcom/vungle/warren/utility/NetworkProvider;->getCurrentNetworkType()I
move-result v0
const/4 v1, 0x1
if-ltz v0, :cond_f
.line 2
iget v2, p1, Lcom/vungle/warren/downloader/DownloadRequest;->networkType:I
const/4 v3, 0x3
if-ne v2, v3, :cond_f
return v1
:cond_f
if-eqz v0, :cond_28
if-eq v0, v1, :cond_26
const/4 v2, 0x4
if-eq v0, v2, :cond_28
const/16 v2, 0x9
if-eq v0, v2, :cond_26
const/16 v2, 0x11
if-eq v0, v2, :cond_28
const/4 v2, 0x6
if-eq v0, v2, :cond_26
const/4 v2, 0x7
if-eq v0, v2, :cond_28
const/4 v2, -0x1
goto :goto_29
:cond_26
const/4 v2, 0x2
goto :goto_29
:cond_28
const/4 v2, 0x1
:goto_29
if-lez v2, :cond_31
.line 3
iget v3, p1, Lcom/vungle/warren/downloader/DownloadRequest;->networkType:I
and-int/2addr v3, v2
if-ne v3, v2, :cond_31
goto :goto_32
:cond_31
const/4 v1, 0x0
.line 4
:goto_32
sget-object v2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "checking pause for type: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v0, " connected "
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
.line 5
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 6
invoke-static {v2, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
return v1
.end method
.method private launchRequest(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
.registers 10
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->addLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
monitor-enter p0
:try_end_4
.catchall {:try_start_3 .. :try_end_4} :catchall_e6
.line 3
:try_start_4
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequest;->isCancelled()Z
move-result v1
const/4 v2, 0x1
const/4 v3, -0x1
const/4 v4, 0x3
if-eqz v1, :cond_48
.line 4
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {v1, p1}, Ljava/util/List;->remove(Ljava/lang/Object;)Z
.line 5
sget-object v1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "Request "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v6, p1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v6, " is cancelled before starting"
invoke-virtual {v5, v6}, 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-static {v1, v5}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 6
new-instance v1, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;
invoke-direct {v1}, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;-><init>()V
.line 7
iput v4, v1, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;->status:I
.line 8
new-instance v1, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;
new-instance v4, Ljava/io/IOException;
const-string v5, "Cancelled"
invoke-direct {v4, v5}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
invoke-direct {v1, v3, v4, v2}, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;-><init>(ILjava/lang/Throwable;I)V
invoke-direct {p0, p1, p2, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
.line 9
monitor-exit p0
:try_end_46
.catchall {:try_start_4 .. :try_end_46} :catchall_e3
:try_start_46
monitor-exit v0
:try_end_47
.catchall {:try_start_46 .. :try_end_47} :catchall_e6
return-void
.line 10
:cond_48
:try_start_48
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->mediatorKeyFromRequest(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object v5
invoke-interface {v1, v5}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;
if-nez v1, :cond_6c
.line 11
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {v1, p1}, Ljava/util/List;->remove(Ljava/lang/Object;)Z
.line 12
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->makeNewMediator(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)Lcom/vungle/warren/downloader/DownloadRequestMediator;
move-result-object p1
.line 13
iget-object p2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->key:Ljava/lang/String;
invoke-interface {p2, v1, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 14
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->load(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.line 15
monitor-exit p0
:try_end_6a
.catchall {:try_start_48 .. :try_end_6a} :catchall_e3
:try_start_6a
monitor-exit v0
:try_end_6b
.catchall {:try_start_6a .. :try_end_6b} :catchall_e6
return-void
.line 16
:cond_6c
:try_start_6c
monitor-exit p0
:try_end_6d
.catchall {:try_start_6c .. :try_end_6d} :catchall_e3
.line 17
:try_start_6d
invoke-virtual {v1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->lock()V
.line 18
monitor-enter p0
:try_end_71
.catchall {:try_start_6d .. :try_end_71} :catchall_de
.line 19
:try_start_71
iget-object v5, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {v5, p1}, Ljava/util/List;->remove(Ljava/lang/Object;)Z
const/4 v5, 0x6
.line 20
invoke-virtual {v1, v5}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->is(I)Z
move-result v5
if-nez v5, :cond_c7
.line 21
invoke-virtual {v1, v4}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->is(I)Z
move-result v4
if-eqz v4, :cond_8a
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequest;->isCancelled()Z
move-result v4
if-nez v4, :cond_8a
goto :goto_c7
.line 22
:cond_8a
iget-boolean v4, v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->isCacheable:Z
if-eqz v4, :cond_9c
.line 23
invoke-virtual {v1, p1, p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->add(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
const/4 p1, 0x2
.line 24
invoke-virtual {v1, p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->is(I)Z
move-result p1
if-eqz p1, :cond_d5
.line 25
invoke-direct {p0, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->load(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
goto :goto_d5
:cond_9c
const-string v4, "AssetDownloader#launchRequest; loadAd sequence"
.line 26
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "request "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v6, " is already running"
invoke-virtual {v5, v6}, 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-static {v4, v5}, Lcom/vungle/warren/VungleLogger;->warn(Ljava/lang/String;Ljava/lang/String;)V
.line 27
new-instance v4, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;
new-instance v5, Ljava/lang/IllegalArgumentException;
const-string v6, "DownloadRequest is already running"
invoke-direct {v5, v6}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
invoke-direct {v4, v3, v5, v2}, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;-><init>(ILjava/lang/Throwable;I)V
invoke-direct {p0, p1, p2, v4}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
goto :goto_d5
.line 28
:cond_c7
:goto_c7
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->makeNewMediator(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)Lcom/vungle/warren/downloader/DownloadRequestMediator;
move-result-object p1
.line 29
iget-object p2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
iget-object v2, v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->key:Ljava/lang/String;
invoke-interface {p2, v2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 30
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->load(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.line 31
:cond_d5
:goto_d5
monitor-exit p0
:try_end_d6
.catchall {:try_start_71 .. :try_end_d6} :catchall_db
.line 32
:try_start_d6
invoke-virtual {v1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->unlock()V
.line 33
monitor-exit v0
:try_end_da
.catchall {:try_start_d6 .. :try_end_da} :catchall_e6
return-void
:catchall_db
move-exception p1
.line 34
:try_start_dc
monitor-exit p0
:try_end_dd
.catchall {:try_start_dc .. :try_end_dd} :catchall_db
:try_start_dd
throw p1
:try_end_de
.catchall {:try_start_dd .. :try_end_de} :catchall_de
:catchall_de
move-exception p1
.line 35
:try_start_df
invoke-virtual {v1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->unlock()V
.line 36
throw p1
:try_end_e3
.catchall {:try_start_df .. :try_end_e3} :catchall_e6
:catchall_e3
move-exception p1
.line 37
:try_start_e4
monitor-exit p0
:try_end_e5
.catchall {:try_start_e4 .. :try_end_e5} :catchall_e3
:try_start_e5
throw p1
:catchall_e6
move-exception p1
.line 38
monitor-exit v0
:try_end_e8
.catchall {:try_start_e5 .. :try_end_e8} :catchall_e6
throw p1
.end method
.method private declared-synchronized load(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 4
monitor-enter p0
.line 1
:try_start_1
invoke-direct {p0}, Lcom/vungle/warren/downloader/AssetDownloader;->addNetworkListener()V
const/4 v0, 0x1
.line 2
invoke-virtual {p1, v0}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->set(I)V
.line 3
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
new-instance v1, Lcom/vungle/warren/downloader/AssetDownloader$2;
invoke-direct {v1, p0, p1, p1}, Lcom/vungle/warren/downloader/AssetDownloader$2;-><init>(Lcom/vungle/warren/downloader/AssetDownloader;Lcom/vungle/warren/downloader/DownloadRequestMediator;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
invoke-virtual {v0, v1}, Ljava/util/concurrent/ThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V
:try_end_12
.catchall {:try_start_1 .. :try_end_12} :catchall_14
.line 4
monitor-exit p0
return-void
:catchall_14
move-exception p1
monitor-exit p0
throw p1
.end method
.method private makeMeta(Ljava/io/File;Lokhttp3/u;Ljava/lang/String;)Ljava/util/HashMap;
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/File;",
"Lokhttp3/u;",
"Ljava/lang/String;",
")",
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.line 1
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
const-string v1, "Download_URL"
.line 2
invoke-virtual {v0, v1, p3}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string p3, "ETag"
.line 3
invoke-virtual {p2, p3}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, p3, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string p3, "Last-Modified"
.line 4
invoke-virtual {p2, p3}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, p3, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string p3, "Accept-Ranges"
.line 5
invoke-virtual {p2, p3}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, p3, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string p3, "Content-Encoding"
.line 6
invoke-virtual {p2, p3}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object p2
invoke-virtual {v0, p3, p2}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 7
invoke-direct {p0, p1, v0}, Lcom/vungle/warren/downloader/AssetDownloader;->saveMeta(Ljava/io/File;Ljava/util/HashMap;)V
return-object v0
.end method
.method private makeNewMediator(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)Lcom/vungle/warren/downloader/DownloadRequestMediator;
.registers 13
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-virtual {p0}, Lcom/vungle/warren/downloader/AssetDownloader;->isCacheEnabled()Z
move-result v0
if-nez v0, :cond_43
.line 2
new-instance v0, Ljava/io/File;
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->path:Ljava/lang/String;
invoke-direct {v0, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 3
new-instance v1, Ljava/io/File;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, ".vng_meta"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 4
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
iget-object v3, p1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p1, Lcom/vungle/warren/downloader/DownloadRequest;->path:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
const/4 v3, 0x0
move-object v8, v2
const/4 v7, 0x0
goto :goto_56
.line 5
:cond_43
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
iget-object v1, p1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-interface {v0, v1}, Lcom/vungle/warren/downloader/DownloaderCache;->getFile(Ljava/lang/String;)Ljava/io/File;
move-result-object v0
.line 6
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {v1, v0}, Lcom/vungle/warren/downloader/DownloaderCache;->getMetaFile(Ljava/io/File;)Ljava/io/File;
move-result-object v1
const/4 v3, 0x1
.line 7
iget-object v2, p1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
move-object v8, v2
const/4 v7, 0x1
.line 8
:goto_56
sget-object v2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Destination file "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 9
new-instance v9, Lcom/vungle/warren/downloader/DownloadRequestMediator;
.line 10
invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v5
.line 11
invoke-virtual {v1}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v6
move-object v2, v9
move-object v3, p1
move-object v4, p2
invoke-direct/range {v2 .. v8}, Lcom/vungle/warren/downloader/DownloadRequestMediator;-><init>(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Ljava/lang/String;Ljava/lang/String;ZLjava/lang/String;)V
return-object v9
.end method
.method private mapExceptionToReason(Ljava/lang/Throwable;Z)I
.registers 4
.line 1
instance-of v0, p1, Ljava/lang/RuntimeException;
if-eqz v0, :cond_6
const/4 p1, 0x4
goto :goto_1f
:cond_6
if-eqz p2, :cond_1e
.line 2
instance-of p2, p1, Ljava/net/SocketException;
if-nez p2, :cond_1e
instance-of p2, p1, Ljava/net/SocketTimeoutException;
if-eqz p2, :cond_11
goto :goto_1e
.line 3
:cond_11
instance-of p2, p1, Ljava/net/UnknownHostException;
if-nez p2, :cond_1c
instance-of p1, p1, Ljavax/net/ssl/SSLException;
if-eqz p1, :cond_1a
goto :goto_1c
:cond_1a
const/4 p1, 0x2
goto :goto_1f
:cond_1c
:goto_1c
const/4 p1, 0x1
goto :goto_1f
:cond_1e
:goto_1e
const/4 p1, 0x0
:goto_1f
return p1
.end method
.method private mediatorKeyFromRequest(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
.registers 3
.line 1
invoke-virtual {p0}, Lcom/vungle/warren/downloader/AssetDownloader;->isCacheEnabled()Z
move-result v0
if-eqz v0, :cond_b
.line 2
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->getCacheableKey(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object p1
goto :goto_f
.line 3
:cond_b
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->getNonCacheableKey(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object p1
:goto_f
return-object p1
.end method
.method private notModified(Ljava/io/File;Lokhttp3/H;Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/util/HashMap;)Z
.registers 10
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/File;",
"Lokhttp3/H;",
"Lcom/vungle/warren/downloader/DownloadRequestMediator;",
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)Z"
}
.end annotation
const/4 v0, 0x0
if-eqz p2, :cond_4a
.line 1
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_4a
invoke-virtual {p1}, Ljava/io/File;->length()J
move-result-wide v1
const-wide/16 v3, 0x0
cmp-long p1, v1, v3
if-lez p1, :cond_4a
iget-boolean p1, p3, Lcom/vungle/warren/downloader/DownloadRequestMediator;->isCacheable:Z
if-nez p1, :cond_18
goto :goto_4a
.line 2
:cond_18
invoke-virtual {p2}, Lokhttp3/H;->g()I
move-result p1
const-string p2, "DOWNLOAD_COMPLETE"
.line 3
invoke-virtual {p4, p2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
invoke-static {p2}, Ljava/lang/Boolean;->parseBoolean(Ljava/lang/String;)Z
move-result p2
if-eqz p2, :cond_4a
const/16 p2, 0x130
if-ne p1, p2, :cond_4a
.line 4
sget-object p1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "304 code, data size matches file size "
invoke-virtual {p2, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-direct {p0, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
move-result-object p3
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {p1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
const/4 p1, 0x1
return p1
:cond_4a
:goto_4a
return v0
.end method
.method private onCancelled(Lcom/vungle/warren/downloader/DownloadRequest;)V
.registers 6
.line 1
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequest;->isCancelled()Z
move-result v0
if-eqz v0, :cond_7
return-void
.line 2
:cond_7
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequest;->cancel()V
.line 3
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->findMediatorForCancellation(Lcom/vungle/warren/downloader/DownloadRequest;)Lcom/vungle/warren/downloader/DownloadRequestMediator;
move-result-object v0
if-eqz v0, :cond_46
.line 4
invoke-virtual {v0}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->getStatus()I
move-result v1
const/4 v2, 0x3
if-eq v1, v2, :cond_46
.line 5
invoke-virtual {v0, p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->remove(Lcom/vungle/warren/downloader/DownloadRequest;)Landroidx/core/f/c;
move-result-object p1
const/4 v1, 0x0
if-nez p1, :cond_20
move-object v3, v1
goto :goto_24
.line 6
:cond_20
iget-object v3, p1, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v3, Lcom/vungle/warren/downloader/DownloadRequest;
:goto_24
if-nez p1, :cond_27
goto :goto_2c
.line 7
:cond_27
iget-object p1, p1, Landroidx/core/f/c;->b:Ljava/lang/Object;
move-object v1, p1
check-cast v1, Lcom/vungle/warren/downloader/AssetDownloadListener;
.line 8
:goto_2c
invoke-virtual {v0}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->values()Ljava/util/List;
move-result-object p1
invoke-interface {p1}, Ljava/util/List;->isEmpty()Z
move-result p1
if-eqz p1, :cond_39
.line 9
invoke-virtual {v0, v2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->set(I)V
:cond_39
if-nez v3, :cond_3c
return-void
.line 10
:cond_3c
new-instance p1, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;
invoke-direct {p1}, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;-><init>()V
.line 11
iput v2, p1, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;->status:I
.line 12
invoke-direct {p0, p1, v3, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverProgress(Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
.line 13
:cond_46
invoke-direct {p0}, Lcom/vungle/warren/downloader/AssetDownloader;->removeNetworkListener()V
return-void
.end method
.method private declared-synchronized onCancelledMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 3
monitor-enter p0
.line 1
:try_start_1
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->requests()Ljava/util/List;
move-result-object p1
.line 2
invoke-interface {p1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_9
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_19
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/vungle/warren/downloader/DownloadRequest;
.line 3
invoke-direct {p0, v0}, Lcom/vungle/warren/downloader/AssetDownloader;->onCancelled(Lcom/vungle/warren/downloader/DownloadRequest;)V
:try_end_18
.catchall {:try_start_1 .. :try_end_18} :catchall_1b
goto :goto_9
.line 4
:cond_19
monitor-exit p0
return-void
:catchall_1b
move-exception p1
monitor-exit p0
goto :goto_1f
:goto_1e
throw p1
:goto_1f
goto :goto_1e
.end method
.method private onErrorMediator(Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 6
const/4 v0, 0x2
.line 1
new-array v0, v0, [Ljava/lang/Object;
const/4 v1, 0x0
aput-object p1, v0, v1
.line 2
invoke-direct {p0, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
move-result-object v1
const/4 v2, 0x1
aput-object v1, v0, v2
const-string v1, "Error %1$s occured; mediator %2$s"
.line 3
invoke-static {v1, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
const-string v1, "AssetDownloader#onErrorMediator; loadAd sequence"
.line 4
invoke-static {v1, v0}, Lcom/vungle/warren/VungleLogger;->error(Ljava/lang/String;Ljava/lang/String;)V
if-nez p1, :cond_26
.line 5
new-instance p1, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;
const/4 v0, -0x1
new-instance v1, Ljava/lang/RuntimeException;
invoke-direct {v1}, Ljava/lang/RuntimeException;-><init>()V
const/4 v2, 0x4
invoke-direct {p1, v0, v1, v2}, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;-><init>(ILjava/lang/Throwable;I)V
.line 6
:cond_26
:try_start_26
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->lock()V
.line 7
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->values()Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_31
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_49
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/core/f/c;
.line 8
iget-object v2, v1, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v2, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object v1, v1, Landroidx/core/f/c;->b:Ljava/lang/Object;
check-cast v1, Lcom/vungle/warren/downloader/AssetDownloadListener;
invoke-direct {p0, v2, v1, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
goto :goto_31
.line 9
:cond_49
invoke-direct {p0, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->removeMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
const/4 p1, 0x6
.line 10
invoke-virtual {p2, p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->set(I)V
:try_end_50
.catchall {:try_start_26 .. :try_end_50} :catchall_54
.line 11
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->unlock()V
return-void
:catchall_54
move-exception p1
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->unlock()V
.line 12
goto :goto_5a
:goto_59
throw p1
:goto_5a
goto :goto_59
.end method
.method private declared-synchronized onNetworkChanged(I)V
.registers 8
monitor-enter p0
.line 1
:try_start_1
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Num of connections: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-interface {v2}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v2
invoke-interface {v2}, Ljava/util/Collection;->size()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 2
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_2b
:goto_2b
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_9e
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;
const/4 v2, 0x3
.line 3
invoke-virtual {v1, v2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->is(I)Z
move-result v2
if-eqz v2, :cond_46
.line 4
sget-object v1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v2, "Result cancelled"
invoke-static {v1, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_2b
.line 5
:cond_46
invoke-direct {p0, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->isAnyConnected(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
move-result v2
.line 6
sget-object v3, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Connected = "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v5, " for "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v3, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 7
invoke-virtual {v1, v2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->setConnected(Z)V
.line 8
invoke-virtual {v1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->isPausable()Z
move-result v3
if-eqz v3, :cond_2b
if-eqz v2, :cond_2b
const/4 v2, 0x2
invoke-virtual {v1, v2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->is(I)Z
move-result v2
if-eqz v2, :cond_2b
.line 9
invoke-direct {p0, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->load(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.line 10
sget-object v2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "resumed "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->key:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, " "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v2, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:try_end_9d
.catchall {:try_start_1 .. :try_end_9d} :catchall_a0
goto :goto_2b
.line 11
:cond_9e
monitor-exit p0
return-void
:catchall_a0
move-exception p1
monitor-exit p0
goto :goto_a4
:goto_a3
throw p1
:goto_a4
goto :goto_a3
.end method
.method private onProgressMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;)V
.registers 7
if-nez p1, :cond_3
return-void
.line 1
:cond_3
invoke-static {p2}, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;->copy(Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;)Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;
move-result-object v0
.line 2
sget-object v1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Progress "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v3, p2, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;->progressPercent:I
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, " status "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p2, p2, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;->status:I
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, " "
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p2, p1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->filePath:Ljava/lang/String;
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {v1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 3
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->values()Ljava/util/List;
move-result-object p1
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_41
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result p2
if-eqz p2, :cond_59
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object p2
check-cast p2, Landroidx/core/f/c;
.line 4
iget-object v1, p2, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v1, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object p2, p2, Landroidx/core/f/c;->b:Ljava/lang/Object;
check-cast p2, Lcom/vungle/warren/downloader/AssetDownloadListener;
invoke-direct {p0, v0, v1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverProgress(Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
goto :goto_41
:cond_59
return-void
.end method
.method private onSuccessMediator(Ljava/io/File;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 9
.line 1
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "OnComplete - Removing connections and listener "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 2
:try_start_16
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->lock()V
.line 3
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->values()Ljava/util/List;
move-result-object v0
.line 4
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v1
if-nez v1, :cond_53
const-string v0, "AssetDownloader#onSuccessMediator; loadAd sequence"
const-string v1, "File %1$s does not exist; mediator %2$s "
const/4 v2, 0x2
.line 5
new-array v3, v2, [Ljava/lang/Object;
const/4 v4, 0x0
.line 6
invoke-virtual {p1}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object p1
aput-object p1, v3, v4
const/4 p1, 0x1
.line 7
invoke-direct {p0, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
move-result-object v4
aput-object v4, v3, p1
.line 8
invoke-static {v1, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
.line 9
invoke-static {v0, p1}, Lcom/vungle/warren/VungleLogger;->error(Ljava/lang/String;Ljava/lang/String;)V
.line 10
new-instance p1, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;
const/4 v0, -0x1
new-instance v1, Ljava/io/IOException;
const-string v3, "File is deleted"
invoke-direct {v1, v3}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
invoke-direct {p1, v0, v1, v2}, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;-><init>(ILjava/lang/Throwable;I)V
invoke-direct {p0, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->onErrorMediator(Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
:try_end_4f
.catchall {:try_start_16 .. :try_end_4f} :catchall_e5
.line 11
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->unlock()V
return-void
.line 12
:cond_53
:try_start_53
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
if-eqz v1, :cond_6e
iget-boolean v1, p2, Lcom/vungle/warren/downloader/DownloadRequestMediator;->isCacheable:Z
if-eqz v1, :cond_6e
.line 13
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v2
int-to-long v2, v2
invoke-interface {v1, p1, v2, v3}, Lcom/vungle/warren/downloader/DownloaderCache;->onCacheHit(Ljava/io/File;J)V
.line 14
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
invoke-interface {v1, p1, v2, v3}, Lcom/vungle/warren/downloader/DownloaderCache;->setCacheLastUpdateTimestamp(Ljava/io/File;J)V
.line 15
:cond_6e
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_72
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_c0
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/core/f/c;
.line 16
new-instance v2, Ljava/io/File;
iget-object v3, v1, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v3, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object v3, v3, Lcom/vungle/warren/downloader/DownloadRequest;->path:Ljava/lang/String;
invoke-direct {v2, v3}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 17
invoke-virtual {v2, p1}, Ljava/io/File;->equals(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_93
.line 18
invoke-direct {p0, p1, v2, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->copyToDestination(Ljava/io/File;Ljava/io/File;Landroidx/core/f/c;)V
goto :goto_94
:cond_93
move-object v2, p1
.line 19
:goto_94
sget-object v3, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Deliver success:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, v1, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v5, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object v5, v5, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, " dest file: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 20
invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 21
invoke-static {v3, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 22
invoke-direct {p0, v1, v2}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverSuccess(Landroidx/core/f/c;Ljava/io/File;)V
goto :goto_72
.line 23
:cond_c0
invoke-direct {p0, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->removeMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
const/4 p1, 0x6
.line 24
invoke-virtual {p2, p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->set(I)V
.line 25
sget-object p1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Finished "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-direct {p0, p2}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {p1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:try_end_e1
.catchall {:try_start_53 .. :try_end_e1} :catchall_e5
.line 26
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->unlock()V
return-void
:catchall_e5
move-exception p1
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->unlock()V
.line 27
goto :goto_eb
:goto_ea
throw p1
:goto_eb
goto :goto_ea
.end method
.method private partialMalformed(JILokhttp3/H;Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
.registers 7
const/16 v0, 0xce
if-ne p3, v0, :cond_a
.line 1
invoke-direct {p0, p4, p1, p2, p5}, Lcom/vungle/warren/downloader/AssetDownloader;->satisfiesPartialDownload(Lokhttp3/H;JLcom/vungle/warren/downloader/DownloadRequestMediator;)Z
move-result p1
if-eqz p1, :cond_e
:cond_a
const/16 p1, 0x1a0
if-ne p3, p1, :cond_10
:cond_e
const/4 p1, 0x1
goto :goto_11
:cond_10
const/4 p1, 0x0
:goto_11
return p1
.end method
.method private pause(Lcom/vungle/warren/downloader/DownloadRequestMediator;Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)Z
.registers 13
const/4 v0, 0x3
.line 1
invoke-virtual {p1, v0}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->is(I)Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_91
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->isAnyConnected(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Z
move-result v0
if-eqz v0, :cond_10
goto/16 :goto_91
:cond_10
const/4 v0, 0x2
.line 2
iput v0, p2, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;->status:I
.line 3
invoke-static {p2}, Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;->copy(Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;)Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;
move-result-object p2
.line 4
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->values()Ljava/util/List;
move-result-object v2
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
const/4 v3, 0x1
const/4 v4, 0x0
:goto_21
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v5
if-eqz v5, :cond_6d
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v5
check-cast v5, Landroidx/core/f/c;
.line 5
iget-object v6, v5, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v6, Lcom/vungle/warren/downloader/DownloadRequest;
if-nez v6, :cond_34
goto :goto_21
.line 6
:cond_34
iget-boolean v7, v6, Lcom/vungle/warren/downloader/DownloadRequest;->pauseOnConnectionLost:Z
if-nez v7, :cond_43
.line 7
invoke-virtual {p1, v6}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->remove(Lcom/vungle/warren/downloader/DownloadRequest;)Landroidx/core/f/c;
.line 8
iget-object v5, v5, Landroidx/core/f/c;->b:Ljava/lang/Object;
check-cast v5, Lcom/vungle/warren/downloader/AssetDownloadListener;
invoke-direct {p0, v6, v5, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
goto :goto_21
.line 9
:cond_43
invoke-virtual {p1, v0}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->set(I)V
.line 10
sget-object v4, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string v8, "Pausing download "
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-direct {p0, v6}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequest;)Ljava/lang/String;
move-result-object v6
invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v4, v6}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 11
iget-object v4, v5, Landroidx/core/f/c;->a:Ljava/lang/Object;
check-cast v4, Lcom/vungle/warren/downloader/DownloadRequest;
iget-object v5, v5, Landroidx/core/f/c;->b:Ljava/lang/Object;
check-cast v5, Lcom/vungle/warren/downloader/AssetDownloadListener;
invoke-direct {p0, p2, v4, v5}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverProgress(Lcom/vungle/warren/downloader/AssetDownloadListener$Progress;Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
const/4 v4, 0x1
goto :goto_21
:cond_6d
if-nez v4, :cond_73
const/4 p2, 0x5
.line 12
invoke-virtual {p1, p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->set(I)V
.line 13
:cond_73
sget-object p2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Attempted to pause - "
invoke-virtual {p3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->getStatus()I
move-result p1
if-ne p1, v0, :cond_86
const/4 v1, 0x1
:cond_86
invoke-virtual {p3, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p2, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
return v4
:cond_91
:goto_91
return v1
.end method
.method private declared-synchronized removeMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
.registers 3
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
iget-object p1, p1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->key:Ljava/lang/String;
invoke-interface {v0, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
:try_end_8
.catchall {:try_start_1 .. :try_end_8} :catchall_a
.line 2
monitor-exit p0
return-void
:catchall_a
move-exception p1
monitor-exit p0
throw p1
.end method
.method private removeNetworkListener()V
.registers 3
.line 1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-eqz v0, :cond_16
.line 2
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v1, "Removing listener"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 3
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->networkProvider:Lcom/vungle/warren/utility/NetworkProvider;
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->networkListener:Lcom/vungle/warren/utility/NetworkProvider$NetworkListener;
invoke-virtual {v0, v1}, Lcom/vungle/warren/utility/NetworkProvider;->removeListener(Lcom/vungle/warren/utility/NetworkProvider$NetworkListener;)V
:cond_16
return-void
.end method
.method private responseVersionMatches(Lokhttp3/H;Ljava/util/HashMap;)Z
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lokhttp3/H;",
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)Z"
}
.end annotation
.line 1
invoke-virtual {p1}, Lokhttp3/H;->o()Lokhttp3/u;
move-result-object p1
const-string v0, "ETag"
.line 2
invoke-virtual {p1, v0}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
const-string v2, "Last-Modified"
.line 3
invoke-virtual {p1, v2}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 4
sget-object v3, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "server etag: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v3, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 5
sget-object v3, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "server lastModified: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v3, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
const/4 v3, 0x0
if-eqz v1, :cond_66
.line 6
invoke-virtual {p2, v0}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v4
invoke-virtual {v1, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_66
.line 7
sget-object p1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "etags miss match current: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v0}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {p1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
return v3
:cond_66
if-eqz p1, :cond_8f
.line 8
invoke-virtual {p2, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-nez p1, :cond_8f
.line 9
sget-object p1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "lastModified miss match current: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {p1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
return v3
:cond_8f
const/4 p1, 0x1
return p1
.end method
.method private satisfiesPartialDownload(Lokhttp3/H;JLcom/vungle/warren/downloader/DownloadRequestMediator;)Z
.registers 9
.line 1
new-instance v0, Lcom/vungle/warren/downloader/RangeResponse;
invoke-virtual {p1}, Lokhttp3/H;->o()Lokhttp3/u;
move-result-object v1
const-string v2, "Content-Range"
invoke-virtual {v1, v2}, Lokhttp3/u;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Lcom/vungle/warren/downloader/RangeResponse;-><init>(Ljava/lang/String;)V
.line 2
invoke-virtual {p1}, Lokhttp3/H;->g()I
move-result p1
const/16 v1, 0xce
if-ne p1, v1, :cond_2f
iget-object p1, v0, Lcom/vungle/warren/downloader/RangeResponse;->dimension:Ljava/lang/String;
const-string v1, "bytes"
.line 3
invoke-virtual {v1, p1}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result p1
if-eqz p1, :cond_2f
iget-wide v0, v0, Lcom/vungle/warren/downloader/RangeResponse;->rangeStart:J
const-wide/16 v2, 0x0
cmp-long p1, v0, v2
if-ltz p1, :cond_2f
cmp-long p1, p2, v0
if-nez p1, :cond_2f
const/4 p1, 0x1
goto :goto_30
:cond_2f
const/4 p1, 0x0
.line 4
:goto_30
sget-object p2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "satisfies partial download: "
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v0, " "
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-direct {p0, p4}, Lcom/vungle/warren/downloader/AssetDownloader;->debugString(Lcom/vungle/warren/downloader/DownloadRequestMediator;)Ljava/lang/String;
move-result-object p4
invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p3
invoke-static {p2, p3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
return p1
.end method
.method private saveMeta(Ljava/io/File;Ljava/util/HashMap;)V
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/File;",
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)V"
}
.end annotation
.line 1
invoke-virtual {p1}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object p1
invoke-static {p1, p2}, Lcom/vungle/warren/utility/FileUtility;->writeMap(Ljava/lang/String;Ljava/util/HashMap;)V
return-void
.end method
.method private sleep(J)V
.registers 5
const-wide/16 v0, 0x0
.line 1
:try_start_2
invoke-static {v0, v1, p1, p2}, Ljava/lang/Math;->max(JJ)J
move-result-wide p1
invoke-static {p1, p2}, Ljava/lang/Thread;->sleep(J)V
:try_end_9
.catch Ljava/lang/InterruptedException; {:try_start_2 .. :try_end_9} :catch_a
goto :goto_19
:catch_a
move-exception p1
.line 2
sget-object p2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v0, "InterruptedException "
invoke-static {p2, v0, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 3
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/Thread;->interrupt()V
:goto_19
return-void
.end method
.method private useCacheOnFail(Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/io/File;Ljava/util/Map;I)Z
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/vungle/warren/downloader/DownloadRequestMediator;",
"Ljava/io/File;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;I)Z"
}
.end annotation
.line 1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
if-eqz v0, :cond_34
iget-boolean p1, p1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->isCacheable:Z
if-eqz p1, :cond_34
const/16 p1, 0xc8
if-eq p4, p1, :cond_34
const/16 p1, 0x1a0
if-eq p4, p1, :cond_34
const/16 p1, 0xce
if-eq p4, p1, :cond_34
const-string p1, "DOWNLOAD_COMPLETE"
.line 2
invoke-interface {p3, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/lang/String;
invoke-static {p1}, Ljava/lang/Boolean;->parseBoolean(Ljava/lang/String;)Z
move-result p1
if-eqz p1, :cond_34
.line 3
invoke-virtual {p2}, Ljava/io/File;->exists()Z
move-result p1
if-eqz p1, :cond_34
.line 4
invoke-virtual {p2}, Ljava/io/File;->length()J
move-result-wide p1
const-wide/16 p3, 0x0
cmp-long v0, p1, p3
if-lez v0, :cond_34
const/4 p1, 0x1
goto :goto_35
:cond_34
const/4 p1, 0x0
:goto_35
return p1
.end method
.method private useCacheWithoutVerification(Lcom/vungle/warren/downloader/DownloadRequestMediator;Ljava/io/File;Ljava/util/Map;)Z
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/vungle/warren/downloader/DownloadRequestMediator;",
"Ljava/io/File;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)Z"
}
.end annotation
const/4 v0, 0x0
if-eqz p3, :cond_45
.line 1
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
if-eqz v1, :cond_45
iget-boolean p1, p1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->isCacheable:Z
if-nez p1, :cond_c
goto :goto_45
:cond_c
const-string p1, "Last-Cache-Verification"
.line 2
invoke-interface {p3, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/lang/String;
if-eqz p1, :cond_45
.line 3
invoke-virtual {p2}, Ljava/io/File;->exists()Z
move-result p2
if-eqz p2, :cond_45
const-string p2, "DOWNLOAD_COMPLETE"
.line 4
invoke-interface {p3, p2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
invoke-static {p2}, Ljava/lang/Boolean;->parseBoolean(Ljava/lang/String;)Z
move-result p2
if-nez p2, :cond_2b
goto :goto_45
.line 5
:cond_2b
:try_start_2b
invoke-static {p1}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide p1
:try_end_2f
.catch Ljava/lang/NumberFormatException; {:try_start_2b .. :try_end_2f} :catch_45
.line 6
iget-wide v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->timeWindow:J
const-wide v3, 0x7fffffffffffffffL
sub-long/2addr v3, p1
cmp-long p3, v1, v3
if-gez p3, :cond_44
add-long/2addr p1, v1
.line 7
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
cmp-long p3, p1, v1
if-ltz p3, :cond_45
:cond_44
const/4 v0, 0x1
:catch_45
:cond_45
:goto_45
return v0
.end method
# virtual methods
.method public declared-synchronized cancel(Lcom/vungle/warren/downloader/DownloadRequest;)V
.registers 2
monitor-enter p0
if-nez p1, :cond_5
.line 1
monitor-exit p0
return-void
.line 2
:cond_5
:try_start_5
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->onCancelled(Lcom/vungle/warren/downloader/DownloadRequest;)V
:try_end_8
.catchall {:try_start_5 .. :try_end_8} :catchall_a
.line 3
monitor-exit p0
return-void
:catchall_a
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized cancelAll()V
.registers 6
monitor-enter p0
.line 1
:try_start_1
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v1, "Cancelling all"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 2
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_e
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_36
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/vungle/warren/downloader/DownloadRequest;
.line 3
sget-object v2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Cancel in transtiotion "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, v1, Lcom/vungle/warren/downloader/DownloadRequest;->url:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 4
invoke-virtual {p0, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->cancel(Lcom/vungle/warren/downloader/DownloadRequest;)V
goto :goto_e
.line 5
:cond_36
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Cancel in mediator "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-interface {v2}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v2
invoke-interface {v2}, Ljava/util/Collection;->size()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 6
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_60
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_88
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;
.line 7
sget-object v2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Cancel in mediator "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, v1, Lcom/vungle/warren/downloader/DownloadRequestMediator;->key:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 8
invoke-direct {p0, v1}, Lcom/vungle/warren/downloader/AssetDownloader;->onCancelledMediator(Lcom/vungle/warren/downloader/DownloadRequestMediator;)V
:try_end_87
.catchall {:try_start_1 .. :try_end_87} :catchall_8a
goto :goto_60
.line 9
:cond_88
monitor-exit p0
return-void
:catchall_8a
move-exception v0
monitor-exit p0
goto :goto_8e
:goto_8d
throw v0
:goto_8e
goto :goto_8d
.end method
.method public cancelAndAwait(Lcom/vungle/warren/downloader/DownloadRequest;J)Z
.registers 9
const/4 v0, 0x0
if-nez p1, :cond_4
return v0
.line 1
:cond_4
invoke-virtual {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->cancel(Lcom/vungle/warren/downloader/DownloadRequest;)V
.line 2
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
const-wide/16 v3, 0x0
invoke-static {v3, v4, p2, p3}, Ljava/lang/Math;->max(JJ)J
move-result-wide p2
add-long/2addr v1, p2
.line 3
:goto_12
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide p2
cmp-long v3, p2, v1
if-gez v3, :cond_40
.line 4
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->findMediatorForCancellation(Lcom/vungle/warren/downloader/DownloadRequest;)Lcom/vungle/warren/downloader/DownloadRequestMediator;
move-result-object p2
.line 5
monitor-enter p0
.line 6
:try_start_1f
iget-object p3, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {p3, p1}, Ljava/util/List;->contains(Ljava/lang/Object;)Z
move-result p3
if-nez p3, :cond_36
if-eqz p2, :cond_33
.line 7
invoke-virtual {p2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->requests()Ljava/util/List;
move-result-object p2
invoke-interface {p2, p1}, Ljava/util/List;->contains(Ljava/lang/Object;)Z
move-result p2
if-nez p2, :cond_36
:cond_33
const/4 p1, 0x1
.line 8
monitor-exit p0
return p1
.line 9
:cond_36
monitor-exit p0
:try_end_37
.catchall {:try_start_1f .. :try_end_37} :catchall_3d
const-wide/16 p2, 0xa
.line 10
invoke-direct {p0, p2, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->sleep(J)V
goto :goto_12
:catchall_3d
move-exception p1
.line 11
:try_start_3e
monitor-exit p0
:try_end_3f
.catchall {:try_start_3e .. :try_end_3f} :catchall_3d
throw p1
:cond_40
return v0
.end method
.method public declared-synchronized clearCache()V
.registers 2
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
if-eqz v0, :cond_a
.line 2
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {v0}, Lcom/vungle/warren/downloader/DownloaderCache;->clear()V
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_c
.line 3
:cond_a
monitor-exit p0
return-void
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized download(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
.registers 7
monitor-enter p0
if-nez p1, :cond_20
:try_start_3
const-string p1, "AssetDownloader#download; loadAd sequence"
const-string v0, "downloadRequest is null"
.line 1
invoke-static {p1, v0}, Lcom/vungle/warren/VungleLogger;->error(Ljava/lang/String;Ljava/lang/String;)V
if-eqz p2, :cond_1e
const/4 p1, 0x0
.line 2
new-instance v0, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;
const/4 v1, -0x1
new-instance v2, Ljava/lang/IllegalArgumentException;
const-string v3, "DownloadRequest is null"
invoke-direct {v2, v3}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
const/4 v3, 0x1
invoke-direct {v0, v1, v2, v3}, Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;-><init>(ILjava/lang/Throwable;I)V
invoke-direct {p0, p1, p2, v0}, Lcom/vungle/warren/downloader/AssetDownloader;->deliverError(Lcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;Lcom/vungle/warren/downloader/AssetDownloadListener$DownloadError;)V
:try_end_1e
.catchall {:try_start_3 .. :try_end_1e} :catchall_34
.line 3
:cond_1e
monitor-exit p0
return-void
.line 4
:cond_20
:try_start_20
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {v0, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 5
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
new-instance v1, Lcom/vungle/warren/downloader/AssetDownloader$1;
const v2, -0x7fffffff
invoke-direct {v1, p0, v2, p1, p2}, Lcom/vungle/warren/downloader/AssetDownloader$1;-><init>(Lcom/vungle/warren/downloader/AssetDownloader;ILcom/vungle/warren/downloader/DownloadRequest;Lcom/vungle/warren/downloader/AssetDownloadListener;)V
invoke-virtual {v0, v1}, Ljava/util/concurrent/ThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V
:try_end_32
.catchall {:try_start_20 .. :try_end_32} :catchall_34
.line 6
monitor-exit p0
return-void
:catchall_34
move-exception p1
monitor-exit p0
throw p1
.end method
.method public dropCache(Ljava/lang/String;)Z
.registers 6
.line 1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
const/4 v1, 0x0
if-eqz v0, :cond_44
if-eqz p1, :cond_44
.line 2
:try_start_7
invoke-interface {v0, p1}, Lcom/vungle/warren/downloader/DownloaderCache;->getFile(Ljava/lang/String;)Ljava/io/File;
move-result-object p1
.line 3
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Broken asset, deleting "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 4
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {v0, p1}, Lcom/vungle/warren/downloader/DownloaderCache;->deleteAndRemove(Ljava/io/File;)Z
move-result p1
:try_end_2b
.catch Ljava/io/IOException; {:try_start_7 .. :try_end_2b} :catch_2c
return p1
:catch_2c
move-exception p1
const/4 v0, 0x1
.line 5
new-array v0, v0, [Ljava/lang/Object;
aput-object p1, v0, v1
const-string v2, "Error %1$s occured"
.line 6
invoke-static {v2, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
const-string v2, "AssetDownloader#dropCache; loadAd sequence"
.line 7
invoke-static {v2, v0}, Lcom/vungle/warren/VungleLogger;->error(Ljava/lang/String;Ljava/lang/String;)V
.line 8
sget-object v0, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v2, "There was an error to get file"
invoke-static {v0, v2, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:cond_44
return v1
.end method
.method public declared-synchronized getAllRequests()Ljava/util/List;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Lcom/vungle/warren/downloader/DownloadRequest;",
">;"
}
.end annotation
monitor-enter p0
.line 1
:try_start_1
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 2
new-instance v1, Ljava/util/ArrayList;
iget-object v2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-interface {v2}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v2
invoke-direct {v1, v2}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V
.line 3
invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_15
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_29
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/vungle/warren/downloader/DownloadRequestMediator;
.line 4
invoke-virtual {v2}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->requests()Ljava/util/List;
move-result-object v2
invoke-interface {v0, v2}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
goto :goto_15
.line 5
:cond_29
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
:try_end_2e
.catchall {:try_start_1 .. :try_end_2e} :catchall_30
.line 6
monitor-exit p0
return-object v0
:catchall_30
move-exception v0
monitor-exit p0
goto :goto_34
:goto_33
throw v0
:goto_34
goto :goto_33
.end method
.method public declared-synchronized init()V
.registers 2
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
if-eqz v0, :cond_a
.line 2
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {v0}, Lcom/vungle/warren/downloader/DownloaderCache;->init()V
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_c
.line 3
:cond_a
monitor-exit p0
return-void
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized isCacheEnabled()Z
.registers 2
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
if-eqz v0, :cond_b
iget-boolean v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->isCacheEnabled:Z
:try_end_7
.catchall {:try_start_1 .. :try_end_7} :catchall_e
if-eqz v0, :cond_b
const/4 v0, 0x1
goto :goto_c
:cond_b
const/4 v0, 0x0
:goto_c
monitor-exit p0
return v0
:catchall_e
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized setCacheEnabled(Z)V
.registers 2
monitor-enter p0
.line 1
:try_start_1
iput-boolean p1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->isCacheEnabled:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
.line 2
monitor-exit p0
return-void
:catchall_5
move-exception p1
monitor-exit p0
throw p1
.end method
.method declared-synchronized setDownloadedForTests(ZLjava/lang/String;Ljava/lang/String;)V
.registers 7
monitor-enter p0
.line 1
:try_start_1
new-instance v0, Ljava/util/ArrayList;
const/4 v1, 0x2
invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(I)V
.line 2
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
:try_end_9
.catchall {:try_start_1 .. :try_end_9} :catchall_6b
if-eqz v1, :cond_2b
.line 3
:try_start_b
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
iget-object v2, p0, Lcom/vungle/warren/downloader/AssetDownloader;->cache:Lcom/vungle/warren/downloader/DownloaderCache;
invoke-interface {v2, p2}, Lcom/vungle/warren/downloader/DownloaderCache;->getFile(Ljava/lang/String;)Ljava/io/File;
move-result-object p2
invoke-interface {v1, p2}, Lcom/vungle/warren/downloader/DownloaderCache;->getMetaFile(Ljava/io/File;)Ljava/io/File;
move-result-object p2
invoke-interface {v0, p2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:try_end_1a
.catch Ljava/io/IOException; {:try_start_b .. :try_end_1a} :catch_1b
.catchall {:try_start_b .. :try_end_1a} :catchall_6b
goto :goto_2b
:catch_1b
move-exception p1
.line 4
:try_start_1c
sget-object p2, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string p3, "Cannot add or get meta file"
invoke-static {p2, p3, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 5
new-instance p1, Ljava/lang/RuntimeException;
const-string p2, "Failed to get file for request"
invoke-direct {p1, p2}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.line 6
:cond_2b
:goto_2b
new-instance p2, Ljava/io/File;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p3, ".vng_meta"
invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p3
invoke-direct {p2, p3}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-interface {v0, p2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 7
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p2
:goto_48
invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z
move-result p3
if-eqz p3, :cond_69
invoke-interface {p2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object p3
check-cast p3, Ljava/io/File;
.line 8
invoke-direct {p0, p3}, Lcom/vungle/warren/downloader/AssetDownloader;->extractMeta(Ljava/io/File;)Ljava/util/HashMap;
move-result-object v0
const-string v1, "DOWNLOAD_COMPLETE"
.line 9
invoke-static {p1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Boolean;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v1, v2}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 10
invoke-static {p3, v0}, Lcom/vungle/warren/utility/FileUtility;->writeSerializable(Ljava/io/File;Ljava/io/Serializable;)V
:try_end_68
.catchall {:try_start_1c .. :try_end_68} :catchall_6b
goto :goto_48
.line 11
:cond_69
monitor-exit p0
return-void
:catchall_6b
move-exception p1
monitor-exit p0
goto :goto_6f
:goto_6e
throw p1
:goto_6f
goto :goto_6e
.end method
.method public setProgressStep(I)V
.registers 2
if-eqz p1, :cond_4
.line 1
iput p1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->progressStep:I
:cond_4
return-void
.end method
.method declared-synchronized shutdown()V
.registers 5
monitor-enter p0
const/4 v0, 0x0
.line 1
:try_start_2
invoke-virtual {p0, v0}, Lcom/vungle/warren/downloader/AssetDownloader;->cancel(Lcom/vungle/warren/downloader/DownloadRequest;)V
.line 2
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->transitioning:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->clear()V
.line 3
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->mediators:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->clear()V
.line 4
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->uiExecutor:Ljava/util/concurrent/ExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->shutdownNow()Ljava/util/List;
.line 5
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
invoke-virtual {v0}, Ljava/util/concurrent/ThreadPoolExecutor;->shutdownNow()Ljava/util/List;
:try_end_19
.catchall {:try_start_2 .. :try_end_19} :catchall_3b
.line 6
:try_start_19
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
sget-object v1, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v2, 0x2
invoke-virtual {v0, v2, v3, v1}, Ljava/util/concurrent/ThreadPoolExecutor;->awaitTermination(JLjava/util/concurrent/TimeUnit;)Z
.line 7
iget-object v0, p0, Lcom/vungle/warren/downloader/AssetDownloader;->uiExecutor:Ljava/util/concurrent/ExecutorService;
sget-object v1, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v0, v2, v3, v1}, Ljava/util/concurrent/ExecutorService;->awaitTermination(JLjava/util/concurrent/TimeUnit;)Z
:try_end_29
.catch Ljava/lang/InterruptedException; {:try_start_19 .. :try_end_29} :catch_2a
.catchall {:try_start_19 .. :try_end_29} :catchall_3b
goto :goto_39
:catch_2a
move-exception v0
.line 8
:try_start_2b
sget-object v1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
const-string v2, "InterruptedException "
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 9
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
:try_end_39
.catchall {:try_start_2b .. :try_end_39} :catchall_3b
.line 10
:goto_39
monitor-exit p0
return-void
:catchall_3b
move-exception v0
monitor-exit p0
throw v0
.end method
.method public updatePriority(Lcom/vungle/warren/downloader/DownloadRequest;)V
.registers 6
.line 1
invoke-direct {p0, p1}, Lcom/vungle/warren/downloader/AssetDownloader;->findMediatorForCancellation(Lcom/vungle/warren/downloader/DownloadRequest;)Lcom/vungle/warren/downloader/DownloadRequestMediator;
move-result-object p1
if-eqz p1, :cond_33
.line 2
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->getRunnable()Ljava/lang/Runnable;
move-result-object v0
if-eqz v0, :cond_33
.line 3
iget-object v1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
invoke-virtual {v1, v0}, Ljava/util/concurrent/ThreadPoolExecutor;->remove(Ljava/lang/Runnable;)Z
move-result v1
if-eqz v1, :cond_33
.line 4
sget-object v1, Lcom/vungle/warren/downloader/AssetDownloader;->TAG:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "prio: updated to "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lcom/vungle/warren/downloader/DownloadRequestMediator;->getPriority()I
move-result p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v1, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 5
iget-object p1, p0, Lcom/vungle/warren/downloader/AssetDownloader;->downloadExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
invoke-virtual {p1, v0}, Ljava/util/concurrent/ThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V
:cond_33
return-void
.end method