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

org.codehaus.httpcache4j.auth.bearer.BearerAuthenticatorStrategy Maven / Gradle / Ivy

There is a newer version: 5.1.1
Show newest version
package org.codehaus.httpcache4j.auth.bearer;

import org.codehaus.httpcache4j.Challenge;
import org.codehaus.httpcache4j.HTTPRequest;
import org.codehaus.httpcache4j.HeaderConstants;
import org.codehaus.httpcache4j.Headers;
import org.codehaus.httpcache4j.auth.AuthScheme;
import org.codehaus.httpcache4j.auth.AuthenticatorStrategy;

/**
 * http://datatracker.ietf.org/doc/draft-ietf-oauth-v2-bearer/?include_text=1
 *
 * @author Erlend Hamnaberg
 */
public final class BearerAuthenticatorStrategy implements AuthenticatorStrategy {
    public boolean supports(AuthScheme scheme) {
        return "Bearer".equalsIgnoreCase(scheme.getType());
    }

    public HTTPRequest prepare(HTTPRequest request, AuthScheme scheme) {
        String uriScheme = request.getRequestURI().getScheme();
        if (!"https".equals(uriScheme)) {
            throw new IllegalStateException("Bearer token MUST be sent over a secure connection. the URIs scheme was " + uriScheme);
        }
        HTTPRequest req = request;
        Challenge challenge = request.getChallenge().orElse(null);
        if (challenge instanceof BearerTokenChallenge) {
            BearerTokenChallenge token = (BearerTokenChallenge) challenge;
            req = req.addHeader(HeaderConstants.AUTHORIZATION, token.getToken().toHeaderValue());
        }
        return req;
    }

    public HTTPRequest prepareWithProxy(HTTPRequest request, Challenge challenge, AuthScheme scheme) {
        throw new UnsupportedOperationException("Proxy authentication is not handled by the Bearer spec");
    }

    public AuthScheme afterSuccessfulAuthentication(AuthScheme scheme, Headers headers) {
        return scheme;
    }

    public AuthScheme afterSuccessfulProxyAuthentication(AuthScheme scheme, Headers headers) {
        throw new UnsupportedOperationException("Proxy authentication is not handled by the Bearer spec");
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy