ClientConnectionRequestFactory$Handler.smali

.class Lcom/amazonaws/http/conn/ClientConnectionRequestFactory$Handler;
.super Ljava/lang/Object;
.source "ClientConnectionRequestFactory.java"

# interfaces
.implements Ljava/lang/reflect/InvocationHandler;


# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
    value = Lcom/amazonaws/http/conn/ClientConnectionRequestFactory;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0xa
    name = "Handler"
.end annotation


# instance fields
.field private final orig:Lorg/apache/http/conn/ClientConnectionRequest;


# direct methods
.method constructor <init>(Lorg/apache/http/conn/ClientConnectionRequest;)V
    .registers 2

    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 2
    iput-object p1, p0, Lcom/amazonaws/http/conn/ClientConnectionRequestFactory$Handler;->orig:Lorg/apache/http/conn/ClientConnectionRequest;

    return-void
.end method


# virtual methods
.method public invoke(Ljava/lang/Object;Ljava/lang/reflect/Method;[Ljava/lang/Object;)Ljava/lang/Object;
    .registers 5
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/Throwable;
        }
    .end annotation

    :try_start_0
    const-string p1, "getConnection"

    .line 1
    invoke-virtual {p2}, Ljava/lang/reflect/Method;->getName()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result p1

    if-eqz p1, :cond_32

    .line 2
    new-instance p1, Lcom/amazonaws/metrics/ServiceLatencyProvider;

    sget-object v0, Lcom/amazonaws/util/AWSServiceMetrics;->HttpClientGetConnectionTime:Lcom/amazonaws/util/AWSServiceMetrics;

    invoke-direct {p1, v0}, Lcom/amazonaws/metrics/ServiceLatencyProvider;-><init>(Lcom/amazonaws/metrics/ServiceMetricType;)V
    :try_end_13
    .catch Ljava/lang/reflect/InvocationTargetException; {:try_start_0 .. :try_end_13} :catch_39

    .line 3
    :try_start_13
    iget-object v0, p0, Lcom/amazonaws/http/conn/ClientConnectionRequestFactory$Handler;->orig:Lorg/apache/http/conn/ClientConnectionRequest;

    invoke-virtual {p2, v0, p3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p2
    :try_end_19
    .catchall {:try_start_13 .. :try_end_19} :catchall_25

    .line 4
    :try_start_19
    invoke-static {}, Lcom/amazonaws/metrics/AwsSdkMetrics;->getServiceMetricCollector()Lcom/amazonaws/metrics/ServiceMetricCollector;

    move-result-object p3

    .line 5
    invoke-virtual {p1}, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endTiming()Lcom/amazonaws/metrics/ServiceLatencyProvider;

    move-result-object p1

    invoke-virtual {p3, p1}, Lcom/amazonaws/metrics/ServiceMetricCollector;->collectLatency(Lcom/amazonaws/metrics/ServiceLatencyProvider;)V

    return-object p2

    :catchall_25
    move-exception p2

    .line 6
    invoke-static {}, Lcom/amazonaws/metrics/AwsSdkMetrics;->getServiceMetricCollector()Lcom/amazonaws/metrics/ServiceMetricCollector;

    move-result-object p3

    .line 7
    invoke-virtual {p1}, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endTiming()Lcom/amazonaws/metrics/ServiceLatencyProvider;

    move-result-object p1

    invoke-virtual {p3, p1}, Lcom/amazonaws/metrics/ServiceMetricCollector;->collectLatency(Lcom/amazonaws/metrics/ServiceLatencyProvider;)V

    .line 8
    throw p2

    .line 9
    :cond_32
    iget-object p1, p0, Lcom/amazonaws/http/conn/ClientConnectionRequestFactory$Handler;->orig:Lorg/apache/http/conn/ClientConnectionRequest;

    invoke-virtual {p2, p1, p3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1
    :try_end_38
    .catch Ljava/lang/reflect/InvocationTargetException; {:try_start_19 .. :try_end_38} :catch_39

    return-object p1

    :catch_39
    move-exception p1

    .line 10
    # getter for: Lcom/amazonaws/http/conn/ClientConnectionRequestFactory;->log:Lcom/amazonaws/logging/Log;
    invoke-static {}, Lcom/amazonaws/http/conn/ClientConnectionRequestFactory;->access$000()Lcom/amazonaws/logging/Log;

    move-result-object p2

    const-string p3, ""

    invoke-interface {p2, p3, p1}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V

    .line 11
    invoke-virtual {p1}, Ljava/lang/reflect/InvocationTargetException;->getCause()Ljava/lang/Throwable;

    move-result-object p1

    throw p1
.end method