/* * Copyright 2015-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file 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 com.amazonaws.http; import com.amazonaws.AmazonWebServiceRequest; import org.apache.http.conn.ssl.BrowserCompatHostnameVerifier; import java.io.IOException; /** * Interface for an HTTP client. Its main responsibility is to execute an * {@link HttpRequest} and return a {@link HttpResponse}. There are some * requirements for its implementation. * <ul> * <li>Execute the request without any modification. An {@link HttpRequest} is * converted from an {@link AmazonWebServiceRequest} with signature information. * If modified, the request is likely to be rejected by AWS service.</li> * <li>Disable retry logic and redirect which are handled by the service client * itself.</li> * <li>Enable {@link BrowserCompatHostnameVerifier} so that a wildcard (such as * "*.amazonaws.com") matches all subdomains, including "a.b.amazonaws.com". * This is needed for S3 virtual hosting. See <a * href="http://docs.aws.amazon.com/AmazonS3/latest/dev/VirtualHosting.html" * >Virtual Hosting of Buckets</a> for more details.</li> * <li>Beware of the Expect 100-continue header. Currently it's only used in <a * href="http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectPUT.html">S3's * Put Object API</a>. S3 can fail the request with a status code other than 100 * (continue) or 417 (reject) an an error message in the body.</li> * <li>Cache is unnecessary and isn't recommended to implement until it's * supported by AWS service.</li> * </ul> */ public interface HttpClient { /** * Executes a {@link HttpRequest} and returns a {@link HttpResponse}. * * @param request a HTTP request * @return the response object * @throws IOException in case of a connection problem */ HttpResponse execute(HttpRequest request) throws IOException; /** * Forcefully shutdown this HTTP client and release all underlying * resources. */ void shutdown(); }