All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.basho.riak.client.raw.http.HTTPClientConfig Maven / Gradle / Ivy

There is a newer version: 2.1.1
Show newest version
/*
 * This file is provided to you 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 com.basho.riak.client.raw.http;

import java.net.URI;
import java.net.URISyntaxException;

import org.apache.http.client.HttpClient;
import org.apache.http.client.HttpRequestRetryHandler;

import com.basho.riak.client.raw.RawClient;
import com.basho.riak.client.raw.config.Configuration;

/**
 * The set of configuration parameters to use when creating an HTTP RawClient
 * instance.
 * 
 * @author russell
 * @see HTTPClusterConfig
 */
public class HTTPClientConfig implements Configuration {
	private final URI uri;
	private final String mapreducePath;
	private final HttpClient httpClient;
	private final Integer timeout;
	private final Integer maxConnections;
	private final HttpRequestRetryHandler retryHandler;

	/**
	 * Create a new instance, use the {@link Builder}
	 * 
	 * @param url
	 *            the URL for Riak's REST interface (scheme://host:port/path)
	 * @param mapreducePath
	 *            the path to Riak's REST M/R interface (eg /mapreduce)
	 * @param httpClient
	 *            a fully configured Apache {@link HttpClient} that you want to
	 *            be used by Riak HTTP client
	 * @param timeout
	 *            the connection and socket read timeout in milliseconds
	 * @param maxConnections
	 *            the maximum number of connections to the Riak REST interface
	 *            at url to create
	 * @param retryHandler
	 *            an implementation of {@link HttpRequestRetryHandler} to be
	 *            used by the underlying {@link HttpClient}
	 */
	private HTTPClientConfig(String url, String mapreducePath, HttpClient httpClient, Integer timeout,
							 Integer maxConnections, HttpRequestRetryHandler retryHandler) {
		try {
			this.uri = new URI(url);
		} catch (URISyntaxException e) {
			throw new IllegalArgumentException(e);
		}

		this.mapreducePath = mapreducePath;
		this.httpClient = httpClient;
		this.timeout = timeout;
		this.maxConnections = maxConnections;
		this.retryHandler = retryHandler;
	}

	/**
	 * Create a config with all the default values, see {@link Builder} for the
	 * defaults.
	 * 
	 * @return an HTTP client config populated with default values;
	 * @see Builder
	 */
	public static HTTPClientConfig defaults() {
		return new Builder().build();
	}

	/**
	 * @return the URL 
	 */
	public String getUrl() {
		return uri.toString();
	}

	/**
	 * @return the mapreduce path
	 */
	public String getMapreducePath() {
		return mapreducePath;
	}

	/**
	 * @return the Apache {@link HttpClient}
	 */
	public HttpClient getHttpClient() {
		return httpClient;
	}

	/**
	 * @return the timeout in milliseconds for socket connect & read (also used
	 *         by HttpClient for pooled connection blocking acquisition timeout)
	 */
	public Integer getTimeout() {
		return timeout;
	}

	/**
	 * @return the max connections
	 */
	public Integer getMaxConnections() {
		return maxConnections;
	}

	/**
	 * @return the {@link HttpRequestRetryHandler}
	 */
	public HttpRequestRetryHandler getRetryHandler() {
		return retryHandler;
	}

