S3ErrorResponseHandler.smali
.class public Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/amazonaws/http/HttpResponseHandler;
# annotations
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/Object;",
"Lcom/amazonaws/http/HttpResponseHandler<",
"Lcom/amazonaws/AmazonServiceException;",
">;"
}
.end annotation
# static fields
.field public static final a:Lcom/amazonaws/logging/Log;
# direct methods
.method public static constructor <clinit>()V
.registers 1
const-class v0, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;
invoke-static {v0}, Lcom/amazonaws/logging/LogFactory;->a(Ljava/lang/Class;)Lcom/amazonaws/logging/Log;
move-result-object v0
sput-object v0, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;->a:Lcom/amazonaws/logging/Log;
return-void
.end method
.method public constructor <init>()V
.registers 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public final a()Z
.registers 2
const/4 v0, 0x0
return v0
.end method
.method public final b(Lcom/amazonaws/http/HttpResponse;)Ljava/lang/Object;
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
.line 1
invoke-virtual {p1}, Lcom/amazonaws/http/HttpResponse;->a()Ljava/io/InputStream;
move-result-object v0
if-nez v0, :cond_e
.line 2
iget-object v0, p1, Lcom/amazonaws/http/HttpResponse;->a:Ljava/lang/String;
.line 3
invoke-virtual {p0, v0, p1}, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;->c(Ljava/lang/String;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/services/s3/model/AmazonS3Exception;
move-result-object p1
goto/16 :goto_8a
.line 4
:cond_e
:try_start_e
invoke-static {v0}, Lcom/amazonaws/util/IOUtils;->toString(Ljava/io/InputStream;)Ljava/lang/String;
move-result-object v0
:try_end_12
.catch Ljava/io/IOException; {:try_start_e .. :try_end_12} :catch_74
.line 5
:try_start_12
invoke-static {v0}, Lcom/amazonaws/util/XpathUtils;->b(Ljava/lang/String;)Lorg/w3c/dom/Document;
move-result-object v1
const-string v2, "Error/Message"
.line 6
invoke-static {v2, v1}, Lcom/amazonaws/util/XpathUtils;->a(Ljava/lang/String;Lorg/w3c/dom/Node;)Ljava/lang/String;
move-result-object v2
const-string v3, "Error/Code"
.line 7
invoke-static {v3, v1}, Lcom/amazonaws/util/XpathUtils;->a(Ljava/lang/String;Lorg/w3c/dom/Node;)Ljava/lang/String;
move-result-object v3
const-string v4, "Error/RequestId"
.line 8
invoke-static {v4, v1}, Lcom/amazonaws/util/XpathUtils;->a(Ljava/lang/String;Lorg/w3c/dom/Node;)Ljava/lang/String;
move-result-object v4
const-string v5, "Error/HostId"
.line 9
invoke-static {v5, v1}, Lcom/amazonaws/util/XpathUtils;->a(Ljava/lang/String;Lorg/w3c/dom/Node;)Ljava/lang/String;
move-result-object v1
.line 10
new-instance v5, Lcom/amazonaws/services/s3/model/AmazonS3Exception;
invoke-direct {v5, v2}, Lcom/amazonaws/services/s3/model/AmazonS3Exception;-><init>(Ljava/lang/String;)V
.line 11
iget v2, p1, Lcom/amazonaws/http/HttpResponse;->b:I
.line 12
iput v2, v5, Lcom/amazonaws/AmazonServiceException;->d:I
const/16 v6, 0x1f4
if-lt v2, v6, :cond_3e
.line 13
sget-object v2, Lcom/amazonaws/AmazonServiceException$ErrorType;->Service:Lcom/amazonaws/AmazonServiceException$ErrorType;
goto :goto_40
:cond_3e
sget-object v2, Lcom/amazonaws/AmazonServiceException$ErrorType;->Client:Lcom/amazonaws/AmazonServiceException$ErrorType;
.line 14
:goto_40
iput-object v3, v5, Lcom/amazonaws/AmazonServiceException;->b:Ljava/lang/String;
.line 15
iput-object v4, v5, Lcom/amazonaws/AmazonServiceException;->a:Ljava/lang/String;
.line 16
iput-object v1, v5, Lcom/amazonaws/services/s3/model/AmazonS3Exception;->f:Ljava/lang/String;
.line 17
iget-object v1, p1, Lcom/amazonaws/http/HttpResponse;->d:Ljava/util/Map;
const-string v2, "X-Amz-Cf-Id"
.line 18
invoke-interface {v1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
:try_end_50
.catch Ljava/lang/Exception; {:try_start_12 .. :try_end_50} :catch_52
move-object p1, v5
goto :goto_8a
:catch_52
move-exception v1
.line 19
sget-object v2, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;->a:Lcom/amazonaws/logging/Log;
invoke-interface {v2}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v3
if-eqz v3, :cond_6f
.line 20
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Failed in parsing the response as XML: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-interface {v2, v3, v1}, Lcom/amazonaws/logging/Log;->b(Ljava/lang/Object;Ljava/lang/Throwable;)V
.line 21
:cond_6f
invoke-virtual {p0, v0, p1}, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;->c(Ljava/lang/String;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/services/s3/model/AmazonS3Exception;
move-result-object p1
goto :goto_8a
:catch_74
move-exception v0
.line 22
sget-object v1, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;->a:Lcom/amazonaws/logging/Log;
invoke-interface {v1}, Lcom/amazonaws/logging/Log;->isDebugEnabled()Z
move-result v1
if-eqz v1, :cond_84
.line 23
sget-object v1, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;->a:Lcom/amazonaws/logging/Log;
const-string v2, "Failed in reading the error response"
invoke-interface {v1, v2, v0}, Lcom/amazonaws/logging/Log;->b(Ljava/lang/Object;Ljava/lang/Throwable;)V
.line 24
:cond_84
iget-object v0, p1, Lcom/amazonaws/http/HttpResponse;->a:Ljava/lang/String;
.line 25
invoke-virtual {p0, v0, p1}, Lcom/amazonaws/services/s3/internal/S3ErrorResponseHandler;->c(Ljava/lang/String;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/services/s3/model/AmazonS3Exception;
move-result-object p1
:goto_8a
return-object p1
.end method
.method public final c(Ljava/lang/String;Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/services/s3/model/AmazonS3Exception;
.registers 6
.line 1
new-instance v0, Lcom/amazonaws/services/s3/model/AmazonS3Exception;
invoke-direct {v0, p1}, Lcom/amazonaws/services/s3/model/AmazonS3Exception;-><init>(Ljava/lang/String;)V
.line 2
iget p1, p2, Lcom/amazonaws/http/HttpResponse;->b:I
.line 3
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, " "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 4
iget-object v2, p2, Lcom/amazonaws/http/HttpResponse;->a:Ljava/lang/String;
.line 5
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 6
iput-object v1, v0, Lcom/amazonaws/AmazonServiceException;->b:Ljava/lang/String;
.line 7
iput p1, v0, Lcom/amazonaws/AmazonServiceException;->d:I
const/16 v1, 0x1f4
if-lt p1, v1, :cond_28
.line 8
sget-object p1, Lcom/amazonaws/AmazonServiceException$ErrorType;->Service:Lcom/amazonaws/AmazonServiceException$ErrorType;
goto :goto_2a
:cond_28
sget-object p1, Lcom/amazonaws/AmazonServiceException$ErrorType;->Client:Lcom/amazonaws/AmazonServiceException$ErrorType;
.line 9
:goto_2a
iget-object p1, p2, Lcom/amazonaws/http/HttpResponse;->d:Ljava/util/Map;
const-string/jumbo p2, "x-amz-request-id"
.line 10
invoke-interface {p1, p2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
.line 11
iput-object p2, v0, Lcom/amazonaws/AmazonServiceException;->a:Ljava/lang/String;
const-string/jumbo p2, "x-amz-id-2"
.line 12
invoke-interface {p1, p2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
.line 13
iput-object p2, v0, Lcom/amazonaws/services/s3/model/AmazonS3Exception;->f:Ljava/lang/String;
const-string p2, "X-Amz-Cf-Id"
.line 14
invoke-interface {p1, p2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/lang/String;
.line 15
new-instance p2, Ljava/util/HashMap;
invoke-direct {p2}, Ljava/util/HashMap;-><init>()V
const-string/jumbo v1, "x-amz-bucket-region"
.line 16
invoke-interface {p1, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
.line 17
invoke-virtual {p2, v1, p1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 18
iput-object p2, v0, Lcom/amazonaws/services/s3/model/AmazonS3Exception;->g:Ljava/util/Map;
return-object v0
.end method