com.gooddata.sdk.service.gdc.GdcSardine Maven / Gradle / Ivy
/*
* (C) 2023 GoodData Corporation.
* This source code is licensed under the BSD-style license found in the
* LICENSE.txt file in the root directory of this source tree.
*/
package com.gooddata.sdk.service.gdc;
import static com.gooddata.sdk.common.util.Validate.notNull;
import com.github.sardine.impl.SardineImpl;
import com.github.sardine.impl.io.ContentLengthInputStream;
import com.github.sardine.impl.io.HttpMethodReleaseInputStream;
import org.apache.http.Header;
import org.apache.http.HttpResponse;
import org.apache.http.client.ResponseHandler;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpRequestBase;
import org.apache.http.impl.client.HttpClientBuilder;
import java.io.IOException;
import java.util.List;
import java.util.Map;
/**
* This class extends SardineImpl, connections were not correctly closed by parent
*/
class GdcSardine extends SardineImpl {
public GdcSardine(HttpClientBuilder builder) {
super(builder);
}
/**
* had to be overriden, because parent method did not close connection after execution
*/
@Override
protected T execute(HttpRequestBase request, ResponseHandler responseHandler) throws IOException {
notNull(request, "request");
try {
return super.execute(request, responseHandler);
} finally {
request.releaseConnection();
}
}
/**
* The method body is retrieved from {@link SardineImpl#get(String, Map)} and extended about the response handler
* to be able to handle responses arbitrarily.
*
* @param url Path to the resource including protocol and hostname
* @param headers Additional HTTP headers to add to the request
* @param responseHandler Arbitrary response handler to manipulate with responses
* @return Data stream to read from
* @throws IOException I/O error or HTTP response validation failure
*/
public ContentLengthInputStream get(final String url, final List headers,
final ResponseHandler responseHandler) throws IOException {
final HttpGet get = new HttpGet(url);
for (Header header : headers) {
get.addHeader(header);
}
// Must use #execute without handler, otherwise the entity is consumed
// already after the handler exits.
final HttpResponse response = this.execute(get);
try {
responseHandler.handleResponse(response);
// Will abort the read when closed before EOF.
return new ContentLengthInputStream(new HttpMethodReleaseInputStream(response), response.getEntity().getContentLength());
} catch (IOException ex) {
get.abort();
throw ex;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy