CallServerInterceptor.smali
.class public final Lokhttp3/internal/http/CallServerInterceptor;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lokhttp3/Interceptor;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lokhttp3/internal/http/CallServerInterceptor$CountingSink;
}
.end annotation
# instance fields
.field private final forWebSocket:Z
# direct methods
.method public constructor <init>(Z)V
.registers 2
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
iput-boolean p1, p0, Lokhttp3/internal/http/CallServerInterceptor;->forWebSocket:Z
return-void
.end method
# virtual methods
.method public getName()Ljava/lang/String;
.registers 2
const-string v0, "CallServerInterceptor"
return-object v0
.end method
.method public intercept(Lokhttp3/Interceptor$Chain;)Lokhttp3/Response;
.registers 15
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
const-class v0, Lokhttp3/HttpRequestTag;
check-cast p1, Lokhttp3/internal/http/RealInterceptorChain;
.line 2
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->httpStream()Lokhttp3/internal/http/HttpCodec;
move-result-object v1
.line 3
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->streamAllocation()Lokhttp3/internal/connection/StreamAllocation;
move-result-object v2
.line 4
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->connection()Lokhttp3/Connection;
move-result-object v3
check-cast v3, Lokhttp3/internal/connection/RealConnection;
.line 5
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->request()Lokhttp3/Request;
move-result-object v4
if-eqz v3, :cond_52
.line 6
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->route()Lokhttp3/Route;
move-result-object v5
if-eqz v5, :cond_52
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->route()Lokhttp3/Route;
move-result-object v5
invoke-virtual {v5}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v5
if-eqz v5, :cond_52
.line 7
invoke-virtual {v4, v0}, Lokhttp3/Request;->tag(Ljava/lang/Class;)Ljava/lang/Object;
move-result-object v5
check-cast v5, Lokhttp3/HttpRequestTag;
if-eqz v5, :cond_52
.line 8
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->route()Lokhttp3/Route;
move-result-object v6
invoke-virtual {v6}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v6
invoke-virtual {v6}, Lokhttp3/Address;->isFromHttpDns()Z
move-result v6
invoke-virtual {v5, v6}, Lokhttp3/HttpRequestTag;->setFromHttpDns(Z)V
.line 9
:try_start_3f
invoke-virtual {v5}, Lokhttp3/HttpRequestTag;->getExtInfo()Ljava/util/HashMap;
move-result-object v5
const-string v6, "connectionHashCode"
invoke-virtual {v3}, Ljava/lang/Object;->hashCode()I
move-result v7
invoke-static {v7}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v7
invoke-virtual {v5, v6, v7}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_50
.catchall {:try_start_3f .. :try_end_50} :catchall_51
goto :goto_52
:catchall_51
nop
.line 10
:cond_52
:goto_52
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v5
.line 11
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v7
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object v8
invoke-virtual {v7, v8}, Lokhttp3/EventListener;->requestHeadersStart(Lokhttp3/Call;)V
.line 12
invoke-interface {v1, v4}, Lokhttp3/internal/http/HttpCodec;->writeRequestHeaders(Lokhttp3/Request;)V
.line 13
instance-of v7, v1, Lokhttp3/internal/http2/Http2Codec;
if-eqz v7, :cond_88
.line 14
invoke-virtual {v4, v0}, Lokhttp3/Request;->tag(Ljava/lang/Class;)Ljava/lang/Object;
move-result-object v7
if-eqz v7, :cond_88
.line 15
invoke-virtual {v4, v0}, Lokhttp3/Request;->tag(Ljava/lang/Class;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lokhttp3/HttpRequestTag;
invoke-virtual {v0}, Lokhttp3/HttpRequestTag;->getRequestID()Ljava/lang/String;
move-result-object v0
.line 16
move-object v7, v1
check-cast v7, Lokhttp3/internal/http2/Http2Codec;
iget-object v7, v7, Lokhttp3/internal/http2/Http2Codec;->connection:Lokhttp3/internal/http2/Http2Connection;
iget-object v7, v7, Lokhttp3/internal/http2/Http2Connection;->writer:Lokhttp3/internal/http2/Http2Writer;
iget-wide v7, v7, Lokhttp3/internal/http2/Http2Writer;->lastHeaderSize:J
.line 17
invoke-static {v7, v8}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v7
invoke-static {v0, v7}, Lokhttp3/utils/Http2HeaderHelper;->recordHeaderSize(Ljava/lang/String;Ljava/lang/Long;)V
.line 18
:cond_88
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v0
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object v7
invoke-virtual {v0, v7, v4}, Lokhttp3/EventListener;->requestHeadersEnd(Lokhttp3/Call;Lokhttp3/Request;)V
const/4 v0, 0x0
.line 19
invoke-virtual {v4}, Lokhttp3/Request;->method()Ljava/lang/String;
move-result-object v7
invoke-static {v7}, Lokhttp3/internal/http/HttpMethod;->permitsRequestBody(Ljava/lang/String;)Z
move-result v7
const/4 v8, 0x1
const/4 v9, 0x0
if-eqz v7, :cond_10d
invoke-virtual {v4}, Lokhttp3/Request;->body()Lokhttp3/RequestBody;
move-result-object v7
if-eqz v7, :cond_10d
const-string v7, "Expect"
.line 20
invoke-virtual {v4, v7}, Lokhttp3/Request;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object v7
const-string v10, "100-continue"
invoke-virtual {v10, v7}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v7
if-eqz v7, :cond_c7
.line 21
invoke-interface {v1}, Lokhttp3/internal/http/HttpCodec;->flushRequest()V
.line 22
invoke-interface {v1, v8}, Lokhttp3/internal/http/HttpCodec;->readResponseHeaders(Z)Lokhttp3/Response$Builder;
move-result-object v0
.line 23
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v7
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object v8
invoke-virtual {v7, v8}, Lokhttp3/EventListener;->responseHeadersStart(Lokhttp3/Call;)V
const/4 v8, 0x0
:cond_c7
if-nez v0, :cond_104
.line 24
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v3
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object v7
invoke-virtual {v3, v7}, Lokhttp3/EventListener;->requestBodyStart(Lokhttp3/Call;)V
.line 25
invoke-virtual {v4}, Lokhttp3/Request;->body()Lokhttp3/RequestBody;
move-result-object v3
invoke-virtual {v3}, Lokhttp3/RequestBody;->contentLength()J
move-result-wide v10
.line 26
new-instance v3, Lokhttp3/internal/http/CallServerInterceptor$CountingSink;
.line 27
invoke-interface {v1, v4, v10, v11}, Lokhttp3/internal/http/HttpCodec;->createRequestBody(Lokhttp3/Request;J)Lokio/v;
move-result-object v7
invoke-direct {v3, v7}, Lokhttp3/internal/http/CallServerInterceptor$CountingSink;-><init>(Lokio/v;)V
.line 28
sget-object v7, Lokio/k;->a:Ljava/util/logging/Logger;
.line 29
new-instance v7, Lokio/q;
invoke-direct {v7, v3}, Lokio/q;-><init>(Lokio/v;)V
.line 30
invoke-virtual {v4}, Lokhttp3/Request;->body()Lokhttp3/RequestBody;
move-result-object v10
invoke-virtual {v10, v7}, Lokhttp3/RequestBody;->writeTo(Lokio/c;)V
.line 31
invoke-virtual {v7}, Lokio/q;->close()V
.line 32
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v7
.line 33
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object v10
iget-wide v11, v3, Lokhttp3/internal/http/CallServerInterceptor$CountingSink;->successfulCount:J
invoke-virtual {v7, v10, v11, v12}, Lokhttp3/EventListener;->requestBodyEnd(Lokhttp3/Call;J)V
goto :goto_10d
.line 34
:cond_104
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->isMultiplexed()Z
move-result v3
if-nez v3, :cond_10d
.line 35
invoke-virtual {v2}, Lokhttp3/internal/connection/StreamAllocation;->noNewStreams()V
.line 36
:cond_10d
:goto_10d
invoke-interface {v1}, Lokhttp3/internal/http/HttpCodec;->finishRequest()V
if-nez v0, :cond_124
.line 37
invoke-interface {v1, v9}, Lokhttp3/internal/http/HttpCodec;->readResponseHeaders(Z)Lokhttp3/Response$Builder;
move-result-object v0
if-eqz v8, :cond_124
.line 38
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v3
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object v7
invoke-virtual {v3, v7}, Lokhttp3/EventListener;->responseHeadersStart(Lokhttp3/Call;)V
const/4 v8, 0x0
.line 39
:cond_124
invoke-virtual {v0, v4}, Lokhttp3/Response$Builder;->request(Lokhttp3/Request;)Lokhttp3/Response$Builder;
move-result-object v0
.line 40
invoke-virtual {v2}, Lokhttp3/internal/connection/StreamAllocation;->connection()Lokhttp3/internal/connection/RealConnection;
move-result-object v3
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->handshake()Lokhttp3/Handshake;
move-result-object v3
invoke-virtual {v0, v3}, Lokhttp3/Response$Builder;->handshake(Lokhttp3/Handshake;)Lokhttp3/Response$Builder;
move-result-object v0
.line 41
invoke-virtual {v0, v5, v6}, Lokhttp3/Response$Builder;->sentRequestAtMillis(J)Lokhttp3/Response$Builder;
move-result-object v0
.line 42
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v10
invoke-virtual {v0, v10, v11}, Lokhttp3/Response$Builder;->receivedResponseAtMillis(J)Lokhttp3/Response$Builder;
move-result-object v0
.line 43
invoke-virtual {v0}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object v0
.line 44
invoke-virtual {v0}, Lokhttp3/Response;->code()I
move-result v3
const/16 v7, 0x64
if-ne v3, v7, :cond_181
.line 45
invoke-interface {v1, v9}, Lokhttp3/internal/http/HttpCodec;->readResponseHeaders(Z)Lokhttp3/Response$Builder;
move-result-object v0
if-eqz v8, :cond_15d
.line 46
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v3
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object v7
invoke-virtual {v3, v7}, Lokhttp3/EventListener;->responseHeadersStart(Lokhttp3/Call;)V
.line 47
:cond_15d
invoke-virtual {v0, v4}, Lokhttp3/Response$Builder;->request(Lokhttp3/Request;)Lokhttp3/Response$Builder;
move-result-object v0
.line 48
invoke-virtual {v2}, Lokhttp3/internal/connection/StreamAllocation;->connection()Lokhttp3/internal/connection/RealConnection;
move-result-object v3
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->handshake()Lokhttp3/Handshake;
move-result-object v3
invoke-virtual {v0, v3}, Lokhttp3/Response$Builder;->handshake(Lokhttp3/Handshake;)Lokhttp3/Response$Builder;
move-result-object v0
.line 49
invoke-virtual {v0, v5, v6}, Lokhttp3/Response$Builder;->sentRequestAtMillis(J)Lokhttp3/Response$Builder;
move-result-object v0
.line 50
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v3
invoke-virtual {v0, v3, v4}, Lokhttp3/Response$Builder;->receivedResponseAtMillis(J)Lokhttp3/Response$Builder;
move-result-object v0
.line 51
invoke-virtual {v0}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object v0
.line 52
invoke-virtual {v0}, Lokhttp3/Response;->code()I
move-result v3
.line 53
:cond_181
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->eventListener()Lokhttp3/EventListener;
move-result-object v4
.line 54
invoke-virtual {p1}, Lokhttp3/internal/http/RealInterceptorChain;->call()Lokhttp3/Call;
move-result-object p1
invoke-virtual {v4, p1, v0}, Lokhttp3/EventListener;->responseHeadersEnd(Lokhttp3/Call;Lokhttp3/Response;)V
.line 55
iget-boolean p1, p0, Lokhttp3/internal/http/CallServerInterceptor;->forWebSocket:Z
if-eqz p1, :cond_1a3
const/16 p1, 0x65
if-ne v3, p1, :cond_1a3
.line 56
invoke-virtual {v0}, Lokhttp3/Response;->newBuilder()Lokhttp3/Response$Builder;
move-result-object p1
sget-object v0, Lokhttp3/internal/Util;->EMPTY_RESPONSE:Lokhttp3/ResponseBody;
.line 57
invoke-virtual {p1, v0}, Lokhttp3/Response$Builder;->body(Lokhttp3/ResponseBody;)Lokhttp3/Response$Builder;
move-result-object p1
.line 58
invoke-virtual {p1}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object p1
goto :goto_1b3
.line 59
:cond_1a3
invoke-virtual {v0}, Lokhttp3/Response;->newBuilder()Lokhttp3/Response$Builder;
move-result-object p1
.line 60
invoke-interface {v1, v0}, Lokhttp3/internal/http/HttpCodec;->openResponseBody(Lokhttp3/Response;)Lokhttp3/ResponseBody;
move-result-object v0
invoke-virtual {p1, v0}, Lokhttp3/Response$Builder;->body(Lokhttp3/ResponseBody;)Lokhttp3/Response$Builder;
move-result-object p1
.line 61
invoke-virtual {p1}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object p1
.line 62
:goto_1b3
invoke-virtual {p1}, Lokhttp3/Response;->request()Lokhttp3/Request;
move-result-object v0
const-string v1, "Connection"
invoke-virtual {v0, v1}, Lokhttp3/Request;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
const-string v4, "close"
invoke-virtual {v4, v0}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_1cf
.line 63
invoke-virtual {p1, v1}, Lokhttp3/Response;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v4, v0}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_1d2
.line 64
:cond_1cf
invoke-virtual {v2}, Lokhttp3/internal/connection/StreamAllocation;->noNewStreams()V
:cond_1d2
const/16 v0, 0xcc
if-eq v3, v0, :cond_1da
const/16 v0, 0xcd
if-ne v3, v0, :cond_1e8
.line 65
:cond_1da
invoke-virtual {p1}, Lokhttp3/Response;->body()Lokhttp3/ResponseBody;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/ResponseBody;->contentLength()J
move-result-wide v0
const-wide/16 v4, 0x0
cmp-long v2, v0, v4
if-gtz v2, :cond_1e9
:cond_1e8
return-object p1
.line 66
:cond_1e9
new-instance v0, Ljava/net/ProtocolException;
const-string v1, "HTTP "
const-string v2, " had non-zero Content-Length: "
.line 67
invoke-static {v1, v3, v2}, Landroidx/core/content/c;->g(Ljava/lang/String;ILjava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 68
invoke-virtual {p1}, Lokhttp3/Response;->body()Lokhttp3/ResponseBody;
move-result-object p1
invoke-virtual {p1}, Lokhttp3/ResponseBody;->contentLength()J
move-result-wide v2
invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw v0
.end method