org.apereo.cas.web.DelegatedAuthenticationWebApplicationServiceFactory Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cas-server-support-pac4j-webflow Show documentation
Show all versions of cas-server-support-pac4j-webflow Show documentation
cas-server-support-pac4j-webflow
package org.apereo.cas.web;
import org.apereo.cas.authentication.principal.WebApplicationServiceFactory;
import org.apereo.cas.util.HttpRequestUtils;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import lombok.val;
import org.apache.commons.lang3.StringUtils;
import org.pac4j.core.client.BaseClient;
import org.pac4j.core.client.Clients;
import org.pac4j.core.context.JEEContext;
import org.pac4j.core.context.Pac4jConstants;
import org.pac4j.core.context.session.SessionStore;
import javax.servlet.http.HttpServletRequest;
/**
* This is {@link DelegatedAuthenticationWebApplicationServiceFactory}.
*
* @author Misagh Moayyed
* @since 6.0.0
*/
@Slf4j
@RequiredArgsConstructor
public class DelegatedAuthenticationWebApplicationServiceFactory extends WebApplicationServiceFactory {
private final Clients clients;
private final DelegatedClientWebflowManager delegatedClientWebflowManager;
private final SessionStore sessionStore;
@Override
protected String getRequestedService(final HttpServletRequest request) {
val service = super.getRequestedService(request);
if (StringUtils.isNotBlank(service)) {
return service;
}
val clientName = request.getParameter(Pac4jConstants.DEFAULT_CLIENT_NAME_PARAMETER);
LOGGER.trace("Indicated client name for service extraction is [{}]", clientName);
if (StringUtils.isBlank(clientName)) {
LOGGER.trace("No client name found in the request");
return null;
}
val clientResult = this.clients.findClient(clientName);
if (clientResult.isEmpty()) {
LOGGER.warn("No client could be located for [{}]", clientName);
return null;
}
val webContext = new JEEContext(request,
HttpRequestUtils.getHttpServletResponseFromRequestAttributes(),
this.sessionStore);
val client = BaseClient.class.cast(clientResult.get());
val clientId = delegatedClientWebflowManager.getDelegatedClientId(webContext, client);
if (StringUtils.isNotBlank(clientId)) {
val ticket = delegatedClientWebflowManager.retrieveSessionTicketViaClientId(webContext, clientId);
if (ticket == null || ticket.getService() == null) {
LOGGER.warn("Session ticket [{}] is not found or does not have a service associated with it", ticket);
return null;
}
return ticket.getService().getId();
}
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy