tmap/smali_classes5/org/apache/http/client/protocol/RequestAddCookies.smali
2022-06-10 21:38:30 +09:00

582 lines
15 KiB
Smali

.class public Lorg/apache/http/client/protocol/RequestAddCookies;
.super Ljava/lang/Object;
.source "RequestAddCookies.java"
# interfaces
.implements Lorg/apache/http/HttpRequestInterceptor;
# annotations
.annotation build Lorg/apache/http/annotation/Immutable;
.end annotation
# instance fields
.field private final log:Lorg/apache/commons/logging/Log;
# direct methods
.method public constructor <init>()V
.locals 1
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-static {v0}, Lorg/apache/commons/logging/LogFactory;->getLog(Ljava/lang/Class;)Lorg/apache/commons/logging/Log;
move-result-object v0
iput-object v0, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
return-void
.end method
# virtual methods
.method public process(Lorg/apache/http/HttpRequest;Lorg/apache/http/protocol/HttpContext;)V
.locals 9
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/apache/http/HttpException;,
Ljava/io/IOException;
}
.end annotation
if-eqz p1, :cond_13
if-eqz p2, :cond_12
.line 1
invoke-interface {p1}, Lorg/apache/http/HttpRequest;->getRequestLine()Lorg/apache/http/RequestLine;
move-result-object v0
invoke-interface {v0}, Lorg/apache/http/RequestLine;->getMethod()Ljava/lang/String;
move-result-object v0
const-string v1, "CONNECT"
.line 2
invoke-virtual {v0, v1}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_0
return-void
:cond_0
const-string v0, "http.cookie-store"
.line 3
invoke-interface {p2, v0}, Lorg/apache/http/protocol/HttpContext;->getAttribute(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/apache/http/client/CookieStore;
if-nez v0, :cond_1
.line 4
iget-object p1, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
const-string p2, "Cookie store not available in HTTP context"
invoke-interface {p1, p2}, Lorg/apache/commons/logging/Log;->info(Ljava/lang/Object;)V
return-void
:cond_1
const-string v1, "http.cookiespec-registry"
.line 5
invoke-interface {p2, v1}, Lorg/apache/http/protocol/HttpContext;->getAttribute(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lorg/apache/http/cookie/CookieSpecRegistry;
if-nez v1, :cond_2
.line 6
iget-object p1, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
const-string p2, "CookieSpec registry not available in HTTP context"
invoke-interface {p1, p2}, Lorg/apache/commons/logging/Log;->info(Ljava/lang/Object;)V
return-void
:cond_2
const-string v2, "http.target_host"
.line 7
invoke-interface {p2, v2}, Lorg/apache/http/protocol/HttpContext;->getAttribute(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lorg/apache/http/HttpHost;
if-eqz v2, :cond_11
const-string v3, "http.connection"
.line 8
invoke-interface {p2, v3}, Lorg/apache/http/protocol/HttpContext;->getAttribute(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Lorg/apache/http/conn/ManagedClientConnection;
if-eqz v3, :cond_10
.line 9
invoke-interface {p1}, Lorg/apache/http/HttpMessage;->getParams()Lorg/apache/http/params/HttpParams;
move-result-object v4
invoke-static {v4}, Lorg/apache/http/client/params/HttpClientParams;->getCookiePolicy(Lorg/apache/http/params/HttpParams;)Ljava/lang/String;
move-result-object v4
.line 10
iget-object v5, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
invoke-interface {v5}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z
move-result v5
if-eqz v5, :cond_3
.line 11
iget-object v5, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "CookieSpec selected: "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-interface {v5, v6}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V
.line 12
:cond_3
instance-of v5, p1, Lorg/apache/http/client/methods/HttpUriRequest;
if-eqz v5, :cond_4
.line 13
move-object v5, p1
check-cast v5, Lorg/apache/http/client/methods/HttpUriRequest;
invoke-interface {v5}, Lorg/apache/http/client/methods/HttpUriRequest;->getURI()Ljava/net/URI;
move-result-object v5
goto :goto_0
.line 14
:cond_4
:try_start_0
new-instance v5, Ljava/net/URI;
invoke-interface {p1}, Lorg/apache/http/HttpRequest;->getRequestLine()Lorg/apache/http/RequestLine;
move-result-object v6
invoke-interface {v6}, Lorg/apache/http/RequestLine;->getUri()Ljava/lang/String;
move-result-object v6
invoke-direct {v5, v6}, Ljava/net/URI;-><init>(Ljava/lang/String;)V
:try_end_0
.catch Ljava/net/URISyntaxException; {:try_start_0 .. :try_end_0} :catch_0
.line 15
:goto_0
invoke-virtual {v2}, Lorg/apache/http/HttpHost;->getHostName()Ljava/lang/String;
move-result-object v6
.line 16
invoke-virtual {v2}, Lorg/apache/http/HttpHost;->getPort()I
move-result v7
if-gez v7, :cond_6
const-string v8, "http.scheme-registry"
.line 17
invoke-interface {p2, v8}, Lorg/apache/http/protocol/HttpContext;->getAttribute(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v8
check-cast v8, Lorg/apache/http/conn/scheme/SchemeRegistry;
if-eqz v8, :cond_5
.line 18
invoke-virtual {v2}, Lorg/apache/http/HttpHost;->getSchemeName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v8, v2}, Lorg/apache/http/conn/scheme/SchemeRegistry;->get(Ljava/lang/String;)Lorg/apache/http/conn/scheme/Scheme;
move-result-object v2
.line 19
invoke-virtual {v2, v7}, Lorg/apache/http/conn/scheme/Scheme;->resolvePort(I)I
move-result v7
goto :goto_1
.line 20
:cond_5
invoke-interface {v3}, Lorg/apache/http/HttpInetConnection;->getRemotePort()I
move-result v7
.line 21
:cond_6
:goto_1
new-instance v2, Lorg/apache/http/cookie/CookieOrigin;
invoke-virtual {v5}, Ljava/net/URI;->getPath()Ljava/lang/String;
move-result-object v5
invoke-interface {v3}, Lorg/apache/http/conn/ManagedClientConnection;->isSecure()Z
move-result v3
invoke-direct {v2, v6, v7, v5, v3}, Lorg/apache/http/cookie/CookieOrigin;-><init>(Ljava/lang/String;ILjava/lang/String;Z)V
.line 22
invoke-interface {p1}, Lorg/apache/http/HttpMessage;->getParams()Lorg/apache/http/params/HttpParams;
move-result-object v3
invoke-virtual {v1, v4, v3}, Lorg/apache/http/cookie/CookieSpecRegistry;->getCookieSpec(Ljava/lang/String;Lorg/apache/http/params/HttpParams;)Lorg/apache/http/cookie/CookieSpec;
move-result-object v1
.line 23
new-instance v3, Ljava/util/ArrayList;
invoke-interface {v0}, Lorg/apache/http/client/CookieStore;->getCookies()Ljava/util/List;
move-result-object v0
invoke-direct {v3, v0}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V
.line 24
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 25
new-instance v4, Ljava/util/Date;
invoke-direct {v4}, Ljava/util/Date;-><init>()V
.line 26
invoke-virtual {v3}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v3
:cond_7
:goto_2
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v5
if-eqz v5, :cond_a
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v5
check-cast v5, Lorg/apache/http/cookie/Cookie;
.line 27
invoke-interface {v5, v4}, Lorg/apache/http/cookie/Cookie;->isExpired(Ljava/util/Date;)Z
move-result v6
const-string v7, "Cookie "
if-nez v6, :cond_9
.line 28
invoke-interface {v1, v5, v2}, Lorg/apache/http/cookie/CookieSpec;->match(Lorg/apache/http/cookie/Cookie;Lorg/apache/http/cookie/CookieOrigin;)Z
move-result v6
if-eqz v6, :cond_7
.line 29
iget-object v6, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
invoke-interface {v6}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z
move-result v6
if-eqz v6, :cond_8
.line 30
iget-object v6, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v7, " match "
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-interface {v6, v7}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V
.line 31
:cond_8
invoke-virtual {v0, v5}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_2
.line 32
:cond_9
iget-object v6, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
invoke-interface {v6}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z
move-result v6
if-eqz v6, :cond_7
.line 33
iget-object v6, p0, Lorg/apache/http/client/protocol/RequestAddCookies;->log:Lorg/apache/commons/logging/Log;
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v5, " expired"
invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-interface {v6, v5}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V
goto :goto_2
.line 34
:cond_a
invoke-virtual {v0}, Ljava/util/ArrayList;->isEmpty()Z
move-result v3
if-nez v3, :cond_b
.line 35
invoke-interface {v1, v0}, Lorg/apache/http/cookie/CookieSpec;->formatCookies(Ljava/util/List;)Ljava/util/List;
move-result-object v3
.line 36
invoke-interface {v3}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_3
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_b
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lorg/apache/http/Header;
.line 37
invoke-interface {p1, v4}, Lorg/apache/http/HttpMessage;->addHeader(Lorg/apache/http/Header;)V
goto :goto_3
.line 38
:cond_b
invoke-interface {v1}, Lorg/apache/http/cookie/CookieSpec;->getVersion()I
move-result v3
if-lez v3, :cond_f
const/4 v4, 0x0
.line 39
invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_c
:goto_4
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v5
if-eqz v5, :cond_e
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v5
check-cast v5, Lorg/apache/http/cookie/Cookie;
.line 40
invoke-interface {v5}, Lorg/apache/http/cookie/Cookie;->getVersion()I
move-result v6
if-ne v3, v6, :cond_d
instance-of v5, v5, Lorg/apache/http/cookie/SetCookie2;
if-nez v5, :cond_c
:cond_d
const/4 v4, 0x1
goto :goto_4
:cond_e
if-eqz v4, :cond_f
.line 41
invoke-interface {v1}, Lorg/apache/http/cookie/CookieSpec;->getVersionHeader()Lorg/apache/http/Header;
move-result-object v0
if-eqz v0, :cond_f
.line 42
invoke-interface {p1, v0}, Lorg/apache/http/HttpMessage;->addHeader(Lorg/apache/http/Header;)V
:cond_f
const-string p1, "http.cookie-spec"
.line 43
invoke-interface {p2, p1, v1}, Lorg/apache/http/protocol/HttpContext;->setAttribute(Ljava/lang/String;Ljava/lang/Object;)V
const-string p1, "http.cookie-origin"
.line 44
invoke-interface {p2, p1, v2}, Lorg/apache/http/protocol/HttpContext;->setAttribute(Ljava/lang/String;Ljava/lang/Object;)V
return-void
:catch_0
move-exception p2
.line 45
new-instance v0, Lorg/apache/http/ProtocolException;
const-string v1, "Invalid request URI: "
invoke-static {v1}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-interface {p1}, Lorg/apache/http/HttpRequest;->getRequestLine()Lorg/apache/http/RequestLine;
move-result-object p1
invoke-interface {p1}, Lorg/apache/http/RequestLine;->getUri()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1, p2}, Lorg/apache/http/ProtocolException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v0
.line 46
:cond_10
new-instance p1, Ljava/lang/IllegalStateException;
const-string p2, "Client connection not specified in HTTP context"
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
.line 47
:cond_11
new-instance p1, Ljava/lang/IllegalStateException;
const-string p2, "Target host not specified in HTTP context"
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
.line 48
:cond_12
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "HTTP context may not be null"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 49
:cond_13
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "HTTP request may not be null"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.end method