Rabbit-R1/android (non root)/java/sources/okhttp3/internal/http1/Http1ExchangeCodec.java
2024-05-21 17:08:36 -04:00

614 lines
33 KiB
Java

package okhttp3.internal.http1;
import com.google.common.net.HttpHeaders;
import io.sentry.ProfilingTraceData;
import io.sentry.SentryBaseEvent;
import io.sentry.SentryEnvelopeItemHeader;
import io.sentry.okhttp.SentryOkHttpEventListener;
import io.sentry.protocol.Request;
import io.sentry.protocol.Response;
import io.sentry.protocol.SentryThread;
import io.sentry.protocol.TransactionInfo;
import java.io.EOFException;
import java.io.IOException;
import java.net.ProtocolException;
import java.net.Proxy;
import java.util.concurrent.TimeUnit;
import kotlin.Metadata;
import kotlin.jvm.internal.Intrinsics;
import kotlin.text.StringsKt;
import kotlin.text.Typography;
import okhttp3.CookieJar;
import okhttp3.Headers;
import okhttp3.HttpUrl;
import okhttp3.OkHttpClient;
import okhttp3.Response;
import okhttp3.internal.Util;
import okhttp3.internal.connection.RealConnection;
import okhttp3.internal.http.ExchangeCodec;
import okhttp3.internal.http.RequestLine;
import okhttp3.internal.http.StatusLine;
import okio.Buffer;
import okio.BufferedSink;
import okio.BufferedSource;
import okio.ForwardingTimeout;
import okio.Sink;
import okio.Source;
import okio.Timeout;
/* compiled from: Http1ExchangeCodec.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u0000\u0088\u0001\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0004\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u000b\n\u0002\b\u0002\n\u0002\u0010\b\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\t\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\b\u0004\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0007\n\u0002\u0018\u0002\n\u0002\b\u0006\n\u0002\u0010\u000e\n\u0002\b\t\u0018\u0000 ?2\u00020\u0001:\u0007<=>?@ABB'\u0012\b\u0010\u0002\u001a\u0004\u0018\u00010\u0003\u0012\u0006\u0010\u0004\u001a\u00020\u0005\u0012\u0006\u0010\u0006\u001a\u00020\u0007\u0012\u0006\u0010\b\u001a\u00020\\u0006\u0002\u0010\nJ\b\u0010\u001b\u001a\u00020\u001cH\u0016J\u0018\u0010\u001d\u001a\u00020\u001e2\u0006\u0010\u001f\u001a\u00020\u00172\u0006\u0010 \u001a\u00020!H\u0016J\u0010\u0010\"\u001a\u00020\u001c2\u0006\u0010#\u001a\u00020$H\u0002J\b\u0010%\u001a\u00020\u001cH\u0016J\b\u0010&\u001a\u00020\u001cH\u0016J\b\u0010'\u001a\u00020\u001eH\u0002J\u0010\u0010(\u001a\u00020)2\u0006\u0010*\u001a\u00020+H\u0002J\u0010\u0010,\u001a\u00020)2\u0006\u0010-\u001a\u00020!H\u0002J\b\u0010.\u001a\u00020\u001eH\u0002J\b\u0010/\u001a\u00020)H\u0002J\u0010\u00100\u001a\u00020)2\u0006\u00101\u001a\u00020\u0019H\u0016J\u0012\u00102\u001a\u0004\u0018\u0001032\u0006\u00104\u001a\u00020\u0010H\u0016J\u0010\u00105\u001a\u00020!2\u0006\u00101\u001a\u00020\u0019H\u0016J\u000e\u00106\u001a\u00020\u001c2\u0006\u00101\u001a\u00020\u0019J\b\u0010\u0014\u001a\u00020\u0015H\u0016J\u0016\u00107\u001a\u00020\u001c2\u0006\u00108\u001a\u00020\u00152\u0006\u00109\u001a\u00020:J\u0010\u0010;\u001a\u00020\u001c2\u0006\u0010\u001f\u001a\u00020\u0017H\u0016R\u0010\u0010\u0002\u001a\u0004\u0018\u00010\u0003X\u0082\u0004¢\u0006\u0002\n\u0000R\u0014\u0010\u0004\u001a\u00020\u0005X\u0096\u0004¢\u0006\b\n\u0000\u001a\u0004\b\u000b\u0010\fR\u000e\u0010\r\u001a\u00020\u000eX\u0082\u0004¢\u0006\u0002\n\u0000R\u0011\u0010\u000f\u001a\u00020\u00108F¢\u0006\u0006\u001a\u0004\b\u000f\u0010\u0011R\u000e\u0010\b\u001a\u00020\tX\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\u0006\u001a\u00020\u0007X\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\u0012\u001a\u00020\u0013X\u0082\u000e¢\u0006\u0002\n\u0000R\u0010\u0010\u0014\u001a\u0004\u0018\u00010\u0015X\u0082\u000e¢\u0006\u0002\n\u0000R\u0018\u0010\u0016\u001a\u00020\u0010*\u00020\u00178BX\u0082\u0004¢\u0006\u0006\u001a\u0004\b\u0016\u0010\u0018R\u0018\u0010\u0016\u001a\u00020\u0010*\u00020\u00198BX\u0082\u0004¢\u0006\u0006\u001a\u0004\b\u0016\u0010\u001a¨\u0006C"}, d2 = {"Lokhttp3/internal/http1/Http1ExchangeCodec;", "Lokhttp3/internal/http/ExchangeCodec;", "client", "Lokhttp3/OkHttpClient;", SentryOkHttpEventListener.CONNECTION_EVENT, "Lokhttp3/internal/connection/RealConnection;", TransactionInfo.JsonKeys.SOURCE, "Lokio/BufferedSource;", "sink", "Lokio/BufferedSink;", "(Lokhttp3/OkHttpClient;Lokhttp3/internal/connection/RealConnection;Lokio/BufferedSource;Lokio/BufferedSink;)V", "getConnection", "()Lokhttp3/internal/connection/RealConnection;", "headersReader", "Lokhttp3/internal/http1/HeadersReader;", "isClosed", "", "()Z", SentryThread.JsonKeys.STATE, "", "trailers", "Lokhttp3/Headers;", "isChunked", "Lokhttp3/Request;", "(Lokhttp3/Request;)Z", "Lokhttp3/Response;", "(Lokhttp3/Response;)Z", "cancel", "", "createRequestBody", "Lokio/Sink;", SentryBaseEvent.JsonKeys.REQUEST, "contentLength", "", "detachTimeout", ProfilingTraceData.TRUNCATION_REASON_TIMEOUT, "Lokio/ForwardingTimeout;", "finishRequest", "flushRequest", "newChunkedSink", "newChunkedSource", "Lokio/Source;", Request.JsonKeys.URL, "Lokhttp3/HttpUrl;", "newFixedLengthSource", SentryEnvelopeItemHeader.JsonKeys.LENGTH, "newKnownLengthSink", "newUnknownLengthSource", "openResponseBodySource", Response.TYPE, "readResponseHeaders", "Lokhttp3/Response$Builder;", "expectContinue", "reportedContentLength", "skipConnectBody", "writeRequest", "headers", "requestLine", "", "writeRequestHeaders", "AbstractSource", "ChunkedSink", "ChunkedSource", "Companion", "FixedLengthSource", "KnownLengthSink", "UnknownLengthSource", "okhttp"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public final class Http1ExchangeCodec implements ExchangeCodec {
private static final long NO_CHUNK_YET = -1;
private static final int STATE_CLOSED = 6;
private static final int STATE_IDLE = 0;
private static final int STATE_OPEN_REQUEST_BODY = 1;
private static final int STATE_OPEN_RESPONSE_BODY = 4;
private static final int STATE_READING_RESPONSE_BODY = 5;
private static final int STATE_READ_RESPONSE_HEADERS = 3;
private static final int STATE_WRITING_REQUEST_BODY = 2;
private final OkHttpClient client;
private final RealConnection connection;
private final HeadersReader headersReader;
private final BufferedSink sink;
private final BufferedSource source;
private int state;
private Headers trailers;
@Override // okhttp3.internal.http.ExchangeCodec
public RealConnection getConnection() {
return this.connection;
}
public final boolean isClosed() {
return this.state == 6;
}
public Http1ExchangeCodec(OkHttpClient okHttpClient, RealConnection connection, BufferedSource source, BufferedSink sink) {
Intrinsics.checkNotNullParameter(connection, "connection");
Intrinsics.checkNotNullParameter(source, "source");
Intrinsics.checkNotNullParameter(sink, "sink");
this.client = okHttpClient;
this.connection = connection;
this.source = source;
this.sink = sink;
this.headersReader = new HeadersReader(source);
}
private final boolean isChunked(okhttp3.Response response) {
return StringsKt.equals("chunked", okhttp3.Response.header$default(response, HttpHeaders.TRANSFER_ENCODING, null, 2, null), true);
}
private final boolean isChunked(okhttp3.Request request) {
return StringsKt.equals("chunked", request.header(HttpHeaders.TRANSFER_ENCODING), true);
}
@Override // okhttp3.internal.http.ExchangeCodec
public Sink createRequestBody(okhttp3.Request request, long contentLength) {
Intrinsics.checkNotNullParameter(request, "request");
if (request.body() != null && request.body().isDuplex()) {
throw new ProtocolException("Duplex connections are not supported for HTTP/1");
}
if (isChunked(request)) {
return newChunkedSink();
}
if (contentLength != -1) {
return newKnownLengthSink();
}
throw new IllegalStateException("Cannot stream a request body without chunked encoding or a known content length!");
}
@Override // okhttp3.internal.http.ExchangeCodec
public void cancel() {
getConnection().cancel();
}
@Override // okhttp3.internal.http.ExchangeCodec
public void writeRequestHeaders(okhttp3.Request request) {
Intrinsics.checkNotNullParameter(request, "request");
RequestLine requestLine = RequestLine.INSTANCE;
Proxy.Type type = getConnection().getRoute().proxy().type();
Intrinsics.checkNotNullExpressionValue(type, "connection.route().proxy.type()");
writeRequest(request.headers(), requestLine.get(request, type));
}
@Override // okhttp3.internal.http.ExchangeCodec
public long reportedContentLength(okhttp3.Response response) {
Intrinsics.checkNotNullParameter(response, "response");
if (!okhttp3.internal.http.HttpHeaders.promisesBody(response)) {
return 0L;
}
if (isChunked(response)) {
return -1L;
}
return Util.headersContentLength(response);
}
@Override // okhttp3.internal.http.ExchangeCodec
public Source openResponseBodySource(okhttp3.Response response) {
Intrinsics.checkNotNullParameter(response, "response");
if (!okhttp3.internal.http.HttpHeaders.promisesBody(response)) {
return newFixedLengthSource(0L);
}
if (isChunked(response)) {
return newChunkedSource(response.request().url());
}
long headersContentLength = Util.headersContentLength(response);
if (headersContentLength != -1) {
return newFixedLengthSource(headersContentLength);
}
return newUnknownLengthSource();
}
@Override // okhttp3.internal.http.ExchangeCodec
public Headers trailers() {
if (!(this.state == 6)) {
throw new IllegalStateException("too early; can't read the trailers yet".toString());
}
Headers headers = this.trailers;
return headers != null ? headers : Util.EMPTY_HEADERS;
}
@Override // okhttp3.internal.http.ExchangeCodec
public void flushRequest() {
this.sink.flush();
}
@Override // okhttp3.internal.http.ExchangeCodec
public void finishRequest() {
this.sink.flush();
}
public final void writeRequest(Headers headers, String requestLine) {
Intrinsics.checkNotNullParameter(headers, "headers");
Intrinsics.checkNotNullParameter(requestLine, "requestLine");
if (!(this.state == 0)) {
throw new IllegalStateException(("state: " + this.state).toString());
}
this.sink.writeUtf8(requestLine).writeUtf8("\r\n");
int size = headers.size();
for (int i = 0; i < size; i++) {
this.sink.writeUtf8(headers.name(i)).writeUtf8(": ").writeUtf8(headers.value(i)).writeUtf8("\r\n");
}
this.sink.writeUtf8("\r\n");
this.state = 1;
}
@Override // okhttp3.internal.http.ExchangeCodec
public Response.Builder readResponseHeaders(boolean expectContinue) {
int i = this.state;
boolean z = true;
if (i != 1 && i != 3) {
z = false;
}
if (!z) {
throw new IllegalStateException(("state: " + this.state).toString());
}
try {
StatusLine parse = StatusLine.INSTANCE.parse(this.headersReader.readLine());
Response.Builder headers = new Response.Builder().protocol(parse.protocol).code(parse.code).message(parse.message).headers(this.headersReader.readHeaders());
if (expectContinue && parse.code == 100) {
return null;
}
if (parse.code == 100) {
this.state = 3;
return headers;
}
this.state = 4;
return headers;
} catch (EOFException e) {
throw new IOException("unexpected end of stream on " + getConnection().getRoute().address().url().redact(), e);
}
}
private final Sink newChunkedSink() {
if (!(this.state == 1)) {
throw new IllegalStateException(("state: " + this.state).toString());
}
this.state = 2;
return new ChunkedSink();
}
private final Sink newKnownLengthSink() {
if (!(this.state == 1)) {
throw new IllegalStateException(("state: " + this.state).toString());
}
this.state = 2;
return new KnownLengthSink();
}
private final Source newFixedLengthSource(long length) {
if (!(this.state == 4)) {
throw new IllegalStateException(("state: " + this.state).toString());
}
this.state = 5;
return new FixedLengthSource(length);
}
private final Source newChunkedSource(HttpUrl url) {
if (!(this.state == 4)) {
throw new IllegalStateException(("state: " + this.state).toString());
}
this.state = 5;
return new ChunkedSource(this, url);
}
private final Source newUnknownLengthSource() {
if (!(this.state == 4)) {
throw new IllegalStateException(("state: " + this.state).toString());
}
this.state = 5;
getConnection().noNewExchanges$okhttp();
return new UnknownLengthSource();
}
/* JADX INFO: Access modifiers changed from: private */
public final void detachTimeout(ForwardingTimeout timeout) {
Timeout delegate = timeout.getDelegate();
timeout.setDelegate(Timeout.NONE);
delegate.clearDeadline();
delegate.clearTimeout();
}
public final void skipConnectBody(okhttp3.Response response) {
Intrinsics.checkNotNullParameter(response, "response");
long headersContentLength = Util.headersContentLength(response);
if (headersContentLength == -1) {
return;
}
Source newFixedLengthSource = newFixedLengthSource(headersContentLength);
Util.skipAll(newFixedLengthSource, Integer.MAX_VALUE, TimeUnit.MILLISECONDS);
newFixedLengthSource.close();
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: Http1ExchangeCodec.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u00002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\t\n\u0000\b\u0082\u0004\u0018\u00002\u00020\u0001B\u0005¢\u0006\u0002\u0010\u0002J\b\u0010\u0007\u001a\u00020\bH\u0016J\b\u0010\t\u001a\u00020\bH\u0016J\b\u0010\u0005\u001a\u00020\nH\u0016J\u0018\u0010\u000b\u001a\u00020\b2\u0006\u0010\f\u001a\u00020\r2\u0006\u0010\u000e\u001a\u00020\u000fH\u0016R\u000e\u0010\u0003\u001a\u00020\u0004X\u0082\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u0004¢\u0006\u0002\n\u0000¨\u0006\u0010"}, d2 = {"Lokhttp3/internal/http1/Http1ExchangeCodec$KnownLengthSink;", "Lokio/Sink;", "(Lokhttp3/internal/http1/Http1ExchangeCodec;)V", "closed", "", ProfilingTraceData.TRUNCATION_REASON_TIMEOUT, "Lokio/ForwardingTimeout;", "close", "", "flush", "Lokio/Timeout;", "write", TransactionInfo.JsonKeys.SOURCE, "Lokio/Buffer;", "byteCount", "", "okhttp"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public final class KnownLengthSink implements Sink {
private boolean closed;
private final ForwardingTimeout timeout;
public KnownLengthSink() {
this.timeout = new ForwardingTimeout(Http1ExchangeCodec.this.sink.getTimeout());
}
@Override // okio.Sink
/* renamed from: timeout */
public Timeout getTimeout() {
return this.timeout;
}
@Override // okio.Sink
public void write(Buffer source, long byteCount) {
Intrinsics.checkNotNullParameter(source, "source");
if (!(!this.closed)) {
throw new IllegalStateException("closed".toString());
}
Util.checkOffsetAndCount(source.size(), 0L, byteCount);
Http1ExchangeCodec.this.sink.write(source, byteCount);
}
@Override // okio.Sink, java.io.Flushable
public void flush() {
if (this.closed) {
return;
}
Http1ExchangeCodec.this.sink.flush();
}
@Override // okio.Sink, java.io.Closeable, java.lang.AutoCloseable
public void close() {
if (this.closed) {
return;
}
this.closed = true;
Http1ExchangeCodec.this.detachTimeout(this.timeout);
Http1ExchangeCodec.this.state = 3;
}
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: Http1ExchangeCodec.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u00002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\t\n\u0000\b\u0082\u0004\u0018\u00002\u00020\u0001B\u0005¢\u0006\u0002\u0010\u0002J\b\u0010\u0007\u001a\u00020\bH\u0016J\b\u0010\t\u001a\u00020\bH\u0016J\b\u0010\u0005\u001a\u00020\nH\u0016J\u0018\u0010\u000b\u001a\u00020\b2\u0006\u0010\f\u001a\u00020\r2\u0006\u0010\u000e\u001a\u00020\u000fH\u0016R\u000e\u0010\u0003\u001a\u00020\u0004X\u0082\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u0004¢\u0006\u0002\n\u0000¨\u0006\u0010"}, d2 = {"Lokhttp3/internal/http1/Http1ExchangeCodec$ChunkedSink;", "Lokio/Sink;", "(Lokhttp3/internal/http1/Http1ExchangeCodec;)V", "closed", "", ProfilingTraceData.TRUNCATION_REASON_TIMEOUT, "Lokio/ForwardingTimeout;", "close", "", "flush", "Lokio/Timeout;", "write", TransactionInfo.JsonKeys.SOURCE, "Lokio/Buffer;", "byteCount", "", "okhttp"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public final class ChunkedSink implements Sink {
private boolean closed;
private final ForwardingTimeout timeout;
public ChunkedSink() {
this.timeout = new ForwardingTimeout(Http1ExchangeCodec.this.sink.getTimeout());
}
@Override // okio.Sink
/* renamed from: timeout */
public Timeout getTimeout() {
return this.timeout;
}
@Override // okio.Sink
public void write(Buffer source, long byteCount) {
Intrinsics.checkNotNullParameter(source, "source");
if (!(!this.closed)) {
throw new IllegalStateException("closed".toString());
}
if (byteCount == 0) {
return;
}
Http1ExchangeCodec.this.sink.writeHexadecimalUnsignedLong(byteCount);
Http1ExchangeCodec.this.sink.writeUtf8("\r\n");
Http1ExchangeCodec.this.sink.write(source, byteCount);
Http1ExchangeCodec.this.sink.writeUtf8("\r\n");
}
@Override // okio.Sink, java.io.Flushable
public synchronized void flush() {
if (this.closed) {
return;
}
Http1ExchangeCodec.this.sink.flush();
}
@Override // okio.Sink, java.io.Closeable, java.lang.AutoCloseable
public synchronized void close() {
if (this.closed) {
return;
}
this.closed = true;
Http1ExchangeCodec.this.sink.writeUtf8("0\r\n\r\n");
Http1ExchangeCodec.this.detachTimeout(this.timeout);
Http1ExchangeCodec.this.state = 3;
}
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: Http1ExchangeCodec.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u00004\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0002\b\u0005\n\u0002\u0018\u0002\n\u0002\b\u0003\n\u0002\u0010\t\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u0002\n\u0002\u0018\u0002\n\u0000\\u0004\u0018\u00002\u00020\u0001B\u0005¢\u0006\u0002\u0010\u0002J\u0018\u0010\r\u001a\u00020\u000e2\u0006\u0010\u000f\u001a\u00020\u00102\u0006\u0010\u0011\u001a\u00020\u000eH\u0016J\u0006\u0010\u0012\u001a\u00020\u0013J\b\u0010\t\u001a\u00020\u0014H\u0016R\u001a\u0010\u0003\u001a\u00020\u0004X\u0084\u000e¢\u0006\u000e\n\u0000\u001a\u0004\b\u0005\u0010\u0006\"\u0004\b\u0007\u0010\bR\u0014\u0010\t\u001a\u00020\nX\u0084\u0004¢\u0006\b\n\u0000\u001a\u0004\b\u000b\u0010\\u0006\u0015"}, d2 = {"Lokhttp3/internal/http1/Http1ExchangeCodec$AbstractSource;", "Lokio/Source;", "(Lokhttp3/internal/http1/Http1ExchangeCodec;)V", "closed", "", "getClosed", "()Z", "setClosed", "(Z)V", ProfilingTraceData.TRUNCATION_REASON_TIMEOUT, "Lokio/ForwardingTimeout;", "getTimeout", "()Lokio/ForwardingTimeout;", "read", "", "sink", "Lokio/Buffer;", "byteCount", "responseBodyComplete", "", "Lokio/Timeout;", "okhttp"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public abstract class AbstractSource implements Source {
private boolean closed;
private final ForwardingTimeout timeout;
protected final boolean getClosed() {
return this.closed;
}
protected final ForwardingTimeout getTimeout() {
return this.timeout;
}
protected final void setClosed(boolean z) {
this.closed = z;
}
public AbstractSource() {
this.timeout = new ForwardingTimeout(Http1ExchangeCodec.this.source.getTimeout());
}
@Override // okio.Source
/* renamed from: timeout */
public Timeout getTimeout() {
return this.timeout;
}
@Override // okio.Source
public long read(Buffer sink, long byteCount) {
Intrinsics.checkNotNullParameter(sink, "sink");
try {
return Http1ExchangeCodec.this.source.read(sink, byteCount);
} catch (IOException e) {
Http1ExchangeCodec.this.getConnection().noNewExchanges$okhttp();
this.responseBodyComplete();
throw e;
}
}
public final void responseBodyComplete() {
if (Http1ExchangeCodec.this.state == 6) {
return;
}
if (Http1ExchangeCodec.this.state == 5) {
Http1ExchangeCodec.this.detachTimeout(this.timeout);
Http1ExchangeCodec.this.state = 6;
return;
}
throw new IllegalStateException("state: " + Http1ExchangeCodec.this.state);
}
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: Http1ExchangeCodec.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u0000&\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\t\n\u0002\b\u0002\n\u0002\u0010\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\b\u0082\u0004\u0018\u00002\u00060\u0001R\u00020\u0002B\r\u0012\u0006\u0010\u0003\u001a\u00020\u0004¢\u0006\u0002\u0010\u0005J\b\u0010\u0006\u001a\u00020\u0007H\u0016J\u0018\u0010\b\u001a\u00020\u00042\u0006\u0010\t\u001a\u00020\n2\u0006\u0010\u000b\u001a\u00020\u0004H\u0016R\u000e\u0010\u0003\u001a\u00020\u0004X\u0082\u000e¢\u0006\u0002\n\u0000¨\u0006\f"}, d2 = {"Lokhttp3/internal/http1/Http1ExchangeCodec$FixedLengthSource;", "Lokhttp3/internal/http1/Http1ExchangeCodec$AbstractSource;", "Lokhttp3/internal/http1/Http1ExchangeCodec;", "bytesRemaining", "", "(Lokhttp3/internal/http1/Http1ExchangeCodec;J)V", "close", "", "read", "sink", "Lokio/Buffer;", "byteCount", "okhttp"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public final class FixedLengthSource extends AbstractSource {
private long bytesRemaining;
public FixedLengthSource(long j) {
super();
this.bytesRemaining = j;
if (j == 0) {
responseBodyComplete();
}
}
@Override // okhttp3.internal.http1.Http1ExchangeCodec.AbstractSource, okio.Source
public long read(Buffer sink, long byteCount) {
Intrinsics.checkNotNullParameter(sink, "sink");
if (!(byteCount >= 0)) {
throw new IllegalArgumentException(("byteCount < 0: " + byteCount).toString());
}
if (!(!getClosed())) {
throw new IllegalStateException("closed".toString());
}
long j = this.bytesRemaining;
if (j == 0) {
return -1L;
}
long read = super.read(sink, Math.min(j, byteCount));
if (read == -1) {
Http1ExchangeCodec.this.getConnection().noNewExchanges$okhttp();
ProtocolException protocolException = new ProtocolException("unexpected end of stream");
responseBodyComplete();
throw protocolException;
}
long j2 = this.bytesRemaining - read;
this.bytesRemaining = j2;
if (j2 == 0) {
responseBodyComplete();
}
return read;
}
@Override // okio.Source, java.io.Closeable, java.lang.AutoCloseable
public void close() {
if (getClosed()) {
return;
}
if (this.bytesRemaining != 0 && !Util.discard(this, 100, TimeUnit.MILLISECONDS)) {
Http1ExchangeCodec.this.getConnection().noNewExchanges$okhttp();
responseBodyComplete();
}
setClosed(true);
}
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: Http1ExchangeCodec.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u00002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\t\n\u0000\n\u0002\u0010\u000b\n\u0000\n\u0002\u0010\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\b\u0003\b\u0082\u0004\u0018\u00002\u00060\u0001R\u00020\u0002B\r\u0012\u0006\u0010\u0003\u001a\u00020\u0004¢\u0006\u0002\u0010\u0005J\b\u0010\n\u001a\u00020\u000bH\u0016J\u0018\u0010\f\u001a\u00020\u00072\u0006\u0010\r\u001a\u00020\u000e2\u0006\u0010\u000f\u001a\u00020\u0007H\u0016J\b\u0010\u0010\u001a\u00020\u000bH\u0002R\u000e\u0010\u0006\u001a\u00020\u0007X\u0082\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\b\u001a\u00020\tX\u0082\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\u0003\u001a\u00020\u0004X\u0082\u0004¢\u0006\u0002\n\u0000¨\u0006\u0011"}, d2 = {"Lokhttp3/internal/http1/Http1ExchangeCodec$ChunkedSource;", "Lokhttp3/internal/http1/Http1ExchangeCodec$AbstractSource;", "Lokhttp3/internal/http1/Http1ExchangeCodec;", Request.JsonKeys.URL, "Lokhttp3/HttpUrl;", "(Lokhttp3/internal/http1/Http1ExchangeCodec;Lokhttp3/HttpUrl;)V", "bytesRemainingInChunk", "", "hasMoreChunks", "", "close", "", "read", "sink", "Lokio/Buffer;", "byteCount", "readChunkSize", "okhttp"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public final class ChunkedSource extends AbstractSource {
private long bytesRemainingInChunk;
private boolean hasMoreChunks;
final /* synthetic */ Http1ExchangeCodec this$0;
private final HttpUrl url;
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public ChunkedSource(Http1ExchangeCodec http1ExchangeCodec, HttpUrl url) {
super();
Intrinsics.checkNotNullParameter(url, "url");
this.this$0 = http1ExchangeCodec;
this.url = url;
this.bytesRemainingInChunk = -1L;
this.hasMoreChunks = true;
}
@Override // okhttp3.internal.http1.Http1ExchangeCodec.AbstractSource, okio.Source
public long read(Buffer sink, long byteCount) {
Intrinsics.checkNotNullParameter(sink, "sink");
if (!(byteCount >= 0)) {
throw new IllegalArgumentException(("byteCount < 0: " + byteCount).toString());
}
if (!(!getClosed())) {
throw new IllegalStateException("closed".toString());
}
if (!this.hasMoreChunks) {
return -1L;
}
long j = this.bytesRemainingInChunk;
if (j == 0 || j == -1) {
readChunkSize();
if (!this.hasMoreChunks) {
return -1L;
}
}
long read = super.read(sink, Math.min(byteCount, this.bytesRemainingInChunk));
if (read != -1) {
this.bytesRemainingInChunk -= read;
return read;
}
this.this$0.getConnection().noNewExchanges$okhttp();
ProtocolException protocolException = new ProtocolException("unexpected end of stream");
responseBodyComplete();
throw protocolException;
}
private final void readChunkSize() {
if (this.bytesRemainingInChunk != -1) {
this.this$0.source.readUtf8LineStrict();
}
try {
this.bytesRemainingInChunk = this.this$0.source.readHexadecimalUnsignedLong();
String readUtf8LineStrict = this.this$0.source.readUtf8LineStrict();
if (readUtf8LineStrict == null) {
throw new NullPointerException("null cannot be cast to non-null type kotlin.CharSequence");
}
String obj = StringsKt.trim((CharSequence) readUtf8LineStrict).toString();
if (this.bytesRemainingInChunk < 0 || (obj.length() > 0 && !StringsKt.startsWith$default(obj, ";", false, 2, (Object) null))) {
throw new ProtocolException("expected chunk size and optional extensions but was \"" + this.bytesRemainingInChunk + obj + Typography.quote);
}
if (this.bytesRemainingInChunk == 0) {
this.hasMoreChunks = false;
Http1ExchangeCodec http1ExchangeCodec = this.this$0;
http1ExchangeCodec.trailers = http1ExchangeCodec.headersReader.readHeaders();
OkHttpClient okHttpClient = this.this$0.client;
Intrinsics.checkNotNull(okHttpClient);
CookieJar cookieJar = okHttpClient.cookieJar();
HttpUrl httpUrl = this.url;
Headers headers = this.this$0.trailers;
Intrinsics.checkNotNull(headers);
okhttp3.internal.http.HttpHeaders.receiveHeaders(cookieJar, httpUrl, headers);
responseBodyComplete();
}
} catch (NumberFormatException e) {
throw new ProtocolException(e.getMessage());
}
}
@Override // okio.Source, java.io.Closeable, java.lang.AutoCloseable
public void close() {
if (getClosed()) {
return;
}
if (this.hasMoreChunks && !Util.discard(this, 100, TimeUnit.MILLISECONDS)) {
this.this$0.getConnection().noNewExchanges$okhttp();
responseBodyComplete();
}
setClosed(true);
}
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: Http1ExchangeCodec.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u0000*\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0000\n\u0002\u0010\u0002\n\u0000\n\u0002\u0010\t\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\b\u0082\u0004\u0018\u00002\u00060\u0001R\u00020\u0002B\u0005¢\u0006\u0002\u0010\u0003J\b\u0010\u0006\u001a\u00020\u0007H\u0016J\u0018\u0010\b\u001a\u00020\t2\u0006\u0010\n\u001a\u00020\u000b2\u0006\u0010\f\u001a\u00020\tH\u0016R\u000e\u0010\u0004\u001a\u00020\u0005X\u0082\u000e¢\u0006\u0002\n\u0000¨\u0006\r"}, d2 = {"Lokhttp3/internal/http1/Http1ExchangeCodec$UnknownLengthSource;", "Lokhttp3/internal/http1/Http1ExchangeCodec$AbstractSource;", "Lokhttp3/internal/http1/Http1ExchangeCodec;", "(Lokhttp3/internal/http1/Http1ExchangeCodec;)V", "inputExhausted", "", "close", "", "read", "", "sink", "Lokio/Buffer;", "byteCount", "okhttp"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public final class UnknownLengthSource extends AbstractSource {
private boolean inputExhausted;
public UnknownLengthSource() {
super();
}
@Override // okhttp3.internal.http1.Http1ExchangeCodec.AbstractSource, okio.Source
public long read(Buffer sink, long byteCount) {
Intrinsics.checkNotNullParameter(sink, "sink");
if (!(byteCount >= 0)) {
throw new IllegalArgumentException(("byteCount < 0: " + byteCount).toString());
}
if (!(!getClosed())) {
throw new IllegalStateException("closed".toString());
}
if (this.inputExhausted) {
return -1L;
}
long read = super.read(sink, byteCount);
if (read != -1) {
return read;
}
this.inputExhausted = true;
responseBodyComplete();
return -1L;
}
@Override // okio.Source, java.io.Closeable, java.lang.AutoCloseable
public void close() {
if (getClosed()) {
return;
}
if (!this.inputExhausted) {
responseBodyComplete();
}
setClosed(true);
}
}
}