AmazonHttpClient.smali
.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 static final log:Lcom/amazonaws/logging/Log;
# instance fields
.field final config:Lcom/amazonaws/ClientConfiguration;
.field 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 static constructor <clinit>()V
.registers 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 <init>(Lcom/amazonaws/ClientConfiguration;)V
.registers 3
.line 1
new-instance v0, Lcom/amazonaws/http/UrlHttpClient;
invoke-direct {v0, p1}, Lcom/amazonaws/http/UrlHttpClient;-><init>(Lcom/amazonaws/ClientConfiguration;)V
invoke-direct {p0, p1, v0}, Lcom/amazonaws/http/AmazonHttpClient;-><init>(Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;)V
return-void
.end method
.method public constructor <init>(Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;)V
.registers 4
.line 3
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 4
new-instance v0, Lcom/amazonaws/http/HttpRequestFactory;
invoke-direct {v0}, Lcom/amazonaws/http/HttpRequestFactory;-><init>()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 <init>(Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;Lcom/amazonaws/metrics/RequestMetricCollector;)V
.registers 5
.annotation runtime Ljava/lang/Deprecated;
.end annotation
.line 8
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 9
new-instance v0, Lcom/amazonaws/http/HttpRequestFactory;
invoke-direct {v0}, Lcom/amazonaws/http/HttpRequestFactory;-><init>()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 <init>(Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/metrics/RequestMetricCollector;)V
.registers 4
.annotation runtime Ljava/lang/Deprecated;
.end annotation
.line 2
new-instance v0, Lcom/amazonaws/http/UrlHttpClient;
invoke-direct {v0, p1}, Lcom/amazonaws/http/UrlHttpClient;-><init>(Lcom/amazonaws/ClientConfiguration;)V
invoke-direct {p0, p1, v0, p2}, Lcom/amazonaws/http/AmazonHttpClient;-><init>(Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/HttpClient;Lcom/amazonaws/metrics/RequestMetricCollector;)V
return-void
.end method
.method static createUserAgentString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 3
.line 1
invoke-virtual {p0, p1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_7
return-object p0
.line 2
:cond_7
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()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;
.registers 5
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_13
.line 3
invoke-virtual {p1, v1}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I
move-result v1
goto :goto_19
:cond_13
const-string v1, " - 15"
.line 4
invoke-virtual {p1, v1}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I
move-result v1
:goto_19
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;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Throwable;",
">(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
sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->Exception:Lcom/amazonaws/util/AWSRequestMetrics$Field;
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
.registers 3
.line 1
invoke-virtual {p1}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I
move-result p1
const/16 v0, 0xc8
if-lt p1, v0, :cond_e
const/16 v0, 0x12c
if-ge p1, v0, :cond_e
const/4 p1, 0x1
goto :goto_f
:cond_e
const/4 p1, 0x0
:goto_f
return p1
.end method
.method private static isTemporaryRedirect(Lcom/amazonaws/http/HttpResponse;)Z
.registers 3
.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_1e
if-eqz p0, :cond_1e
.line 3
invoke-virtual {p0}, Ljava/lang/String;->isEmpty()Z
move-result p0
if-nez p0, :cond_1e
const/4 p0, 0x1
goto :goto_1f
:cond_1e
const/4 p0, 0x0
:goto_1f
return p0
.end method
.method private pauseBeforeNextRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)J
.registers 7
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 p4
if-eqz p4, :cond_32
.line 3
sget-object p4, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()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_32
:try_start_32
invoke-static {p1, p2}, Ljava/lang/Thread;->sleep(J)V
:try_end_35
.catch Ljava/lang/InterruptedException; {:try_start_32 .. :try_end_35} :catch_36
return-wide p1
:catch_36
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;-><init>(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
.registers 8
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_10
.line 2
invoke-virtual {p5}, Lcom/amazonaws/retry/RetryPolicy;->isMaxErrorRetryInClientConfigHonored()Z
move-result v1
if-nez v1, :cond_14
.line 3
:cond_10
invoke-virtual {p5}, Lcom/amazonaws/retry/RetryPolicy;->getMaxErrorRetry()I
move-result v0
:cond_14
const/4 v1, 0x0
if-lt p4, v0, :cond_18
return v1
:cond_18
if-eqz p2, :cond_30
.line 4
invoke-virtual {p2}, Ljava/io/InputStream;->markSupported()Z
move-result p2
if-nez p2, :cond_30
.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 p1
if-eqz p1, :cond_2f
.line 6
sget-object p1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
const-string p2, "Content not repeatable"
invoke-interface {p1, p2}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V
:cond_2f
return v1
.line 7
:cond_30
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 afterError(Lcom/amazonaws/Request;Lcom/amazonaws/Response;Ljava/util/List;Lcom/amazonaws/AmazonClientException;)V
.registers 6
.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_4
invoke-interface {p3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_14
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_4
:cond_14
return-void
.end method
.method afterResponse(Lcom/amazonaws/Request;Ljava/util/List;Lcom/amazonaws/Response;Lcom/amazonaws/util/TimingInfo;)V
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(",
"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_4
invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z
move-result p4
if-eqz p4, :cond_14
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_4
:cond_14
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;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(",
"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
if-eqz p4, :cond_20
.line 1
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 2
invoke-virtual {p4}, Lcom/amazonaws/http/ExecutionContext;->getAwsRequestMetrics()Lcom/amazonaws/util/AWSRequestMetrics;
move-result-object v1
const/4 v2, 0x0
.line 3
:try_start_b
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 4
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 5
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_1a
.catch Lcom/amazonaws/AmazonClientException; {:try_start_b .. :try_end_1a} :catch_1b
return-object v2
:catch_1b
move-exception p2
.line 6
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 7
throw p2
.line 8
:cond_20
new-instance p1, Lcom/amazonaws/AmazonClientException;
const-string p2, "Internal SDK Error: No execution context parameter specified."
invoke-direct {p1, p2}, Lcom/amazonaws/AmazonClientException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method executeHelper(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/ExecutionContext;)Lcom/amazonaws/Response;
.registers 32
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(",
"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;-><init>(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;-><init>(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_4e
.line 10
invoke-virtual {v13}, Ljava/io/InputStream;->markSupported()Z
move-result v0
if-eqz v0, :cond_4e
const/4 v0, -0x1
.line 11
invoke-virtual {v13, v0}, Ljava/io/InputStream;->mark(I)V
.line 12
:cond_4e
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 v3, v1
const/4 v1, 0x0
const/4 v2, 0x0
const/4 v5, 0x0
const/4 v6, 0x0
const/16 v16, 0x0
const/16 v17, 0x0
:goto_5e
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-wide/from16 v20, v3
int-to-long v3, v6
invoke-virtual {v10, v0, v3, v4}, Lcom/amazonaws/util/AWSRequestMetrics;->setCounter(Lcom/amazonaws/metrics/MetricType;J)V
if-le v6, v15, :cond_76
.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_76
if-eqz v16, :cond_ae
.line 17
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getEndpoint()Ljava/net/URI;
move-result-object v0
if-nez v0, :cond_ae
.line 18
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getResourcePath()Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_ae
.line 19
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
.line 20
invoke-virtual/range {v16 .. v16}, Ljava/net/URI;->getScheme()Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "://"
invoke-virtual {v0, v3}, 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 v3
invoke-virtual {v0, v3}, 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_ae
const-string v4, "Cannot close the response content."
if-le v6, v15, :cond_f3
.line 23
:try_start_b2
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_b7
.catch Ljava/io/IOException; {:try_start_b2 .. :try_end_b7} :catch_e6
.catch Ljava/lang/RuntimeException; {:try_start_b2 .. :try_end_b7} :catch_32f
.catch Ljava/lang/Error; {:try_start_b2 .. :try_end_b7} :catch_327
.catchall {:try_start_b2 .. :try_end_b7} :catchall_e1
.line 24
:try_start_b7
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest;
move-result-object v0
iget-object v3, v7, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
.line 25
invoke-virtual {v3}, Lcom/amazonaws/ClientConfiguration;->getRetryPolicy()Lcom/amazonaws/retry/RetryPolicy;
move-result-object v3
.line 26
invoke-direct {v7, v0, v1, v6, v3}, Lcom/amazonaws/http/AmazonHttpClient;->pauseBeforeNextRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)J
move-result-wide v20
:try_end_c5
.catchall {:try_start_b7 .. :try_end_c5} :catchall_da
.line 27
:try_start_c5
sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RetryPauseTime:Lcom/amazonaws/util/AWSRequestMetrics$Field;
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_f3
.line 29
invoke-virtual {v0}, Ljava/io/InputStream;->markSupported()Z
move-result v1
if-eqz v1, :cond_f3
.line 30
invoke-virtual {v0}, Ljava/io/InputStream;->reset()V
goto :goto_f3
:catchall_da
move-exception v0
.line 31
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_e1
.catch Ljava/io/IOException; {:try_start_c5 .. :try_end_e1} :catch_e6
.catch Ljava/lang/RuntimeException; {:try_start_c5 .. :try_end_e1} :catch_32f
.catch Ljava/lang/Error; {:try_start_c5 .. :try_end_e1} :catch_327
.catchall {:try_start_c5 .. :try_end_e1} :catchall_e1
:catchall_e1
move-exception v0
move-object v1, v0
move-object v9, v4
goto/16 :goto_3d9
:catch_e6
move-exception v0
move-object v9, v4
move-object v15, v11
move-object/from16 v22, v12
move-wide/from16 v25, v20
move-object/from16 v20, v2
:goto_ef
move-object v11, v5
move v12, v6
goto/16 :goto_341
:cond_f3
:goto_f3
move-object v15, v11
move-object/from16 v22, v12
move-wide/from16 v11, v20
:try_start_f8
const-string v0, "aws-sdk-retry"
.line 33
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
add-int/lit8 v3, v6, -0x1
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, "/"
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v11, v12}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-interface {v8, v0, v1}, Lcom/amazonaws/Request;->addHeader(Ljava/lang/String;Ljava/lang/String;)V
:try_end_113
.catch Ljava/io/IOException; {:try_start_f8 .. :try_end_113} :catch_339
.catch Ljava/lang/RuntimeException; {:try_start_f8 .. :try_end_113} :catch_32f
.catch Ljava/lang/Error; {:try_start_f8 .. :try_end_113} :catch_327
.catchall {:try_start_f8 .. :try_end_113} :catchall_322
if-nez v2, :cond_125
.line 34
:try_start_115
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 v2
:try_end_11d
.catch Ljava/io/IOException; {:try_start_115 .. :try_end_11d} :catch_11e
.catch Ljava/lang/RuntimeException; {:try_start_115 .. :try_end_11d} :catch_32f
.catch Ljava/lang/Error; {:try_start_115 .. :try_end_11d} :catch_327
.catchall {:try_start_115 .. :try_end_11d} :catchall_e1
goto :goto_125
:catch_11e
move-exception v0
move-object/from16 v20, v2
:goto_121
move-object v9, v4
move-wide/from16 v25, v11
goto :goto_ef
:cond_125
:goto_125
move-object v3, v2
if-eqz v3, :cond_144
if-eqz v14, :cond_144
.line 35
:try_start_12a
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_12f
.catch Ljava/io/IOException; {:try_start_12a .. :try_end_12f} :catch_140
.catch Ljava/lang/RuntimeException; {:try_start_12a .. :try_end_12f} :catch_32f
.catch Ljava/lang/Error; {:try_start_12a .. :try_end_12f} :catch_327
.catchall {:try_start_12a .. :try_end_12f} :catchall_e1
.line 36
:try_start_12f
invoke-interface {v3, v8, v14}, Lcom/amazonaws/auth/Signer;->sign(Lcom/amazonaws/Request;Lcom/amazonaws/auth/AWSCredentials;)V
:try_end_132
.catchall {:try_start_12f .. :try_end_132} :catchall_138
.line 37
:try_start_132
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
goto :goto_144
:catchall_138
move-exception v0
move-object v1, 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 v1
:try_end_140
.catch Ljava/io/IOException; {:try_start_132 .. :try_end_140} :catch_140
.catch Ljava/lang/RuntimeException; {:try_start_132 .. :try_end_140} :catch_32f
.catch Ljava/lang/Error; {:try_start_132 .. :try_end_140} :catch_327
.catchall {:try_start_132 .. :try_end_140} :catchall_e1
:catch_140
move-exception v0
:goto_141
move-object/from16 v20, v3
goto :goto_121
.line 39
:cond_144
:goto_144
:try_start_144
sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log;
invoke-interface {v0}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v0
:try_end_14a
.catch Ljava/io/IOException; {:try_start_144 .. :try_end_14a} :catch_31a
.catch Ljava/lang/RuntimeException; {:try_start_144 .. :try_end_14a} :catch_32f
.catch Ljava/lang/Error; {:try_start_144 .. :try_end_14a} :catch_327
.catchall {:try_start_144 .. :try_end_14a} :catchall_322
if-eqz v0, :cond_166
.line 40
:try_start_14c
sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Sending Request: "
invoke-virtual {v1, v2}, 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 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-interface {v0, v1}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V
:try_end_166
.catch Ljava/io/IOException; {:try_start_14c .. :try_end_166} :catch_140
.catch Ljava/lang/RuntimeException; {:try_start_14c .. :try_end_166} :catch_32f
.catch Ljava/lang/Error; {:try_start_14c .. :try_end_166} :catch_327
.catchall {:try_start_14c .. :try_end_166} :catchall_e1
.line 41
:cond_166
:try_start_166
iget-object v0, v7, Lcom/amazonaws/http/AmazonHttpClient;->requestFactory:Lcom/amazonaws/http/HttpRequestFactory;
iget-object v1, v7, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
invoke-virtual {v0, v8, v1, v9}, Lcom/amazonaws/http/HttpRequestFactory;->createHttpRequest(Lcom/amazonaws/Request;Lcom/amazonaws/ClientConfiguration;Lcom/amazonaws/http/ExecutionContext;)Lcom/amazonaws/http/HttpRequest;
move-result-object v2
:try_end_16e
.catch Ljava/io/IOException; {:try_start_166 .. :try_end_16e} :catch_31a
.catch Ljava/lang/RuntimeException; {:try_start_166 .. :try_end_16e} :catch_32f
.catch Ljava/lang/Error; {:try_start_166 .. :try_end_16e} :catch_327
.catchall {:try_start_166 .. :try_end_16e} :catchall_322
.line 42
:try_start_16e
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_173
.catch Ljava/io/IOException; {:try_start_16e .. :try_end_173} :catch_30d
.catch Ljava/lang/RuntimeException; {:try_start_16e .. :try_end_173} :catch_32f
.catch Ljava/lang/Error; {:try_start_16e .. :try_end_173} :catch_327
.catchall {:try_start_16e .. :try_end_173} :catchall_322
.line 43
:try_start_173
iget-object v0, v7, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient;
invoke-interface {v0, v2}, Lcom/amazonaws/http/HttpClient;->execute(Lcom/amazonaws/http/HttpRequest;)Lcom/amazonaws/http/HttpResponse;
move-result-object v5
:try_end_179
.catchall {:try_start_173 .. :try_end_179} :catchall_2f8
.line 44
:try_start_179
sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->HttpRequestTime:Lcom/amazonaws/util/AWSRequestMetrics$Field;
invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V
.line 45
invoke-direct {v7, v5}, Lcom/amazonaws/http/AmazonHttpClient;->isRequestSuccessful(Lcom/amazonaws/http/HttpResponse;)Z
move-result v0
:try_end_182
.catch Ljava/io/IOException; {:try_start_179 .. :try_end_182} :catch_2ed
.catch Ljava/lang/RuntimeException; {:try_start_179 .. :try_end_182} :catch_2e9
.catch Ljava/lang/Error; {:try_start_179 .. :try_end_182} :catch_2e5
.catchall {:try_start_179 .. :try_end_182} :catchall_2e1
if-eqz v0, :cond_1bd
.line 46
:try_start_184
sget-object v0, Lcom/amazonaws/util/AWSRequestMetrics$Field;->StatusCode:Lcom/amazonaws/util/AWSRequestMetrics$Field;
invoke-virtual {v5}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I
move-result v1
invoke-static {v1}, 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 v17
move-object/from16 v1, p2
.line 48
invoke-virtual {v7, v8, v1, v5, 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 v1, Lcom/amazonaws/Response;
invoke-direct {v1, v0, v5}, Lcom/amazonaws/Response;-><init>(Ljava/lang/Object;Lcom/amazonaws/http/HttpResponse;)V
:try_end_1a0
.catch Ljava/io/IOException; {:try_start_184 .. :try_end_1a0} :catch_1b9
.catch Ljava/lang/RuntimeException; {:try_start_184 .. :try_end_1a0} :catch_32f
.catch Ljava/lang/Error; {:try_start_184 .. :try_end_1a0} :catch_327
.catchall {:try_start_184 .. :try_end_1a0} :catchall_e1
if-nez v17, :cond_1b8
if-eqz v5, :cond_1b8
.line 50
:try_start_1a4
invoke-virtual {v5}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_1b8
.line 51
invoke-virtual {v5}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
invoke-virtual {v0}, Ljava/io/InputStream;->close()V
:try_end_1b1
.catch Ljava/io/IOException; {:try_start_1a4 .. :try_end_1b1} :catch_1b2
goto :goto_1b8
:catch_1b2
move-exception v0
.line 52
sget-object v2, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
invoke-interface {v2, v4, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
:cond_1b8
:goto_1b8
return-object v1
:catch_1b9
move-exception v0
move-object/from16 v19, v2
goto :goto_141
.line 53
:cond_1bd
:try_start_1bd
invoke-static {v5}, Lcom/amazonaws/http/AmazonHttpClient;->isTemporaryRedirect(Lcom/amazonaws/http/HttpResponse;)Z
move-result v0
:try_end_1c1
.catch Ljava/io/IOException; {:try_start_1bd .. :try_end_1c1} :catch_2ed
.catch Ljava/lang/RuntimeException; {:try_start_1bd .. :try_end_1c1} :catch_2e9
.catch Ljava/lang/Error; {:try_start_1bd .. :try_end_1c1} :catch_2e5
.catchall {:try_start_1bd .. :try_end_1c1} :catchall_2e1
if-eqz v0, :cond_235
.line 54
:try_start_1c3
invoke-virtual {v5}, 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;
:try_end_1d1
.catch Ljava/io/IOException; {:try_start_1c3 .. :try_end_1d1} :catch_22e
.catch Ljava/lang/RuntimeException; {:try_start_1c3 .. :try_end_1d1} :catch_32f
.catch Ljava/lang/Error; {:try_start_1c3 .. :try_end_1d1} :catch_327
.catchall {:try_start_1c3 .. :try_end_1d1} :catchall_e1
move-object/from16 v20, v3
:try_start_1d3
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
:try_end_1d8
.catch Ljava/io/IOException; {:try_start_1d3 .. :try_end_1d8} :catch_22c
.catch Ljava/lang/RuntimeException; {:try_start_1d3 .. :try_end_1d8} :catch_32f
.catch Ljava/lang/Error; {:try_start_1d3 .. :try_end_1d8} :catch_327
.catchall {:try_start_1d3 .. :try_end_1d8} :catchall_e1
move-object/from16 v21, v4
:try_start_1da
const-string v4, "Redirecting to: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-interface {v1, v3}, 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 {v5}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I
move-result v3
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
invoke-virtual {v10, v1, v3}, 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_20c
.catch Ljava/io/IOException; {:try_start_1da .. :try_end_20c} :catch_223
.catch Ljava/lang/RuntimeException; {:try_start_1da .. :try_end_20c} :catch_220
.catch Ljava/lang/Error; {:try_start_1da .. :try_end_20c} :catch_21d
.catchall {:try_start_1da .. :try_end_20c} :catchall_217
move-object/from16 v24, v2
move-wide/from16 v25, v11
move-object/from16 v9, v21
const/4 v1, 0x0
move-object v11, v5
move v12, v6
goto/16 :goto_298
:catchall_217
move-exception v0
move-object v1, v0
move-object/from16 v9, v21
goto/16 :goto_3d9
:catch_21d
move-exception v0
goto/16 :goto_2cf
:catch_220
move-exception v0
goto/16 :goto_2d5
:catch_223
move-exception v0
move-object/from16 v19, v2
move-wide/from16 v25, v11
move-object/from16 v9, v21
goto/16 :goto_ef
:catch_22c
move-exception v0
goto :goto_231
:catch_22e
move-exception v0
move-object/from16 v20, v3
:goto_231
move-object/from16 v19, v2
goto/16 :goto_121
:cond_235
move-object/from16 v20, v3
move-object/from16 v21, v4
.line 62
:try_start_239
invoke-interface/range {p3 .. p3}, Lcom/amazonaws/http/HttpResponseHandler;->needsConnectionLeftOpen()Z
move-result v17
move-object/from16 v4, p3
.line 63
invoke-virtual {v7, v8, v4, v5}, 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 v3
invoke-virtual {v10, v1, v3}, 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 v3
invoke-virtual {v10, v1, v3}, 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 v3
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
invoke-virtual {v10, v1, v3}, 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 v3
.line 68
invoke-virtual {v2}, 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 v23
:try_end_270
.catch Ljava/io/IOException; {:try_start_239 .. :try_end_270} :catch_2d9
.catch Ljava/lang/RuntimeException; {:try_start_239 .. :try_end_270} :catch_2d3
.catch Ljava/lang/Error; {:try_start_239 .. :try_end_270} :catch_2cd
.catchall {:try_start_239 .. :try_end_270} :catchall_2c7
move-object/from16 v1, p0
move-object/from16 v24, v2
move-object v2, v3
move-object/from16 v3, v19
move-object/from16 v9, v21
move-object v4, v0
move-wide/from16 v25, v11
move-object v11, v5
move v5, v6
move v12, v6
move-object/from16 v6, v23
.line 70
:try_start_281
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_2bb
.line 71
invoke-static {v0}, Lcom/amazonaws/retry/RetryUtils;->isClockSkewError(Lcom/amazonaws/AmazonServiceException;)Z
move-result v1
if-eqz v1, :cond_294
.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_294
invoke-virtual {v7, v8, v0}, Lcom/amazonaws/http/AmazonHttpClient;->resetRequestAfterError(Lcom/amazonaws/Request;Ljava/lang/Exception;)V
:try_end_297
.catch Ljava/io/IOException; {:try_start_281 .. :try_end_297} :catch_2c4
.catch Ljava/lang/RuntimeException; {:try_start_281 .. :try_end_297} :catch_2c0
.catch Ljava/lang/Error; {:try_start_281 .. :try_end_297} :catch_2bc
.catchall {:try_start_281 .. :try_end_297} :catchall_3d6
move-object v1, v0
:goto_298
if-nez v17, :cond_2b0
if-eqz v11, :cond_2b0
.line 75
:try_start_29c
invoke-virtual {v11}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_2b0
.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_2a9
.catch Ljava/io/IOException; {:try_start_29c .. :try_end_2a9} :catch_2aa
goto :goto_2b0
:catch_2aa
move-exception v0
.line 77
sget-object v2, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
invoke-interface {v2, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
:cond_2b0
:goto_2b0
move-object v5, v11
move-object/from16 v2, v20
move-object/from16 v6, v24
move-wide/from16 v3, v25
const/16 v23, 0x0
goto/16 :goto_3cd
.line 78
:cond_2bb
:try_start_2bb
throw v0
:try_end_2bc
.catch Ljava/io/IOException; {:try_start_2bb .. :try_end_2bc} :catch_2c4
.catch Ljava/lang/RuntimeException; {:try_start_2bb .. :try_end_2bc} :catch_2c0
.catch Ljava/lang/Error; {:try_start_2bb .. :try_end_2bc} :catch_2bc
.catchall {:try_start_2bb .. :try_end_2bc} :catchall_3d6
:catch_2bc
move-exception v0
move-object v5, v11
goto/16 :goto_329
:catch_2c0
move-exception v0
move-object v5, v11
goto/16 :goto_331
:catch_2c4
move-exception v0
goto/16 :goto_317
:catchall_2c7
move-exception v0
move-object v11, v5
move-object/from16 v9, v21
goto/16 :goto_324
:catch_2cd
move-exception v0
move-object v11, v5
:goto_2cf
move-object/from16 v9, v21
goto/16 :goto_329
:catch_2d3
move-exception v0
move-object v11, v5
:goto_2d5
move-object/from16 v9, v21
goto/16 :goto_331
:catch_2d9
move-exception v0
move-object/from16 v24, v2
move-wide/from16 v25, v11
move-object/from16 v9, v21
goto :goto_2f5
:catchall_2e1
move-exception v0
move-object v9, v4
move-object v11, v5
goto :goto_324
:catch_2e5
move-exception v0
move-object v9, v4
move-object v11, v5
goto :goto_329
:catch_2e9
move-exception v0
move-object v9, v4
move-object v11, v5
goto :goto_331
:catch_2ed
move-exception v0
move-object/from16 v24, v2
move-object/from16 v20, v3
move-object v9, v4
move-wide/from16 v25, v11
:goto_2f5
move-object v11, v5
move v12, v6
goto :goto_317
:catchall_2f8
move-exception v0
move-object/from16 v24, v2
move-object/from16 v20, v3
move-object v9, v4
move-wide/from16 v25, v11
move v12, v6
.line 79
:try_start_301
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_307
.catch Ljava/io/IOException; {:try_start_301 .. :try_end_307} :catch_30b
.catch Ljava/lang/RuntimeException; {:try_start_301 .. :try_end_307} :catch_309
.catch Ljava/lang/Error; {:try_start_301 .. :try_end_307} :catch_307
.catchall {:try_start_301 .. :try_end_307} :catchall_337
:catch_307
move-exception v0
goto :goto_329
:catch_309
move-exception v0
goto :goto_331
:catch_30b
move-exception v0
goto :goto_316
:catch_30d
move-exception v0
move-object/from16 v24, v2
move-object/from16 v20, v3
move-object v9, v4
move-wide/from16 v25, v11
move v12, v6
:goto_316
move-object v11, v5
:goto_317
move-object/from16 v19, v24
goto :goto_341
:catch_31a
move-exception v0
move-object/from16 v20, v3
move-object v9, v4
move-wide/from16 v25, v11
move v12, v6
goto :goto_340
:catchall_322
move-exception v0
move-object v9, v4
:goto_324
move-object v1, v0
goto/16 :goto_3d9
:catch_327
move-exception v0
move-object v9, v4
.line 81
:goto_329
:try_start_329
invoke-direct {v7, v0, v10}, Lcom/amazonaws/http/AmazonHttpClient;->handleUnexpectedFailure(Ljava/lang/Throwable;Lcom/amazonaws/util/AWSRequestMetrics;)Ljava/lang/Throwable;
check-cast v0, Ljava/lang/Error;
throw v0
:catch_32f
move-exception v0
move-object v9, v4
.line 82
:goto_331
invoke-direct {v7, v0, v10}, Lcom/amazonaws/http/AmazonHttpClient;->handleUnexpectedFailure(Ljava/lang/Throwable;Lcom/amazonaws/util/AWSRequestMetrics;)Ljava/lang/Throwable;
check-cast v0, Ljava/lang/RuntimeException;
throw v0
:try_end_337
.catchall {:try_start_329 .. :try_end_337} :catchall_337
:catchall_337
move-exception v0
goto :goto_324
:catch_339
move-exception v0
move-object v9, v4
move-wide/from16 v25, v11
move v12, v6
move-object/from16 v20, v2
:goto_340
move-object v11, v5
.line 83
:goto_341
:try_start_341
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
invoke-interface {v1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v1
:try_end_347
.catchall {:try_start_341 .. :try_end_347} :catchall_3d6
const-string v2, "Unable to execute HTTP request: "
if-eqz v1, :cond_363
.line 84
:try_start_34b
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v3, v2}, 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 {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-interface {v1, v3, v0}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V
.line 85
:cond_363
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
sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->Exception:Lcom/amazonaws/util/AWSRequestMetrics$Field;
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 v6, 0x0
invoke-virtual {v10, v1, v6}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V
.line 88
new-instance v5, Lcom/amazonaws/AmazonClientException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v2}, 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 {v5, v1, v0}, Lcom/amazonaws/AmazonClientException;-><init>(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 {v19 .. v19}, 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, v5
move-object/from16 v21, v5
move v5, v12
move-object/from16 v23, 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_3d5
.line 94
invoke-virtual {v7, v8, v0}, Lcom/amazonaws/http/AmazonHttpClient;->resetRequestAfterError(Lcom/amazonaws/Request;Ljava/lang/Exception;)V
:try_end_3ac
.catchall {:try_start_34b .. :try_end_3ac} :catchall_3d6
if-nez v17, :cond_3c4
if-eqz v11, :cond_3c4
.line 95
:try_start_3b0
invoke-virtual {v11}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_3c4
.line 96
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_3bd
.catch Ljava/io/IOException; {:try_start_3b0 .. :try_end_3bd} :catch_3be
goto :goto_3c4
:catch_3be
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_3c4
:goto_3c4
move-object v5, v11
move-object/from16 v6, v19
move-object/from16 v2, v20
move-object/from16 v1, v21
move-wide/from16 v3, v25
:goto_3cd
move-object/from16 v9, p4
move v0, v12
move-object v11, v15
move-object/from16 v12, v22
goto/16 :goto_5e
.line 98
:cond_3d5
:try_start_3d5
throw v21
:try_end_3d6
.catchall {:try_start_3d5 .. :try_end_3d6} :catchall_3d6
:catchall_3d6
move-exception v0
move-object v1, v0
move-object v5, v11
:goto_3d9
if-nez v17, :cond_3f1
if-eqz v5, :cond_3f1
.line 99
:try_start_3dd
invoke-virtual {v5}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_3f1
.line 100
invoke-virtual {v5}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
invoke-virtual {v0}, Ljava/io/InputStream;->close()V
:try_end_3ea
.catch Ljava/io/IOException; {:try_start_3dd .. :try_end_3ea} :catch_3eb
goto :goto_3f1
:catch_3eb
move-exception v0
.line 101
sget-object v2, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
invoke-interface {v2, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
.line 102
:cond_3f1
:goto_3f1
goto :goto_3f3
:goto_3f2
throw v1
:goto_3f3
goto :goto_3f2
.end method
.method protected finalize()V
.registers 1
.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;
.registers 2
.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;
.registers 2
.annotation runtime Ljava/lang/Deprecated;
.end annotation
const/4 p1, 0x0
return-object p1
.end method
.method handleErrorResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/AmazonServiceException;
.registers 8
.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_4
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;-><init>()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_24
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_24} :catch_25
goto :goto_6d
:catch_25
move-exception p2
const/16 v1, 0x19d
if-ne v0, v1, :cond_44
.line 4
new-instance p2, Lcom/amazonaws/AmazonServiceException;
const-string p3, "Request entity too large"
invoke-direct {p2, p3}, Lcom/amazonaws/AmazonServiceException;-><init>(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_6d
:cond_44
const/16 v1, 0x1f7
if-ne v0, v1, :cond_7b
.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_7b
.line 10
new-instance p2, Lcom/amazonaws/AmazonServiceException;
const-string p3, "Service unavailable"
invoke-direct {p2, p3}, Lcom/amazonaws/AmazonServiceException;-><init>(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_6d
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_7b
instance-of p1, p2, Ljava/io/IOException;
if-eqz p1, :cond_82
.line 19
check-cast p2, Ljava/io/IOException;
throw p2
.line 20
:cond_82
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Unable to unmarshall error response ("
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p3
.end method
.method handleResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/http/ExecutionContext;)Ljava/lang/Object;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(",
"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_2
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_b
.catch Lcom/amazonaws/internal/CRC32MismatchException; {:try_start_2 .. :try_end_b} :catch_b4
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_b} :catch_b2
.catch Ljava/lang/Exception; {:try_start_2 .. :try_end_b} :catch_80
.line 3
:try_start_b
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_11
.catchall {:try_start_b .. :try_end_11} :catchall_79
.line 4
:try_start_11
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
if-eqz p2, :cond_54
.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 v0
if-eqz v0, :cond_46
.line 6
sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()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_46
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_54
new-instance p2, Ljava/lang/RuntimeException;
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4}, Ljava/lang/StringBuilder;-><init>()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;-><init>(Ljava/lang/String;)V
throw p2
:catchall_79
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_80
.catch Lcom/amazonaws/internal/CRC32MismatchException; {:try_start_11 .. :try_end_80} :catch_b4
.catch Ljava/io/IOException; {:try_start_11 .. :try_end_80} :catch_b2
.catch Ljava/lang/Exception; {:try_start_11 .. :try_end_80} :catch_80
:catch_80
move-exception p2
.line 16
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Unable to unmarshall response ("
invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p3
:catch_b2
move-exception p1
.line 19
throw p1
:catch_b4
move-exception p1
.line 20
throw p1
.end method
.method parseClockSkewOffset(Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/AmazonServiceException;)I
.registers 6
.line 1
new-instance v0, Ljava/util/Date;
invoke-direct {v0}, Ljava/util/Date;-><init>()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_20
.line 3
:try_start_14
invoke-virtual {p1}, Ljava/lang/String;->isEmpty()Z
move-result v2
:try_end_18
.catch Ljava/lang/RuntimeException; {:try_start_14 .. :try_end_18} :catch_3d
if-eqz v2, :cond_1b
goto :goto_20
.line 4
:cond_1b
:try_start_1b
invoke-static {p1}, Lcom/amazonaws/util/DateUtils;->parseRFC822Date(Ljava/lang/String;)Ljava/util/Date;
move-result-object p1
:try_end_1f
.catch Ljava/lang/RuntimeException; {:try_start_1b .. :try_end_1f} :catch_3a
goto :goto_2c
.line 5
:cond_20
:goto_20
:try_start_20
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_28
.catch Ljava/lang/RuntimeException; {:try_start_20 .. :try_end_28} :catch_3d
.line 6
:try_start_28
invoke-static {p1}, Lcom/amazonaws/util/DateUtils;->parseCompressedISO8601Date(Ljava/lang/String;)Ljava/util/Date;
move-result-object p1
:try_end_2c
.catch Ljava/lang/RuntimeException; {:try_start_28 .. :try_end_2c} :catch_3a
.line 7
:goto_2c
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_3a
move-exception p2
move-object v1, p1
goto :goto_3e
:catch_3d
move-exception p2
.line 9
:goto_3e
sget-object p1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Unable to parse clock skew offset from response: "
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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
invoke-interface {p1, v0, p2}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
const/4 p1, 0x0
return p1
.end method
.method requestHandler2s(Lcom/amazonaws/Request;Lcom/amazonaws/http/ExecutionContext;)Ljava/util/List;
.registers 8
.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_b
.line 2
invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
move-result-object p1
return-object p1
.line 3
:cond_b
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_f
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_2d
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_29
.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_29
invoke-virtual {v2, p1}, Lcom/amazonaws/handlers/RequestHandler2;->beforeRequest(Lcom/amazonaws/Request;)V
goto :goto_f
:cond_2d
return-object v0
.end method
.method resetRequestAfterError(Lcom/amazonaws/Request;Ljava/lang/Exception;)V
.registers 4
.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_7
return-void
.line 2
:cond_7
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_21
.line 3
:try_start_11
invoke-interface {p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream;
move-result-object p1
invoke-virtual {p1}, Ljava/io/InputStream;->reset()V
:try_end_18
.catch Ljava/io/IOException; {:try_start_11 .. :try_end_18} :catch_19
return-void
.line 4
:catch_19
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;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p1
.line 5
:cond_21
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;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p1
.end method
.method setUserAgent(Lcom/amazonaws/Request;)V
.registers 5
.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_1a
.line 3
invoke-virtual {v1}, Lcom/amazonaws/AmazonWebServiceRequest;->getRequestClientOptions()Lcom/amazonaws/RequestClientOptions;
move-result-object v1
if-eqz v1, :cond_1a
.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_1a
.line 5
invoke-static {v0, v1}, Lcom/amazonaws/http/AmazonHttpClient;->createUserAgentString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 6
:cond_1a
sget-object v1, Lcom/amazonaws/ClientConfiguration;->DEFAULT_USER_AGENT:Ljava/lang/String;
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 {v1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_32
.line 7
iget-object v1, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
invoke-virtual {v1}, Lcom/amazonaws/ClientConfiguration;->getUserAgent()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcom/amazonaws/http/AmazonHttpClient;->createUserAgentString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
:cond_32
const-string v1, "User-Agent"
.line 8
invoke-interface {p1, v1, v0}, Lcom/amazonaws/Request;->addHeader(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public shutdown()V
.registers 2
.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