RealConnection.smali
.class public final Lokhttp3/internal/connection/RealConnection;
.super Lokhttp3/internal/http2/Http2Connection$Listener;
.source "RealConnection.java"
# interfaces
.implements Lokhttp3/Connection;
# static fields
.field private static final MAX_TUNNEL_ATTEMPTS:I = 0x15
.field private static final NPE_THROW_WITH_NULL:Ljava/lang/String; = "throw with null exception"
# instance fields
.field public allocationLimit:I
.field public final allocations:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Ljava/lang/ref/Reference<",
"Lokhttp3/internal/connection/StreamAllocation;",
">;>;"
}
.end annotation
.end field
.field private final connectionPool:Lokhttp3/ConnectionPool;
.field private handshake:Lokhttp3/Handshake;
.field private http2Connection:Lokhttp3/internal/http2/Http2Connection;
.field public idleAtNanos:J
.field public noNewStreams:Z
.field private protocol:Lokhttp3/Protocol;
.field private rawSocket:Ljava/net/Socket;
.field private final route:Lokhttp3/Route;
.field private sink:Lokio/BufferedSink;
.field private socket:Ljava/net/Socket;
.field private source:Lokio/BufferedSource;
.field public successCount:I
# direct methods
.method public constructor <init>(Lokhttp3/ConnectionPool;Lokhttp3/Route;)V
.registers 5
.line 117
invoke-direct {p0}, Lokhttp3/internal/http2/Http2Connection$Listener;-><init>()V
const/4 v0, 0x1
.line 109
iput v0, p0, Lokhttp3/internal/connection/RealConnection;->allocationLimit:I
.line 112
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
const-wide v0, 0x7fffffffffffffffL
.line 115
iput-wide v0, p0, Lokhttp3/internal/connection/RealConnection;->idleAtNanos:J
.line 118
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->connectionPool:Lokhttp3/ConnectionPool;
.line 119
iput-object p2, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
return-void
.end method
.method private connectSocket(IILokhttp3/Call;Lokhttp3/EventListener;)V
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 230
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->proxy()Ljava/net/Proxy;
move-result-object v0
.line 231
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
.line 233
invoke-virtual {v0}, Ljava/net/Proxy;->type()Ljava/net/Proxy$Type;
move-result-object v2
sget-object v3, Ljava/net/Proxy$Type;->DIRECT:Ljava/net/Proxy$Type;
if-eq v2, v3, :cond_23
invoke-virtual {v0}, Ljava/net/Proxy;->type()Ljava/net/Proxy$Type;
move-result-object v2
sget-object v3, Ljava/net/Proxy$Type;->HTTP:Ljava/net/Proxy$Type;
if-ne v2, v3, :cond_1d
goto :goto_23
.line 235
:cond_1d
new-instance v1, Ljava/net/Socket;
invoke-direct {v1, v0}, Ljava/net/Socket;-><init>(Ljava/net/Proxy;)V
goto :goto_2b
.line 234
:cond_23
:goto_23
invoke-virtual {v1}, Lokhttp3/Address;->socketFactory()Ljavax/net/SocketFactory;
move-result-object v1
invoke-virtual {v1}, Ljavax/net/SocketFactory;->createSocket()Ljava/net/Socket;
move-result-object v1
.line 235
:goto_2b
iput-object v1, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
.line 237
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object v1
invoke-virtual {p4, p3, v1, v0}, Lokhttp3/EventListener;->connectStart(Lokhttp3/Call;Ljava/net/InetSocketAddress;Ljava/net/Proxy;)V
.line 238
iget-object p3, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
invoke-virtual {p3, p2}, Ljava/net/Socket;->setSoTimeout(I)V
.line 240
:try_start_3b
invoke-static {}, Lokhttp3/internal/platform/Platform;->get()Lokhttp3/internal/platform/Platform;
move-result-object p2
iget-object p3, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
iget-object p4, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {p4}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object p4
invoke-virtual {p2, p3, p4, p1}, Lokhttp3/internal/platform/Platform;->connectSocket(Ljava/net/Socket;Ljava/net/InetSocketAddress;I)V
:try_end_4a
.catch Ljava/net/ConnectException; {:try_start_3b .. :try_end_4a} :catch_77
.line 252
:try_start_4a
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
invoke-static {p1}, Lokio/Okio;->source(Ljava/net/Socket;)Lokio/Source;
move-result-object p1
invoke-static {p1}, Lokio/Okio;->buffer(Lokio/Source;)Lokio/BufferedSource;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
.line 253
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
invoke-static {p1}, Lokio/Okio;->sink(Ljava/net/Socket;)Lokio/Sink;
move-result-object p1
invoke-static {p1}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
:try_end_62
.catch Ljava/lang/NullPointerException; {:try_start_4a .. :try_end_62} :catch_63
goto :goto_70
:catch_63
move-exception p1
.line 255
invoke-virtual {p1}, Ljava/lang/NullPointerException;->getMessage()Ljava/lang/String;
move-result-object p2
const-string p3, "throw with null exception"
invoke-virtual {p3, p2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p2
if-nez p2, :cond_71
:goto_70
return-void
.line 256
:cond_71
new-instance p2, Ljava/io/IOException;
invoke-direct {p2, p1}, Ljava/io/IOException;-><init>(Ljava/lang/Throwable;)V
throw p2
:catch_77
move-exception p1
.line 242
new-instance p2, Ljava/net/ConnectException;
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "Failed to connect to "
invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p3
iget-object p4, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {p4}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object p4
invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object p3
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p3
invoke-direct {p2, p3}, Ljava/net/ConnectException;-><init>(Ljava/lang/String;)V
.line 243
invoke-virtual {p2, p1}, Ljava/net/ConnectException;->initCause(Ljava/lang/Throwable;)Ljava/lang/Throwable;
.line 244
throw p2
.end method
.method private connectTls(Lokhttp3/internal/connection/ConnectionSpecSelector;)V
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 285
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v0
.line 286
invoke-virtual {v0}, Lokhttp3/Address;->sslSocketFactory()Ljavax/net/ssl/SSLSocketFactory;
move-result-object v1
const/4 v2, 0x0
.line 291
:try_start_b
iget-object v3, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
.line 292
invoke-virtual {v0}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v4
invoke-virtual {v4}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v4
invoke-virtual {v0}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v5
invoke-virtual {v5}, Lokhttp3/HttpUrl;->port()I
move-result v5
const/4 v6, 0x1
.line 291
invoke-virtual {v1, v3, v4, v5, v6}, Ljavax/net/ssl/SSLSocketFactory;->createSocket(Ljava/net/Socket;Ljava/lang/String;IZ)Ljava/net/Socket;
move-result-object v1
check-cast v1, Ljavax/net/ssl/SSLSocket;
:try_end_24
.catch Ljava/lang/AssertionError; {:try_start_b .. :try_end_24} :catch_11e
.catchall {:try_start_b .. :try_end_24} :catchall_11c
.line 295
:try_start_24
invoke-virtual {p1, v1}, Lokhttp3/internal/connection/ConnectionSpecSelector;->configureSecureSocket(Ljavax/net/ssl/SSLSocket;)Lokhttp3/ConnectionSpec;
move-result-object p1
.line 296
invoke-virtual {p1}, Lokhttp3/ConnectionSpec;->supportsTlsExtensions()Z
move-result v3
if-eqz v3, :cond_41
.line 297
invoke-static {}, Lokhttp3/internal/platform/Platform;->get()Lokhttp3/internal/platform/Platform;
move-result-object v3
.line 298
invoke-virtual {v0}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v4
invoke-virtual {v4}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v4
invoke-virtual {v0}, Lokhttp3/Address;->protocols()Ljava/util/List;
move-result-object v5
.line 297
invoke-virtual {v3, v1, v4, v5}, Lokhttp3/internal/platform/Platform;->configureTlsExtensions(Ljavax/net/ssl/SSLSocket;Ljava/lang/String;Ljava/util/List;)V
.line 302
:cond_41
invoke-virtual {v1}, Ljavax/net/ssl/SSLSocket;->startHandshake()V
.line 304
invoke-virtual {v1}, Ljavax/net/ssl/SSLSocket;->getSession()Ljavax/net/ssl/SSLSession;
move-result-object v3
.line 305
invoke-direct {p0, v3}, Lokhttp3/internal/connection/RealConnection;->isValid(Ljavax/net/ssl/SSLSession;)Z
move-result v4
if-eqz v4, :cond_10e
.line 308
invoke-static {v3}, Lokhttp3/Handshake;->get(Ljavax/net/ssl/SSLSession;)Lokhttp3/Handshake;
move-result-object v4
.line 311
invoke-virtual {v0}, Lokhttp3/Address;->hostnameVerifier()Ljavax/net/ssl/HostnameVerifier;
move-result-object v5
invoke-virtual {v0}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v6
invoke-virtual {v6}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v6
invoke-interface {v5, v6, v3}, Ljavax/net/ssl/HostnameVerifier;->verify(Ljava/lang/String;Ljavax/net/ssl/SSLSession;)Z
move-result v3
if-eqz v3, :cond_b4
.line 320
invoke-virtual {v0}, Lokhttp3/Address;->certificatePinner()Lokhttp3/CertificatePinner;
move-result-object v3
invoke-virtual {v0}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v0
.line 321
invoke-virtual {v4}, Lokhttp3/Handshake;->peerCertificates()Ljava/util/List;
move-result-object v5
.line 320
invoke-virtual {v3, v0, v5}, Lokhttp3/CertificatePinner;->check(Ljava/lang/String;Ljava/util/List;)V
.line 324
invoke-virtual {p1}, Lokhttp3/ConnectionSpec;->supportsTlsExtensions()Z
move-result p1
if-eqz p1, :cond_85
.line 325
invoke-static {}, Lokhttp3/internal/platform/Platform;->get()Lokhttp3/internal/platform/Platform;
move-result-object p1
invoke-virtual {p1, v1}, Lokhttp3/internal/platform/Platform;->getSelectedProtocol(Ljavax/net/ssl/SSLSocket;)Ljava/lang/String;
move-result-object v2
.line 327
:cond_85
iput-object v1, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
.line 328
invoke-static {v1}, Lokio/Okio;->source(Ljava/net/Socket;)Lokio/Source;
move-result-object p1
invoke-static {p1}, Lokio/Okio;->buffer(Lokio/Source;)Lokio/BufferedSource;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
.line 329
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-static {p1}, Lokio/Okio;->sink(Ljava/net/Socket;)Lokio/Sink;
move-result-object p1
invoke-static {p1}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
.line 330
iput-object v4, p0, Lokhttp3/internal/connection/RealConnection;->handshake:Lokhttp3/Handshake;
if-eqz v2, :cond_a6
.line 332
invoke-static {v2}, Lokhttp3/Protocol;->get(Ljava/lang/String;)Lokhttp3/Protocol;
move-result-object p1
goto :goto_a8
.line 333
:cond_a6
sget-object p1, Lokhttp3/Protocol;->HTTP_1_1:Lokhttp3/Protocol;
:goto_a8
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
:try_end_aa
.catch Ljava/lang/AssertionError; {:try_start_24 .. :try_end_aa} :catch_119
.catchall {:try_start_24 .. :try_end_aa} :catchall_116
if-eqz v1, :cond_b3
.line 340
invoke-static {}, Lokhttp3/internal/platform/Platform;->get()Lokhttp3/internal/platform/Platform;
move-result-object p1
invoke-virtual {p1, v1}, Lokhttp3/internal/platform/Platform;->afterHandshake(Ljavax/net/ssl/SSLSocket;)V
:cond_b3
return-void
.line 312
:cond_b4
:try_start_b4
invoke-virtual {v4}, Lokhttp3/Handshake;->peerCertificates()Ljava/util/List;
move-result-object p1
const/4 v2, 0x0
invoke-interface {p1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/security/cert/X509Certificate;
.line 313
new-instance v2, Ljavax/net/ssl/SSLPeerUnverifiedException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Hostname "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v0}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v3, " not verified:\n certificate: "
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
.line 314
invoke-static {p1}, Lokhttp3/CertificatePinner;->pin(Ljava/security/cert/Certificate;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v3, "\n DN: "
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
.line 315
invoke-virtual {p1}, Ljava/security/cert/X509Certificate;->getSubjectDN()Ljava/security/Principal;
move-result-object v3
invoke-interface {v3}, Ljava/security/Principal;->getName()Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v3, "\n subjectAltNames: "
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
.line 316
invoke-static {p1}, Lokhttp3/internal/tls/OkHostnameVerifier;->allSubjectAltNames(Ljava/security/cert/X509Certificate;)Ljava/util/List;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v2, p1}, Ljavax/net/ssl/SSLPeerUnverifiedException;-><init>(Ljava/lang/String;)V
throw v2
.line 306
:cond_10e
new-instance p1, Ljava/io/IOException;
const-string v0, "a valid ssl session was not established"
invoke-direct {p1, v0}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
:try_end_116
.catch Ljava/lang/AssertionError; {:try_start_b4 .. :try_end_116} :catch_119
.catchall {:try_start_b4 .. :try_end_116} :catchall_116
:catchall_116
move-exception p1
move-object v2, v1
goto :goto_12c
:catch_119
move-exception p1
move-object v2, v1
goto :goto_11f
:catchall_11c
move-exception p1
goto :goto_12c
:catch_11e
move-exception p1
.line 336
:goto_11f
:try_start_11f
invoke-static {p1}, Lokhttp3/internal/Util;->isAndroidGetsocknameError(Ljava/lang/AssertionError;)Z
move-result v0
if-eqz v0, :cond_12b
new-instance v0, Ljava/io/IOException;
invoke-direct {v0, p1}, Ljava/io/IOException;-><init>(Ljava/lang/Throwable;)V
throw v0
.line 337
:cond_12b
throw p1
:try_end_12c
.catchall {:try_start_11f .. :try_end_12c} :catchall_11c
:goto_12c
if-eqz v2, :cond_135
.line 340
invoke-static {}, Lokhttp3/internal/platform/Platform;->get()Lokhttp3/internal/platform/Platform;
move-result-object v0
invoke-virtual {v0, v2}, Lokhttp3/internal/platform/Platform;->afterHandshake(Ljavax/net/ssl/SSLSocket;)V
.line 343
:cond_135
invoke-static {v2}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
throw p1
.end method
.method private connectTunnel(IIILokhttp3/Call;Lokhttp3/EventListener;)V
.registers 12
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 209
invoke-direct {p0}, Lokhttp3/internal/connection/RealConnection;->createTunnelRequest()Lokhttp3/Request;
move-result-object v0
.line 210
invoke-virtual {v0}, Lokhttp3/Request;->url()Lokhttp3/HttpUrl;
move-result-object v1
const/4 v2, 0x0
:goto_9
const/16 v3, 0x15
if-ge v2, v3, :cond_35
.line 212
invoke-direct {p0, p1, p2, p4, p5}, Lokhttp3/internal/connection/RealConnection;->connectSocket(IILokhttp3/Call;Lokhttp3/EventListener;)V
.line 213
invoke-direct {p0, p2, p3, v0, v1}, Lokhttp3/internal/connection/RealConnection;->createTunnel(IILokhttp3/Request;Lokhttp3/HttpUrl;)Lokhttp3/Request;
move-result-object v0
if-nez v0, :cond_17
goto :goto_35
.line 219
:cond_17
iget-object v3, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
invoke-static {v3}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
const/4 v3, 0x0
.line 220
iput-object v3, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
.line 221
iput-object v3, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
.line 222
iput-object v3, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
.line 223
iget-object v4, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v4}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object v4
iget-object v5, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v5}, Lokhttp3/Route;->proxy()Ljava/net/Proxy;
move-result-object v5
invoke-virtual {p5, p4, v4, v5, v3}, Lokhttp3/EventListener;->connectEnd(Lokhttp3/Call;Ljava/net/InetSocketAddress;Ljava/net/Proxy;Lokhttp3/Protocol;)V
add-int/lit8 v2, v2, 0x1
goto :goto_9
:cond_35
:goto_35
return-void
.end method
.method private createTunnel(IILokhttp3/Request;Lokhttp3/HttpUrl;)Lokhttp3/Request;
.registers 11
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 361
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "CONNECT "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const/4 v1, 0x1
invoke-static {p4, v1}, Lokhttp3/internal/Util;->hostHeader(Lokhttp3/HttpUrl;Z)Ljava/lang/String;
move-result-object p4
invoke-virtual {v0, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p4
const-string v0, " HTTP/1.1"
invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p4
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
.line 363
:goto_1e
new-instance v0, Lokhttp3/internal/http1/Http1Codec;
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
iget-object v2, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
const/4 v3, 0x0
invoke-direct {v0, v3, v3, v1, v2}, Lokhttp3/internal/http1/Http1Codec;-><init>(Lokhttp3/OkHttpClient;Lokhttp3/internal/connection/StreamAllocation;Lokio/BufferedSource;Lokio/BufferedSink;)V
.line 364
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
invoke-interface {v1}, Lokio/BufferedSource;->timeout()Lokio/Timeout;
move-result-object v1
int-to-long v4, p1
sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v1, v4, v5, v2}, Lokio/Timeout;->timeout(JLjava/util/concurrent/TimeUnit;)Lokio/Timeout;
.line 365
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
invoke-interface {v1}, Lokio/BufferedSink;->timeout()Lokio/Timeout;
move-result-object v1
int-to-long v4, p2
sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v1, v4, v5, v2}, Lokio/Timeout;->timeout(JLjava/util/concurrent/TimeUnit;)Lokio/Timeout;
.line 366
invoke-virtual {p3}, Lokhttp3/Request;->headers()Lokhttp3/Headers;
move-result-object v1
invoke-virtual {v0, v1, p4}, Lokhttp3/internal/http1/Http1Codec;->writeRequest(Lokhttp3/Headers;Ljava/lang/String;)V
.line 367
invoke-virtual {v0}, Lokhttp3/internal/http1/Http1Codec;->finishRequest()V
const/4 v1, 0x0
.line 368
invoke-virtual {v0, v1}, Lokhttp3/internal/http1/Http1Codec;->readResponseHeaders(Z)Lokhttp3/Response$Builder;
move-result-object v1
.line 369
invoke-virtual {v1, p3}, Lokhttp3/Response$Builder;->request(Lokhttp3/Request;)Lokhttp3/Response$Builder;
move-result-object p3
.line 370
invoke-virtual {p3}, Lokhttp3/Response$Builder;->build()Lokhttp3/Response;
move-result-object p3
.line 373
invoke-static {p3}, Lokhttp3/internal/http/HttpHeaders;->contentLength(Lokhttp3/Response;)J
move-result-wide v1
const-wide/16 v4, -0x1
cmp-long v4, v1, v4
if-nez v4, :cond_63
const-wide/16 v1, 0x0
.line 377
:cond_63
invoke-virtual {v0, v1, v2}, Lokhttp3/internal/http1/Http1Codec;->newFixedLengthSource(J)Lokio/Source;
move-result-object v0
const v1, 0x7fffffff
.line 378
sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-static {v0, v1, v2}, Lokhttp3/internal/Util;->skipAll(Lokio/Source;ILjava/util/concurrent/TimeUnit;)Z
.line 379
invoke-interface {v0}, Lokio/Source;->close()V
.line 381
invoke-virtual {p3}, Lokhttp3/Response;->code()I
move-result v0
const/16 v1, 0xc8
if-eq v0, v1, :cond_c7
const/16 v1, 0x197
if-ne v0, v1, :cond_aa
.line 393
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/Address;->proxyAuthenticator()Lokhttp3/Authenticator;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-interface {v0, v1, p3}, Lokhttp3/Authenticator;->authenticate(Lokhttp3/Route;Lokhttp3/Response;)Lokhttp3/Request;
move-result-object v0
if-eqz v0, :cond_a2
const-string v1, "Connection"
.line 396
invoke-virtual {p3, v1}, Lokhttp3/Response;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object p3
const-string v1, "close"
invoke-virtual {v1, p3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result p3
if-eqz p3, :cond_9f
return-object v0
:cond_9f
move-object p3, v0
goto/16 :goto_1e
.line 394
:cond_a2
new-instance p1, Ljava/io/IOException;
const-string p2, "Failed to authenticate with proxy"
invoke-direct {p1, p2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
.line 402
:cond_aa
new-instance p1, Ljava/io/IOException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "Unexpected response code for CONNECT: "
invoke-virtual {p2, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p2
.line 403
invoke-virtual {p3}, Lokhttp3/Response;->code()I
move-result p3
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object p2
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
.line 387
:cond_c7
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
invoke-interface {p1}, Lokio/BufferedSource;->buffer()Lokio/Buffer;
move-result-object p1
invoke-virtual {p1}, Lokio/Buffer;->exhausted()Z
move-result p1
if-eqz p1, :cond_e0
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
invoke-interface {p1}, Lokio/BufferedSink;->buffer()Lokio/Buffer;
move-result-object p1
invoke-virtual {p1}, Lokio/Buffer;->exhausted()Z
move-result p1
if-eqz p1, :cond_e0
return-object v3
.line 388
:cond_e0
new-instance p1, Ljava/io/IOException;
const-string p2, "TLS tunnel buffered too many bytes!"
invoke-direct {p1, p2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private createTunnelRequest()Lokhttp3/Request;
.registers 4
.line 414
new-instance v0, Lokhttp3/Request$Builder;
invoke-direct {v0}, Lokhttp3/Request$Builder;-><init>()V
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
.line 415
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v1
invoke-virtual {v0, v1}, Lokhttp3/Request$Builder;->url(Lokhttp3/HttpUrl;)Lokhttp3/Request$Builder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
.line 416
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v1
const/4 v2, 0x1
invoke-static {v1, v2}, Lokhttp3/internal/Util;->hostHeader(Lokhttp3/HttpUrl;Z)Ljava/lang/String;
move-result-object v1
const-string v2, "Host"
invoke-virtual {v0, v2, v1}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
const-string v1, "Proxy-Connection"
const-string v2, "Keep-Alive"
.line 417
invoke-virtual {v0, v1, v2}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
.line 418
invoke-static {}, Lokhttp3/internal/Version;->userAgent()Ljava/lang/String;
move-result-object v1
const-string v2, "User-Agent"
invoke-virtual {v0, v2, v1}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
.line 419
invoke-virtual {v0}, Lokhttp3/Request$Builder;->build()Lokhttp3/Request;
move-result-object v0
return-object v0
.end method
.method private establishProtocol(Lokhttp3/internal/connection/ConnectionSpecSelector;ILokhttp3/Call;Lokhttp3/EventListener;)V
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 263
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/Address;->sslSocketFactory()Ljavax/net/ssl/SSLSocketFactory;
move-result-object v0
if-nez v0, :cond_15
.line 264
sget-object p1, Lokhttp3/Protocol;->HTTP_1_1:Lokhttp3/Protocol;
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
.line 265
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
return-void
.line 269
:cond_15
invoke-virtual {p4, p3}, Lokhttp3/EventListener;->secureConnectStart(Lokhttp3/Call;)V
.line 270
invoke-direct {p0, p1}, Lokhttp3/internal/connection/RealConnection;->connectTls(Lokhttp3/internal/connection/ConnectionSpecSelector;)V
.line 271
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->handshake:Lokhttp3/Handshake;
invoke-virtual {p4, p3, p1}, Lokhttp3/EventListener;->secureConnectEnd(Lokhttp3/Call;Lokhttp3/Handshake;)V
.line 273
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
sget-object p3, Lokhttp3/Protocol;->HTTP_2:Lokhttp3/Protocol;
if-ne p1, p3, :cond_5b
.line 274
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
const/4 p3, 0x0
invoke-virtual {p1, p3}, Ljava/net/Socket;->setSoTimeout(I)V
.line 275
new-instance p1, Lokhttp3/internal/http2/Http2Connection$Builder;
const/4 p3, 0x1
invoke-direct {p1, p3}, Lokhttp3/internal/http2/Http2Connection$Builder;-><init>(Z)V
iget-object p3, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
iget-object p4, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
.line 276
invoke-virtual {p4}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object p4
invoke-virtual {p4}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object p4
invoke-virtual {p4}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object p4
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
invoke-virtual {p1, p3, p4, v0, v1}, Lokhttp3/internal/http2/Http2Connection$Builder;->socket(Ljava/net/Socket;Ljava/lang/String;Lokio/BufferedSource;Lokio/BufferedSink;)Lokhttp3/internal/http2/Http2Connection$Builder;
move-result-object p1
.line 277
invoke-virtual {p1, p0}, Lokhttp3/internal/http2/Http2Connection$Builder;->listener(Lokhttp3/internal/http2/Http2Connection$Listener;)Lokhttp3/internal/http2/Http2Connection$Builder;
move-result-object p1
.line 278
invoke-virtual {p1, p2}, Lokhttp3/internal/http2/Http2Connection$Builder;->pingIntervalMillis(I)Lokhttp3/internal/http2/Http2Connection$Builder;
move-result-object p1
.line 279
invoke-virtual {p1}, Lokhttp3/internal/http2/Http2Connection$Builder;->build()Lokhttp3/internal/http2/Http2Connection;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
.line 280
invoke-virtual {p1}, Lokhttp3/internal/http2/Http2Connection;->start()V
:cond_5b
return-void
.end method
.method private isValid(Ljavax/net/ssl/SSLSession;)Z
.registers 4
.line 350
invoke-interface {p1}, Ljavax/net/ssl/SSLSession;->getProtocol()Ljava/lang/String;
move-result-object v0
const-string v1, "NONE"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_1a
.line 351
invoke-interface {p1}, Ljavax/net/ssl/SSLSession;->getCipherSuite()Ljava/lang/String;
move-result-object p1
const-string v0, "SSL_NULL_WITH_NULL_NULL"
.line 350
invoke-virtual {v0, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-nez p1, :cond_1a
const/4 p1, 0x1
goto :goto_1b
:cond_1a
const/4 p1, 0x0
:goto_1b
return p1
.end method
.method public static testConnection(Lokhttp3/ConnectionPool;Lokhttp3/Route;Ljava/net/Socket;J)Lokhttp3/internal/connection/RealConnection;
.registers 6
.line 124
new-instance v0, Lokhttp3/internal/connection/RealConnection;
invoke-direct {v0, p0, p1}, Lokhttp3/internal/connection/RealConnection;-><init>(Lokhttp3/ConnectionPool;Lokhttp3/Route;)V
.line 125
iput-object p2, v0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
.line 126
iput-wide p3, v0, Lokhttp3/internal/connection/RealConnection;->idleAtNanos:J
return-object v0
.end method
# virtual methods
.method public cancel()V
.registers 2
.line 508
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
return-void
.end method
.method public connect(IIIIZLokhttp3/Call;Lokhttp3/EventListener;)V
.registers 24
move-object/from16 v7, p0
move-object/from16 v8, p6
move-object/from16 v9, p7
.line 133
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
if-nez v0, :cond_134
.line 136
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/Address;->connectionSpecs()Ljava/util/List;
move-result-object v0
.line 137
new-instance v10, Lokhttp3/internal/connection/ConnectionSpecSelector;
invoke-direct {v10, v0}, Lokhttp3/internal/connection/ConnectionSpecSelector;-><init>(Ljava/util/List;)V
.line 139
iget-object v1, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->sslSocketFactory()Ljavax/net/ssl/SSLSocketFactory;
move-result-object v1
if-nez v1, :cond_77
.line 140
sget-object v1, Lokhttp3/ConnectionSpec;->CLEARTEXT:Lokhttp3/ConnectionSpec;
invoke-interface {v0, v1}, Ljava/util/List;->contains(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_6a
.line 144
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v0
.line 145
invoke-static {}, Lokhttp3/internal/platform/Platform;->get()Lokhttp3/internal/platform/Platform;
move-result-object v1
invoke-virtual {v1, v0}, Lokhttp3/internal/platform/Platform;->isCleartextTrafficPermitted(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_46
goto :goto_77
.line 146
:cond_46
new-instance v1, Lokhttp3/internal/connection/RouteException;
new-instance v2, Ljava/net/UnknownServiceException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "CLEARTEXT communication to "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v3, " not permitted by network security policy"
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v2, v0}, Ljava/net/UnknownServiceException;-><init>(Ljava/lang/String;)V
invoke-direct {v1, v2}, Lokhttp3/internal/connection/RouteException;-><init>(Ljava/io/IOException;)V
throw v1
.line 141
:cond_6a
new-instance v0, Lokhttp3/internal/connection/RouteException;
new-instance v1, Ljava/net/UnknownServiceException;
const-string v2, "CLEARTEXT communication not enabled for client"
invoke-direct {v1, v2}, Ljava/net/UnknownServiceException;-><init>(Ljava/lang/String;)V
invoke-direct {v0, v1}, Lokhttp3/internal/connection/RouteException;-><init>(Ljava/io/IOException;)V
throw v0
:cond_77
:goto_77
const/4 v11, 0x0
move-object v12, v11
.line 153
:goto_79
:try_start_79
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->requiresTunnel()Z
move-result v0
if-eqz v0, :cond_9a
move-object/from16 v1, p0
move/from16 v2, p1
move/from16 v3, p2
move/from16 v4, p3
move-object/from16 v5, p6
move-object/from16 v6, p7
.line 154
invoke-direct/range {v1 .. v6}, Lokhttp3/internal/connection/RealConnection;->connectTunnel(IIILokhttp3/Call;Lokhttp3/EventListener;)V
.line 155
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
:try_end_92
.catch Ljava/io/IOException; {:try_start_79 .. :try_end_92} :catch_ea
if-nez v0, :cond_95
goto :goto_b7
:cond_95
move/from16 v13, p1
move/from16 v14, p2
goto :goto_a1
:cond_9a
move/from16 v13, p1
move/from16 v14, p2
.line 160
:try_start_9e
invoke-direct {v7, v13, v14, v8, v9}, Lokhttp3/internal/connection/RealConnection;->connectSocket(IILokhttp3/Call;Lokhttp3/EventListener;)V
:try_end_a1
.catch Ljava/io/IOException; {:try_start_9e .. :try_end_a1} :catch_e8
:goto_a1
move/from16 v15, p4
.line 162
:try_start_a3
invoke-direct {v7, v10, v15, v8, v9}, Lokhttp3/internal/connection/RealConnection;->establishProtocol(Lokhttp3/internal/connection/ConnectionSpecSelector;ILokhttp3/Call;Lokhttp3/EventListener;)V
.line 163
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object v0
iget-object v1, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->proxy()Ljava/net/Proxy;
move-result-object v1
iget-object v2, v7, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
invoke-virtual {v9, v8, v0, v1, v2}, Lokhttp3/EventListener;->connectEnd(Lokhttp3/Call;Ljava/net/InetSocketAddress;Ljava/net/Proxy;Lokhttp3/Protocol;)V
:try_end_b7
.catch Ljava/io/IOException; {:try_start_a3 .. :try_end_b7} :catch_e6
.line 190
:goto_b7
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->requiresTunnel()Z
move-result v0
if-eqz v0, :cond_d1
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
if-eqz v0, :cond_c4
goto :goto_d1
.line 191
:cond_c4
new-instance v0, Ljava/net/ProtocolException;
const-string v1, "Too many tunnel connections attempted: 21"
invoke-direct {v0, v1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
.line 193
new-instance v1, Lokhttp3/internal/connection/RouteException;
invoke-direct {v1, v0}, Lokhttp3/internal/connection/RouteException;-><init>(Ljava/io/IOException;)V
throw v1
.line 196
:cond_d1
:goto_d1
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
if-eqz v0, :cond_e5
.line 197
iget-object v1, v7, Lokhttp3/internal/connection/RealConnection;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v1
.line 198
:try_start_d8
iget-object v0, v7, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
invoke-virtual {v0}, Lokhttp3/internal/http2/Http2Connection;->maxConcurrentStreams()I
move-result v0
iput v0, v7, Lokhttp3/internal/connection/RealConnection;->allocationLimit:I
.line 199
monitor-exit v1
goto :goto_e5
:catchall_e2
move-exception v0
monitor-exit v1
:try_end_e4
.catchall {:try_start_d8 .. :try_end_e4} :catchall_e2
throw v0
:cond_e5
:goto_e5
return-void
:catch_e6
move-exception v0
goto :goto_f1
:catch_e8
move-exception v0
goto :goto_ef
:catch_ea
move-exception v0
move/from16 v13, p1
move/from16 v14, p2
:goto_ef
move/from16 v15, p4
.line 166
:goto_f1
iget-object v1, v7, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 167
iget-object v1, v7, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 168
iput-object v11, v7, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
.line 169
iput-object v11, v7, Lokhttp3/internal/connection/RealConnection;->rawSocket:Ljava/net/Socket;
.line 170
iput-object v11, v7, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
.line 171
iput-object v11, v7, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
.line 172
iput-object v11, v7, Lokhttp3/internal/connection/RealConnection;->handshake:Lokhttp3/Handshake;
.line 173
iput-object v11, v7, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
.line 174
iput-object v11, v7, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
.line 176
iget-object v1, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object v3
iget-object v1, v7, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->proxy()Ljava/net/Proxy;
move-result-object v4
const/4 v5, 0x0
move-object/from16 v1, p7
move-object/from16 v2, p6
move-object v6, v0
invoke-virtual/range {v1 .. v6}, Lokhttp3/EventListener;->connectFailed(Lokhttp3/Call;Ljava/net/InetSocketAddress;Ljava/net/Proxy;Lokhttp3/Protocol;Ljava/io/IOException;)V
if-nez v12, :cond_126
.line 179
new-instance v12, Lokhttp3/internal/connection/RouteException;
invoke-direct {v12, v0}, Lokhttp3/internal/connection/RouteException;-><init>(Ljava/io/IOException;)V
goto :goto_129
.line 181
:cond_126
invoke-virtual {v12, v0}, Lokhttp3/internal/connection/RouteException;->addConnectException(Ljava/io/IOException;)V
:goto_129
if-eqz p5, :cond_133
.line 184
invoke-virtual {v10, v0}, Lokhttp3/internal/connection/ConnectionSpecSelector;->connectionFailed(Ljava/io/IOException;)Z
move-result v0
if-eqz v0, :cond_133
goto/16 :goto_79
.line 185
:cond_133
throw v12
.line 133
:cond_134
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "already connected"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public handshake()Lokhttp3/Handshake;
.registers 2
.line 560
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->handshake:Lokhttp3/Handshake;
return-object v0
.end method
.method public isEligible(Lokhttp3/Address;Lokhttp3/Route;)Z
.registers 7
.param p2 # Lokhttp3/Route;
.annotation runtime Ljavax/annotation/Nullable;
.end annotation
.end param
.line 428
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
iget v1, p0, Lokhttp3/internal/connection/RealConnection;->allocationLimit:I
const/4 v2, 0x0
if-ge v0, v1, :cond_a5
iget-boolean v0, p0, Lokhttp3/internal/connection/RealConnection;->noNewStreams:Z
if-eqz v0, :cond_11
goto/16 :goto_a5
.line 431
:cond_11
sget-object v0, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v0, v1, p1}, Lokhttp3/internal/Internal;->equalsNonHost(Lokhttp3/Address;Lokhttp3/Address;)Z
move-result v0
if-nez v0, :cond_20
return v2
.line 434
:cond_20
invoke-virtual {p1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v0
invoke-virtual {p0}, Lokhttp3/internal/connection/RealConnection;->route()Lokhttp3/Route;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
const/4 v1, 0x1
if-eqz v0, :cond_40
return v1
.line 444
:cond_40
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
if-nez v0, :cond_45
return v2
:cond_45
if-nez p2, :cond_48
return v2
.line 450
:cond_48
invoke-virtual {p2}, Lokhttp3/Route;->proxy()Ljava/net/Proxy;
move-result-object v0
invoke-virtual {v0}, Ljava/net/Proxy;->type()Ljava/net/Proxy$Type;
move-result-object v0
sget-object v3, Ljava/net/Proxy$Type;->DIRECT:Ljava/net/Proxy$Type;
if-eq v0, v3, :cond_55
return v2
.line 451
:cond_55
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->proxy()Ljava/net/Proxy;
move-result-object v0
invoke-virtual {v0}, Ljava/net/Proxy;->type()Ljava/net/Proxy$Type;
move-result-object v0
sget-object v3, Ljava/net/Proxy$Type;->DIRECT:Ljava/net/Proxy$Type;
if-eq v0, v3, :cond_64
return v2
.line 452
:cond_64
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v0}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object v0
invoke-virtual {p2}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/net/InetSocketAddress;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_75
return v2
.line 455
:cond_75
invoke-virtual {p2}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object p2
invoke-virtual {p2}, Lokhttp3/Address;->hostnameVerifier()Ljavax/net/ssl/HostnameVerifier;
move-result-object p2
sget-object v0, Lokhttp3/internal/tls/OkHostnameVerifier;->INSTANCE:Lokhttp3/internal/tls/OkHostnameVerifier;
if-eq p2, v0, :cond_82
return v2
.line 456
:cond_82
invoke-virtual {p1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object p2
invoke-virtual {p0, p2}, Lokhttp3/internal/connection/RealConnection;->supportsUrl(Lokhttp3/HttpUrl;)Z
move-result p2
if-nez p2, :cond_8d
return v2
.line 460
:cond_8d
:try_start_8d
invoke-virtual {p1}, Lokhttp3/Address;->certificatePinner()Lokhttp3/CertificatePinner;
move-result-object p2
invoke-virtual {p1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object p1
invoke-virtual {p1}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object p1
invoke-virtual {p0}, Lokhttp3/internal/connection/RealConnection;->handshake()Lokhttp3/Handshake;
move-result-object v0
invoke-virtual {v0}, Lokhttp3/Handshake;->peerCertificates()Ljava/util/List;
move-result-object v0
invoke-virtual {p2, p1, v0}, Lokhttp3/CertificatePinner;->check(Ljava/lang/String;Ljava/util/List;)V
:try_end_a4
.catch Ljavax/net/ssl/SSLPeerUnverifiedException; {:try_start_8d .. :try_end_a4} :catch_a5
return v1
:catch_a5
:cond_a5
:goto_a5
return v2
.end method
.method public isHealthy(Z)Z
.registers 6
.line 517
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {v0}, Ljava/net/Socket;->isClosed()Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_4f
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {v0}, Ljava/net/Socket;->isInputShutdown()Z
move-result v0
if-nez v0, :cond_4f
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {v0}, Ljava/net/Socket;->isOutputShutdown()Z
move-result v0
if-eqz v0, :cond_1a
goto :goto_4f
.line 521
:cond_1a
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
const/4 v2, 0x1
if-eqz v0, :cond_25
.line 522
invoke-virtual {v0}, Lokhttp3/internal/http2/Http2Connection;->isShutdown()Z
move-result p1
xor-int/2addr p1, v2
return p1
:cond_25
if-eqz p1, :cond_4e
.line 527
:try_start_27
iget-object p1, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {p1}, Ljava/net/Socket;->getSoTimeout()I
move-result p1
:try_end_2d
.catch Ljava/net/SocketTimeoutException; {:try_start_27 .. :try_end_2d} :catch_4e
.catch Ljava/io/IOException; {:try_start_27 .. :try_end_2d} :catch_4d
.line 529
:try_start_2d
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {v0, v2}, Ljava/net/Socket;->setSoTimeout(I)V
.line 530
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
invoke-interface {v0}, Lokio/BufferedSource;->exhausted()Z
move-result v0
:try_end_38
.catchall {:try_start_2d .. :try_end_38} :catchall_46
if-eqz v0, :cond_40
.line 535
:try_start_3a
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {v0, p1}, Ljava/net/Socket;->setSoTimeout(I)V
return v1
:cond_40
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {v0, p1}, Ljava/net/Socket;->setSoTimeout(I)V
return v2
:catchall_46
move-exception v0
iget-object v3, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-virtual {v3, p1}, Ljava/net/Socket;->setSoTimeout(I)V
throw v0
:try_end_4d
.catch Ljava/net/SocketTimeoutException; {:try_start_3a .. :try_end_4d} :catch_4e
.catch Ljava/io/IOException; {:try_start_3a .. :try_end_4d} :catch_4d
:catch_4d
return v1
:catch_4e
:cond_4e
return v2
:cond_4f
:goto_4f
return v1
.end method
.method public isMultiplexed()Z
.registers 2
.line 568
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
if-eqz v0, :cond_6
const/4 v0, 0x1
goto :goto_7
:cond_6
const/4 v0, 0x0
:goto_7
return v0
.end method
.method public newCodec(Lokhttp3/OkHttpClient;Lokhttp3/Interceptor$Chain;Lokhttp3/internal/connection/StreamAllocation;)Lokhttp3/internal/http/HttpCodec;
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/net/SocketException;
}
.end annotation
.line 484
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
if-eqz v0, :cond_c
.line 485
new-instance v0, Lokhttp3/internal/http2/Http2Codec;
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->http2Connection:Lokhttp3/internal/http2/Http2Connection;
invoke-direct {v0, p1, p2, p3, v1}, Lokhttp3/internal/http2/Http2Codec;-><init>(Lokhttp3/OkHttpClient;Lokhttp3/Interceptor$Chain;Lokhttp3/internal/connection/StreamAllocation;Lokhttp3/internal/http2/Http2Connection;)V
return-object v0
.line 487
:cond_c
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
invoke-interface {p2}, Lokhttp3/Interceptor$Chain;->readTimeoutMillis()I
move-result v1
invoke-virtual {v0, v1}, Ljava/net/Socket;->setSoTimeout(I)V
.line 488
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
invoke-interface {v0}, Lokio/BufferedSource;->timeout()Lokio/Timeout;
move-result-object v0
invoke-interface {p2}, Lokhttp3/Interceptor$Chain;->readTimeoutMillis()I
move-result v1
int-to-long v1, v1
sget-object v3, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v0, v1, v2, v3}, Lokio/Timeout;->timeout(JLjava/util/concurrent/TimeUnit;)Lokio/Timeout;
.line 489
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
invoke-interface {v0}, Lokio/BufferedSink;->timeout()Lokio/Timeout;
move-result-object v0
invoke-interface {p2}, Lokhttp3/Interceptor$Chain;->writeTimeoutMillis()I
move-result p2
int-to-long v1, p2
sget-object p2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v0, v1, v2, p2}, Lokio/Timeout;->timeout(JLjava/util/concurrent/TimeUnit;)Lokio/Timeout;
.line 490
new-instance p2, Lokhttp3/internal/http1/Http1Codec;
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
invoke-direct {p2, p1, p3, v0, v1}, Lokhttp3/internal/http1/Http1Codec;-><init>(Lokhttp3/OkHttpClient;Lokhttp3/internal/connection/StreamAllocation;Lokio/BufferedSource;Lokio/BufferedSink;)V
return-object p2
.end method
.method public newWebSocketStreams(Lokhttp3/internal/connection/StreamAllocation;)Lokhttp3/internal/ws/RealWebSocket$Streams;
.registers 9
.line 495
new-instance v6, Lokhttp3/internal/connection/RealConnection$1;
iget-object v3, p0, Lokhttp3/internal/connection/RealConnection;->source:Lokio/BufferedSource;
iget-object v4, p0, Lokhttp3/internal/connection/RealConnection;->sink:Lokio/BufferedSink;
const/4 v2, 0x1
move-object v0, v6
move-object v1, p0
move-object v5, p1
invoke-direct/range {v0 .. v5}, Lokhttp3/internal/connection/RealConnection$1;-><init>(Lokhttp3/internal/connection/RealConnection;ZLokio/BufferedSource;Lokio/BufferedSink;Lokhttp3/internal/connection/StreamAllocation;)V
return-object v6
.end method
.method public onSettings(Lokhttp3/internal/http2/Http2Connection;)V
.registers 3
.line 554
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v0
.line 555
:try_start_3
invoke-virtual {p1}, Lokhttp3/internal/http2/Http2Connection;->maxConcurrentStreams()I
move-result p1
iput p1, p0, Lokhttp3/internal/connection/RealConnection;->allocationLimit:I
.line 556
monitor-exit v0
return-void
:catchall_b
move-exception p1
monitor-exit v0
:try_end_d
.catchall {:try_start_3 .. :try_end_d} :catchall_b
throw p1
.end method
.method public onStream(Lokhttp3/internal/http2/Http2Stream;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 549
sget-object v0, Lokhttp3/internal/http2/ErrorCode;->REFUSED_STREAM:Lokhttp3/internal/http2/ErrorCode;
invoke-virtual {p1, v0}, Lokhttp3/internal/http2/Http2Stream;->close(Lokhttp3/internal/http2/ErrorCode;)V
return-void
.end method
.method public protocol()Lokhttp3/Protocol;
.registers 2
.line 572
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
return-object v0
.end method
.method public route()Lokhttp3/Route;
.registers 2
.line 503
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
return-object v0
.end method
.method public socket()Ljava/net/Socket;
.registers 2
.line 512
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->socket:Ljava/net/Socket;
return-object v0
.end method
.method public supportsUrl(Lokhttp3/HttpUrl;)Z
.registers 6
.line 469
invoke-virtual {p1}, Lokhttp3/HttpUrl;->port()I
move-result v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/HttpUrl;->port()I
move-result v1
const/4 v2, 0x0
if-eq v0, v1, :cond_16
return v2
.line 473
:cond_16
invoke-virtual {p1}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
const/4 v1, 0x1
if-nez v0, :cond_4d
.line 475
iget-object v0, p0, Lokhttp3/internal/connection/RealConnection;->handshake:Lokhttp3/Handshake;
if-eqz v0, :cond_4c
sget-object v0, Lokhttp3/internal/tls/OkHostnameVerifier;->INSTANCE:Lokhttp3/internal/tls/OkHostnameVerifier;
.line 476
invoke-virtual {p1}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object p1
iget-object v3, p0, Lokhttp3/internal/connection/RealConnection;->handshake:Lokhttp3/Handshake;
invoke-virtual {v3}, Lokhttp3/Handshake;->peerCertificates()Ljava/util/List;
move-result-object v3
invoke-interface {v3, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/security/cert/X509Certificate;
.line 475
invoke-virtual {v0, p1, v3}, Lokhttp3/internal/tls/OkHostnameVerifier;->verify(Ljava/lang/String;Ljava/security/cert/X509Certificate;)Z
move-result p1
if-eqz p1, :cond_4c
move v2, v1
:cond_4c
return v2
:cond_4d
return v1
.end method
.method public toString()Ljava/lang/String;
.registers 3
.line 576
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Connection{"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
.line 577
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/HttpUrl;->host()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, ":"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
invoke-virtual {v1}, Lokhttp3/Route;->address()Lokhttp3/Address;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/Address;->url()Lokhttp3/HttpUrl;
move-result-object v1
invoke-virtual {v1}, Lokhttp3/HttpUrl;->port()I
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, ", proxy="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
.line 579
invoke-virtual {v1}, Lokhttp3/Route;->proxy()Ljava/net/Proxy;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " hostAddress="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->route:Lokhttp3/Route;
.line 581
invoke-virtual {v1}, Lokhttp3/Route;->socketAddress()Ljava/net/InetSocketAddress;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " cipherSuite="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->handshake:Lokhttp3/Handshake;
if-eqz v1, :cond_64
.line 583
invoke-virtual {v1}, Lokhttp3/Handshake;->cipherSuite()Lokhttp3/CipherSuite;
move-result-object v1
goto :goto_66
:cond_64
const-string v1, "none"
:goto_66
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " protocol="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/connection/RealConnection;->protocol:Lokhttp3/Protocol;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const/16 v1, 0x7d
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method