VideoDownloader$VideoDownloaderTask.smali
.class Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;
.super Landroid/os/AsyncTask;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/mopub/mobileads/VideoDownloader;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x8
name = "VideoDownloaderTask"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"Landroid/os/AsyncTask<",
"Ljava/lang/String;",
"Ljava/lang/Void;",
"Ljava/lang/Boolean;",
">;"
}
.end annotation
# instance fields
.field private final mListener:Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;
.field private final mWeakSelf:Ljava/lang/ref/WeakReference;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/ref/WeakReference<",
"Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;",
">;"
}
.end annotation
.end field
# direct methods
.method constructor <init>(Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;)V
.registers 3
.line 102
invoke-direct {p0}, Landroid/os/AsyncTask;-><init>()V
.line 103
iput-object p1, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mListener:Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;
.line 104
new-instance p1, Ljava/lang/ref/WeakReference;
invoke-direct {p1, p0}, Ljava/lang/ref/WeakReference;-><init>(Ljava/lang/Object;)V
iput-object p1, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mWeakSelf:Ljava/lang/ref/WeakReference;
.line 105
# getter for: Lcom/mopub/mobileads/VideoDownloader;->sDownloaderTasks:Ljava/util/Deque;
invoke-static {}, Lcom/mopub/mobileads/VideoDownloader;->access$000()Ljava/util/Deque;
move-result-object p1
iget-object v0, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mWeakSelf:Ljava/lang/ref/WeakReference;
invoke-interface {p1, v0}, Ljava/util/Deque;->add(Ljava/lang/Object;)Z
return-void
.end method
# virtual methods
.method protected varargs doInBackground([Ljava/lang/String;)Ljava/lang/Boolean;
.registers 12
const/4 v0, 0x1
const/4 v1, 0x0
if-eqz p1, :cond_ba
.line 110
array-length v2, p1
if-eqz v2, :cond_ba
aget-object v2, p1, v1
if-nez v2, :cond_d
goto/16 :goto_ba
.line 115
:cond_d
aget-object p1, p1, v1
const/4 v2, 0x2
const/4 v3, 0x0
.line 119
:try_start_11
invoke-static {p1}, Lcom/mopub/common/MoPubHttpUrlConnection;->getHttpUrlConnection(Ljava/lang/String;)Ljava/net/HttpURLConnection;
move-result-object v4
:try_end_15
.catch Ljava/lang/Exception; {:try_start_11 .. :try_end_15} :catch_97
.catchall {:try_start_11 .. :try_end_15} :catchall_94
.line 120
:try_start_15
new-instance v5, Ljava/io/BufferedInputStream;
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v6
invoke-direct {v5, v6}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;)V
:try_end_1e
.catch Ljava/lang/Exception; {:try_start_15 .. :try_end_1e} :catch_92
.catchall {:try_start_15 .. :try_end_1e} :catchall_90
.line 123
:try_start_1e
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result v3
const/16 v6, 0xc8
if-lt v3, v6, :cond_6c
const/16 v6, 0x12c
if-lt v3, v6, :cond_2b
goto :goto_6c
.line 132
:cond_2b
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->getContentLength()I
move-result v3
const/high16 v6, 0x1900000
if-le v3, v6, :cond_5b
.line 134
sget-object p1, Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;->CUSTOM:Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;
new-array v7, v0, [Ljava/lang/Object;
const-string v8, "VideoDownloader encountered video larger than disk cap. (%d bytes / %d maximum)."
new-array v9, v2, [Ljava/lang/Object;
.line 137
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
aput-object v3, v9, v1
.line 138
invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
aput-object v3, v9, v0
.line 134
invoke-static {v8, v9}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
aput-object v3, v7, v1
invoke-static {p1, v7}, Lcom/mopub/common/logging/MoPubLog;->log(Lcom/mopub/common/logging/MoPubLog$MPLogEventType;[Ljava/lang/Object;)V
.line 139
sget-object p1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
:try_end_52
.catch Ljava/lang/Exception; {:try_start_1e .. :try_end_52} :catch_8d
.catchall {:try_start_1e .. :try_end_52} :catchall_8a
.line 148
invoke-static {v5}, Lcom/mopub/common/util/Streams;->closeStream(Ljava/io/Closeable;)V
if-eqz v4, :cond_5a
.line 150
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_5a
return-object p1
.line 142
:cond_5b
:try_start_5b
invoke-static {p1, v5}, Lcom/mopub/common/CacheService;->putToDiskCache(Ljava/lang/String;Ljava/io/InputStream;)Z
move-result p1
.line 143
invoke-static {p1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object p1
:try_end_63
.catch Ljava/lang/Exception; {:try_start_5b .. :try_end_63} :catch_8d
.catchall {:try_start_5b .. :try_end_63} :catchall_8a
.line 148
invoke-static {v5}, Lcom/mopub/common/util/Streams;->closeStream(Ljava/io/Closeable;)V
if-eqz v4, :cond_6b
.line 150
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_6b
return-object p1
.line 126
:cond_6c
:goto_6c
:try_start_6c
sget-object p1, Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;->CUSTOM:Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;
new-array v6, v0, [Ljava/lang/Object;
const-string v7, "VideoDownloader encountered unexpected statusCode: "
invoke-static {v3}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v3
invoke-virtual {v7, v3}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
aput-object v3, v6, v1
invoke-static {p1, v6}, Lcom/mopub/common/logging/MoPubLog;->log(Lcom/mopub/common/logging/MoPubLog$MPLogEventType;[Ljava/lang/Object;)V
.line 128
sget-object p1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
:try_end_81
.catch Ljava/lang/Exception; {:try_start_6c .. :try_end_81} :catch_8d
.catchall {:try_start_6c .. :try_end_81} :catchall_8a
.line 148
invoke-static {v5}, Lcom/mopub/common/util/Streams;->closeStream(Ljava/io/Closeable;)V
if-eqz v4, :cond_89
.line 150
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_89
return-object p1
:catchall_8a
move-exception p1
move-object v3, v5
goto :goto_b1
:catch_8d
move-exception p1
move-object v3, v5
goto :goto_99
:catchall_90
move-exception p1
goto :goto_b1
:catch_92
move-exception p1
goto :goto_99
:catchall_94
move-exception p1
move-object v4, v3
goto :goto_b1
:catch_97
move-exception p1
move-object v4, v3
.line 145
:goto_99
:try_start_99
sget-object v5, Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;->ERROR:Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;
new-array v2, v2, [Ljava/lang/Object;
const-string v6, "VideoDownloader task threw an internal exception."
aput-object v6, v2, v1
aput-object p1, v2, v0
invoke-static {v5, v2}, Lcom/mopub/common/logging/MoPubLog;->log(Lcom/mopub/common/logging/MoPubLog$MPLogEventType;[Ljava/lang/Object;)V
.line 146
sget-object p1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
:try_end_a8
.catchall {:try_start_99 .. :try_end_a8} :catchall_90
.line 148
invoke-static {v3}, Lcom/mopub/common/util/Streams;->closeStream(Ljava/io/Closeable;)V
if-eqz v4, :cond_b0
.line 150
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_b0
return-object p1
.line 148
:goto_b1
invoke-static {v3}, Lcom/mopub/common/util/Streams;->closeStream(Ljava/io/Closeable;)V
if-eqz v4, :cond_b9
.line 150
invoke-virtual {v4}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_b9
throw p1
.line 111
:cond_ba
:goto_ba
sget-object p1, Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;->CUSTOM:Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;
new-array v0, v0, [Ljava/lang/Object;
const-string v2, "VideoDownloader task tried to execute null or empty url."
aput-object v2, v0, v1
invoke-static {p1, v0}, Lcom/mopub/common/logging/MoPubLog;->log(Lcom/mopub/common/logging/MoPubLog$MPLogEventType;[Ljava/lang/Object;)V
.line 112
sget-object p1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
return-object p1
.end method
.method protected bridge synthetic doInBackground([Ljava/lang/Object;)Ljava/lang/Object;
.registers 2
.line 96
check-cast p1, [Ljava/lang/String;
invoke-virtual {p0, p1}, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->doInBackground([Ljava/lang/String;)Ljava/lang/Boolean;
move-result-object p1
return-object p1
.end method
.method protected onCancelled()V
.registers 5
.line 174
sget-object v0, Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;->CUSTOM:Lcom/mopub/common/logging/MoPubLog$SdkLogEvent;
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
const-string v2, "VideoDownloader task was cancelled."
const/4 v3, 0x0
aput-object v2, v1, v3
invoke-static {v0, v1}, Lcom/mopub/common/logging/MoPubLog;->log(Lcom/mopub/common/logging/MoPubLog$MPLogEventType;[Ljava/lang/Object;)V
.line 175
# getter for: Lcom/mopub/mobileads/VideoDownloader;->sDownloaderTasks:Ljava/util/Deque;
invoke-static {}, Lcom/mopub/mobileads/VideoDownloader;->access$000()Ljava/util/Deque;
move-result-object v0
iget-object v1, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mWeakSelf:Ljava/lang/ref/WeakReference;
invoke-interface {v0, v1}, Ljava/util/Deque;->remove(Ljava/lang/Object;)Z
.line 176
iget-object v0, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mListener:Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;
invoke-interface {v0, v3}, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;->onComplete(Z)V
return-void
.end method
.method protected onPostExecute(Ljava/lang/Boolean;)V
.registers 4
.line 157
invoke-virtual {p0}, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->isCancelled()Z
move-result v0
if-eqz v0, :cond_a
.line 158
invoke-virtual {p0}, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->onCancelled()V
return-void
.line 162
:cond_a
# getter for: Lcom/mopub/mobileads/VideoDownloader;->sDownloaderTasks:Ljava/util/Deque;
invoke-static {}, Lcom/mopub/mobileads/VideoDownloader;->access$000()Ljava/util/Deque;
move-result-object v0
iget-object v1, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mWeakSelf:Ljava/lang/ref/WeakReference;
invoke-interface {v0, v1}, Ljava/util/Deque;->remove(Ljava/lang/Object;)Z
if-nez p1, :cond_1c
.line 165
iget-object p1, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mListener:Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;
const/4 v0, 0x0
invoke-interface {p1, v0}, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;->onComplete(Z)V
return-void
.line 169
:cond_1c
iget-object v0, p0, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->mListener:Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;
invoke-virtual {p1}, Ljava/lang/Boolean;->booleanValue()Z
move-result p1
invoke-interface {v0, p1}, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderListener;->onComplete(Z)V
return-void
.end method
.method protected bridge synthetic onPostExecute(Ljava/lang/Object;)V
.registers 2
.line 96
check-cast p1, Ljava/lang/Boolean;
invoke-virtual {p0, p1}, Lcom/mopub/mobileads/VideoDownloader$VideoDownloaderTask;->onPostExecute(Ljava/lang/Boolean;)V
return-void
.end method