package org.apereo.cas.web.flow; import org.springframework.webflow.definition.registry.FlowDefinitionRegistry; import org.springframework.webflow.engine.ActionState; import org.springframework.webflow.engine.Flow; import org.springframework.webflow.engine.TransitionSet; import org.springframework.webflow.engine.builder.support.FlowBuilderServices; /** * The {@link SpengoWebflowConfigurer} is responsible for * adjusting the CAS webflow context for spnego integration. * * @author Misagh Moayyed * @since 4.2 */ public class SpengoWebflowConfigurer extends AbstractCasWebflowConfigurer { private static final String SPNEGO = "spnego"; private static final String START_SPNEGO_AUTHENTICATE = "startSpnegoAuthenticate"; private static final String SPNEGO_NEGOTIATE = "negociateSpnego"; private static final String EVALUATE_SPNEGO_CLIENT = "evaluateClientRequest"; public SpengoWebflowConfigurer(final FlowBuilderServices flowBuilderServices, final FlowDefinitionRegistry loginFlowDefinitionRegistry) { super(flowBuilderServices, loginFlowDefinitionRegistry); } @Override protected void doInitialize() throws Exception { final Flow flow = getLoginFlow(); if (flow != null) { createStartSpnegoAction(flow); createEvaluateSpnegoClientAction(flow); final ActionState spnego = createSpnegoActionState(flow); registerMultifactorProvidersStateTransitionsIntoWebflow(spnego); augmentWebflowToStartSpnego(flow); } } private void augmentWebflowToStartSpnego(final Flow flow) { final ActionState state = (ActionState) flow.getState(CasWebflowConstants.STATE_ID_INIT_LOGIN_FORM); createTransitionForState(state, CasWebflowConstants.TRANSITION_ID_SUCCESS, START_SPNEGO_AUTHENTICATE, true); } private void createStartSpnegoAction(final Flow flow) { final ActionState actionState = createActionState(flow, START_SPNEGO_AUTHENTICATE, createEvaluateAction(SPNEGO_NEGOTIATE)); actionState.getTransitionSet().add(createTransition(CasWebflowConstants.TRANSITION_ID_SUCCESS, SPNEGO)); actionState.getTransitionSet().add(createTransition(CasWebflowConstants.TRANSITION_ID_ERROR, CasWebflowConstants.STATE_ID_VIEW_LOGIN_FORM)); } private ActionState createSpnegoActionState(final Flow flow) { final ActionState spnego = createActionState(flow, SPNEGO, createEvaluateAction(SPNEGO)); final TransitionSet transitions = spnego.getTransitionSet(); transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_SUCCESS, CasWebflowConstants.TRANSITION_ID_SEND_TICKET_GRANTING_TICKET)); transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_ERROR, CasWebflowConstants.STATE_ID_VIEW_LOGIN_FORM)); transitions.add(createTransition(CasWebflowConstants.TRANSITION_ID_AUTHENTICATION_FAILURE, CasWebflowConstants.STATE_ID_VIEW_LOGIN_FORM)); spnego.getExitActionList().add(createEvaluateAction("clearWebflowCredentialsAction")); return spnego; } private void createEvaluateSpnegoClientAction(final Flow flow) { final ActionState evaluateClientRequest = createActionState(flow, EVALUATE_SPNEGO_CLIENT, createEvaluateAction(casProperties.getAuthn().getSpnego().getHostNameClientActionStrategy())); evaluateClientRequest.getTransitionSet().add(createTransition(CasWebflowConstants.TRANSITION_ID_YES, START_SPNEGO_AUTHENTICATE)); evaluateClientRequest.getTransitionSet().add(createTransition(CasWebflowConstants.TRANSITION_ID_NO, getStartState(flow))); } }