org.codehaus.httpcache4j.auth.AuthenticatorBase Maven / Gradle / Ivy
/*
* Copyright (c) 2010. The Codehaus. 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.
* 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 org.codehaus.httpcache4j.auth;
import org.codehaus.httpcache4j.HTTPHost;
import org.codehaus.httpcache4j.HTTPResponse;
import org.codehaus.httpcache4j.Header;
import org.codehaus.httpcache4j.util.Pair;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.stream.Collectors;
/**
* @author Erlend Hamnaberg
* @version $Revision: $
*/
//TODO: Find an algorithm for selecting the most secure supported authentication method.
//I imagine the Set of ("Digest", "Basic"); and anything else is more secure than those.
class AuthenticatorBase {
private final List strategies;
protected final SchemeRegistry registry = new DefaultSchemeRegistry();
public AuthenticatorBase() {
this(defaultStrategies());
}
public AuthenticatorBase(List strategies) {
ArrayList s = new ArrayList<>(strategies);
this.strategies = Collections.unmodifiableList(s);
}
protected static List defaultStrategies() {
return Arrays.asList(new DigestAuthenticatorStrategy(), new BasicAuthenticatorStrategy());
}
protected Pair select(List authScheme) {
AuthenticatorStrategy selected = null;
AuthScheme selectedScheme = null;
for (AuthenticatorStrategy strategy : strategies) {
for (AuthScheme scheme : authScheme) {
if (strategy.supports(scheme)) {
selected = strategy;
selectedScheme = scheme;
break;
}
}
}
if (selected == null) {
selected = new NullAuthenticatorStrategy();
}
return Pair.of(selected, selectedScheme);
}
public boolean canAuthenticatePreemptively(HTTPHost host) {
return registry.matches(host);
}
protected List toAuthSchemes(HTTPResponse response, String name) {
List authenticateHeader = response.getHeaders().getHeaders(name);
return authenticateHeader.stream().
flatMap( h -> h.getDirectives().stream()).
map(AuthScheme::new).
collect(Collectors.toList());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy