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