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

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 matchers = Lists.newArrayList(AcceptAllMatcher.INSTANCE); protected List 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 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