	/**
	 * Use the builder to create a new instance of {@link HTTPClientConfig}.
	 * 
	 * The defaults are as follows:
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
	 * 
fielddefault value
urlhttp://127.0.0.1:8098/riak (derived from defaults for * scheme://host:port/path)
schemehttp
host127.0.0.1
port8098
pathriak
mapreducePath/mapred
httpClientnull (IE the library creates one)
timeoutnull (will then use HttpClient default which is 0 (for infinite))
maxConnectionsnull (will then use the HttpClient default which is a max of *2*)
httpRequestRetryHandlernull (will use the HttpClient default)
* */ public static final class Builder { private URI uri = null; private String scheme = "http"; private String host = "127.0.0.1"; private int port = 8098; private String riakPath = "/riak"; private String mapreducePath = "/mapred"; private HttpClient httpClient = null; private Integer timeout = null; private Integer maxConnections = null; private HttpRequestRetryHandler retryHandler = null; /** * @return a {@link HTTPClientConfig} */ public HTTPClientConfig build() { String builderUrl; if (uri == null) { StringBuilder sb = new StringBuilder(scheme).append("://").append(host).append(":").append(port); if (!riakPath.startsWith("/")) { sb.append("/"); } builderUrl = sb.append(riakPath).toString(); } else { builderUrl = uri.toString(); } return new HTTPClientConfig(builderUrl, mapreducePath, httpClient, timeout, maxConnections, retryHandler); } /** * Create a new builder with values all copied from * copyConfig * * @param copyConfig * the {@link HTTPClientConfig} to copy values from * @return a new {@link Builder} populated with copyConfig * 's values. */ public static Builder from(HTTPClientConfig copyConfig) { Builder b = new Builder(); b.mapreducePath = copyConfig.mapreducePath; b.httpClient = copyConfig.httpClient; b.timeout = copyConfig.timeout; b.maxConnections = copyConfig.maxConnections; b.retryHandler = copyConfig.retryHandler; // This avoids the new builder from being unchangable due to // the withUrl() method taking precendent if (copyConfig.uri != null) { b.scheme = copyConfig.uri.getScheme(); b.riakPath = copyConfig.uri.getRawPath(); b.host = copyConfig.uri.getHost(); b.port = copyConfig.uri.getPort(); } return b; } /** * The URL Riak REST interface. *

* NOTE: Setting this take precedence over setting scheme, * host, port and path *

* * @param url * the Riak REST URL * @return this */ public Builder withUrl(String url) { try { this.uri = new URI(url); } catch (URISyntaxException ex) { // no-op to not change behavior. This will be caught in build() // when the constructor for HTTPClientConfig is called } return this; } /** * Set the scheme. *

* NOTE: setting the url takes precedence. *

* * @param scheme * HTTP or HTTPS * @return this */ public Builder withScheme(String scheme) { this.scheme = scheme; return this; } /** * Set the host. *

* NOTE: setting the url takes precedence. *

* * @param host * @return this */ public Builder withHost(String host) { this.host = host; return this; } /** * Set the port. *

* NOTE: setting the url takes precedence. *

* * @param port * @return this */ public Builder withPort(int port) { this.port = port; return this; } /** * Set the path to the base Riak REST resource. *

* NOTE: setting the url takes precedence. *

* * @param path * e.g. /riak * @return this */ public Builder withRiakPath(String path) { this.riakPath = path; return this; } /** * The location of Riak's map reduce resource * * @param path * e.g. /mapreduce * @return this */ public Builder withMapreducePath(String path) { this.mapreducePath = path; return this; } /** * You can supply a preconfigured HttpClient that you want the * {@link RawClient} to delegate to. * * @param client * a implementation of {@link HttpClient} * @return this */ public Builder withHttpClient(HttpClient client) { this.httpClient = client; return this; } /** * The connection, socket read and pooled connection acquisition timeout * in milliseconds * * @param timeout * in milliseconds * @return this */ public Builder withTimeout(int timeout) { this.timeout = timeout; return this; } /** * Maximum number of connections this client may have open at any time. * * @param maxConnections * @return this */ public Builder withMaxConnctions(int maxConnections) { this.maxConnections = maxConnections; return this; } /** * Apache HttpClient treats some HTTP methods as retry-able, and * provides a default implementation of {@link HttpRequestRetryHandler} * to be called when a request fails. Provide an implementation here to * override the default behaviour. * * @param retryHandler * an {@link HttpRequestRetryHandler} implementation * @return this */ public Builder withRetryHandler(HttpRequestRetryHandler retryHandler) { this.retryHandler = retryHandler; return this; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy