org.mapfish.print.http.HttpProxy Maven / Gradle / Ivy
package org.mapfish.print.http;
import org.apache.http.HttpHost;
import org.mapfish.print.config.Configuration;
import org.mapfish.print.processor.http.matcher.URIMatcher;
import java.util.List;
/**
* This configuration object configures the proxies to be used by the system. This is configured as
* one of the root elements of the config.yaml
*
* Example - Explicitly declare that requests to localhost or www.camptocamp.org require proxying:
*
* proxies:
* - !proxy
* requireProxy:
* - !localMatch {}
* - !ipMatch
* ip: www.camptocamp.org
* host: proxy.host.com
* port: 8888
* username: username
* password: xyzpassword
*
* Example - Proxy all requests except localhost and www.camptocamp.org:
*
* proxies:
* - !proxy
* noProxy:
* - !localMatch {}
* - !ipMatch
* ip: www.camptocamp.org
* scheme: http
* host: proxy.host.com
* port: 8888
* username: username
* password: xyzpassword
*
*
* @author Jesse on 6/25/2014.
*/
public final class HttpProxy extends HttpCredential {
private String host;
// CSOFF: MagicNumber
private int port = 80;
// CSON: MagicNumber
private String scheme;
public HttpHost getHttpHost() {
return new HttpHost(this.host, this.port, getScheme());
}
private String getScheme() {
if (this.scheme == null) {
if (super.getUsername() == null) {
return "http";
} else {
return "https";
}
}
return this.scheme;
}
/**
* Matchers are used to choose which requests this proxy applies to.
*
* @see org.mapfish.print.processor.http.matcher.URIMatcher
* @see org.mapfish.print.processor.http.RestrictUrisProcessor
*
* @param matchers the matchers to use to determine which requests the applies can be used for
*/
public void setMatchers(final List extends URIMatcher> matchers) {
super.setMatchers(matchers);
}
/**
* The host of the proxy. Can be a hostname or ip address.
*
* This is required.
*
*
* @param host the host of the proxy
*/
public void setHost(final String host) {
this.host = host;
}
/**
* The scheme (http, https) of the proxy.
*
* This is optional, default is http if no username and https if there is a password
*
*
* @param scheme the scheme of the proxy
*/
public void setScheme(final String scheme) {
this.scheme = scheme;
}
/**
* The username for authenticating with the proxy.
*
* This is optional
*
*
* @param username the username for authenticating with the proxy
*/
public void setUsername(final String username) {
super.setUsername(username);
}
/**
* The password for authenticating with the proxy.
*
* This is optional
*
*
* @param password the password for authenticating with the proxy
*/
public void setPassword(final String password) {
super.setPassword(password);
}
/**
* The host of the proxy. Can be a hostname or ip address.
*
* This is optional. The default value is 80.
*
*
* @param port the port of the proxy
*/
public void setPort(final int port) {
this.port = port;
}
@Override
public void validate(final List validationErrors, final Configuration configuration) {
if (this.host == null) {
validationErrors.add(new IllegalStateException("The parameter 'host' is required."));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy