HttpUrlSource.smali
.class public Lcom/danikula/videocache/HttpUrlSource;
.super Ljava/lang/Object;
.source "HttpUrlSource.java"
# interfaces
.implements Lcom/danikula/videocache/Source;
# static fields
.field private static final LOG:Lorg/slf4j/Logger;
.field private static final MAX_REDIRECTS:I = 0x5
# instance fields
.field private connection:Ljava/net/HttpURLConnection;
.field private final headerInjector:Lcom/danikula/videocache/headers/HeaderInjector;
.field private inputStream:Ljava/io/InputStream;
.field private sourceInfo:Lcom/danikula/videocache/SourceInfo;
.field private final sourceInfoStorage:Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 36
const-string v0, "HttpUrlSource"
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->getLogger(Ljava/lang/String;)Lorg/slf4j/Logger;
move-result-object v0
sput-object v0, Lcom/danikula/videocache/HttpUrlSource;->LOG:Lorg/slf4j/Logger;
return-void
.end method
.method public constructor <init>(Lcom/danikula/videocache/HttpUrlSource;)V
.registers 3
.param p1, "source" # Lcom/danikula/videocache/HttpUrlSource;
.line 61
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 62
iget-object v0, p1, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iput-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
.line 63
iget-object v0, p1, Lcom/danikula/videocache/HttpUrlSource;->sourceInfoStorage:Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
iput-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfoStorage:Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
.line 64
iget-object v0, p1, Lcom/danikula/videocache/HttpUrlSource;->headerInjector:Lcom/danikula/videocache/headers/HeaderInjector;
iput-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->headerInjector:Lcom/danikula/videocache/headers/HeaderInjector;
.line 65
return-void
.end method
.method public constructor <init>(Ljava/lang/String;)V
.registers 3
.param p1, "url" # Ljava/lang/String;
.line 46
invoke-static {}, Lcom/danikula/videocache/sourcestorage/SourceInfoStorageFactory;->newEmptySourceInfoStorage()Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
move-result-object v0
invoke-direct {p0, p1, v0}, Lcom/danikula/videocache/HttpUrlSource;-><init>(Ljava/lang/String;Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;)V
.line 47
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;)V
.registers 4
.param p1, "url" # Ljava/lang/String;
.param p2, "sourceInfoStorage" # Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
.line 50
new-instance v0, Lcom/danikula/videocache/headers/EmptyHeadersInjector;
invoke-direct {v0}, Lcom/danikula/videocache/headers/EmptyHeadersInjector;-><init>()V
invoke-direct {p0, p1, p2, v0}, Lcom/danikula/videocache/HttpUrlSource;-><init>(Ljava/lang/String;Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;Lcom/danikula/videocache/headers/HeaderInjector;)V
.line 51
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;Lcom/danikula/videocache/headers/HeaderInjector;)V
.registers 9
.param p1, "url" # Ljava/lang/String;
.param p2, "sourceInfoStorage" # Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
.param p3, "headerInjector" # Lcom/danikula/videocache/headers/HeaderInjector;
.line 53
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 54
invoke-static {p2}, Lcom/danikula/videocache/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
iput-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfoStorage:Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
.line 55
invoke-static {p3}, Lcom/danikula/videocache/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/danikula/videocache/headers/HeaderInjector;
iput-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->headerInjector:Lcom/danikula/videocache/headers/HeaderInjector;
.line 56
invoke-interface {p2, p1}, Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;->get(Ljava/lang/String;)Lcom/danikula/videocache/SourceInfo;
move-result-object v0
.line 57
.local v0, "sourceInfo":Lcom/danikula/videocache/SourceInfo;
if-eqz v0, :cond_1b
move-object v1, v0
goto :goto_27
:cond_1b
new-instance v1, Lcom/danikula/videocache/SourceInfo;
const-wide/32 v2, -0x80000000
.line 58
invoke-static {p1}, Lcom/danikula/videocache/ProxyCacheUtils;->getSupposablyMime(Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
invoke-direct {v1, p1, v2, v3, v4}, Lcom/danikula/videocache/SourceInfo;-><init>(Ljava/lang/String;JLjava/lang/String;)V
:goto_27
iput-object v1, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
.line 59
return-void
.end method
.method private fetchContentInfo()V
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/danikula/videocache/ProxyCacheException;
}
.end annotation
.line 134
sget-object v0, Lcom/danikula/videocache/HttpUrlSource;->LOG:Lorg/slf4j/Logger;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Read content info from "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v2, v2, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-interface {v0, v1}, Lorg/slf4j/Logger;->debug(Ljava/lang/String;)V
.line 135
const/4 v0, 0x0
.line 136
.local v0, "urlConnection":Ljava/net/HttpURLConnection;
const/4 v1, 0x0
.line 138
.local v1, "inputStream":Ljava/io/InputStream;
const-wide/16 v2, 0x0
const/16 v4, 0x2710
:try_start_20
invoke-direct {p0, v2, v3, v4}, Lcom/danikula/videocache/HttpUrlSource;->openConnection(JI)Ljava/net/HttpURLConnection;
move-result-object v2
move-object v0, v2
.line 139
invoke-direct {p0, v0}, Lcom/danikula/videocache/HttpUrlSource;->getContentLength(Ljava/net/HttpURLConnection;)J
move-result-wide v2
.line 140
.local v2, "length":J
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->getContentType()Ljava/lang/String;
move-result-object v4
.line 141
.local v4, "mime":Ljava/lang/String;
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v5
move-object v1, v5
.line 142
new-instance v5, Lcom/danikula/videocache/SourceInfo;
iget-object v6, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v6, v6, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
invoke-direct {v5, v6, v2, v3, v4}, Lcom/danikula/videocache/SourceInfo;-><init>(Ljava/lang/String;JLjava/lang/String;)V
iput-object v5, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
.line 143
iget-object v6, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfoStorage:Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
iget-object v5, v5, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
iget-object v7, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
invoke-interface {v6, v5, v7}, Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;->put(Ljava/lang/String;Lcom/danikula/videocache/SourceInfo;)V
.line 144
sget-object v5, Lcom/danikula/videocache/HttpUrlSource;->LOG:Lorg/slf4j/Logger;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "Source info fetched: "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v7, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-interface {v5, v6}, Lorg/slf4j/Logger;->debug(Ljava/lang/String;)V
:try_end_5e
.catch Ljava/io/IOException; {:try_start_20 .. :try_end_5e} :catch_69
.catchall {:try_start_20 .. :try_end_5e} :catchall_67
.line 148
.end local v2 # "length":J
.end local v4 # "mime":Ljava/lang/String;
invoke-static {v1}, Lcom/danikula/videocache/ProxyCacheUtils;->close(Ljava/io/Closeable;)V
.line 149
if-eqz v0, :cond_8a
.line 150
:goto_63
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->disconnect()V
goto :goto_8a
.line 148
:catchall_67
move-exception v2
goto :goto_8b
.line 145
:catch_69
move-exception v2
.line 146
.local v2, "e":Ljava/io/IOException;
:try_start_6a
sget-object v3, Lcom/danikula/videocache/HttpUrlSource;->LOG:Lorg/slf4j/Logger;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Error fetching info from "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v5, v5, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
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-interface {v3, v4, v2}, Lorg/slf4j/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_84
.catchall {:try_start_6a .. :try_end_84} :catchall_67
.line 148
.end local v2 # "e":Ljava/io/IOException;
invoke-static {v1}, Lcom/danikula/videocache/ProxyCacheUtils;->close(Ljava/io/Closeable;)V
.line 149
if-eqz v0, :cond_8a
.line 150
goto :goto_63
.line 153
:cond_8a
:goto_8a
return-void
.line 148
:goto_8b
invoke-static {v1}, Lcom/danikula/videocache/ProxyCacheUtils;->close(Ljava/io/Closeable;)V
.line 149
if-eqz v0, :cond_93
.line 150
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->disconnect()V
.line 152
:cond_93
goto :goto_95
:goto_94
throw v2
:goto_95
goto :goto_94
.end method
.method private getContentLength(Ljava/net/HttpURLConnection;)J
.registers 5
.param p1, "connection" # Ljava/net/HttpURLConnection;
.line 96
const-string v0, "Content-Length"
invoke-virtual {p1, v0}, Ljava/net/HttpURLConnection;->getHeaderField(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 97
.local v0, "contentLengthValue":Ljava/lang/String;
if-nez v0, :cond_b
const-wide/16 v1, -0x1
goto :goto_f
:cond_b
invoke-static {v0}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v1
:goto_f
return-wide v1
.end method
.method private injectCustomHeaders(Ljava/net/HttpURLConnection;Ljava/lang/String;)V
.registers 8
.param p1, "connection" # Ljava/net/HttpURLConnection;
.param p2, "url" # Ljava/lang/String;
.line 186
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->headerInjector:Lcom/danikula/videocache/headers/HeaderInjector;
invoke-interface {v0, p2}, Lcom/danikula/videocache/headers/HeaderInjector;->addHeaders(Ljava/lang/String;)Ljava/util/Map;
move-result-object v0
.line 187
.local v0, "extraHeaders":Ljava/util/Map;, "Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;"
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v1
invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_e
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_2a
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/util/Map$Entry;
.line 188
.local v2, "header":Ljava/util/Map$Entry;, "Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;"
invoke-interface {v2}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
invoke-interface {v2}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/lang/String;
invoke-virtual {p1, v3, v4}, Ljava/net/HttpURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
.line 189
.end local v2 # "header":Ljava/util/Map$Entry;, "Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;"
goto :goto_e
.line 190
:cond_2a
return-void
.end method
.method private openConnection(JI)Ljava/net/HttpURLConnection;
.registers 12
.param p1, "offset" # J
.param p3, "timeout" # I
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;,
Lcom/danikula/videocache/ProxyCacheException;
}
.end annotation
.line 158
const/4 v0, 0x0
.line 159
.local v0, "redirectCount":I
iget-object v1, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v1, v1, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
.line 161
.local v1, "url":Ljava/lang/String;
:cond_5
sget-object v2, Lcom/danikula/videocache/HttpUrlSource;->LOG:Lorg/slf4j/Logger;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Open connection "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-wide/16 v4, 0x0
cmp-long v6, p1, v4
if-lez v6, :cond_29
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, " with offset "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, p1, p2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
goto :goto_2b
:cond_29
const-string v6, ""
:goto_2b
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v6, " to "
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, 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-interface {v2, v3}, Lorg/slf4j/Logger;->debug(Ljava/lang/String;)V
.line 162
new-instance v2, Ljava/net/URL;
invoke-direct {v2, v1}, Ljava/net/URL;-><init>(Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection;
move-result-object v2
check-cast v2, Ljava/net/HttpURLConnection;
.line 163
.local v2, "connection":Ljava/net/HttpURLConnection;
invoke-direct {p0, v2, v1}, Lcom/danikula/videocache/HttpUrlSource;->injectCustomHeaders(Ljava/net/HttpURLConnection;Ljava/lang/String;)V
.line 164
cmp-long v3, p1, v4
if-lez v3, :cond_6a
.line 165
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "bytes="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1, p2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string 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
const-string v4, "Range"
invoke-virtual {v2, v4, v3}, Ljava/net/HttpURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
.line 167
:cond_6a
if-lez p3, :cond_72
.line 168
invoke-virtual {v2, p3}, Ljava/net/HttpURLConnection;->setConnectTimeout(I)V
.line 169
invoke-virtual {v2, p3}, Ljava/net/HttpURLConnection;->setReadTimeout(I)V
.line 171
:cond_72
invoke-virtual {v2}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result v3
.line 172
.local v3, "code":I
const/16 v4, 0x12d
if-eq v3, v4, :cond_85
const/16 v4, 0x12e
if-eq v3, v4, :cond_85
const/16 v4, 0x12f
if-ne v3, v4, :cond_83
goto :goto_85
:cond_83
const/4 v4, 0x0
goto :goto_86
:cond_85
:goto_85
const/4 v4, 0x1
.line 173
.local v4, "redirected":Z
:goto_86
if-eqz v4, :cond_93
.line 174
const-string v5, "Location"
invoke-virtual {v2, v5}, Ljava/net/HttpURLConnection;->getHeaderField(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
.line 175
add-int/lit8 v0, v0, 0x1
.line 176
invoke-virtual {v2}, Ljava/net/HttpURLConnection;->disconnect()V
.line 178
:cond_93
const/4 v5, 0x5
if-gt v0, v5, :cond_99
.line 181
.end local v3 # "code":I
if-nez v4, :cond_5
.line 182
return-object v2
.line 179
.restart local v3 # "code":I
:cond_99
new-instance v5, Lcom/danikula/videocache/ProxyCacheException;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "Too many redirects: "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-direct {v5, v6}, Lcom/danikula/videocache/ProxyCacheException;-><init>(Ljava/lang/String;)V
goto :goto_b1
:goto_b0
throw v5
:goto_b1
goto :goto_b0
.end method
.method private readSourceAvailableBytes(Ljava/net/HttpURLConnection;JI)J
.registers 9
.param p1, "connection" # Ljava/net/HttpURLConnection;
.param p2, "offset" # J
.param p4, "responseCode" # I
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 90
invoke-direct {p0, p1}, Lcom/danikula/videocache/HttpUrlSource;->getContentLength(Ljava/net/HttpURLConnection;)J
move-result-wide v0
.line 91
.local v0, "contentLength":J
const/16 v2, 0xc8
if-ne p4, v2, :cond_a
move-wide v2, v0
goto :goto_15
:cond_a
const/16 v2, 0xce
if-ne p4, v2, :cond_11
add-long v2, v0, p2
goto :goto_15
:cond_11
iget-object v2, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-wide v2, v2, Lcom/danikula/videocache/SourceInfo;->length:J
:goto_15
return-wide v2
.end method
# virtual methods
.method public close()V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/danikula/videocache/ProxyCacheException;
}
.end annotation
.line 102
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->connection:Ljava/net/HttpURLConnection;
if-eqz v0, :cond_1c
.line 104
:try_start_4
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->disconnect()V
:try_end_7
.catch Ljava/lang/NullPointerException; {:try_start_4 .. :try_end_7} :catch_13
.catch Ljava/lang/IllegalArgumentException; {:try_start_4 .. :try_end_7} :catch_11
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_4 .. :try_end_7} :catch_8
.line 115
goto :goto_1c
.line 111
:catch_8
move-exception v0
.line 112
.local v0, "e":Ljava/lang/ArrayIndexOutOfBoundsException;
sget-object v1, Lcom/danikula/videocache/HttpUrlSource;->LOG:Lorg/slf4j/Logger;
const-string v2, "Error closing connection correctly. Should happen only on Android L. If anybody know how to fix it, please visit https://github.com/danikula/AndroidVideoCache/issues/88. Until good solution is not know, just ignore this issue :("
invoke-interface {v1, v2, v0}, Lorg/slf4j/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_1c
.line 105
.end local v0 # "e":Ljava/lang/ArrayIndexOutOfBoundsException;
:catch_11
move-exception v0
goto :goto_14
:catch_13
move-exception v0
.line 106
.local v0, "e":Ljava/lang/RuntimeException;
:goto_14
const-string v1, "Wait... but why? WTF!? Really shouldn\'t happen any more after fixing https://github.com/danikula/AndroidVideoCache/issues/43. If you read it on your device log, please, notify me danikula@gmail.com or create issue here https://github.com/danikula/AndroidVideoCache/issues."
.line 110
.local v1, "message":Ljava/lang/String;
new-instance v2, Ljava/lang/RuntimeException;
invoke-direct {v2, v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
.line 117
.end local v0 # "e":Ljava/lang/RuntimeException;
.end local v1 # "message":Ljava/lang/String;
:cond_1c
:goto_1c
return-void
.end method
.method public declared-synchronized getMime()Ljava/lang/String;
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/danikula/videocache/ProxyCacheException;
}
.end annotation
monitor-enter p0
.line 193
:try_start_1
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v0, v0, Lcom/danikula/videocache/SourceInfo;->mime:Ljava/lang/String;
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_e
.line 194
invoke-direct {p0}, Lcom/danikula/videocache/HttpUrlSource;->fetchContentInfo()V
.line 196
.end local p0 # "this":Lcom/danikula/videocache/HttpUrlSource;
:cond_e
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v0, v0, Lcom/danikula/videocache/SourceInfo;->mime:Ljava/lang/String;
:try_end_12
.catchall {:try_start_1 .. :try_end_12} :catchall_14
monitor-exit p0
return-object v0
.line 192
:catchall_14
move-exception v0
monitor-exit p0
throw v0
.end method
.method public getUrl()Ljava/lang/String;
.registers 2
.line 200
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v0, v0, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
return-object v0
.end method
.method public declared-synchronized length()J
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/danikula/videocache/ProxyCacheException;
}
.end annotation
monitor-enter p0
.line 69
:try_start_1
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-wide v0, v0, Lcom/danikula/videocache/SourceInfo;->length:J
const-wide/32 v2, -0x80000000
cmp-long v4, v0, v2
if-nez v4, :cond_f
.line 70
invoke-direct {p0}, Lcom/danikula/videocache/HttpUrlSource;->fetchContentInfo()V
.line 72
.end local p0 # "this":Lcom/danikula/videocache/HttpUrlSource;
:cond_f
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-wide v0, v0, Lcom/danikula/videocache/SourceInfo;->length:J
:try_end_13
.catchall {:try_start_1 .. :try_end_13} :catchall_15
monitor-exit p0
return-wide v0
.line 68
:catchall_15
move-exception v0
monitor-exit p0
throw v0
.end method
.method public open(J)V
.registers 9
.param p1, "offset" # J
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/danikula/videocache/ProxyCacheException;
}
.end annotation
.line 78
const/4 v0, -0x1
:try_start_1
invoke-direct {p0, p1, p2, v0}, Lcom/danikula/videocache/HttpUrlSource;->openConnection(JI)Ljava/net/HttpURLConnection;
move-result-object v0
iput-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->connection:Ljava/net/HttpURLConnection;
.line 79
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->getContentType()Ljava/lang/String;
move-result-object v0
.line 80
.local v0, "mime":Ljava/lang/String;
new-instance v1, Ljava/io/BufferedInputStream;
iget-object v2, p0, Lcom/danikula/videocache/HttpUrlSource;->connection:Ljava/net/HttpURLConnection;
invoke-virtual {v2}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v2
const/16 v3, 0x2000
invoke-direct {v1, v2, v3}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;I)V
iput-object v1, p0, Lcom/danikula/videocache/HttpUrlSource;->inputStream:Ljava/io/InputStream;
.line 81
iget-object v1, p0, Lcom/danikula/videocache/HttpUrlSource;->connection:Ljava/net/HttpURLConnection;
iget-object v2, p0, Lcom/danikula/videocache/HttpUrlSource;->connection:Ljava/net/HttpURLConnection;
invoke-virtual {v2}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result v2
invoke-direct {p0, v1, p1, p2, v2}, Lcom/danikula/videocache/HttpUrlSource;->readSourceAvailableBytes(Ljava/net/HttpURLConnection;JI)J
move-result-wide v1
.line 82
.local v1, "length":J
new-instance v3, Lcom/danikula/videocache/SourceInfo;
iget-object v4, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v4, v4, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
invoke-direct {v3, v4, v1, v2, v0}, Lcom/danikula/videocache/SourceInfo;-><init>(Ljava/lang/String;JLjava/lang/String;)V
iput-object v3, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
.line 83
iget-object v4, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfoStorage:Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;
iget-object v3, v3, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
iget-object v5, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
invoke-interface {v4, v3, v5}, Lcom/danikula/videocache/sourcestorage/SourceInfoStorage;->put(Ljava/lang/String;Lcom/danikula/videocache/SourceInfo;)V
:try_end_3a
.catch Ljava/io/IOException; {:try_start_1 .. :try_end_3a} :catch_3c
.line 86
.end local v0 # "mime":Ljava/lang/String;
.end local v1 # "length":J
nop
.line 87
return-void
.line 84
:catch_3c
move-exception v0
.line 85
.local v0, "e":Ljava/io/IOException;
new-instance v1, Lcom/danikula/videocache/ProxyCacheException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Error opening connection for "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v3, v3, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " with offset "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1, p2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2, v0}, Lcom/danikula/videocache/ProxyCacheException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.end method
.method public read([B)I
.registers 6
.param p1, "buffer" # [B
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/danikula/videocache/ProxyCacheException;
}
.end annotation
.line 121
iget-object v0, p0, Lcom/danikula/videocache/HttpUrlSource;->inputStream:Ljava/io/InputStream;
const-string v1, "Error reading data from "
if-eqz v0, :cond_48
.line 125
const/4 v2, 0x0
:try_start_7
array-length v3, p1
invoke-virtual {v0, p1, v2, v3}, Ljava/io/InputStream;->read([BII)I
move-result v0
:try_end_c
.catch Ljava/io/InterruptedIOException; {:try_start_7 .. :try_end_c} :catch_27
.catch Ljava/io/IOException; {:try_start_7 .. :try_end_c} :catch_d
return v0
.line 128
:catch_d
move-exception v0
.line 129
.local v0, "e":Ljava/io/IOException;
new-instance v2, Lcom/danikula/videocache/ProxyCacheException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v1, v1, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v2, v1, v0}, Lcom/danikula/videocache/ProxyCacheException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
.line 126
.end local v0 # "e":Ljava/io/IOException;
:catch_27
move-exception v0
.line 127
.local v0, "e":Ljava/io/InterruptedIOException;
new-instance v1, Lcom/danikula/videocache/InterruptedProxyCacheException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Reading source "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v3, v3, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " is interrupted"
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, v0}, Lcom/danikula/videocache/InterruptedProxyCacheException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.line 122
.end local v0 # "e":Ljava/io/InterruptedIOException;
:cond_48
new-instance v0, Lcom/danikula/videocache/ProxyCacheException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
iget-object v1, v1, Lcom/danikula/videocache/SourceInfo;->url:Ljava/lang/String;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ": connection is absent!"
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Lcom/danikula/videocache/ProxyCacheException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public toString()Ljava/lang/String;
.registers 3
.line 205
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "HttpUrlSource{sourceInfo=\'"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/danikula/videocache/HttpUrlSource;->sourceInfo:Lcom/danikula/videocache/SourceInfo;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string/jumbo 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
return-object v0
.end method