ratpack.http.client.internal.RequestSpecBacking Maven / Gradle / Ivy
/*
* Copyright 2014 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package ratpack.http.client.internal;
import com.google.common.base.Preconditions;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.ByteBufAllocator;
import io.netty.buffer.ByteBufOutputStream;
import io.netty.buffer.Unpooled;
import io.netty.util.CharsetUtil;
import ratpack.api.Nullable;
import ratpack.func.Action;
import ratpack.func.Function;
import ratpack.http.MutableHeaders;
import ratpack.http.client.ReceivedResponse;
import ratpack.http.client.RequestSpec;
import ratpack.http.internal.HttpHeaderConstants;
import javax.net.ssl.SSLContext;
import java.io.OutputStream;
import java.net.URI;
import java.nio.charset.Charset;
import java.time.Duration;
class RequestSpecBacking {
private final MutableHeaders headers;
private final URI uri;
private final ByteBufAllocator byteBufAllocator;
private final RequestParams requestParams;
private boolean decompressResponse;
private ByteBuf bodyByteBuf;
private String method = "GET";
private int maxRedirects = RequestSpec.DEFAULT_MAX_REDIRECTS;
private SSLContext sslContext;
private Function super ReceivedResponse, Action super RequestSpec>> onRedirect;
public RequestSpecBacking(MutableHeaders headers, URI uri, ByteBufAllocator byteBufAllocator, RequestParams requestParams) {
this.headers = headers;
this.uri = uri;
this.byteBufAllocator = byteBufAllocator;
this.requestParams = requestParams;
this.bodyByteBuf = byteBufAllocator.buffer(0, 0);
this.decompressResponse = true;
}
public Function super ReceivedResponse, Action super RequestSpec>> getOnRedirect() {
return onRedirect;
}
public String getMethod() {
return method;
}
public int getMaxRedirects() {
return maxRedirects;
}
public boolean isDecompressResponse() {
return decompressResponse;
}
@Nullable
public SSLContext getSslContext() {
return sslContext;
}
@Nullable
public ByteBuf getBody() {
return bodyByteBuf;
}
public RequestSpec asSpec() {
return new Spec();
}
private class Spec implements RequestSpec {
private BodyImpl body = new BodyImpl();
@Override
public RequestSpec onRedirect(Function super ReceivedResponse, Action super RequestSpec>> function) {
RequestSpecBacking.this.onRedirect = function;
return this;
}
@Override
public RequestSpec redirects(int maxRedirects) {
Preconditions.checkArgument(maxRedirects >= 0);
RequestSpecBacking.this.maxRedirects = maxRedirects;
return this;
}
@Override
public RequestSpec sslContext(SSLContext sslContext) {
RequestSpecBacking.this.sslContext = sslContext;
return this;
}
@Override
public MutableHeaders getHeaders() {
return headers;
}
@Override
public RequestSpec headers(Action super MutableHeaders> action) throws Exception {
action.execute(getHeaders());
return this;
}
@Override
public RequestSpec method(String method) {
RequestSpecBacking.this.method = method.toUpperCase();
return this;
}
@Override
public RequestSpec decompressResponse(boolean shouldDecompress) {
RequestSpecBacking.this.decompressResponse = shouldDecompress;
return this;
}
@Override
public URI getUrl() {
return uri;
}
@Override
public RequestSpec readTimeout(Duration duration) {
requestParams.readTimeoutNanos = duration.toNanos();
return this;
}
private void setBodyByteBuf(ByteBuf byteBuf) {
if (bodyByteBuf != null) {
bodyByteBuf.release();
}
bodyByteBuf = byteBuf;
}
private class BodyImpl implements Body {
@Override
public Body type(String contentType) {
getHeaders().set(HttpHeaderConstants.CONTENT_TYPE, contentType);
return this;
}
@Override
public Body stream(Action super OutputStream> action) throws Exception {
ByteBuf byteBuf = byteBufAllocator.buffer();
try (OutputStream outputStream = new ByteBufOutputStream(byteBuf)) {
action.execute(outputStream);
} catch (Throwable t) {
byteBuf.release();
throw t;
}
setBodyByteBuf(byteBuf);
return this;
}
@Override
public Body buffer(ByteBuf byteBuf) {
setBodyByteBuf(byteBuf.retain());
return this;
}
@Override
public Body bytes(byte[] bytes) {
setBodyByteBuf(Unpooled.wrappedBuffer(bytes));
return this;
}
@Override
public Body text(CharSequence text) {
return text(text, CharsetUtil.UTF_8);
}
@Override
public Body text(CharSequence text, Charset charset) {
if (charset.equals(CharsetUtil.UTF_8)) {
maybeSetContentType(HttpHeaderConstants.PLAIN_TEXT_UTF8);
} else {
maybeSetContentType("text/plain;charset=" + charset.name());
}
setBodyByteBuf(Unpooled.copiedBuffer(text, charset));
return this;
}
private void maybeSetContentType(CharSequence s) {
if (!headers.contains(HttpHeaderConstants.CONTENT_TYPE.toString())) {
headers.set(HttpHeaderConstants.CONTENT_TYPE, s);
}
}
}
@Override
public Body getBody() {
return body;
}
@Override
public RequestSpec body(Action super Body> action) throws Exception {
action.execute(getBody());
return this;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy