Files
rr3-apk/smali/com/amazonaws/http/AmazonHttpClient.smali
supermegamestre 4bbd74a497 First Upload
Just the APK
Force update disabled, will only work offline.
2026-01-26 00:26:29 -03:00

3052 lines
79 KiB
Smali

.class public Lcom/amazonaws/http/AmazonHttpClient;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field public static final REQUEST_LOG:Lcom/amazonaws/logging/Log;
.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 public final requestFactory:Lcom/amazonaws/http/HttpRequestFactory;
.field public final requestMetricCollector:Lcom/amazonaws/metrics/RequestMetricCollector;
# direct methods
.method static constructor <clinit>()V
.locals 1
const-string v0, "com.amazonaws.request"
.line 82
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;
const-class v0, Lcom/amazonaws/http/AmazonHttpClient;
.line 88
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;Lcom/amazonaws/http/HttpClient;)V
.locals 1
.line 144
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 105
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;
iput-object p1, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
iput-object p2, p0, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient;
const/4 p1, 0x0
iput-object p1, p0, Lcom/amazonaws/http/AmazonHttpClient;->requestMetricCollector:Lcom/amazonaws/metrics/RequestMetricCollector;
return-void
.end method
.method public static createUserAgentString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.locals 1
.line 560
invoke-virtual {p0, p1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_0
return-object p0
.line 563
:cond_0
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 public static isTemporaryRedirect(Lcom/amazonaws/http/HttpResponse;)Z
.locals 2
.line 625
invoke-virtual {p0}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I
move-result v0
.line 626
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 628
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
# virtual methods
.method public afterError(Lcom/amazonaws/Request;Lcom/amazonaws/Response;Ljava/util/List;Lcom/amazonaws/AmazonClientException;)V
.locals 1
.line 242
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 243
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
.line 251
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 252
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
.line 208
invoke-interface {p1}, Lcom/amazonaws/Request;->getHostPrefix()Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_0
.line 210
:try_start_0
invoke-interface {p1}, Lcom/amazonaws/Request;->getEndpoint()Ljava/net/URI;
move-result-object v0
.line 211
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()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 212
invoke-static {v0}, Lcom/amazonaws/util/URIBuilder;->builder(Ljava/net/URI;)Lcom/amazonaws/util/URIBuilder;
move-result-object v0
.line 213
invoke-virtual {v0, v1}, Lcom/amazonaws/util/URIBuilder;->host(Ljava/lang/String;)Lcom/amazonaws/util/URIBuilder;
move-result-object v0
.line 214
invoke-virtual {v0}, Lcom/amazonaws/util/URIBuilder;->build()Ljava/net/URI;
move-result-object v0
.line 212
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
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 216
invoke-interface {v1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v2
if-eqz v2, :cond_0
.line 217
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Failed to prepend host prefix: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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 225
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 226
invoke-virtual {p4}, Lcom/amazonaws/http/ExecutionContext;->getAwsRequestMetrics()Lcom/amazonaws/util/AWSRequestMetrics;
move-result-object v1
.line 229
: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 p2
:try_end_1
.catch Lcom/amazonaws/AmazonClientException; {:try_start_1 .. :try_end_1} :catch_2
.line 231
:try_start_2
invoke-virtual {v1}, Lcom/amazonaws/util/AWSRequestMetrics;->getTimingInfo()Lcom/amazonaws/util/TimingInfo;
move-result-object p3
invoke-virtual {p3}, Lcom/amazonaws/util/TimingInfo;->endTiming()Lcom/amazonaws/util/TimingInfo;
move-result-object p3
.line 232
invoke-virtual {p0, p1, v0, p2, p3}, Lcom/amazonaws/http/AmazonHttpClient;->afterResponse(Lcom/amazonaws/Request;Ljava/util/List;Lcom/amazonaws/Response;Lcom/amazonaws/util/TimingInfo;)V
:try_end_2
.catch Lcom/amazonaws/AmazonClientException; {:try_start_2 .. :try_end_2} :catch_1
return-object p2
:catch_1
move-exception p3
goto :goto_1
:catch_2
move-exception p3
const/4 p2, 0x0
.line 235
:goto_1
invoke-virtual {p0, p1, p2, v0, p3}, Lcom/amazonaws/http/AmazonHttpClient;->afterError(Lcom/amazonaws/Request;Lcom/amazonaws/Response;Ljava/util/List;Lcom/amazonaws/AmazonClientException;)V
.line 236
throw p3
.line 222
: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;-><init>(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
move-object/from16 v7, p0
move-object/from16 v8, p1
move-object/from16 v9, p4
.line 296
invoke-virtual/range {p4 .. p4}, Lcom/amazonaws/http/ExecutionContext;->getAwsRequestMetrics()Lcom/amazonaws/util/AWSRequestMetrics;
move-result-object v10
.line 301
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 302
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 306
invoke-virtual/range {p0 .. p1}, Lcom/amazonaws/http/AmazonHttpClient;->setUserAgent(Lcom/amazonaws/Request;)V
.line 307
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 315
new-instance v11, Ljava/util/LinkedHashMap;
.line 316
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 317
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 319
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream;
move-result-object v13
if-eqz v13, :cond_0
.line 320
invoke-virtual {v13}, Ljava/io/InputStream;->markSupported()Z
move-result v0
if-eqz v0, :cond_0
const/4 v0, -0x1
.line 321
invoke-virtual {v13, v0}, Ljava/io/InputStream;->mark(I)V
.line 324
: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
add-int/lit8 v15, v0, 0x1
move/from16 v19, v1
.line 331
sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RequestCount:Lcom/amazonaws/util/AWSRequestMetrics$Field;
move-wide/from16 v20, v2
int-to-long v2, v15
invoke-virtual {v10, v1, v2, v3}, Lcom/amazonaws/util/AWSRequestMetrics;->setCounter(Lcom/amazonaws/metrics/MetricType;J)V
const/4 v1, 0x1
if-le v15, v1, :cond_1
.line 333
invoke-interface {v8, v11}, Lcom/amazonaws/Request;->setParameters(Ljava/util/Map;)V
.line 334
invoke-interface {v8, v12}, Lcom/amazonaws/Request;->setHeaders(Ljava/util/Map;)V
.line 335
invoke-interface {v8, v13}, Lcom/amazonaws/Request;->setContent(Ljava/io/InputStream;)V
:cond_1
if-eqz v16, :cond_2
.line 337
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getEndpoint()Ljava/net/URI;
move-result-object v2
if-nez v2, :cond_2
.line 338
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getResourcePath()Ljava/lang/String;
move-result-object v2
if-nez v2, :cond_2
.line 339
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
.line 340
invoke-virtual/range {v16 .. v16}, Ljava/net/URI;->getScheme()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "://"
invoke-virtual {v2, 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 {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
.line 339
invoke-static {v2}, Ljava/net/URI;->create(Ljava/lang/String;)Ljava/net/URI;
move-result-object v2
invoke-interface {v8, v2}, Lcom/amazonaws/Request;->setEndpoint(Ljava/net/URI;)V
.line 341
invoke-virtual/range {v16 .. v16}, Ljava/net/URI;->getPath()Ljava/lang/String;
move-result-object v2
invoke-interface {v8, v2}, Lcom/amazonaws/Request;->setResourcePath(Ljava/lang/String;)V
:cond_2
const-string v3, "Cannot close the response content."
if-le v15, v1, :cond_4
.line 346
:try_start_0
sget-object v1, Lcom/amazonaws/util/AWSRequestMetrics$Field;->RetryPauseTime:Lcom/amazonaws/util/AWSRequestMetrics$Field;
invoke-virtual {v10, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->startEvent(Lcom/amazonaws/metrics/MetricType;)V
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_5
.catch Ljava/lang/RuntimeException; {:try_start_0 .. :try_end_0} :catch_4
.catch Ljava/lang/Error; {:try_start_0 .. :try_end_0} :catch_3
.catchall {:try_start_0 .. :try_end_0} :catchall_3
.line 348
:try_start_1
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest;
move-result-object v2
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_2
move-object/from16 v22, v6
:try_start_2
iget-object v6, v7, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
.line 351
invoke-virtual {v6}, Lcom/amazonaws/ClientConfiguration;->getRetryPolicy()Lcom/amazonaws/retry/RetryPolicy;
move-result-object v6
.line 348
invoke-virtual {v7, v2, v4, v15, v6}, Lcom/amazonaws/http/AmazonHttpClient;->pauseBeforeNextRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)J
move-result-wide v20
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_1
.line 353
:try_start_3
invoke-virtual {v10, v1}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V
.line 355
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream;
move-result-object v1
if-eqz v1, :cond_3
.line 356
invoke-virtual {v1}, Ljava/io/InputStream;->markSupported()Z
move-result v2
if-eqz v2, :cond_3
.line 357
invoke-virtual {v1}, Ljava/io/InputStream;->reset()V
goto :goto_6
:catchall_0
move-exception v0
move-object v2, v0
move-object v9, v3
:goto_1
move/from16 v1, v19
move-object/from16 v6, v22
goto/16 :goto_28
:catch_0
move-exception v0
move-object v9, v3
:goto_2
move/from16 v1, v19
move-object/from16 v6, v22
goto/16 :goto_23
:catch_1
move-exception v0
move-object v9, v3
:goto_3
move/from16 v1, v19
move-object/from16 v6, v22
goto/16 :goto_24
:catch_2
move-exception v0
:goto_4
move-object v9, v3
move-object/from16 v25, v5
:goto_5
move-object/from16 v23, v11
goto/16 :goto_25
:cond_3
:goto_6
move-wide/from16 v1, v20
goto :goto_b
:catchall_1
move-exception v0
goto :goto_7
:catchall_2
move-exception v0
move-object/from16 v22, v6
.line 353
:goto_7
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 354
throw v0
:try_end_3
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_2
.catch Ljava/lang/RuntimeException; {:try_start_3 .. :try_end_3} :catch_1
.catch Ljava/lang/Error; {:try_start_3 .. :try_end_3} :catch_0
.catchall {:try_start_3 .. :try_end_3} :catchall_0
:catchall_3
move-exception v0
move-object/from16 v22, v6
move-object v2, v0
move-object v9, v3
:goto_8
move/from16 v1, v19
goto/16 :goto_28
:catch_3
move-exception v0
move-object/from16 v22, v6
move-object v9, v3
:goto_9
move/from16 v1, v19
goto/16 :goto_23
:catch_4
move-exception v0
move-object/from16 v22, v6
move-object v9, v3
:goto_a
move/from16 v1, v19
goto/16 :goto_24
:catch_5
move-exception v0
move-object/from16 v22, v6
goto :goto_4
:cond_4
move-object/from16 v22, v6
goto :goto_6
:goto_b
:try_start_4
const-string v4, "aws-sdk-retry"
.line 360
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v0, "/"
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-interface {v8, v4, v0}, 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_28
.catch Ljava/lang/RuntimeException; {:try_start_4 .. :try_end_4} :catch_1
.catch Ljava/lang/Error; {:try_start_4 .. :try_end_4} :catch_0
.catchall {:try_start_4 .. :try_end_4} :catchall_f
if-nez v5, :cond_5
.line 365
: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 v5
:try_end_5
.catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_6
.catch Ljava/lang/RuntimeException; {:try_start_5 .. :try_end_5} :catch_1
.catch Ljava/lang/Error; {:try_start_5 .. :try_end_5} :catch_0
.catchall {:try_start_5 .. :try_end_5} :catchall_0
:cond_5
move-object v6, v5
goto :goto_c
:catch_6
move-exception v0
move-wide/from16 v20, v1
goto :goto_4
:goto_c
if-eqz v6, :cond_6
if-eqz v14, :cond_6
.line 368
: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_7
.catch Ljava/lang/RuntimeException; {:try_start_6 .. :try_end_6} :catch_1
.catch Ljava/lang/Error; {:try_start_6 .. :try_end_6} :catch_0
.catchall {:try_start_6 .. :try_end_6} :catchall_0
.line 370
:try_start_7
invoke-interface {v6, 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_4
.line 372
:try_start_8
invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V
goto :goto_e
:catch_7
move-exception v0
move-wide/from16 v20, v1
move-object v9, v3
:goto_d
move-object/from16 v25, v6
goto :goto_5
:catchall_4
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 373
throw v4
:try_end_8
.catch Ljava/io/IOException; {:try_start_8 .. :try_end_8} :catch_7
.catch Ljava/lang/RuntimeException; {:try_start_8 .. :try_end_8} :catch_1
.catch Ljava/lang/Error; {:try_start_8 .. :try_end_8} :catch_0
.catchall {:try_start_8 .. :try_end_8} :catchall_0
:cond_6
:goto_e
:try_start_9
sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log;
.line 376
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_7
.catch Ljava/lang/RuntimeException; {:try_start_9 .. :try_end_9} :catch_1
.catch Ljava/lang/Error; {:try_start_9 .. :try_end_9} :catch_0
.catchall {:try_start_9 .. :try_end_9} :catchall_f
if-eqz v4, :cond_7
.line 377
:try_start_a
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()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_7
.catch Ljava/lang/RuntimeException; {:try_start_a .. :try_end_a} :catch_1
.catch Ljava/lang/Error; {:try_start_a .. :try_end_a} :catch_0
.catchall {:try_start_a .. :try_end_a} :catchall_0
: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;
.line 380
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_7
.catch Ljava/lang/RuntimeException; {:try_start_b .. :try_end_b} :catch_1
.catch Ljava/lang/Error; {:try_start_b .. :try_end_b} :catch_0
.catchall {:try_start_b .. :try_end_b} :catchall_f
.line 384
: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_27
.catch Ljava/lang/RuntimeException; {:try_start_c .. :try_end_c} :catch_1
.catch Ljava/lang/Error; {:try_start_c .. :try_end_c} :catch_0
.catchall {:try_start_c .. :try_end_c} :catchall_f
:try_start_d
iget-object v4, v7, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient;
.line 386
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_d
.line 388
:try_start_e
invoke-virtual {v10, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V
.line 391
invoke-virtual {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_23
.catch Ljava/lang/RuntimeException; {:try_start_e .. :try_end_e} :catch_21
.catch Ljava/lang/Error; {:try_start_e .. :try_end_e} :catch_20
.catchall {:try_start_e .. :try_end_e} :catchall_c
if-eqz v0, :cond_9
.line 392
: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_f
.catch Ljava/lang/RuntimeException; {:try_start_f .. :try_end_f} :catch_d
.catch Ljava/lang/Error; {:try_start_f .. :try_end_f} :catch_c
.catchall {:try_start_f .. :try_end_f} :catchall_6
move-wide/from16 v20, 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 397
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_e
.catch Ljava/lang/RuntimeException; {:try_start_10 .. :try_end_10} :catch_d
.catch Ljava/lang/Error; {:try_start_10 .. :try_end_10} :catch_c
.catchall {:try_start_10 .. :try_end_10} :catchall_6
move-object/from16 v2, p2
.line 398
: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 401
new-instance v2, Lcom/amazonaws/Response;
invoke-direct {v2, v0, v4}, Lcom/amazonaws/Response;-><init>(Ljava/lang/Object;Lcom/amazonaws/http/HttpResponse;)V
:try_end_11
.catch Ljava/io/IOException; {:try_start_11 .. :try_end_11} :catch_b
.catch Ljava/lang/RuntimeException; {:try_start_11 .. :try_end_11} :catch_a
.catch Ljava/lang/Error; {:try_start_11 .. :try_end_11} :catch_9
.catchall {:try_start_11 .. :try_end_11} :catchall_5
if-nez v1, :cond_8
.line 482
:try_start_12
invoke-virtual {v4}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_8
.line 483
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_8
goto :goto_f
:catch_8
move-exception v0
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 486
invoke-interface {v1, v3, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
:cond_8
:goto_f
return-object v2
:catchall_5
move-exception v0
move-object v2, v0
move-object v9, v3
move-object v6, v4
goto/16 :goto_28
:catch_9
move-exception v0
move-object v9, v3
move-object v6, v4
goto/16 :goto_23
:catch_a
move-exception v0
move-object v9, v3
move-object v6, v4
goto/16 :goto_24
:catch_b
move-exception v0
move/from16 v19, v1
:goto_10
move-object v9, v3
move-object/from16 v22, v4
move-object/from16 v17, v5
goto/16 :goto_d
:catchall_6
move-exception v0
move-object v2, v0
move-object v9, v3
move-object v6, v4
goto/16 :goto_8
:catch_c
move-exception v0
move-object v9, v3
move-object v6, v4
goto/16 :goto_9
:catch_d
move-exception v0
move-object v9, v3
move-object v6, v4
goto/16 :goto_a
:catch_e
move-exception v0
goto :goto_10
:catch_f
move-exception v0
move-wide/from16 v20, v1
goto :goto_10
:cond_9
move-wide/from16 v20, v1
.line 402
: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_22
.catch Ljava/lang/RuntimeException; {:try_start_13 .. :try_end_13} :catch_21
.catch Ljava/lang/Error; {:try_start_13 .. :try_end_13} :catch_20
.catchall {:try_start_13 .. :try_end_13} :catchall_c
if-eqz v0, :cond_a
.line 409
: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;
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 410
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
:try_end_14
.catch Ljava/io/IOException; {:try_start_14 .. :try_end_14} :catch_15
.catch Ljava/lang/RuntimeException; {:try_start_14 .. :try_end_14} :catch_14
.catch Ljava/lang/Error; {:try_start_14 .. :try_end_14} :catch_13
.catchall {:try_start_14 .. :try_end_14} :catchall_8
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 412
invoke-static {v0}, Ljava/net/URI;->create(Ljava/lang/String;)Ljava/net/URI;
move-result-object v16
const/4 v1, 0x0
.line 413
invoke-interface {v8, v1}, Lcom/amazonaws/Request;->setEndpoint(Ljava/net/URI;)V
.line 414
invoke-interface {v8, v1}, Lcom/amazonaws/Request;->setResourcePath(Ljava/lang/String;)V
.line 415
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 416
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 417
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_12
.catch Ljava/lang/RuntimeException; {:try_start_15 .. :try_end_15} :catch_11
.catch Ljava/lang/Error; {:try_start_15 .. :try_end_15} :catch_10
.catchall {:try_start_15 .. :try_end_15} :catchall_7
move-object/from16 v24, v5
move-object/from16 v25, v6
move/from16 v1, v19
move-object/from16 v9, v23
const/4 v2, 0x0
move-object/from16 v23, v11
move-object v11, v4
goto/16 :goto_1b
:catchall_7
move-exception v0
:goto_11
move-object v2, v0
move-object v6, v4
move/from16 v1, v19
move-object/from16 v9, v23
goto/16 :goto_28
:catch_10
move-exception v0
:goto_12
move-object v6, v4
move/from16 v1, v19
move-object/from16 v9, v23
goto/16 :goto_23
:catch_11
move-exception v0
:goto_13
move-object v6, v4
move/from16 v1, v19
move-object/from16 v9, v23
goto/16 :goto_24
:catch_12
move-exception v0
:goto_14
move-object/from16 v22, v4
move-object/from16 v17, v5
move-object/from16 v25, v6
move-object/from16 v9, v23
goto/16 :goto_5
:catchall_8
move-exception v0
move-object/from16 v23, v3
goto :goto_11
:catch_13
move-exception v0
move-object/from16 v23, v3
goto :goto_12
:catch_14
move-exception v0
move-object/from16 v23, v3
goto :goto_13
:catch_15
move-exception v0
move-object/from16 v23, v3
goto :goto_14
:cond_a
move-object/from16 v23, v3
.line 419
: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_1f
.catch Ljava/lang/RuntimeException; {:try_start_16 .. :try_end_16} :catch_1e
.catch Ljava/lang/Error; {:try_start_16 .. :try_end_16} :catch_1d
.catchall {:try_start_16 .. :try_end_16} :catchall_b
move-object/from16 v3, p3
.line 420
: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 422
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 423
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 424
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 426
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest;
move-result-object v2
.line 427
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 430
invoke-virtual {v1}, Lcom/amazonaws/ClientConfiguration;->getRetryPolicy()Lcom/amazonaws/retry/RetryPolicy;
move-result-object v22
:try_end_17
.catch Ljava/io/IOException; {:try_start_17 .. :try_end_17} :catch_1c
.catch Ljava/lang/RuntimeException; {:try_start_17 .. :try_end_17} :catch_1b
.catch Ljava/lang/Error; {:try_start_17 .. :try_end_17} :catch_1a
.catchall {:try_start_17 .. :try_end_17} :catchall_a
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, v15
move-object/from16 v25, v6
move-object/from16 v6, v22
.line 426
:try_start_18
invoke-virtual/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 441
invoke-static {v0}, Lcom/amazonaws/retry/RetryUtils;->isClockSkewError(Lcom/amazonaws/AmazonServiceException;)Z
move-result v1
if-eqz v1, :cond_b
.line 442
invoke-virtual {v7, v11, v0}, Lcom/amazonaws/http/AmazonHttpClient;->parseClockSkewOffset(Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/AmazonServiceException;)J
move-result-wide v1
.line 443
invoke-static {v1, v2}, Lcom/amazonaws/SDKGlobalConfiguration;->setGlobalTimeOffset(J)V
goto :goto_1a
:catchall_9
move-exception v0
:goto_15
move-object v2, v0
move-object v6, v11
move/from16 v1, v17
goto/16 :goto_28
:catch_16
move-exception v0
:goto_16
move-object v6, v11
move/from16 v1, v17
goto/16 :goto_23
:catch_17
move-exception v0
:goto_17
move-object v6, v11
move/from16 v1, v17
goto/16 :goto_24
:catch_18
move-exception v0
:goto_18
move-object/from16 v22, v11
move/from16 v19, v17
:goto_19
move-object/from16 v17, v24
goto/16 :goto_25
.line 445
:cond_b
:goto_1a
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_18
.catch Ljava/lang/RuntimeException; {:try_start_18 .. :try_end_18} :catch_17
.catch Ljava/lang/Error; {:try_start_18 .. :try_end_18} :catch_16
.catchall {:try_start_18 .. :try_end_18} :catchall_9
move-object v2, v0
move/from16 v1, v17
:goto_1b
if-nez v1, :cond_c
if-eqz v11, :cond_c
.line 482
:try_start_19
invoke-virtual {v11}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_c
.line 483
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_19
goto :goto_1c
:catch_19
move-exception v0
sget-object v3, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 486
invoke-interface {v3, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
:cond_c
:goto_1c
move-object v4, v2
move-object v6, v11
move-wide/from16 v2, v20
move-object/from16 v17, v24
move-object/from16 v5, v25
const/4 v11, 0x0
goto/16 :goto_27
.line 431
:cond_d
:try_start_1a
throw v0
:try_end_1a
.catch Ljava/io/IOException; {:try_start_1a .. :try_end_1a} :catch_18
.catch Ljava/lang/RuntimeException; {:try_start_1a .. :try_end_1a} :catch_17
.catch Ljava/lang/Error; {:try_start_1a .. :try_end_1a} :catch_16
.catchall {:try_start_1a .. :try_end_1a} :catchall_9
:catchall_a
move-exception v0
move-object v11, v4
move-object/from16 v9, v23
goto :goto_15
:catch_1a
move-exception v0
move-object v11, v4
move-object/from16 v9, v23
goto :goto_16
:catch_1b
move-exception v0
move-object v11, v4
move-object/from16 v9, v23
goto :goto_17
:catch_1c
move-exception v0
move-object/from16 v24, v5
move-object/from16 v25, v6
move-object/from16 v9, v23
move-object/from16 v23, v11
move-object v11, v4
goto :goto_18
:catchall_b
move-exception v0
move-object v11, v4
move-object/from16 v9, v23
:goto_1d
move-object v2, v0
move-object v6, v11
goto/16 :goto_8
:catch_1d
move-exception v0
move-object v11, v4
move-object/from16 v9, v23
:goto_1e
move-object v6, v11
goto/16 :goto_9
:catch_1e
move-exception v0
move-object v11, v4
move-object/from16 v9, v23
:goto_1f
move-object v6, v11
goto/16 :goto_a
:catch_1f
move-exception v0
move-object/from16 v24, v5
move-object/from16 v25, v6
move-object/from16 v9, v23
:goto_20
move-object/from16 v23, v11
move-object v11, v4
move-object/from16 v22, v11
goto :goto_19
:catchall_c
move-exception v0
move-object v9, v3
move-object v11, v4
goto :goto_1d
:catch_20
move-exception v0
move-object v9, v3
move-object v11, v4
goto :goto_1e
:catch_21
move-exception v0
move-object v9, v3
move-object v11, v4
goto :goto_1f
:catch_22
move-exception v0
:goto_21
move-object v9, v3
move-object/from16 v24, v5
move-object/from16 v25, v6
goto :goto_20
:catch_23
move-exception v0
move-wide/from16 v20, v1
goto :goto_21
:catchall_d
move-exception v0
move-wide/from16 v20, v1
move-object v9, v3
move-object/from16 v24, v5
move-object/from16 v25, v6
move-object/from16 v23, v11
.line 388
: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 389
throw v0
:try_end_1b
.catch Ljava/io/IOException; {:try_start_1b .. :try_end_1b} :catch_26
.catch Ljava/lang/RuntimeException; {:try_start_1b .. :try_end_1b} :catch_25
.catch Ljava/lang/Error; {:try_start_1b .. :try_end_1b} :catch_24
.catchall {:try_start_1b .. :try_end_1b} :catchall_e
:catchall_e
move-exception v0
:goto_22
move-object v2, v0
goto/16 :goto_1
:catch_24
move-exception v0
goto/16 :goto_2
:catch_25
move-exception v0
goto/16 :goto_3
:catch_26
move-exception v0
goto/16 :goto_19
:catchall_f
move-exception v0
move-object v9, v3
goto :goto_22
:catch_27
move-exception v0
move-wide/from16 v20, v1
move-object v9, v3
move-object/from16 v24, v5
move-object/from16 v25, v6
move-object/from16 v23, v11
goto/16 :goto_19
:catch_28
move-exception v0
move-wide/from16 v20, v1
move-object v9, v3
move-object/from16 v23, v11
move-object/from16 v25, v5
goto :goto_25
.line 471
:goto_23
:try_start_1c
invoke-virtual {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
:catchall_10
move-exception v0
move-object v2, v0
goto/16 :goto_28
.line 469
:goto_24
invoke-virtual {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_10
:goto_25
:try_start_1d
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 448
invoke-interface {v1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v2
:try_end_1d
.catchall {:try_start_1d .. :try_end_1d} :catchall_e
const-string v3, "Unable to execute HTTP request: "
if-eqz v2, :cond_e
.line 449
:try_start_1e
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/Throwable;->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 451
: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 452
invoke-virtual {v10, v1, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V
.line 453
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 455
new-instance v6, Lcom/amazonaws/AmazonClientException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 456
invoke-virtual {v0}, Ljava/lang/Throwable;->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;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 457
invoke-interface/range {p1 .. p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest;
move-result-object v2
.line 458
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 461
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 v5, v15
move-object/from16 v24, v6
move-object/from16 v6, v18
.line 457
invoke-virtual/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 467
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_e
if-nez v19, :cond_f
if-eqz v22, :cond_f
.line 482
:try_start_1f
invoke-virtual/range {v22 .. v22}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_f
.line 483
invoke-virtual/range {v22 .. v22}, 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_29
goto :goto_26
:catch_29
move-exception v0
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 486
invoke-interface {v1, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
:cond_f
:goto_26
move/from16 v1, v19
move-wide/from16 v2, v20
move-object/from16 v6, v22
move-object/from16 v4, v24
move-object/from16 v5, v25
:goto_27
move-object/from16 v9, p4
move v0, v15
move-object/from16 v11, v23
goto/16 :goto_0
.line 462
:cond_10
:try_start_20
throw v24
:try_end_20
.catchall {:try_start_20 .. :try_end_20} :catchall_e
:goto_28
if-nez v1, :cond_11
if-eqz v6, :cond_11
.line 482
:try_start_21
invoke-virtual {v6}, Lcom/amazonaws/http/HttpResponse;->getRawContent()Ljava/io/InputStream;
move-result-object v0
if-eqz v0, :cond_11
.line 483
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_2a
goto :goto_29
:catch_2a
move-exception v0
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 486
invoke-interface {v1, v9, v0}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;Ljava/lang/Throwable;)V
.line 489
:cond_11
:goto_29
throw v2
.end method
.method public finalize()V
.locals 0
.line 835
invoke-virtual {p0}, Lcom/amazonaws/http/AmazonHttpClient;->shutdown()V
.line 836
invoke-super {p0}, Ljava/lang/Object;->finalize()V
return-void
.end method
.method public getRequestMetricCollector()Lcom/amazonaws/metrics/RequestMetricCollector;
.locals 1
iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->requestMetricCollector:Lcom/amazonaws/metrics/RequestMetricCollector;
return-object v0
.end method
.method public final getServerDateFromException(Ljava/lang/String;)Ljava/lang/String;
.locals 3
const-string v0, "("
.line 795
invoke-virtual {p1, v0}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I
move-result v0
const-string v1, " + 15"
.line 797
invoke-virtual {p1, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_0
.line 798
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 800
invoke-virtual {p1, v1}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I
move-result v1
:goto_0
add-int/lit8 v0, v0, 0x1
.line 802
invoke-virtual {p1, v0, v1}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method public handleErrorResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/AmazonServiceException;
.locals 4
.line 707
invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusCode()I
move-result v0
.line 711
: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;
sget-object v1, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log;
.line 712
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/Object;->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 717
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 718
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 719
invoke-virtual {p2, v1}, Lcom/amazonaws/AmazonServiceException;->setStatusCode(I)V
.line 720
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 721
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
const-string v2, "Service Unavailable"
.line 723
invoke-virtual {p3}, Lcom/amazonaws/http/HttpResponse;->getStatusText()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_1
.line 724
new-instance p2, Lcom/amazonaws/AmazonServiceException;
const-string p3, "Service unavailable"
invoke-direct {p2, p3}, Lcom/amazonaws/AmazonServiceException;-><init>(Ljava/lang/String;)V
.line 725
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 726
invoke-virtual {p2, v1}, Lcom/amazonaws/AmazonServiceException;->setStatusCode(I)V
.line 727
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 728
invoke-virtual {p2, p3}, Lcom/amazonaws/AmazonServiceException;->setErrorCode(Ljava/lang/String;)V
.line 740
:goto_0
invoke-virtual {p2, v0}, Lcom/amazonaws/AmazonServiceException;->setStatusCode(I)V
.line 741
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 742
invoke-virtual {p2}, Ljava/lang/Throwable;->fillInStackTrace()Ljava/lang/Throwable;
return-object p2
.line 729
:cond_1
instance-of p1, p2, Ljava/io/IOException;
if-eqz p1, :cond_2
.line 730
check-cast p2, Ljava/io/IOException;
throw p2
.line 732
:cond_2
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/Throwable;->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 734
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 735
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 736
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 public handleResponse(Lcom/amazonaws/Request;Lcom/amazonaws/http/HttpResponseHandler;Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/http/ExecutionContext;)Ljava/lang/Object;
.locals 3
const-string p1, ", Response Text: "
.line 657
:try_start_0
invoke-virtual {p4}, Lcom/amazonaws/http/ExecutionContext;->getAwsRequestMetrics()Lcom/amazonaws/util/AWSRequestMetrics;
move-result-object p4
.line 659
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 661
: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 663
:try_start_2
invoke-virtual {p4, v0}, Lcom/amazonaws/util/AWSRequestMetrics;->endEvent(Lcom/amazonaws/metrics/MetricType;)V
if-eqz p2, :cond_1
sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->REQUEST_LOG:Lcom/amazonaws/logging/Log;
.line 673
invoke-interface {v0}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v1
if-eqz v1, :cond_0
.line 674
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 675
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 674
invoke-interface {v0, v1}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V
goto :goto_0
:catch_0
move-exception p2
goto :goto_1
:catch_1
move-exception p1
goto :goto_2
:catch_2
move-exception p1
goto :goto_3
.line 677
:cond_0
:goto_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 679
invoke-virtual {p2}, Lcom/amazonaws/AmazonWebServiceResponse;->getResult()Ljava/lang/Object;
move-result-object p1
return-object p1
.line 667
:cond_1
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 669
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 670
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_0
move-exception p2
.line 663
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 664
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
.line 685
:goto_1
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/Throwable;->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 687
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 688
new-instance p3, Lcom/amazonaws/AmazonClientException;
invoke-direct {p3, p1, p2}, Lcom/amazonaws/AmazonClientException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p3
.line 683
:goto_2
throw p1
.line 681
:goto_3
throw p1
.end method
.method public final handleUnexpectedFailure(Ljava/lang/Throwable;Lcom/amazonaws/util/AWSRequestMetrics;)Ljava/lang/Throwable;
.locals 1
.line 497
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 498
invoke-virtual {p2, v0, p1}, Lcom/amazonaws/util/AWSRequestMetrics;->addProperty(Lcom/amazonaws/metrics/MetricType;Ljava/lang/Object;)V
return-object p1
.end method
.method public final isRequestSuccessful(Lcom/amazonaws/http/HttpResponse;)Z
.locals 1
.line 632
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 public parseClockSkewOffset(Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/AmazonServiceException;)J
.locals 3
.line 807
new-instance v0, Ljava/util/Date;
invoke-direct {v0}, Ljava/util/Date;-><init>()V
.line 810
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 814
: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 820
: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
:catch_0
move-exception p2
goto :goto_2
:catch_1
move-exception p2
move-object p1, v1
goto :goto_2
.line 816
:cond_1
:goto_0
:try_start_2
invoke-virtual {p2}, Lcom/amazonaws/AmazonServiceException;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {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 817
: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 829
: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 830
div-long/2addr v0, p1
return-wide v0
:goto_2
sget-object v0, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 823
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()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-wide/16 p1, 0x0
return-wide p1
.end method
.method public final pauseBeforeNextRetry(Lcom/amazonaws/AmazonWebServiceRequest;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)J
.locals 2
add-int/lit8 p3, p3, -0x2
.line 766
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
sget-object p4, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 769
invoke-interface {p4}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v0
if-eqz v0, :cond_0
.line 770
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 775
: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 778
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object p2
invoke-virtual {p2}, Ljava/lang/Thread;->interrupt()V
.line 779
new-instance p2, Lcom/amazonaws/AmazonClientException;
invoke-virtual {p1}, Ljava/lang/Throwable;->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 public requestHandler2s(Lcom/amazonaws/Request;Lcom/amazonaws/http/ExecutionContext;)Ljava/util/List;
.locals 2
.line 259
invoke-virtual {p2}, Lcom/amazonaws/http/ExecutionContext;->getRequestHandler2s()Ljava/util/List;
move-result-object p2
if-nez p2, :cond_0
.line 261
invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
move-result-object p1
return-object p1
.line 265
:cond_0
invoke-interface {p2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_0
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_1
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/amazonaws/handlers/RequestHandler2;
.line 272
invoke-virtual {v1, p1}, Lcom/amazonaws/handlers/RequestHandler2;->beforeRequest(Lcom/amazonaws/Request;)V
goto :goto_0
:cond_1
return-object p2
.end method
.method public resetRequestAfterError(Lcom/amazonaws/Request;Ljava/lang/Exception;)V
.locals 1
.line 514
invoke-interface {p1}, Lcom/amazonaws/Request;->getContent()Ljava/io/InputStream;
move-result-object v0
if-nez v0, :cond_0
return-void
.line 517
: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 522
: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 526
: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;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p1
.line 518
: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;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p1
.end method
.method public setUserAgent(Lcom/amazonaws/Request;)V
.locals 3
.line 536
sget-object v0, Lcom/amazonaws/ClientConfiguration;->DEFAULT_USER_AGENT:Ljava/lang/String;
.line 538
invoke-interface {p1}, Lcom/amazonaws/Request;->getOriginalRequest()Lcom/amazonaws/AmazonWebServiceRequest;
move-result-object v1
if-eqz v1, :cond_0
.line 540
invoke-virtual {v1}, Lcom/amazonaws/AmazonWebServiceRequest;->getRequestClientOptions()Lcom/amazonaws/RequestClientOptions;
move-result-object v1
if-eqz v1, :cond_0
.line 542
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 544
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
:goto_0
iget-object v2, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
.line 549
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
iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
.line 550
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
:cond_1
iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
.line 553
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 552
invoke-interface {p1, v0, v1}, Lcom/amazonaws/Request;->addHeader(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public final shouldRetry(Lcom/amazonaws/AmazonWebServiceRequest;Ljava/io/InputStream;Lcom/amazonaws/AmazonClientException;ILcom/amazonaws/retry/RetryPolicy;)Z
.locals 2
add-int/lit8 p4, p4, -0x1
iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->config:Lcom/amazonaws/ClientConfiguration;
.line 594
invoke-virtual {v0}, Lcom/amazonaws/ClientConfiguration;->getMaxErrorRetry()I
move-result v0
if-ltz v0, :cond_0
.line 600
invoke-virtual {p5}, Lcom/amazonaws/retry/RetryPolicy;->isMaxErrorRetryInClientConfigHonored()Z
move-result v1
if-nez v1, :cond_1
.line 601
: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 610
invoke-virtual {p2}, Ljava/io/InputStream;->markSupported()Z
move-result p2
if-nez p2, :cond_4
sget-object p1, Lcom/amazonaws/http/AmazonHttpClient;->log:Lcom/amazonaws/logging/Log;
.line 611
invoke-interface {p1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result p2
if-eqz p2, :cond_3
const-string p2, "Content not repeatable"
.line 612
invoke-interface {p1, p2}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V
:cond_3
return v1
.line 619
: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
.method public shutdown()V
.locals 1
iget-object v0, p0, Lcom/amazonaws/http/AmazonHttpClient;->httpClient:Lcom/amazonaws/http/HttpClient;
.line 574
invoke-interface {v0}, Lcom/amazonaws/http/HttpClient;->shutdown()V
return-void
.end method