org.mapfish.print.http.HttpCredential Maven / Gradle / Ivy
package org.mapfish.print.http;
import com.google.common.collect.Lists;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.Credentials;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.mapfish.print.config.Configuration;
import org.mapfish.print.config.ConfigurationObject;
import org.mapfish.print.processor.http.matcher.AcceptAllMatcher;
import org.mapfish.print.processor.http.matcher.MatchInfo;
import org.mapfish.print.processor.http.matcher.URIMatcher;
import java.net.MalformedURLException;
import java.net.SocketException;
import java.net.UnknownHostException;
import java.util.List;
import javax.annotation.Nullable;
/**
* Represents a set of credentials to use for an http request. These can be configured in the Configuration yaml file.
*
*
* Note: proxies are also HttpCredentials and when searching for credentials, the proxies will also be searched
* for credentials.
*
*
* @author Jesse on 9/4/2014.
*/
// CSOFF: DesignForExtension
public class HttpCredential implements ConfigurationObject {
private String username;
private char[] password;
private List extends URIMatcher> matchers = Lists.newArrayList(AcceptAllMatcher.INSTANCE);
protected List extends URIMatcher> getMatchers() {
return this.matchers;
}
/**
* Matchers are used to choose which requests the credentials apply 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 credentials can be used for
*/
public void setMatchers(final List extends URIMatcher> matchers) {
this.matchers = matchers;
}
/**
* The username for authenticating with the credentials.
*
* This is optional
*
*
* @param username the username for authenticating with the credentials
*/
public void setUsername(final String username) {
this.username = username;
}
/**
* Get the username.
*/
protected String getUsername() {
return this.username;
}
/**
* The password for authenticating with the credentials.
*
* This is optional
*
*
* @param password the password for authenticating with the credentials
*/
public void setPassword(final String password) {
if (password == null) {
throw new IllegalArgumentException("Do not set a null password, simply exclude it from configuration file. " +
"If there is supposed to be a password perhaps it has illegal characters, " +
"surround password with quotes");
}
this.password = password.toCharArray();
}
@Override
public void validate(final List validationErrors, final Configuration configuration) {
if (this.username == null) {
validationErrors.add(new IllegalStateException("The parameter 'username' is required."));
}
}
/**
* Returns true if this proxy should be used for the provided URI.
*
* @param matchInfo the information for making the patch
*/
public boolean matches(final MatchInfo matchInfo) throws SocketException, UnknownHostException, MalformedURLException {
for (URIMatcher uriMatcher : this.getMatchers()) {
if (uriMatcher.matches(matchInfo)) {
return true;
}
}
return false;
}
/**
* Check if this applies to the provided authorization scope and return the credentials for that scope or null if it
* doesn't apply to the scope.
*
* @param authscope the scope to test against.
*/
@Nullable
public final Credentials toCredentials(final AuthScope authscope) {
try {
if (!matches(MatchInfo.fromAuthScope(authscope))) {
return null;
}
} catch (UnknownHostException e) {
throw new RuntimeException(e);
} catch (MalformedURLException e) {
throw new RuntimeException(e);
} catch (SocketException e) {
throw new RuntimeException(e);
}
if (this.username == null) {
return null;
}
final String passwordString;
if (this.password != null) {
passwordString = new String(this.password);
} else {
passwordString = null;
}
return new UsernamePasswordCredentials(this.username, passwordString);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy