org.apereo.cas.web.flow.SpnegoWebflowConfigurer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cas-server-support-spnego-webflow Show documentation
Show all versions of cas-server-support-spnego-webflow Show documentation
cas-server-support-spnego-webflow
package org.apereo.cas.web.flow;
import org.apereo.cas.configuration.CasConfigurationProperties;
import org.apereo.cas.web.flow.configurer.AbstractCasWebflowConfigurer;
import lombok.val;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.webflow.definition.registry.FlowDefinitionRegistry;
import org.springframework.webflow.engine.ActionState;
import org.springframework.webflow.engine.Flow;
import org.springframework.webflow.engine.builder.support.FlowBuilderServices;
/**
* The {@link SpnegoWebflowConfigurer} is responsible for
* adjusting the CAS webflow context for spnego integration.
*
* @author Misagh Moayyed
* @since 4.2
*/
public class SpnegoWebflowConfigurer extends AbstractCasWebflowConfigurer {
public SpnegoWebflowConfigurer(final FlowBuilderServices flowBuilderServices,
final FlowDefinitionRegistry loginFlowDefinitionRegistry,
final ConfigurableApplicationContext applicationContext,
final CasConfigurationProperties casProperties) {
super(flowBuilderServices, loginFlowDefinitionRegistry, applicationContext, casProperties);
setOrder(casProperties.getAuthn().getSpnego().getWebflow().getOrder());
}
@Override
protected void doInitialize() {
val flow = getLoginFlow();
if (flow != null) {
createStartSpnegoAction(flow);
createEvaluateSpnegoClientAction(flow);
createSpnegoActionState(flow);
augmentWebflowToStartSpnego(flow);
}
}
private void augmentWebflowToStartSpnego(final Flow flow) {
val state = getState(flow, CasWebflowConstants.STATE_ID_AFTER_INIT_LOGIN_FORM, ActionState.class);
if (casProperties.getAuthn().getSpnego().isMixedModeAuthentication()) {
createTransitionForState(state, CasWebflowConstants.TRANSITION_ID_SUCCESS,
CasWebflowConstants.STATE_ID_EVALUATE_SPNEGO_CLIENT, true);
} else {
createTransitionForState(state, CasWebflowConstants.TRANSITION_ID_SUCCESS,
CasWebflowConstants.STATE_ID_START_SPNEGO_AUTHENTICATE, true);
}
}
private void createStartSpnegoAction(final Flow flow) {
val actionState = createActionState(flow, CasWebflowConstants.STATE_ID_START_SPNEGO_AUTHENTICATE,
CasWebflowConstants.ACTION_ID_SPNEGO_NEGOTIATE);
val transitionSet = actionState.getTransitionSet();
transitionSet.add(createTransition(CasWebflowConstants.TRANSITION_ID_SUCCESS, CasWebflowConstants.STATE_ID_SPNEGO));
transitionSet.add(createTransition(CasWebflowConstants.TRANSITION_ID_ERROR, getStateIdOnSpnegoFailure(flow)));
}
private void createEvaluateSpnegoClientAction(final Flow flow) {
val evaluateClientRequest = createActionState(flow, CasWebflowConstants.STATE_ID_EVALUATE_SPNEGO_CLIENT,
casProperties.getAuthn().getSpnego().getHostNameClientActionStrategy());
val transitionSet = evaluateClientRequest.getTransitionSet();
transitionSet.add(createTransition(CasWebflowConstants.TRANSITION_ID_YES,
CasWebflowConstants.STATE_ID_START_SPNEGO_AUTHENTICATE));
transitionSet.add(createTransition(CasWebflowConstants.TRANSITION_ID_NO, getStateIdOnSpnegoFailure(flow)));
}
private void createSpnegoActionState(final Flow flow) {
val spnego = createActionState(flow, CasWebflowConstants.STATE_ID_SPNEGO, CasWebflowConstants.STATE_ID_SPNEGO);
val transitions = spnego.getTransitionSet();
transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_SUCCESS,
CasWebflowConstants.STATE_ID_CREATE_TICKET_GRANTING_TICKET));
transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_ERROR, getStateIdOnSpnegoFailure(flow)));
transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_WARN, CasWebflowConstants.TRANSITION_ID_WARN));
transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_AUTHENTICATION_FAILURE,
CasWebflowConstants.STATE_ID_VIEW_LOGIN_FORM));
transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_SUCCESS_WITH_WARNINGS,
CasWebflowConstants.STATE_ID_SHOW_AUTHN_WARNING_MSGS));
spnego.getExitActionList().add(createEvaluateAction(CasWebflowConstants.ACTION_ID_CLEAR_WEBFLOW_CREDENTIALS));
}
private String getStateIdOnSpnegoFailure(final Flow flow) {
val state = getState(flow, CasWebflowConstants.STATE_ID_AFTER_INIT_LOGIN_FORM, ActionState.class);
return state.getTransition(CasWebflowConstants.TRANSITION_ID_SUCCESS).getTargetStateId();
}
}