.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 ()V .locals 1 .line 1 invoke-direct {p0}, Ljava/lang/Object;->()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;->()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;->(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;->(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;->(Ljava/util/Collection;)V .line 24 new-instance v0, Ljava/util/ArrayList; invoke-direct {v0}, Ljava/util/ArrayList;->()V .line 25 new-instance v4, Ljava/util/Date; invoke-direct {v4}, Ljava/util/Date;->()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;->()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;->()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;->(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;->(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;->(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;->(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;->(Ljava/lang/String;)V throw p1 .end method