AbstractS3ResponseHandler.smali
.class public abstract Lcom/amazonaws/services/s3/internal/AbstractS3ResponseHandler;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/amazonaws/http/HttpResponseHandler;
# annotations
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">",
"Ljava/lang/Object;",
"Lcom/amazonaws/http/HttpResponseHandler<",
"Lcom/amazonaws/AmazonWebServiceResponse<",
"TT;>;>;"
}
.end annotation
# static fields
.field public static final a:Lcom/amazonaws/logging/Log;
.field public static final b:Ljava/util/HashSet;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
# direct methods
.method public static constructor <clinit>()V
.registers 2
.line 1
const-class v0, Lcom/amazonaws/services/s3/internal/S3MetadataResponseHandler;
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/AbstractS3ResponseHandler;->a:Lcom/amazonaws/logging/Log;
.line 2
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
sput-object v0, Lcom/amazonaws/services/s3/internal/AbstractS3ResponseHandler;->b:Ljava/util/HashSet;
const-string v1, "Date"
.line 3
invoke-virtual {v0, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
const-string v1, "Server"
.line 4
invoke-virtual {v0, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
const-string/jumbo v1, "x-amz-request-id"
.line 5
invoke-virtual {v0, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
const-string/jumbo v1, "x-amz-id-2"
.line 6
invoke-virtual {v0, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
const-string v1, "X-Amz-Cf-Id"
.line 7
invoke-virtual {v0, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
const-string v1, "Connection"
.line 8
invoke-virtual {v0, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
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 a()Z
.registers 1
instance-of p0, p0, Lcom/amazonaws/services/s3/internal/S3ObjectResponseHandler;
return p0
.end method
.method public final c(Lcom/amazonaws/http/HttpResponse;)Lcom/amazonaws/AmazonWebServiceResponse;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/amazonaws/http/HttpResponse;",
")",
"Lcom/amazonaws/AmazonWebServiceResponse<",
"TT;>;"
}
.end annotation
.line 1
new-instance v0, Lcom/amazonaws/AmazonWebServiceResponse;
invoke-direct {v0}, Lcom/amazonaws/AmazonWebServiceResponse;-><init>()V
.line 2
iget-object v1, p1, Lcom/amazonaws/http/HttpResponse;->d:Ljava/util/Map;
const-string/jumbo v2, "x-amz-request-id"
.line 3
invoke-interface {v1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
.line 4
iget-object v2, p1, Lcom/amazonaws/http/HttpResponse;->d:Ljava/util/Map;
const-string/jumbo v3, "x-amz-id-2"
.line 5
invoke-interface {v2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
.line 6
iget-object p1, p1, Lcom/amazonaws/http/HttpResponse;->d:Ljava/util/Map;
const-string v3, "X-Amz-Cf-Id"
.line 7
invoke-interface {p1, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/lang/String;
const-string v3, "AWS_REQUEST_ID"
const-string v4, "HOST_ID"
.line 8
invoke-static {v3, v1, v4, v2}, Landroidx/appcompat/e;->h(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/util/HashMap;
move-result-object v1
const-string v2, "CLOUD_FRONT_ID"
.line 9
invoke-virtual {v1, v2, p1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 10
new-instance p1, Lcom/amazonaws/services/s3/S3ResponseMetadata;
invoke-direct {p1, v1}, Lcom/amazonaws/services/s3/S3ResponseMetadata;-><init>(Ljava/util/Map;)V
.line 11
iput-object p1, v0, Lcom/amazonaws/AmazonWebServiceResponse;->b:Lcom/amazonaws/ResponseMetadata;
return-object v0
.end method
.method public final d(Lcom/amazonaws/http/HttpResponse;Lcom/amazonaws/services/s3/model/ObjectMetadata;)V
.registers 9
.line 1
iget-object v0, p1, Lcom/amazonaws/http/HttpResponse;->d:Ljava/util/Map;
.line 2
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_a
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_180
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 3
invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
const-string/jumbo v3, "x-amz-meta-"
.line 4
invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_37
const/16 v3, 0xb
.line 5
invoke-virtual {v2, v3}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v2
.line 6
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
.line 7
iget-object v3, p2, Lcom/amazonaws/services/s3/model/ObjectMetadata;->a:Ljava/util/Map;
invoke-interface {v3, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_a
.line 8
:cond_37
sget-object v3, Lcom/amazonaws/services/s3/internal/AbstractS3ResponseHandler;->b:Ljava/util/HashSet;
invoke-virtual {v3, v2}, Ljava/util/HashSet;->contains(Ljava/lang/Object;)Z
move-result v3
const/4 v4, 0x0
const/4 v5, 0x1
if-eqz v3, :cond_51
.line 9
sget-object v1, Lcom/amazonaws/services/s3/internal/AbstractS3ResponseHandler;->a:Lcom/amazonaws/logging/Log;
new-array v3, v5, [Ljava/lang/Object;
aput-object v2, v3, v4
const-string v2, "%s is ignored."
invoke-static {v2, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v2}, Lcom/amazonaws/logging/Log;->f(Ljava/lang/Object;)V
goto :goto_a
:cond_51
const-string v3, "Last-Modified"
.line 10
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_83
.line 11
:try_start_59
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
sget-object v4, Lcom/amazonaws/services/s3/internal/ServiceUtils;->a:Lcom/amazonaws/logging/Log;
.line 12
invoke-static {v3}, Lcom/amazonaws/util/DateUtils;->e(Ljava/lang/String;)Ljava/util/Date;
move-result-object v3
.line 13
invoke-virtual {p2, v2, v3}, Lcom/amazonaws/services/s3/model/ObjectMetadata;->o(Ljava/lang/String;Ljava/lang/Object;)V
:try_end_68
.catch Ljava/lang/Exception; {:try_start_59 .. :try_end_68} :catch_69
goto :goto_a
:catch_69
move-exception v2
.line 14
sget-object v3, Lcom/amazonaws/services/s3/internal/AbstractS3ResponseHandler;->a:Lcom/amazonaws/logging/Log;
const-string v4, "Unable to parse last modified date: "
.line 15
invoke-static {v4}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
.line 16
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-interface {v3, v1, v2}, Lcom/amazonaws/logging/Log;->d(Ljava/lang/Object;Ljava/lang/Throwable;)V
goto :goto_a
:cond_83
const-string v3, "Content-Length"
.line 17
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_b9
.line 18
:try_start_8b
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
invoke-static {v3}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v3
invoke-static {v3, v4}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v3
invoke-virtual {p2, v2, v3}, Lcom/amazonaws/services/s3/model/ObjectMetadata;->o(Ljava/lang/String;Ljava/lang/Object;)V
:try_end_9c
.catch Ljava/lang/NumberFormatException; {:try_start_8b .. :try_end_9c} :catch_9e
goto/16 :goto_a
:catch_9e
move-exception v2
.line 19
sget-object v3, Lcom/amazonaws/services/s3/internal/AbstractS3ResponseHandler;->a:Lcom/amazonaws/logging/Log;
const-string v4, "Unable to parse content length: "
.line 20
invoke-static {v4}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
.line 21
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-interface {v3, v1, v2}, Lcom/amazonaws/logging/Log;->d(Ljava/lang/Object;Ljava/lang/Throwable;)V
goto/16 :goto_a
:cond_b9
const-string v3, "ETag"
.line 22
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_d0
.line 23
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-static {v1}, Lcom/amazonaws/services/s3/internal/ServiceUtils;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-virtual {p2, v2, v1}, Lcom/amazonaws/services/s3/model/ObjectMetadata;->o(Ljava/lang/String;Ljava/lang/Object;)V
goto/16 :goto_a
:cond_d0
const-string v3, "Expires"
.line 24
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_101
.line 25
:try_start_d8
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
invoke-static {v2}, Lcom/amazonaws/util/DateUtils;->e(Ljava/lang/String;)Ljava/util/Date;
move-result-object v2
.line 26
iput-object v2, p2, Lcom/amazonaws/services/s3/model/ObjectMetadata;->c:Ljava/util/Date;
:try_end_e4
.catch Ljava/lang/Exception; {:try_start_d8 .. :try_end_e4} :catch_e6
goto/16 :goto_a
:catch_e6
move-exception v2
.line 27
sget-object v3, Lcom/amazonaws/services/s3/internal/AbstractS3ResponseHandler;->a:Lcom/amazonaws/logging/Log;
const-string v4, "Unable to parse http expiration date: "
.line 28
invoke-static {v4}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
.line 29
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-interface {v3, v1, v2}, Lcom/amazonaws/logging/Log;->d(Ljava/lang/Object;Ljava/lang/Throwable;)V
goto/16 :goto_a
:cond_101
const-string/jumbo v3, "x-amz-expiration"
.line 30
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_114
.line 31
new-instance v1, Lcom/amazonaws/services/s3/internal/ObjectExpirationHeaderHandler;
invoke-direct {v1}, Lcom/amazonaws/services/s3/internal/ObjectExpirationHeaderHandler;-><init>()V
invoke-virtual {v1, p2, p1}, Lcom/amazonaws/services/s3/internal/ObjectExpirationHeaderHandler;->b(Lcom/amazonaws/services/s3/internal/ObjectExpirationResult;Lcom/amazonaws/http/HttpResponse;)V
goto/16 :goto_a
:cond_114
const-string/jumbo v3, "x-amz-restore"
.line 32
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_127
.line 33
new-instance v1, Lcom/amazonaws/services/s3/internal/ObjectRestoreHeaderHandler;
invoke-direct {v1}, Lcom/amazonaws/services/s3/internal/ObjectRestoreHeaderHandler;-><init>()V
invoke-virtual {v1, p2, p1}, Lcom/amazonaws/services/s3/internal/ObjectRestoreHeaderHandler;->b(Lcom/amazonaws/services/s3/internal/ObjectRestoreResult;Lcom/amazonaws/http/HttpResponse;)V
goto/16 :goto_a
:cond_127
const-string/jumbo v3, "x-amz-request-charged"
.line 34
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v5
if-eqz v5, :cond_143
.line 35
new-instance v1, Lcom/amazonaws/services/s3/internal/S3RequesterChargedHeaderHandler;
invoke-direct {v1}, Lcom/amazonaws/services/s3/internal/S3RequesterChargedHeaderHandler;-><init>()V
.line 36
iget-object v1, p1, Lcom/amazonaws/http/HttpResponse;->d:Ljava/util/Map;
.line 37
invoke-interface {v1, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
if-eqz v1, :cond_13e
const/4 v4, 0x1
.line 38
:cond_13e
invoke-virtual {p2, v4}, Lcom/amazonaws/services/s3/model/ObjectMetadata;->a(Z)V
goto/16 :goto_a
:cond_143
const-string/jumbo v3, "x-amz-mp-parts-count"
.line 39
invoke-virtual {v2, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_177
.line 40
:try_start_14c
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-static {v1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result v1
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
invoke-virtual {p2, v2, v1}, Lcom/amazonaws/services/s3/model/ObjectMetadata;->o(Ljava/lang/String;Ljava/lang/Object;)V
:try_end_15d
.catch Ljava/lang/NumberFormatException; {:try_start_14c .. :try_end_15d} :catch_15f
goto/16 :goto_a
:catch_15f
move-exception p1
.line 41
new-instance p2, Lcom/amazonaws/AmazonClientException;
const-string v0, "Unable to parse part count. Header x-amz-mp-parts-count has corrupted data"
.line 42
invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
.line 43
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()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
invoke-direct {p2, v0, p1}, Lcom/amazonaws/AmazonClientException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p2
.line 44
:cond_177
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
invoke-virtual {p2, v2, v1}, Lcom/amazonaws/services/s3/model/ObjectMetadata;->o(Ljava/lang/String;Ljava/lang/Object;)V
goto/16 :goto_a
:cond_180
return-void
.end method