
org.zalando.logbook.httpclient.LocalRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of logbook-httpclient Show documentation
Show all versions of logbook-httpclient Show documentation
HTTP Client interceptor for request and response logging
package org.zalando.logbook.httpclient;
/*
* #%L
* Logbook: HTTP Client
* %%
* Copyright (C) 2015 Zalando SE
* %%
* 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.
* #L%
*/
import org.apache.http.Header;
import org.apache.http.HttpEntityEnclosingRequest;
import org.apache.http.HttpRequest;
import org.apache.http.client.methods.HttpRequestWrapper;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.entity.ByteArrayEntity;
import org.apache.http.entity.ContentType;
import org.apache.http.util.EntityUtils;
import org.zalando.logbook.Origin;
import org.zalando.logbook.RawHttpRequest;
import java.io.IOException;
import java.net.URI;
import java.net.UnknownHostException;
import java.nio.charset.Charset;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import static java.nio.charset.StandardCharsets.UTF_8;
import static org.apache.http.util.EntityUtils.toByteArray;
final class LocalRequest implements RawHttpRequest, org.zalando.logbook.HttpRequest {
private final HttpRequest request;
private final Localhost localhost;
private final URI originalRequestUri;
private byte[] body;
LocalRequest(final HttpRequest request, final Localhost localhost) {
this.request = request;
this.localhost = localhost;
this.originalRequestUri = getOriginalRequestUri(request);
}
private static URI getOriginalRequestUri(final HttpRequest request) {
if (request instanceof HttpRequestWrapper) {
return extractRequestUri(HttpRequestWrapper.class.cast(request).getOriginal());
} else if (request instanceof HttpUriRequest) {
return HttpUriRequest.class.cast(request).getURI();
} else {
return extractRequestUri(request);
}
}
private static URI extractRequestUri(final HttpRequest request) {
return URI.create(request.getRequestLine().getUri());
}
@Override
public Origin getOrigin() {
return Origin.LOCAL;
}
@Override
public String getProtocolVersion() {
return request.getRequestLine().getProtocolVersion().toString();
}
@Override
public String getRemote() {
try {
return localhost.getAddress();
} catch (final UnknownHostException e) {
throw new IllegalStateException(e);
}
}
@Override
public String getMethod() {
return request.getRequestLine().getMethod();
}
@Override
public String getScheme() {
return originalRequestUri.getScheme();
}
@Override
public String getHost() {
return originalRequestUri.getHost();
}
@Override
public int getPort() {
final int port = originalRequestUri.getPort();
return port == -1 ? 80 : port; // TODO(whiskeysiera): is that safe to do?
}
@Override
public String getPath() {
return originalRequestUri.getPath();
}
@Override
public String getQuery() {
return Optional.ofNullable(originalRequestUri.getQuery()).orElse("");
}
@Override
public Map> getHeaders() {
final HeadersBuilder builder = new HeadersBuilder();
for (final Header header : request.getAllHeaders()) {
builder.put(header.getName(), header.getValue());
}
return builder.build();
}
@Override
public String getContentType() {
return Optional.of(request)
.map(request -> request.getFirstHeader("Content-Type"))
.map(Header::getValue)
.orElse("");
}
@Override
public Charset getCharset() {
return Optional.of(request)
.map(request -> request.getFirstHeader("Content-Type"))
.map(Header::getValue)
.map(ContentType::parse)
.map(ContentType::getCharset)
.orElse(UTF_8);
}
@Override
public byte[] getBody() {
return body;
}
@Override
public org.zalando.logbook.HttpRequest withBody() throws IOException {
if (request instanceof HttpEntityEnclosingRequest) {
final HttpEntityEnclosingRequest request = (HttpEntityEnclosingRequest) this.request;
this.body = toByteArray(request.getEntity());
request.setEntity(new ByteArrayEntity(body));
} else {
this.body = new byte[0];
}
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy