.class public Lcom/amazonaws/http/AmazonHttpClient; .super Ljava/lang/Object; .source "AmazonHttpClient.java" # static fields .field private static final HEADER_SDK_RETRY_INFO:Ljava/lang/String; = "aws-sdk-retry" .field private static final HEADER_SDK_TRANSACTION_ID:Ljava/lang/String; = "aws-sdk-invocation-id" .field private static final HEADER_USER_AGENT:Ljava/lang/String; = "User-Agent" .field private static final HTTP_STATUS_MULTIPLE_CHOICES:I = 0x12c .field private static final HTTP_STATUS_OK:I = 0xc8 .field private static final HTTP_STATUS_REQ_TOO_LONG:I = 0x19d .field private static final HTTP_STATUS_SERVICE_UNAVAILABLE:I = 0x1f7 .field private static final HTTP_STATUS_TEMP_REDIRECT:I = 0x133 .field private static final REQUEST_LOG:Lcom/amazonaws/logging/Log; .field private static final TIME_MILLISEC:I = 0x3e8 .field public static final log:Lcom/amazonaws/logging/Log; # instance fields .field public final config:Lcom/amazonaws/ClientConfiguration; .field public final httpClient:Lcom/amazonaws/http/HttpClient; .field private final requestFactory:Lcom/amazonaws/http/HttpRequestFactory; .field private final requestMetricCollector:Lcom/amazonaws/metrics/RequestMetricCollector; # direct methods .method public static constructor ()V .locals 1 const-string v0, "com.amazonaws.request" .line 1 invoke-static {v0}, Lcom/amazonaws/logging/LogFactory;->getLog(Ljava/lang/String;)Lcom/amazonaws/logging/Log; move-result-object v0 sput-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log; .line 2 const-class v0, Lcom/amazonaws/http/AmazonHttpClient; invoke-static {v0}, Lcom/amazonaws/logging/LogFactory;->getLog(Ljava/lang/Class;)Lcom/amazonaws/logging/Log; move-result-object v0 sput-object v0, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; return-void .end method .method public constructor (Lcom/amazonaws/ClientConfiguration;)V .locals 1 .line 1 new-instance v0, Lcom/amazonaws/http/UrlHttpClient; invoke-direct {v0, p1}, Lcom/amazonaws/http/UrlHttpClient;->(Lcom/amazonaws/ClientConfiguration;)V invoke-direct {p0, p1, v0}, Lcom/amazonaws/http/AmazonHttpClient;->(Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;)V return-void .end method .method public constructor (Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;)V .locals 1 .line 3 invoke-direct {p0}, Ljava/lang/Object;->()V .line 4 new-instance v0, Lcom/amazonaws/http/HttpRequestFactory; invoke-direct {v0}, Lcom/amazonaws/http/HttpRequestFactory;->()V iput-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->requestFactory:Lcom/amazonaws/http/HttpRequestFactory; .line 5 iput-object p1, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; .line 6 iput-object p2, p0, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient; const/4 p1, 0x0 .line 7 iput-object p1, p0, Lcom/amazonaws/http/AmazonHttpClient;->requestMetricCollector:Lcom/amazonaws/metrics/RequestMetricCollector; return-void .end method .method public constructor (Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;Lcom/amazonaws/metrics/RequestMetricCollector;)V .locals 1 .annotation runtime Ljava/lang/Deprecated; .end annotation .line 8 invoke-direct {p0}, Ljava/lang/Object;->()V .line 9 new-instance v0, Lcom/amazonaws/http/HttpRequestFactory; invoke-direct {v0}, Lcom/amazonaws/http/HttpRequestFactory;->()V iput-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->requestFactory:Lcom/amazonaws/http/HttpRequestFactory; .line 10 iput-object p1, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; .line 11 iput-object p2, p0, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient; .line 12 iput-object p3, p0, Lcom/amazonaws/http/AmazonHttpClient;->requestMetricCollector:Lcom/amazonaws/metrics/RequestMetricCollector; return-void .end method .method public constructor (Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/metrics/RequestMetricCollector;)V .locals 1 .annotation runtime Ljava/lang/Deprecated; .end annotation .line 2 new-instance v0, Lcom/amazonaws/http/UrlHttpClient; invoke-direct {v0, p1}, Lcom/amazonaws/http/UrlHttpClient;->(Lcom/amazonaws/ClientConfiguration;)V invoke-direct {p0, p1, v0, p2}, Lcom/amazonaws/http/AmazonHttpClient;->(Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;Lcom/amazonaws/metrics/RequestMetricCollector;)V return-void .end method .method public static createUserAgentString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; .locals 1 .line 1 invoke-virtual {p0, p1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z move-result v0 if-eqz v0, :cond_0 return-object p0 .line 2 :cond_0 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V invoke-virtual {p0}, Ljava/lang/String;->trim()Ljava/lang/String; move-result-object p0 invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p0, " " invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/String;->trim()Ljava/lang/String; move-result-object p0 invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p0 return-object p0 .end method .method private getServerDateFromException(Ljava/lang/String;)Ljava/lang/String; .locals 3 const-string v0, "(" .line 1 invoke-virtual {p1, v0}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I move-result v0 const-string v1, " + 15" .line 2 invoke-virtual {p1, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z move-result v2 if-eqz v2, :cond_0 .line 3 invoke-virtual {p1, v1}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I move-result v1 goto :goto_0 :cond_0 const-string v1, " - 15" .line 4 invoke-virtual {p1, v1}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I move-result v1 :goto_0 add-int/lit8 v0, v0, 0x1 .line 5 invoke-virtual {p1, v0, v1}, Ljava/lang/String;->substring(II)Ljava/lang/String; move-result-object p1 return-object p1 .end method .method private handleUnexpectedFailure(Ljava/lang/Throwable;Lcom/amazonaws/util/AWSRequestMetrics;)Ljava/lang/Throwable; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(TT;", "Lcom/amazonaws/util/AWSRequestMetrics;", ")TT;" } .end annotation .line 1 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->Exception:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {p2, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->incrementCounter(Lcom/amazonaws/metrics/MetricType;)V .line 2 invoke-virtual {p2, v0, p1}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V return-object p1 .end method .method private isRequestSuccessful(Lcom/amazonaws/http/HttpResponse;)Z .locals 1 .line 1 invoke-virtual {p1}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result p1 const/16 v0, 0xc8 if-lt p1, v0, :cond_0 const/16 v0, 0x12c if-ge p1, v0, :cond_0 const/4 p1, 0x1 goto :goto_0 :cond_0 const/4 p1, 0x0 :goto_0 return p1 .end method .method private static isTemporaryRedirect(Lcom/amazonaws/http/HttpResponse;)Z .locals 2 .line 1 invoke-virtual {p0}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result v0 .line 2 invoke-virtual {p0}, Lcom/amazonaws/http/HttpResponse;->getHeaders()Ljava/util/Map; move-result-object p0 const-string v1, "Location" invoke-interface {p0, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p0 check-cast p0, Ljava/lang/String; const/16 v1, 0x133 if-ne v0, v1, :cond_0 if-eqz p0, :cond_0 .line 3 invoke-virtual {p0}, Ljava/lang/String;->isEmpty()Z move-result p0 if-nez p0, :cond_0 const/4 p0, 0x1 goto :goto_0 :cond_0 const/4 p0, 0x0 :goto_0 return p0 .end method .method private pauseBeforeNextRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)J .locals 2 add-int/lit8 p3, p3, -0x1 add-int/lit8 p3, p3, -0x1 .line 1 invoke-virtual {p4}, Lcom/amazonaws/retry/RetryPolicy;->getBackoffStrategy()Lcom/amazonaws/retry/RetryPolicy$BackoffStrategy; move-result-object p4 invoke-interface {p4, p1, p2, p3}, Lcom/amazonaws/retry/RetryPolicy$BackoffStrategy;->delayBeforeNextRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;I)J move-result-wide p1 .line 2 sget-object p4, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {p4}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z move-result v0 if-eqz v0, :cond_0 .line 3 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v1, "Retriable error detected, will retry in " invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p1, p2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; const-string v1, "ms, attempt number: " invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p3 invoke-interface {p4, p3}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V .line 4 :cond_0 :try_start_0 invoke-static {p1, p2}, Ljava/lang/Thread;->sleep(J)V :try_end_0 .catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_0} :catch_0 return-wide p1 :catch_0 move-exception p1 .line 5 invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread; move-result-object p2 invoke-virtual {p2}, Ljava/lang/Thread;->interrupt()V .line 6 new-instance p2, Lcom/amazonaws/AmazonClientException; invoke-virtual {p1}, Ljava/lang/InterruptedException;->getMessage()Ljava/lang/String; move-result-object p3 invoke-direct {p2, p3, p1}, Lcom/amazonaws/AmazonClientException;->(Ljava/lang/String;Ljava/lang/Throwable;)V throw p2 .end method .method private shouldRetry(Lcom/amazonaws/AmazonWebServiceRequest;Ljava/io/InputStream;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)Z .locals 2 add-int/lit8 p4, p4, -0x1 .line 1 iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; invoke-virtual {v0}, Lcom/amazonaws/ClientConfiguration;->getMaxErrorRetry()I move-result v0 if-ltz v0, :cond_0 .line 2 invoke-virtual {p5}, Lcom/amazonaws/retry/RetryPolicy;->isMaxErrorRetryInClientConfigHonored()Z move-result v1 if-nez v1, :cond_1 .line 3 :cond_0 invoke-virtual {p5}, Lcom/amazonaws/retry/RetryPolicy;->getMaxErrorRetry()I move-result v0 :cond_1 const/4 v1, 0x0 if-lt p4, v0, :cond_2 return v1 :cond_2 if-eqz p2, :cond_4 .line 4 invoke-virtual {p2}, Ljava/io/InputStream;->markSupported()Z move-result p2 if-nez p2, :cond_4 .line 5 sget-object p1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {p1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z move-result p2 if-eqz p2, :cond_3 const-string p2, "Content not repeatable" .line 6 invoke-interface {p1, p2}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V :cond_3 return v1 .line 7 :cond_4 invoke-virtual {p5}, Lcom/amazonaws/retry/RetryPolicy;->getRetryCondition()Lcom/amazonaws/retry/RetryPolicy$RetryCondition; move-result-object p2 invoke-interface {p2, p1, p3, p4}, Lcom/amazonaws/retry/RetryPolicy$RetryCondition;->shouldRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;I)Z move-result p1 return p1 .end method # virtual methods .method public afterError(Lcom/amazonaws/Request;Lcom/amazonaws/Response;Ljava/util/List;Lcom/amazonaws/AmazonClientException;)V .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Lcom/amazonaws/Response<", "*>;", "Ljava/util/List<", "Lcom/amazonaws/handlers/RequestHandler2;", ">;", "Lcom/amazonaws/AmazonClientException;", ")V" } .end annotation .line 1 invoke-interface {p3}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p3 :goto_0 invoke-interface {p3}, Ljava/util/Iterator;->hasNext()Z move-result v0 if-eqz v0, :cond_0 invoke-interface {p3}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/amazonaws/handlers/RequestHandler2; .line 2 invoke-virtual {v0, p1, p2, p4}, Lcom/amazonaws/handlers/RequestHandler2;->afterError(Lcom/amazonaws/Request;Lcom/amazonaws/Response;Ljava/lang/Exception;)V goto :goto_0 :cond_0 return-void .end method .method public afterResponse(Lcom/amazonaws/Request;Ljava/util/List;Lcom/amazonaws/Response;Lcom/amazonaws/util/TimingInfo;)V .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Ljava/util/List<", "Lcom/amazonaws/handlers/RequestHandler2;", ">;", "Lcom/amazonaws/Response<", "TT;>;", "Lcom/amazonaws/util/TimingInfo;", ")V" } .end annotation .line 1 invoke-interface {p2}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p2 :goto_0 invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z move-result p4 if-eqz p4, :cond_0 invoke-interface {p2}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object p4 check-cast p4, Lcom/amazonaws/handlers/RequestHandler2; .line 2 invoke-virtual {p4, p1, p3}, Lcom/amazonaws/handlers/RequestHandler2;->afterResponse(Lcom/amazonaws/Request;Lcom/amazonaws/Response;)V goto :goto_0 :cond_0 return-void .end method .method public execute(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/ExecutionContext;)Lcom/amazonaws/Response; .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Lcom/amazonaws/http/HttpResponseHandler<", "Lcom/amazonaws/AmazonWebServiceResponse<", "TT;>;>;", "Lcom/amazonaws/http/HttpResponseHandler<", "Lcom/amazonaws/AmazonServiceException;", ">;", "Lcom/amazonaws/http/ExecutionContext;", ")", "Lcom/amazonaws/Response<", "TT;>;" } .end annotation .line 1 invoke-interface {p1}, Lcom/amazonaws/Request;->getHostPrefix()Ljava/lang/String; move-result-object v0 if-eqz v0, :cond_0 .line 2 :try_start_0 invoke-interface {p1}, Lcom/amazonaws/Request;->getEndpoint()Ljava/net/URI; move-result-object v0 .line 3 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V invoke-interface {p1}, Lcom/amazonaws/Request;->getHostPrefix()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/net/URI;->getHost()Ljava/lang/String; move-result-object v2 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 .line 4 invoke-static {v0}, Lcom/amazonaws/util/URIBuilder;->builder(Ljava/net/URI;)Lcom/amazonaws/util/URIBuilder; move-result-object v0 .line 5 invoke-virtual {v0, v1}, Lcom/amazonaws/util/URIBuilder;->host(Ljava/lang/String;)Lcom/amazonaws/util/URIBuilder; move-result-object v0 .line 6 invoke-virtual {v0}, Lcom/amazonaws/util/URIBuilder;->build()Ljava/net/URI; move-result-object v0 .line 7 invoke-interface {p1, v0}, Lcom/amazonaws/Request;->setEndpoint(Ljava/net/URI;)V :try_end_0 .catch Ljava/net/URISyntaxException; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 move-exception v0 .line 8 sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {v1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z move-result v2 if-eqz v2, :cond_0 const-string v2, "Failed to prepend host prefix: " .line 9 invoke-static {v2}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v0}, Ljava/net/URISyntaxException;->getMessage()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-interface {v1, v2, v0}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V :cond_0 :goto_0 if-eqz p4, :cond_1 .line 10 invoke-virtual {p0, p1, p4}, Lcom/amazonaws/http/AmazonHttpClient;->requestHandler2s(Lcom/amazonaws/Request;Lcom/amazonaws/http/ExecutionContext;)Ljava/util/List; move-result-object v0 .line 11 invoke-virtual {p4}, Lcom/amazonaws/http/ExecutionContext;->getAwsRequestMetrics()Lcom/amazonaws/util/AWSRequestMetrics; move-result-object v1 const/4 v2, 0x0 .line 12 :try_start_1 invoke-virtual {p0, p1, p2, p3, p4}, Lcom/amazonaws/http/AmazonHttpClient;->executeHelper(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/ExecutionContext;)Lcom/amazonaws/Response; move-result-object v2 .line 13 invoke-virtual {v1}, Lcom/amazonaws/util/AWSRequestMetrics;->getTimingInfo()Lcom/amazonaws/util/TimingInfo; move-result-object p2 invoke-virtual {p2}, Lcom/amazonaws/util/TimingInfo;->endTiming()Lcom/amazonaws/util/TimingInfo; move-result-object p2 .line 14 invoke-virtual {p0, p1, v0, v2, p2}, Lcom/amazonaws/http/AmazonHttpClient;->afterResponse(Lcom/amazonaws/Request;Ljava/util/List;Lcom/amazonaws/Response;Lcom/amazonaws/util/TimingInfo;)V :try_end_1 .catch Lcom/amazonaws/AmazonClientException; {:try_start_1 .. :try_end_1} :catch_1 return-object v2 :catch_1 move-exception p2 .line 15 invoke-virtual {p0, p1, v2, v0, p2}, Lcom/amazonaws/http/AmazonHttpClient;->afterError(Lcom/amazonaws/Request;Lcom/amazonaws/Response;Ljava/util/List;Lcom/amazonaws/AmazonClientException;)V .line 16 throw p2 .line 17 :cond_1 new-instance p1, Lcom/amazonaws/AmazonClientException; const-string p2, "Internal SDK Error: No execution context parameter specified." invoke-direct {p1, p2}, Lcom/amazonaws/AmazonClientException;->(Ljava/lang/String;)V throw p1 .end method .method public executeHelper(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/ExecutionContext;)Lcom/amazonaws/Response; .locals 26 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Lcom/amazonaws/http/HttpResponseHandler<", "Lcom/amazonaws/AmazonWebServiceResponse<", "TT;>;>;", "Lcom/amazonaws/http/HttpResponseHandler<", "Lcom/amazonaws/AmazonServiceException;", ">;", "Lcom/amazonaws/http/ExecutionContext;", ")", "Lcom/amazonaws/Response<", "TT;>;" } .end annotation move-object/from16 v7, p0 move-object/from16 v8, p1 move-object/from16 v9, p4 .line 1 invoke-virtual/range {p4 .. p4}, Lcom/amazonaws/http/ExecutionContext;->getAwsRequestMetrics()Lcom/amazonaws/util/AWSRequestMetrics; move-result-object v10 .line 2 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->ServiceName:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getServiceName()Ljava/lang/String; move-result-object v1 invoke-virtual {v10, v0, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 3 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->ServiceEndpoint:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getEndpoint()Ljava/net/URI; move-result-object v1 invoke-virtual {v10, v0, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 4 invoke-virtual/range {p0 .. p1}, Lcom/amazonaws/http/AmazonHttpClient;->setUserAgent(Lcom/amazonaws/Request;)V .line 5 invoke-static {}, Ljava/util/UUID;->randomUUID()Ljava/util/UUID; move-result-object v0 invoke-virtual {v0}, Ljava/util/UUID;->toString()Ljava/lang/String; move-result-object v0 const-string v1, "aws-sdk-invocation-id" invoke-interface {v8, v1, v0}, Lcom/amazonaws/Request;->addHeader(Ljava/lang/String;Ljava/lang/String;)V .line 6 new-instance v11, Ljava/util/LinkedHashMap; .line 7 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getParameters()Ljava/util/Map; move-result-object v0 invoke-direct {v11, v0}, Ljava/util/LinkedHashMap;->(Ljava/util/Map;)V .line 8 new-instance v12, Ljava/util/HashMap; invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getHeaders()Ljava/util/Map; move-result-object v0 invoke-direct {v12, v0}, Ljava/util/HashMap;->(Ljava/util/Map;)V .line 9 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream; move-result-object v13 if-eqz v13, :cond_0 .line 10 invoke-virtual {v13}, Ljava/io/InputStream;->markSupported()Z move-result v0 if-eqz v0, :cond_0 const/4 v0, -0x1 .line 11 invoke-virtual {v13, v0}, Ljava/io/InputStream;->mark(I)V .line 12 :cond_0 invoke-virtual/range {p4 .. p4}, Lcom/amazonaws/http/ExecutionContext;->getCredentials()Lcom/amazonaws/auth/AWSCredentials; move-result-object v14 const/4 v0, 0x0 const-wide/16 v1, 0x0 move-wide v2, v1 const/4 v4, 0x0 const/4 v5, 0x0 const/4 v6, 0x0 const/16 v16, 0x0 const/16 v17, 0x0 move v1, v0 :goto_0 const/4 v15, 0x1 move-object/from16 v19, v6 add-int/lit8 v6, v0, 0x1 .line 13 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RequestCount:Lcom/amazonaws/util/AWSRequestMetrics$Field; move/from16 v20, v1 move-wide/from16 v21, v2 int-to-long v1, v6 invoke-virtual {v10, v0, v1, v2}, Lcom/amazonaws/util/AWSRequestMetrics;->setCounter(Lcom/amazonaws/metrics/MetricType;J)V if-le v6, v15, :cond_1 .line 14 invoke-interface {v8, v11}, Lcom/amazonaws/Request;->setParameters(Ljava/util/Map;)V .line 15 invoke-interface {v8, v12}, Lcom/amazonaws/Request;->setHeaders(Ljava/util/Map;)V .line 16 invoke-interface {v8, v13}, Lcom/amazonaws/Request;->setContent(Ljava/io/InputStream;)V :cond_1 if-eqz v16, :cond_2 .line 17 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getEndpoint()Ljava/net/URI; move-result-object v0 if-nez v0, :cond_2 .line 18 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getResourcePath()Ljava/lang/String; move-result-object v0 if-nez v0, :cond_2 .line 19 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V .line 20 invoke-virtual/range {v16 .. v16}, Ljava/net/URI;->getScheme()Ljava/lang/String; move-result-object v1 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; invoke-virtual/range {v16 .. v16}, Ljava/net/URI;->getAuthority()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 .line 21 invoke-static {v0}, Ljava/net/URI;->create(Ljava/lang/String;)Ljava/net/URI; move-result-object v0 invoke-interface {v8, v0}, Lcom/amazonaws/Request;->setEndpoint(Ljava/net/URI;)V .line 22 invoke-virtual/range {v16 .. v16}, Ljava/net/URI;->getPath()Ljava/lang/String; move-result-object v0 invoke-interface {v8, v0}, Lcom/amazonaws/Request;->setResourcePath(Ljava/lang/String;)V :cond_2 const-string v3, "Cannot close the response content." if-le v6, v15, :cond_3 .line 23 :try_start_0 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RetryPauseTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->startEvent(Lcom/amazonaws/metrics/MetricType;)V :try_end_0 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_1 .catch Ljava/lang/RuntimeException; {:try_start_0 .. :try_end_0} :catch_21 .catch Ljava/lang/Error; {:try_start_0 .. :try_end_0} :catch_20 .catchall {:try_start_0 .. :try_end_0} :catchall_1 .line 24 :try_start_1 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest; move-result-object v1 iget-object v2, v7, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; .line 25 invoke-virtual {v2}, Lcom/amazonaws/ClientConfiguration;->getRetryPolicy()Lcom/amazonaws/retry/RetryPolicy; move-result-object v2 .line 26 invoke-direct {v7, v1, v4, v6, v2}, Lcom/amazonaws/http/AmazonHttpClient;->pauseBeforeNextRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)J move-result-wide v1 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 27 :try_start_2 invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V .line 28 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream; move-result-object v0 if-eqz v0, :cond_4 .line 29 invoke-virtual {v0}, Ljava/io/InputStream;->markSupported()Z move-result v4 if-eqz v4, :cond_4 .line 30 invoke-virtual {v0}, Ljava/io/InputStream;->reset()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 .catch Ljava/lang/RuntimeException; {:try_start_2 .. :try_end_2} :catch_21 .catch Ljava/lang/Error; {:try_start_2 .. :try_end_2} :catch_20 .catchall {:try_start_2 .. :try_end_2} :catchall_1 goto :goto_4 :catch_0 move-exception v0 move-wide/from16 v21, v1 goto :goto_1 :catchall_0 move-exception v0 .line 31 :try_start_3 sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RetryPauseTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V .line 32 throw v0 :try_end_3 .catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_1 .catch Ljava/lang/RuntimeException; {:try_start_3 .. :try_end_3} :catch_21 .catch Ljava/lang/Error; {:try_start_3 .. :try_end_3} :catch_20 .catchall {:try_start_3 .. :try_end_3} :catchall_1 :catchall_1 move-exception v0 move-object v2, v0 move-object v9, v3 goto/16 :goto_16 :catch_1 move-exception v0 :goto_1 move-object v9, v3 move-object v15, v5 :goto_2 move/from16 v25, v6 :goto_3 move-object/from16 v23, v11 goto/16 :goto_1e :cond_3 move-wide/from16 v1, v21 :cond_4 :goto_4 :try_start_4 const-string v0, "aws-sdk-retry" .line 33 new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V add-int/lit8 v15, v6, -0x1 invoke-virtual {v4, v15}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v15, "/" invoke-virtual {v4, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 invoke-interface {v8, v0, v4}, Lcom/amazonaws/Request;->addHeader(Ljava/lang/String;Ljava/lang/String;)V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_22 .catch Ljava/lang/RuntimeException; {:try_start_4 .. :try_end_4} :catch_21 .catch Ljava/lang/Error; {:try_start_4 .. :try_end_4} :catch_20 .catchall {:try_start_4 .. :try_end_4} :catchall_b if-nez v5, :cond_5 .line 34 :try_start_5 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getEndpoint()Ljava/net/URI; move-result-object v0 invoke-virtual {v9, v0}, Lcom/amazonaws/http/ExecutionContext;->getSignerByURI(Ljava/net/URI;)Lcom/amazonaws/auth/Signer; move-result-object v0 :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_0 .catch Ljava/lang/RuntimeException; {:try_start_5 .. :try_end_5} :catch_21 .catch Ljava/lang/Error; {:try_start_5 .. :try_end_5} :catch_20 .catchall {:try_start_5 .. :try_end_5} :catchall_1 move-object v15, v0 goto :goto_5 :cond_5 move-object v15, v5 :goto_5 if-eqz v15, :cond_6 if-eqz v14, :cond_6 .line 35 :try_start_6 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RequestSigningTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->startEvent(Lcom/amazonaws/metrics/MetricType;)V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_1f .catch Ljava/lang/RuntimeException; {:try_start_6 .. :try_end_6} :catch_21 .catch Ljava/lang/Error; {:try_start_6 .. :try_end_6} :catch_20 .catchall {:try_start_6 .. :try_end_6} :catchall_1 .line 36 :try_start_7 invoke-interface {v15, v8, v14}, Lcom/amazonaws/auth/Signer;->sign(Lcom/amazonaws/Request;Lcom/amazonaws/auth/AWSCredentials;)V :try_end_7 .catchall {:try_start_7 .. :try_end_7} :catchall_2 .line 37 :try_start_8 invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V goto :goto_6 :catchall_2 move-exception v0 move-object v4, v0 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RequestSigningTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V .line 38 throw v4 :try_end_8 .catch Ljava/io/IOException; {:try_start_8 .. :try_end_8} :catch_1f .catch Ljava/lang/RuntimeException; {:try_start_8 .. :try_end_8} :catch_21 .catch Ljava/lang/Error; {:try_start_8 .. :try_end_8} :catch_20 .catchall {:try_start_8 .. :try_end_8} :catchall_1 .line 39 :cond_6 :goto_6 :try_start_9 sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log; invoke-interface {v0}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z move-result v4 :try_end_9 .catch Ljava/io/IOException; {:try_start_9 .. :try_end_9} :catch_1f .catch Ljava/lang/RuntimeException; {:try_start_9 .. :try_end_9} :catch_21 .catch Ljava/lang/Error; {:try_start_9 .. :try_end_9} :catch_20 .catchall {:try_start_9 .. :try_end_9} :catchall_b if-eqz v4, :cond_7 .line 40 :try_start_a new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "Sending Request: " invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual/range {p1 .. p1}, Ljava/lang/Object;->toString()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-interface {v0, v4}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V :try_end_a .catch Ljava/io/IOException; {:try_start_a .. :try_end_a} :catch_1f .catch Ljava/lang/RuntimeException; {:try_start_a .. :try_end_a} :catch_21 .catch Ljava/lang/Error; {:try_start_a .. :try_end_a} :catch_20 .catchall {:try_start_a .. :try_end_a} :catchall_1 .line 41 :cond_7 :try_start_b iget-object v0, v7, Lcom/amazonaws/http/AmazonHttpClient;->requestFactory:Lcom/amazonaws/http/HttpRequestFactory; iget-object v4, v7, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; invoke-virtual {v0, v8, v4, v9}, Lcom/amazonaws/http/HttpRequestFactory;->createHttpRequest(Lcom/amazonaws/Request;Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/ExecutionContext;)Lcom/amazonaws/http/HttpRequest; move-result-object v5 :try_end_b .catch Ljava/io/IOException; {:try_start_b .. :try_end_b} :catch_1f .catch Ljava/lang/RuntimeException; {:try_start_b .. :try_end_b} :catch_21 .catch Ljava/lang/Error; {:try_start_b .. :try_end_b} :catch_20 .catchall {:try_start_b .. :try_end_b} :catchall_b .line 42 :try_start_c sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->HttpRequestTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->startEvent(Lcom/amazonaws/metrics/MetricType;)V :try_end_c .catch Ljava/io/IOException; {:try_start_c .. :try_end_c} :catch_1e .catch Ljava/lang/RuntimeException; {:try_start_c .. :try_end_c} :catch_21 .catch Ljava/lang/Error; {:try_start_c .. :try_end_c} :catch_20 .catchall {:try_start_c .. :try_end_c} :catchall_b .line 43 :try_start_d iget-object v4, v7, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient; invoke-interface {v4, v5}, Lcom/amazonaws/http/HttpClient;->execute(Lcom/amazonaws/http/HttpRequest;)Lcom/amazonaws/http/HttpResponse; move-result-object v4 :try_end_d .catchall {:try_start_d .. :try_end_d} :catchall_a .line 44 :try_start_e invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V .line 45 invoke-direct {v7, v4}, Lcom/amazonaws/http/AmazonHttpClient;->isRequestSuccessful(Lcom/amazonaws/http/HttpResponse;)Z move-result v0 :try_end_e .catch Ljava/io/IOException; {:try_start_e .. :try_end_e} :catch_1a .catch Ljava/lang/RuntimeException; {:try_start_e .. :try_end_e} :catch_19 .catch Ljava/lang/Error; {:try_start_e .. :try_end_e} :catch_18 .catchall {:try_start_e .. :try_end_e} :catchall_9 if-eqz v0, :cond_9 .line 46 :try_start_f sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->StatusCode:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v4}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result v17 :try_end_f .catch Ljava/io/IOException; {:try_start_f .. :try_end_f} :catch_8 .catch Ljava/lang/RuntimeException; {:try_start_f .. :try_end_f} :catch_7 .catch Ljava/lang/Error; {:try_start_f .. :try_end_f} :catch_6 .catchall {:try_start_f .. :try_end_f} :catchall_4 move-wide/from16 v21, v1 :try_start_10 invoke-static/range {v17 .. v17}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v1 invoke-virtual {v10, v0, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 47 invoke-interface/range {p2 .. p2}, Lcom/amazonaws/http/HttpResponseHandler;->needsConnectionLeftOpen()Z move-result v1 :try_end_10 .catch Ljava/io/IOException; {:try_start_10 .. :try_end_10} :catch_c .catch Ljava/lang/RuntimeException; {:try_start_10 .. :try_end_10} :catch_7 .catch Ljava/lang/Error; {:try_start_10 .. :try_end_10} :catch_6 .catchall {:try_start_10 .. :try_end_10} :catchall_4 move-object/from16 v2, p2 .line 48 :try_start_11 invoke-virtual {v7, v8, v2, v4, v9}, Lcom/amazonaws/http/AmazonHttpClient;->handleResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/http/ExecutionContext;)Ljava/lang/Object; move-result-object v0 .line 49 new-instance v2, Lcom/amazonaws/Response; invoke-direct {v2, v0, v4}, Lcom/amazonaws/Response;->(Ljava/lang/Object;Lcom/amazonaws/http/HttpResponse;)V :try_end_11 .catch Ljava/io/IOException; {:try_start_11 .. :try_end_11} :catch_5 .catch Ljava/lang/RuntimeException; {:try_start_11 .. :try_end_11} :catch_4 .catch Ljava/lang/Error; {:try_start_11 .. :try_end_11} :catch_3 .catchall {:try_start_11 .. :try_end_11} :catchall_3 if-nez v1, :cond_8 .line 50 :try_start_12 invoke-virtual {v4}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 if-eqz v0, :cond_8 .line 51 invoke-virtual {v4}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 invoke-virtual {v0}, Ljava/io/InputStream;->close()V :try_end_12 .catch Ljava/io/IOException; {:try_start_12 .. :try_end_12} :catch_2 goto :goto_7 :catch_2 move-exception v0 .line 52 sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {v1, v3, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V :cond_8 :goto_7 return-object v2 :catchall_3 move-exception v0 move-object v2, v0 move-object v9, v3 move-object v6, v4 goto/16 :goto_21 :catch_3 move-exception v0 move-object v9, v3 move-object v6, v4 goto/16 :goto_1a :catch_4 move-exception v0 move-object v9, v3 move-object v6, v4 goto/16 :goto_1d :catch_5 move-exception v0 move/from16 v20, v1 goto :goto_8 :catchall_4 move-exception v0 move-object v2, v0 move-object v9, v3 move-object v6, v4 goto/16 :goto_17 :catch_6 move-exception v0 move-object v9, v3 move-object v6, v4 goto/16 :goto_19 :catch_7 move-exception v0 move-object v9, v3 move-object v6, v4 goto/16 :goto_1c :catch_8 move-exception v0 move-wide/from16 v21, v1 :goto_8 move-object v9, v3 move-object/from16 v19, v4 move-object/from16 v17, v5 goto/16 :goto_2 :cond_9 move-wide/from16 v21, v1 .line 53 :try_start_13 invoke-static {v4}, Lcom/amazonaws/http/AmazonHttpClient;->isTemporaryRedirect(Lcom/amazonaws/http/HttpResponse;)Z move-result v0 :try_end_13 .catch Ljava/io/IOException; {:try_start_13 .. :try_end_13} :catch_17 .catch Ljava/lang/RuntimeException; {:try_start_13 .. :try_end_13} :catch_19 .catch Ljava/lang/Error; {:try_start_13 .. :try_end_13} :catch_18 .catchall {:try_start_13 .. :try_end_13} :catchall_9 if-eqz v0, :cond_a .line 54 :try_start_14 invoke-virtual {v4}, Lcom/amazonaws/http/HttpResponse;->getHeaders()Ljava/util/Map; move-result-object v0 const-string v1, "Location" invoke-interface {v0, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/String; .line 55 sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V :try_end_14 .catch Ljava/io/IOException; {:try_start_14 .. :try_end_14} :catch_c .catch Ljava/lang/RuntimeException; {:try_start_14 .. :try_end_14} :catch_7 .catch Ljava/lang/Error; {:try_start_14 .. :try_end_14} :catch_6 .catchall {:try_start_14 .. :try_end_14} :catchall_4 move-object/from16 v23, v3 :try_start_15 const-string v3, "Redirecting to: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2, v0}, 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-interface {v1, v2}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V .line 56 invoke-static {v0}, Ljava/net/URI;->create(Ljava/lang/String;)Ljava/net/URI; move-result-object v16 const/4 v1, 0x0 .line 57 invoke-interface {v8, v1}, Lcom/amazonaws/Request;->setEndpoint(Ljava/net/URI;)V .line 58 invoke-interface {v8, v1}, Lcom/amazonaws/Request;->setResourcePath(Ljava/lang/String;)V .line 59 sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->StatusCode:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v4}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result v2 invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v2 invoke-virtual {v10, v1, v2}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 60 sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RedirectLocation:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v1, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 61 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->AWSRequestID:Lcom/amazonaws/util/AWSRequestMetrics$Field; const/4 v1, 0x0 invoke-virtual {v10, v0, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V :try_end_15 .catch Ljava/io/IOException; {:try_start_15 .. :try_end_15} :catch_b .catch Ljava/lang/RuntimeException; {:try_start_15 .. :try_end_15} :catch_a .catch Ljava/lang/Error; {:try_start_15 .. :try_end_15} :catch_9 .catchall {:try_start_15 .. :try_end_15} :catchall_5 move-object/from16 v24, v5 move/from16 v25, v6 move/from16 v1, v20 move-object/from16 v9, v23 const/4 v2, 0x0 move-object/from16 v23, v11 move-object v11, v4 goto/16 :goto_9 :catchall_5 move-exception v0 move-object v2, v0 move-object v6, v4 move/from16 v1, v20 move-object/from16 v9, v23 goto/16 :goto_21 :catch_9 move-exception v0 move-object v6, v4 move/from16 v1, v20 move-object/from16 v9, v23 goto/16 :goto_1a :catch_a move-exception v0 move-object v6, v4 move/from16 v1, v20 move-object/from16 v9, v23 goto/16 :goto_1d :catch_b move-exception v0 move-object/from16 v19, v4 move-object/from16 v17, v5 move/from16 v25, v6 move-object/from16 v9, v23 goto/16 :goto_3 :catch_c move-exception v0 goto/16 :goto_8 :cond_a move-object/from16 v23, v3 .line 62 :try_start_16 invoke-interface/range {p3 .. p3}, Lcom/amazonaws/http/HttpResponseHandler;->needsConnectionLeftOpen()Z move-result v17 :try_end_16 .catch Ljava/io/IOException; {:try_start_16 .. :try_end_16} :catch_16 .catch Ljava/lang/RuntimeException; {:try_start_16 .. :try_end_16} :catch_15 .catch Ljava/lang/Error; {:try_start_16 .. :try_end_16} :catch_14 .catchall {:try_start_16 .. :try_end_16} :catchall_8 move-object/from16 v3, p3 .line 63 :try_start_17 invoke-virtual {v7, v8, v3, v4}, Lcom/amazonaws/http/AmazonHttpClient;->handleErrorResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/AmazonServiceException; move-result-object v0 .line 64 sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->AWSRequestID:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v0}, Lcom/amazonaws/AmazonServiceException;->getRequestId()Ljava/lang/String; move-result-object v2 invoke-virtual {v10, v1, v2}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 65 sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->AWSErrorCode:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v0}, Lcom/amazonaws/AmazonServiceException;->getErrorCode()Ljava/lang/String; move-result-object v2 invoke-virtual {v10, v1, v2}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 66 sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->StatusCode:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v0}, Lcom/amazonaws/AmazonServiceException;->getStatusCode()I move-result v2 invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v2 invoke-virtual {v10, v1, v2}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 67 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest; move-result-object v2 .line 68 invoke-virtual {v5}, Lcom/amazonaws/http/HttpRequest;->getContent()Ljava/io/InputStream; move-result-object v19 iget-object v1, v7, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; .line 69 invoke-virtual {v1}, Lcom/amazonaws/ClientConfiguration;->getRetryPolicy()Lcom/amazonaws/retry/RetryPolicy; move-result-object v20 :try_end_17 .catch Ljava/io/IOException; {:try_start_17 .. :try_end_17} :catch_13 .catch Ljava/lang/RuntimeException; {:try_start_17 .. :try_end_17} :catch_12 .catch Ljava/lang/Error; {:try_start_17 .. :try_end_17} :catch_11 .catchall {:try_start_17 .. :try_end_17} :catchall_7 move-object/from16 v1, p0 move-object/from16 v9, v23 move-object/from16 v3, v19 move-object/from16 v23, v11 move-object v11, v4 move-object v4, v0 move-object/from16 v24, v5 move v5, v6 move/from16 v25, v6 move-object/from16 v6, v20 .line 70 :try_start_18 invoke-direct/range {v1 .. v6}, Lcom/amazonaws/http/AmazonHttpClient;->shouldRetry(Lcom/amazonaws/AmazonWebServiceRequest;Ljava/io/InputStream;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)Z move-result v1 if-eqz v1, :cond_d .line 71 invoke-static {v0}, Lcom/amazonaws/retry/RetryUtils;->isClockSkewError(Lcom/amazonaws/AmazonServiceException;)Z move-result v1 if-eqz v1, :cond_b .line 72 invoke-virtual {v7, v11, v0}, Lcom/amazonaws/http/AmazonHttpClient;->parseClockSkewOffset(Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/AmazonServiceException;)I move-result v1 .line 73 invoke-static {v1}, Lcom/amazonaws/SDKGlobalConfiguration;->setGlobalTimeOffset(I)V .line 74 :cond_b invoke-virtual {v7, v8, v0}, Lcom/amazonaws/http/AmazonHttpClient;->resetRequestAfterError(Lcom/amazonaws/Request;Ljava/lang/Exception;)V :try_end_18 .catch Ljava/io/IOException; {:try_start_18 .. :try_end_18} :catch_10 .catch Ljava/lang/RuntimeException; {:try_start_18 .. :try_end_18} :catch_f .catch Ljava/lang/Error; {:try_start_18 .. :try_end_18} :catch_e .catchall {:try_start_18 .. :try_end_18} :catchall_6 move-object v2, v0 move/from16 v1, v17 :goto_9 if-nez v1, :cond_c if-eqz v11, :cond_c .line 75 :try_start_19 invoke-virtual {v11}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 if-eqz v0, :cond_c .line 76 invoke-virtual {v11}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 invoke-virtual {v0}, Ljava/io/InputStream;->close()V :try_end_19 .catch Ljava/io/IOException; {:try_start_19 .. :try_end_19} :catch_d goto :goto_a :catch_d move-exception v0 .line 77 sget-object v3, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {v3, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V :cond_c :goto_a move-object v4, v2 move-object v6, v11 move-object v5, v15 move-wide/from16 v2, v21 move-object/from16 v17, v24 const/4 v11, 0x0 goto/16 :goto_20 .line 78 :cond_d :try_start_1a throw v0 :try_end_1a .catch Ljava/io/IOException; {:try_start_1a .. :try_end_1a} :catch_10 .catch Ljava/lang/RuntimeException; {:try_start_1a .. :try_end_1a} :catch_f .catch Ljava/lang/Error; {:try_start_1a .. :try_end_1a} :catch_e .catchall {:try_start_1a .. :try_end_1a} :catchall_6 :catchall_6 move-exception v0 goto :goto_b :catch_e move-exception v0 goto :goto_c :catch_f move-exception v0 goto :goto_d :catch_10 move-exception v0 goto :goto_e :catchall_7 move-exception v0 move-object v11, v4 move-object/from16 v9, v23 :goto_b move-object v2, v0 move-object v6, v11 move/from16 v1, v17 goto/16 :goto_21 :catch_11 move-exception v0 move-object v11, v4 move-object/from16 v9, v23 :goto_c move-object v6, v11 move/from16 v1, v17 goto/16 :goto_1a :catch_12 move-exception v0 move-object v11, v4 move-object/from16 v9, v23 :goto_d move-object v6, v11 move/from16 v1, v17 goto/16 :goto_1d :catch_13 move-exception v0 move-object/from16 v24, v5 move/from16 v25, v6 move-object/from16 v9, v23 move-object/from16 v23, v11 move-object v11, v4 :goto_e move-object/from16 v19, v11 move/from16 v20, v17 goto/16 :goto_14 :catchall_8 move-exception v0 move-object v11, v4 move-object/from16 v9, v23 goto :goto_f :catch_14 move-exception v0 move-object v11, v4 move-object/from16 v9, v23 goto :goto_10 :catch_15 move-exception v0 move-object v11, v4 move-object/from16 v9, v23 goto :goto_11 :catch_16 move-exception v0 move-object/from16 v24, v5 move/from16 v25, v6 move-object/from16 v9, v23 goto :goto_13 :catch_17 move-exception v0 goto :goto_12 :catchall_9 move-exception v0 move-object v9, v3 move-object v11, v4 :goto_f move-object v2, v0 move-object v6, v11 goto/16 :goto_17 :catch_18 move-exception v0 move-object v9, v3 move-object v11, v4 :goto_10 move-object v6, v11 goto/16 :goto_19 :catch_19 move-exception v0 move-object v9, v3 move-object v11, v4 :goto_11 move-object v6, v11 goto/16 :goto_1c :catch_1a move-exception v0 move-wide/from16 v21, v1 :goto_12 move-object v9, v3 move-object/from16 v24, v5 move/from16 v25, v6 :goto_13 move-object/from16 v23, v11 move-object v11, v4 move-object/from16 v19, v11 goto :goto_14 :catchall_a move-exception v0 move-wide/from16 v21, v1 move-object v9, v3 move-object/from16 v24, v5 move/from16 v25, v6 move-object/from16 v23, v11 .line 79 :try_start_1b sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->HttpRequestTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V .line 80 throw v0 :try_end_1b .catch Ljava/io/IOException; {:try_start_1b .. :try_end_1b} :catch_1d .catch Ljava/lang/RuntimeException; {:try_start_1b .. :try_end_1b} :catch_1c .catch Ljava/lang/Error; {:try_start_1b .. :try_end_1b} :catch_1b .catchall {:try_start_1b .. :try_end_1b} :catchall_d :catch_1b move-exception v0 goto :goto_18 :catch_1c move-exception v0 goto :goto_1b :catch_1d move-exception v0 goto :goto_14 :catch_1e move-exception v0 move-wide/from16 v21, v1 move-object v9, v3 move-object/from16 v24, v5 move/from16 v25, v6 move-object/from16 v23, v11 :goto_14 move-object/from16 v17, v24 goto :goto_1e :catch_1f move-exception v0 move-wide/from16 v21, v1 move-object v9, v3 goto/16 :goto_2 :catchall_b move-exception v0 move-object v9, v3 :goto_15 move-object v2, v0 :goto_16 move-object/from16 v6, v19 :goto_17 move/from16 v1, v20 goto/16 :goto_21 :catch_20 move-exception v0 move-object v9, v3 :goto_18 move-object/from16 v6, v19 :goto_19 move/from16 v1, v20 .line 81 :goto_1a :try_start_1c invoke-direct {v7, v0, v10}, Lcom/amazonaws/http/AmazonHttpClient;->handleUnexpectedFailure(Ljava/lang/Throwable;Lcom/amazonaws/util/AWSRequestMetrics;)Ljava/lang/Throwable; move-result-object v0 check-cast v0, Ljava/lang/Error; throw v0 :catch_21 move-exception v0 move-object v9, v3 :goto_1b move-object/from16 v6, v19 :goto_1c move/from16 v1, v20 .line 82 :goto_1d invoke-direct {v7, v0, v10}, Lcom/amazonaws/http/AmazonHttpClient;->handleUnexpectedFailure(Ljava/lang/Throwable;Lcom/amazonaws/util/AWSRequestMetrics;)Ljava/lang/Throwable; move-result-object v0 check-cast v0, Ljava/lang/RuntimeException; throw v0 :try_end_1c .catchall {:try_start_1c .. :try_end_1c} :catchall_c :catchall_c move-exception v0 move-object v2, v0 goto/16 :goto_21 :catch_22 move-exception v0 move-wide/from16 v21, v1 move-object v9, v3 move/from16 v25, v6 move-object/from16 v23, v11 move-object v15, v5 .line 83 :goto_1e :try_start_1d sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {v1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z move-result v2 :try_end_1d .catchall {:try_start_1d .. :try_end_1d} :catchall_d const-string v3, "Unable to execute HTTP request: " if-eqz v2, :cond_e .line 84 :try_start_1e new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v4 invoke-virtual {v2, v4}, 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-interface {v1, v2, v0}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V .line 85 :cond_e sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->Exception:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {v10, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->incrementCounter(Lcom/amazonaws/metrics/MetricType;)V .line 86 invoke-virtual {v10, v1, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 87 sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->AWSRequestID:Lcom/amazonaws/util/AWSRequestMetrics$Field; const/4 v11, 0x0 invoke-virtual {v10, v1, v11}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 88 new-instance v6, Lcom/amazonaws/AmazonClientException; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 89 invoke-virtual {v0}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v2 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-direct {v6, v1, v0}, Lcom/amazonaws/AmazonClientException;->(Ljava/lang/String;Ljava/lang/Throwable;)V .line 90 invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest; move-result-object v2 .line 91 invoke-virtual/range {v17 .. v17}, Lcom/amazonaws/http/HttpRequest;->getContent()Ljava/io/InputStream; move-result-object v3 iget-object v1, v7, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; .line 92 invoke-virtual {v1}, Lcom/amazonaws/ClientConfiguration;->getRetryPolicy()Lcom/amazonaws/retry/RetryPolicy; move-result-object v18 move-object/from16 v1, p0 move-object v4, v6 move/from16 v5, v25 move-object/from16 v24, v6 move-object/from16 v6, v18 .line 93 invoke-direct/range {v1 .. v6}, Lcom/amazonaws/http/AmazonHttpClient;->shouldRetry(Lcom/amazonaws/AmazonWebServiceRequest;Ljava/io/InputStream;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)Z move-result v1 if-eqz v1, :cond_10 .line 94 invoke-virtual {v7, v8, v0}, Lcom/amazonaws/http/AmazonHttpClient;->resetRequestAfterError(Lcom/amazonaws/Request;Ljava/lang/Exception;)V :try_end_1e .catchall {:try_start_1e .. :try_end_1e} :catchall_d if-nez v20, :cond_f if-eqz v19, :cond_f .line 95 :try_start_1f invoke-virtual/range {v19 .. v19}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 if-eqz v0, :cond_f .line 96 invoke-virtual/range {v19 .. v19}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 invoke-virtual {v0}, Ljava/io/InputStream;->close()V :try_end_1f .catch Ljava/io/IOException; {:try_start_1f .. :try_end_1f} :catch_23 goto :goto_1f :catch_23 move-exception v0 .line 97 sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {v1, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V :cond_f :goto_1f move-object v5, v15 move-object/from16 v6, v19 move/from16 v1, v20 move-wide/from16 v2, v21 move-object/from16 v4, v24 :goto_20 move-object/from16 v9, p4 move-object/from16 v11, v23 move/from16 v0, v25 goto/16 :goto_0 .line 98 :cond_10 :try_start_20 throw v24 :try_end_20 .catchall {:try_start_20 .. :try_end_20} :catchall_d :catchall_d move-exception v0 goto/16 :goto_15 :goto_21 if-nez v1, :cond_11 if-eqz v6, :cond_11 .line 99 :try_start_21 invoke-virtual {v6}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 if-eqz v0, :cond_11 .line 100 invoke-virtual {v6}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream; move-result-object v0 invoke-virtual {v0}, Ljava/io/InputStream;->close()V :try_end_21 .catch Ljava/io/IOException; {:try_start_21 .. :try_end_21} :catch_24 goto :goto_22 :catch_24 move-exception v0 .line 101 sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; invoke-interface {v1, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V .line 102 :cond_11 :goto_22 throw v2 .end method .method public finalize()V .locals 0 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/Throwable; } .end annotation .line 1 invoke-virtual {p0}, Lcom/amazonaws/http/AmazonHttpClient;->shutdown()V .line 2 invoke-super {p0}, Ljava/lang/Object;->finalize()V return-void .end method .method public getRequestMetricCollector()Lcom/amazonaws/metrics/RequestMetricCollector; .locals 1 .line 1 iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->requestMetricCollector:Lcom/amazonaws/metrics/RequestMetricCollector; return-object v0 .end method .method public getResponseMetadataForRequest(Lcom/amazonaws/AmazonWebServiceRequest;)Lcom/amazonaws/ResponseMetadata; .locals 0 .annotation runtime Ljava/lang/Deprecated; .end annotation const/4 p1, 0x0 return-object p1 .end method .method public handleErrorResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/AmazonServiceException; .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Lcom/amazonaws/http/HttpResponseHandler<", "Lcom/amazonaws/AmazonServiceException;", ">;", "Lcom/amazonaws/http/HttpResponse;", ")", "Lcom/amazonaws/AmazonServiceException;" } .end annotation .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 1 invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result v0 .line 2 :try_start_0 invoke-interface {p2, p3}, Lcom/amazonaws/http/HttpResponseHandler;->handle(Lcom/amazonaws/http/HttpResponse;)Ljava/lang/Object; move-result-object p2 check-cast p2, Lcom/amazonaws/AmazonServiceException; .line 3 sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log; new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "Received error response: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/RuntimeException;->toString()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-interface {v1, v2}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 move-exception p2 const/16 v1, 0x19d if-ne v0, v1, :cond_0 .line 4 new-instance p2, Lcom/amazonaws/AmazonServiceException; const-string p3, "Request entity too large" invoke-direct {p2, p3}, Lcom/amazonaws/AmazonServiceException;->(Ljava/lang/String;)V .line 5 invoke-interface {p1}, Lcom/amazonaws/Request;->getServiceName()Ljava/lang/String; move-result-object v2 invoke-virtual {p2, v2}, Lcom/amazonaws/AmazonServiceException;->setServiceName(Ljava/lang/String;)V .line 6 invoke-virtual {p2, v1}, Lcom/amazonaws/AmazonServiceException;->setStatusCode(I)V .line 7 sget-object v1, Lcom/amazonaws/AmazonServiceException$ErrorType;->Client:Lcom/amazonaws/AmazonServiceException$ErrorType; invoke-virtual {p2, v1}, Lcom/amazonaws/AmazonServiceException;->setErrorType(Lcom/amazonaws/AmazonServiceException$ErrorType;)V .line 8 invoke-virtual {p2, p3}, Lcom/amazonaws/AmazonServiceException;->setErrorCode(Ljava/lang/String;)V goto :goto_0 :cond_0 const/16 v1, 0x1f7 if-ne v0, v1, :cond_1 .line 9 invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusText()Ljava/lang/String; move-result-object v2 const-string v3, "Service Unavailable" invoke-virtual {v3, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result v2 if-eqz v2, :cond_1 .line 10 new-instance p2, Lcom/amazonaws/AmazonServiceException; const-string p3, "Service unavailable" invoke-direct {p2, p3}, Lcom/amazonaws/AmazonServiceException;->(Ljava/lang/String;)V .line 11 invoke-interface {p1}, Lcom/amazonaws/Request;->getServiceName()Ljava/lang/String; move-result-object v2 invoke-virtual {p2, v2}, Lcom/amazonaws/AmazonServiceException;->setServiceName(Ljava/lang/String;)V .line 12 invoke-virtual {p2, v1}, Lcom/amazonaws/AmazonServiceException;->setStatusCode(I)V .line 13 sget-object v1, Lcom/amazonaws/AmazonServiceException$ErrorType;->Service:Lcom/amazonaws/AmazonServiceException$ErrorType; invoke-virtual {p2, v1}, Lcom/amazonaws/AmazonServiceException;->setErrorType(Lcom/amazonaws/AmazonServiceException$ErrorType;)V .line 14 invoke-virtual {p2, p3}, Lcom/amazonaws/AmazonServiceException;->setErrorCode(Ljava/lang/String;)V .line 15 :goto_0 invoke-virtual {p2, v0}, Lcom/amazonaws/AmazonServiceException;->setStatusCode(I)V .line 16 invoke-interface {p1}, Lcom/amazonaws/Request;->getServiceName()Ljava/lang/String; move-result-object p1 invoke-virtual {p2, p1}, Lcom/amazonaws/AmazonServiceException;->setServiceName(Ljava/lang/String;)V .line 17 invoke-virtual {p2}, Ljava/lang/RuntimeException;->fillInStackTrace()Ljava/lang/Throwable; return-object p2 .line 18 :cond_1 instance-of p1, p2, Ljava/io/IOException; if-eqz p1, :cond_2 .line 19 check-cast p2, Ljava/io/IOException; throw p2 :cond_2 const-string p1, "Unable to unmarshall error response (" .line 20 invoke-static {p1}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p2}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v1 invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v1, "). Response Code: " invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v0, ", Response Text: " invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 21 invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusText()Ljava/lang/String; move-result-object v0 invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v0, ", Response Headers: " invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 22 invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getHeaders()Ljava/util/Map; move-result-object p3 invoke-virtual {p1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 .line 23 new-instance p3, Lcom/amazonaws/AmazonClientException; invoke-direct {p3, p1, p2}, Lcom/amazonaws/AmazonClientException;->(Ljava/lang/String;Ljava/lang/Throwable;)V throw p3 .end method .method public handleResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/http/ExecutionContext;)Ljava/lang/Object; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Lcom/amazonaws/http/HttpResponseHandler<", "Lcom/amazonaws/AmazonWebServiceResponse<", "TT;>;>;", "Lcom/amazonaws/http/HttpResponse;", "Lcom/amazonaws/http/ExecutionContext;", ")TT;" } .end annotation .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation const-string p1, ", Response Text: " .line 1 :try_start_0 invoke-virtual {p4}, Lcom/amazonaws/http/ExecutionContext;->getAwsRequestMetrics()Lcom/amazonaws/util/AWSRequestMetrics; move-result-object p4 .line 2 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->ResponseProcessingTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {p4, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->startEvent(Lcom/amazonaws/metrics/MetricType;)V :try_end_0 .catch Lcom/amazonaws/internal/CRC32MismatchException; {:try_start_0 .. :try_end_0} :catch_2 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_1 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 3 :try_start_1 invoke-interface {p2, p3}, Lcom/amazonaws/http/HttpResponseHandler;->handle(Lcom/amazonaws/http/HttpResponse;)Ljava/lang/Object; move-result-object p2 check-cast p2, Lcom/amazonaws/AmazonWebServiceResponse; :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 4 :try_start_2 invoke-virtual {p4, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V if-eqz p2, :cond_1 .line 5 sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log; invoke-interface {v0}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z move-result v1 if-eqz v1, :cond_0 .line 6 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "Received successful response: " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v2, ", AWS Request ID: " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 7 invoke-virtual {p2}, Lcom/amazonaws/AmazonWebServiceResponse;->getRequestId()Ljava/lang/String; move-result-object v2 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 .line 8 invoke-interface {v0, v1}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V .line 9 :cond_0 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->AWSRequestID:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {p2}, Lcom/amazonaws/AmazonWebServiceResponse;->getRequestId()Ljava/lang/String; move-result-object v1 invoke-virtual {p4, v0, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V .line 10 invoke-virtual {p2}, Lcom/amazonaws/AmazonWebServiceResponse;->getResult()Ljava/lang/Object; move-result-object p1 return-object p1 .line 11 :cond_1 new-instance p2, Ljava/lang/RuntimeException; new-instance p4, Ljava/lang/StringBuilder; invoke-direct {p4}, Ljava/lang/StringBuilder;->()V const-string v0, "Unable to unmarshall response metadata. Response Code: " invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 12 invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result v0 invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {p4, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 13 invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusText()Ljava/lang/String; move-result-object v0 invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p4 invoke-direct {p2, p4}, Ljava/lang/RuntimeException;->(Ljava/lang/String;)V throw p2 :catchall_0 move-exception p2 .line 14 sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->ResponseProcessingTime:Lcom/amazonaws/util/AWSRequestMetrics$Field; invoke-virtual {p4, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V .line 15 throw p2 :try_end_2 .catch Lcom/amazonaws/internal/CRC32MismatchException; {:try_start_2 .. :try_end_2} :catch_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_1 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_0 :catch_0 move-exception p2 const-string p4, "Unable to unmarshall response (" .line 16 invoke-static {p4}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p4 invoke-virtual {p2}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v0 invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v0, "). Response Code: " invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 17 invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I move-result v0 invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {p4, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusText()Ljava/lang/String; move-result-object 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 .line 18 new-instance p3, Lcom/amazonaws/AmazonClientException; invoke-direct {p3, p1, p2}, Lcom/amazonaws/AmazonClientException;->(Ljava/lang/String;Ljava/lang/Throwable;)V throw p3 :catch_1 move-exception p1 .line 19 throw p1 :catch_2 move-exception p1 .line 20 throw p1 .end method .method public parseClockSkewOffset(Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/AmazonServiceException;)I .locals 3 .line 1 new-instance v0, Ljava/util/Date; invoke-direct {v0}, Ljava/util/Date;->()V .line 2 invoke-virtual {p1}, Lcom/amazonaws/http/HttpResponse;->getHeaders()Ljava/util/Map; move-result-object p1 const-string v1, "Date" invoke-interface {p1, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/String; const/4 v1, 0x0 if-eqz p1, :cond_1 .line 3 :try_start_0 invoke-virtual {p1}, Ljava/lang/String;->isEmpty()Z move-result v2 :try_end_0 .catch Ljava/lang/RuntimeException; {:try_start_0 .. :try_end_0} :catch_1 if-eqz v2, :cond_0 goto :goto_0 .line 4 :cond_0 :try_start_1 invoke-static {p1}, Lcom/amazonaws/util/DateUtils;->parseRFC822Date(Ljava/lang/String;)Ljava/util/Date; move-result-object p1 :try_end_1 .catch Ljava/lang/RuntimeException; {:try_start_1 .. :try_end_1} :catch_0 goto :goto_1 .line 5 :cond_1 :goto_0 :try_start_2 invoke-virtual {p2}, Lcom/amazonaws/AmazonServiceException;->getMessage()Ljava/lang/String; move-result-object p1 invoke-direct {p0, p1}, Lcom/amazonaws/http/AmazonHttpClient;->getServerDateFromException(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 :try_end_2 .catch Ljava/lang/RuntimeException; {:try_start_2 .. :try_end_2} :catch_1 .line 6 :try_start_3 invoke-static {p1}, Lcom/amazonaws/util/DateUtils;->parseCompressedISO8601Date(Ljava/lang/String;)Ljava/util/Date; move-result-object p1 :try_end_3 .catch Ljava/lang/RuntimeException; {:try_start_3 .. :try_end_3} :catch_0 .line 7 :goto_1 invoke-virtual {v0}, Ljava/util/Date;->getTime()J move-result-wide v0 invoke-virtual {p1}, Ljava/util/Date;->getTime()J move-result-wide p1 sub-long/2addr v0, p1 const-wide/16 p1, 0x3e8 .line 8 div-long/2addr v0, p1 long-to-int p1, v0 return p1 :catch_0 move-exception p2 goto :goto_2 :catch_1 move-exception p2 move-object p1, v1 .line 9 :goto_2 sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "Unable to parse clock skew offset from response: " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; 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-interface {v0, p1, p2}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V const/4 p1, 0x0 return p1 .end method .method public requestHandler2s(Lcom/amazonaws/Request;Lcom/amazonaws/http/ExecutionContext;)Ljava/util/List; .locals 5 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Lcom/amazonaws/http/ExecutionContext;", ")", "Ljava/util/List<", "Lcom/amazonaws/handlers/RequestHandler2;", ">;" } .end annotation .line 1 invoke-virtual {p2}, Lcom/amazonaws/http/ExecutionContext;->getRequestHandler2s()Ljava/util/List; move-result-object v0 if-nez v0, :cond_0 .line 2 invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List; move-result-object p1 return-object p1 .line 3 :cond_0 invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object v1 :goto_0 invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z move-result v2 if-eqz v2, :cond_2 invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v2 check-cast v2, Lcom/amazonaws/handlers/RequestHandler2; .line 4 instance-of v3, v2, Lcom/amazonaws/handlers/CredentialsRequestHandler; if-eqz v3, :cond_1 .line 5 move-object v3, v2 check-cast v3, Lcom/amazonaws/handlers/CredentialsRequestHandler; .line 6 invoke-virtual {p2}, Lcom/amazonaws/http/ExecutionContext;->getCredentials()Lcom/amazonaws/auth/AWSCredentials; move-result-object v4 invoke-virtual {v3, v4}, Lcom/amazonaws/handlers/CredentialsRequestHandler;->setCredentials(Lcom/amazonaws/auth/AWSCredentials;)V .line 7 :cond_1 invoke-virtual {v2, p1}, Lcom/amazonaws/handlers/RequestHandler2;->beforeRequest(Lcom/amazonaws/Request;)V goto :goto_0 :cond_2 return-object v0 .end method .method public resetRequestAfterError(Lcom/amazonaws/Request;Ljava/lang/Exception;)V .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;", "Ljava/lang/Exception;", ")V" } .end annotation .line 1 invoke-interface {p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream; move-result-object v0 if-nez v0, :cond_0 return-void .line 2 :cond_0 invoke-interface {p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream; move-result-object v0 invoke-virtual {v0}, Ljava/io/InputStream;->markSupported()Z move-result v0 if-eqz v0, :cond_1 .line 3 :try_start_0 invoke-interface {p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream; move-result-object p1 invoke-virtual {p1}, Ljava/io/InputStream;->reset()V :try_end_0 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0 return-void .line 4 :catch_0 new-instance p1, Lcom/amazonaws/AmazonClientException; const-string v0, "Encountered an exception and couldn\'t reset the stream to retry" invoke-direct {p1, v0, p2}, Lcom/amazonaws/AmazonClientException;->(Ljava/lang/String;Ljava/lang/Throwable;)V throw p1 .line 5 :cond_1 new-instance p1, Lcom/amazonaws/AmazonClientException; const-string v0, "Encountered an exception and stream is not resettable" invoke-direct {p1, v0, p2}, Lcom/amazonaws/AmazonClientException;->(Ljava/lang/String;Ljava/lang/Throwable;)V throw p1 .end method .method public setUserAgent(Lcom/amazonaws/Request;)V .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/amazonaws/Request<", "*>;)V" } .end annotation .line 1 sget-object v0, Lcom/amazonaws/ClientConfiguration;->DEFAULT_USER_AGENT:Ljava/lang/String; .line 2 invoke-interface {p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest; move-result-object v1 if-eqz v1, :cond_0 .line 3 invoke-virtual {v1}, Lcom/amazonaws/AmazonWebServiceRequest;->getRequestClientOptions()Lcom/amazonaws/RequestClientOptions; move-result-object v1 if-eqz v1, :cond_0 .line 4 sget-object v2, Lcom/amazonaws/RequestClientOptions$Marker;->USER_AGENT:Lcom/amazonaws/RequestClientOptions$Marker; invoke-virtual {v1, v2}, Lcom/amazonaws/RequestClientOptions;->getClientMarker(Lcom/amazonaws/RequestClientOptions$Marker;)Ljava/lang/String; move-result-object v1 if-eqz v1, :cond_0 .line 5 invoke-static {v0, v1}, Lcom/amazonaws/http/AmazonHttpClient;->createUserAgentString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object v1 goto :goto_0 :cond_0 move-object v1, v0 .line 6 :goto_0 iget-object v2, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; invoke-virtual {v2}, Lcom/amazonaws/ClientConfiguration;->getUserAgent()Ljava/lang/String; move-result-object v2 invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v0 if-nez v0, :cond_1 .line 7 iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; invoke-virtual {v0}, Lcom/amazonaws/ClientConfiguration;->getUserAgent()Ljava/lang/String; move-result-object v0 invoke-static {v1, v0}, Lcom/amazonaws/http/AmazonHttpClient;->createUserAgentString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object v1 .line 8 :cond_1 iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; .line 9 invoke-virtual {v0}, Lcom/amazonaws/ClientConfiguration;->getUserAgentOverride()Ljava/lang/String; move-result-object v0 if-eqz v0, :cond_2 iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration; invoke-virtual {v0}, Lcom/amazonaws/ClientConfiguration;->getUserAgentOverride()Ljava/lang/String; move-result-object v1 :cond_2 const-string v0, "User-Agent" .line 10 invoke-interface {p1, v0, v1}, Lcom/amazonaws/Request;->addHeader(Ljava/lang/String;Ljava/lang/String;)V return-void .end method .method public shutdown()V .locals 1 .line 1 iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient; invoke-interface {v0}, Lcom/amazonaws/http/HttpClient;->shutdown()V return-void .end method