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

org.codehaus.httpcache4j.auth.DefaultAuthenticator Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2009. 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.*;

import java.util.Arrays;
import java.util.List;

import org.codehaus.httpcache4j.util.Pair;

/**
 * @author Erlend Hamnaberg
 * @version $Revision: $
 */
public class DefaultAuthenticator extends AuthenticatorBase implements Authenticator {

    public DefaultAuthenticator() {
        super();
    }

    public DefaultAuthenticator(List strategies) {
        super(strategies);
    }

    public final HTTPRequest prepareAuthentication(final HTTPRequest request, final HTTPResponse response) {
        HTTPRequest req = request;
        HTTPHost host = new HTTPHost(request.getRequestURI());
        if (response == null && registry.matches(host)) {
            //preemptive auth.
            AuthScheme authScheme = registry.get(host);
            Pair selected = select(Arrays.asList(authScheme));
            return selected.getKey().prepare(request, authScheme);

        }
        if (response != null && response.getStatus() == Status.UNAUTHORIZED) {
            List schemes = toAuthSchemes(response, HeaderConstants.WWW_AUTHENTICATE);
            if (!schemes.isEmpty() && request.getChallenge() != null) {
                Pair selected = select(schemes);
                if (selected.getValue() != null) {
                    req = selected.getKey().prepare(request, selected.getValue());
                    if (req != request) { //If authentication header was added
                        registry.register(host, selected.getValue());
                    }
                }
            }
        }
        return req;
    }

    public boolean canAuthenticatePreemptively(HTTPRequest request) {
        return canAuthenticatePreemptively(new HTTPHost(request.getRequestURI()));
    }

    public HTTPRequest preparePreemptiveAuthentication(HTTPRequest request) {
        return prepareAuthentication(request, null);
    }

    public void afterSuccessfulAuthentication(HTTPRequest request, Headers responseHeaders) {
        HTTPHost host = new HTTPHost(request.getRequestURI());
        if (registry.matches(host)) {
            AuthScheme scheme = registry.get(host);
            Pair select = select(Arrays.asList(scheme));
            AuthScheme updatedScheme = select.getKey().afterSuccessfulAuthentication(scheme, responseHeaders);
            if (updatedScheme != scheme) {
                registry.register(host, updatedScheme);                
            }
        }
    }

    public void afterFailedAuthentication(HTTPRequest request, Headers responseHeaders) {
        HTTPHost host = new HTTPHost(request.getRequestURI());
        registry.remove(host);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy