Search in sources :

Example 1 with HttpAuthResourcePathsConfiguration

use of io.gravitee.am.identityprovider.http.configuration.HttpAuthResourcePathsConfiguration in project gravitee-access-management by gravitee-io.

the class HttpAuthenticationProvider method loadByUsername0.

private Maybe<User> loadByUsername0(AuthenticationContext authenticationContext, User user) {
    // prepare request
    final HttpAuthResourcePathsConfiguration authResourceConfiguration = configuration.getAuthenticationResource().getPaths();
    if (authResourceConfiguration == null) {
        return Maybe.empty();
    }
    if (authResourceConfiguration.getLoadPreAuthUserResource() == null) {
        return Maybe.empty();
    }
    final HttpResourceConfiguration readResourceConfiguration = authResourceConfiguration.getLoadPreAuthUserResource();
    if (readResourceConfiguration.getBaseURL() == null) {
        LOGGER.warn("Missing pre-authenticated user resource base URL");
        return Maybe.empty();
    }
    if (readResourceConfiguration.getHttpMethod() == null) {
        LOGGER.warn("Missing pre-authenticated user resource HTTP method");
        return Maybe.empty();
    }
    try {
        // prepare context
        TemplateEngine templateEngine = authenticationContext.getTemplateEngine();
        templateEngine.getTemplateContext().setVariable(USER_CONTEXT_KEY, user);
        // prepare request
        final String readUserURI = readResourceConfiguration.getBaseURL();
        final HttpMethod readUserHttpMethod = HttpMethod.valueOf(readResourceConfiguration.getHttpMethod().toString());
        final List<HttpHeader> readUserHttpHeaders = readResourceConfiguration.getHttpHeaders();
        final String readUserBody = readResourceConfiguration.getHttpBody();
        final Single<HttpResponse<Buffer>> requestHandler = processRequest(templateEngine, readUserURI, readUserHttpMethod, readUserHttpHeaders, readUserBody);
        return requestHandler.toMaybe().map(httpResponse -> {
            final List<HttpResponseErrorCondition> errorConditions = readResourceConfiguration.getHttpResponseErrorConditions();
            Map<String, Object> userAttributes = processResponse(templateEngine, errorConditions, httpResponse);
            return createUser(authenticationContext, userAttributes);
        }).onErrorResumeNext(ex -> {
            if (ex instanceof AbstractManagementException) {
                return Maybe.error(ex);
            }
            LOGGER.error("An error has occurred when loading pre-authenticated user {} from the remote HTTP identity provider", user.getUsername() != null ? user.getUsername() : user.getEmail(), ex);
            return Maybe.error(new TechnicalManagementException("An error has occurred when loading pre-authenticated user from the remote HTTP identity provider", ex));
        });
    } catch (Exception ex) {
        LOGGER.error("An error has occurred when loading pre-authenticated user {}", user.getUsername() != null ? user.getUsername() : user.getEmail(), ex);
        return Maybe.error(new TechnicalManagementException("An error has occurred when when loading pre-authenticated user", ex));
    }
}
Also used : HttpResourceConfiguration(io.gravitee.am.identityprovider.http.configuration.HttpResourceConfiguration) java.util(java.util) HttpHeaders(io.gravitee.common.http.HttpHeaders) HttpAuthenticationProviderConfiguration(io.gravitee.am.identityprovider.http.authentication.spring.HttpAuthenticationProviderConfiguration) InternalAuthenticationServiceException(io.gravitee.am.common.exception.authentication.InternalAuthenticationServiceException) HttpResponseErrorCondition(io.gravitee.am.identityprovider.http.configuration.HttpResponseErrorCondition) Maybe(io.reactivex.Maybe) LoggerFactory(org.slf4j.LoggerFactory) Autowired(org.springframework.beans.factory.annotation.Autowired) Single(io.reactivex.Single) Constructor(java.lang.reflect.Constructor) HttpIdentityProviderConfiguration(io.gravitee.am.identityprovider.http.configuration.HttpIdentityProviderConfiguration) HttpHeader(io.gravitee.common.http.HttpHeader) TemplateEngine(io.gravitee.el.TemplateEngine) TechnicalManagementException(io.gravitee.am.service.exception.TechnicalManagementException) SanitizeUtils(io.gravitee.am.identityprovider.http.utils.SanitizeUtils) AuthenticationException(io.gravitee.am.common.exception.authentication.AuthenticationException) HttpRequest(io.vertx.reactivex.ext.web.client.HttpRequest) io.gravitee.am.identityprovider.api(io.gravitee.am.identityprovider.api) Qualifier(org.springframework.beans.factory.annotation.Qualifier) JsonObject(io.vertx.core.json.JsonObject) StandardClaims(io.gravitee.am.common.oidc.StandardClaims) Logger(org.slf4j.Logger) HttpResponse(io.vertx.reactivex.ext.web.client.HttpResponse) Import(org.springframework.context.annotation.Import) AbstractManagementException(io.gravitee.am.service.exception.AbstractManagementException) WebClient(io.vertx.reactivex.ext.web.client.WebClient) HttpAuthResourcePathsConfiguration(io.gravitee.am.identityprovider.http.configuration.HttpAuthResourcePathsConfiguration) JsonArray(io.vertx.core.json.JsonArray) MultiMap(io.vertx.reactivex.core.MultiMap) MediaType(io.gravitee.common.http.MediaType) PasswordEncoder(io.gravitee.am.service.authentication.crypto.password.PasswordEncoder) HttpMethod(io.vertx.core.http.HttpMethod) HttpIdentityProviderResponse(io.gravitee.am.identityprovider.http.HttpIdentityProviderResponse) Buffer(io.vertx.reactivex.core.buffer.Buffer) AbstractManagementException(io.gravitee.am.service.exception.AbstractManagementException) HttpResponse(io.vertx.reactivex.ext.web.client.HttpResponse) HttpResourceConfiguration(io.gravitee.am.identityprovider.http.configuration.HttpResourceConfiguration) InternalAuthenticationServiceException(io.gravitee.am.common.exception.authentication.InternalAuthenticationServiceException) TechnicalManagementException(io.gravitee.am.service.exception.TechnicalManagementException) AuthenticationException(io.gravitee.am.common.exception.authentication.AuthenticationException) AbstractManagementException(io.gravitee.am.service.exception.AbstractManagementException) TemplateEngine(io.gravitee.el.TemplateEngine) HttpHeader(io.gravitee.common.http.HttpHeader) HttpAuthResourcePathsConfiguration(io.gravitee.am.identityprovider.http.configuration.HttpAuthResourcePathsConfiguration) MultiMap(io.vertx.reactivex.core.MultiMap) HttpMethod(io.vertx.core.http.HttpMethod) TechnicalManagementException(io.gravitee.am.service.exception.TechnicalManagementException)

Aggregations

AuthenticationException (io.gravitee.am.common.exception.authentication.AuthenticationException)1 InternalAuthenticationServiceException (io.gravitee.am.common.exception.authentication.InternalAuthenticationServiceException)1 StandardClaims (io.gravitee.am.common.oidc.StandardClaims)1 io.gravitee.am.identityprovider.api (io.gravitee.am.identityprovider.api)1 HttpIdentityProviderResponse (io.gravitee.am.identityprovider.http.HttpIdentityProviderResponse)1 HttpAuthenticationProviderConfiguration (io.gravitee.am.identityprovider.http.authentication.spring.HttpAuthenticationProviderConfiguration)1 HttpAuthResourcePathsConfiguration (io.gravitee.am.identityprovider.http.configuration.HttpAuthResourcePathsConfiguration)1 HttpIdentityProviderConfiguration (io.gravitee.am.identityprovider.http.configuration.HttpIdentityProviderConfiguration)1 HttpResourceConfiguration (io.gravitee.am.identityprovider.http.configuration.HttpResourceConfiguration)1 HttpResponseErrorCondition (io.gravitee.am.identityprovider.http.configuration.HttpResponseErrorCondition)1 SanitizeUtils (io.gravitee.am.identityprovider.http.utils.SanitizeUtils)1 PasswordEncoder (io.gravitee.am.service.authentication.crypto.password.PasswordEncoder)1 AbstractManagementException (io.gravitee.am.service.exception.AbstractManagementException)1 TechnicalManagementException (io.gravitee.am.service.exception.TechnicalManagementException)1 HttpHeader (io.gravitee.common.http.HttpHeader)1 HttpHeaders (io.gravitee.common.http.HttpHeaders)1 MediaType (io.gravitee.common.http.MediaType)1 TemplateEngine (io.gravitee.el.TemplateEngine)1 Maybe (io.reactivex.Maybe)1 Single (io.reactivex.Single)1