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

org.apereo.cas.acct.webflow.ValidateAccountRegistrationTokenAction Maven / Gradle / Ivy

There is a newer version: 7.2.0-RC3
Show newest version
package org.apereo.cas.acct.webflow;

import org.apereo.cas.acct.AccountRegistrationService;
import org.apereo.cas.acct.AccountRegistrationUtils;
import org.apereo.cas.authentication.RootCasException;
import org.apereo.cas.ticket.TransientSessionTicket;
import org.apereo.cas.ticket.registry.TicketRegistry;
import org.apereo.cas.util.LoggingUtils;
import org.apereo.cas.web.flow.CasWebflowConstants;
import org.apereo.cas.web.flow.actions.BaseCasWebflowAction;

import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import lombok.val;
import org.springframework.webflow.execution.Event;
import org.springframework.webflow.execution.RequestContext;

/**
 * This is {@link ValidateAccountRegistrationTokenAction}.
 *
 * @author Misagh Moayyed
 * @since 6.5.0
 */
@Slf4j
@RequiredArgsConstructor
public class ValidateAccountRegistrationTokenAction extends BaseCasWebflowAction {
    private final TicketRegistry ticketRegistry;

    private final AccountRegistrationService accountRegistrationService;

    @Override
    protected Event doExecuteInternal(final RequestContext requestContext) throws Exception {
        var accountRegTicket = (TransientSessionTicket) null;
        try {
            val activationToken = requestContext.getRequestParameters()
                .getRequired(AccountRegistrationUtils.REQUEST_PARAMETER_ACCOUNT_REGISTRATION_ACTIVATION_TOKEN);
            accountRegTicket = ticketRegistry.getTicket(activationToken, TransientSessionTicket.class);
            val token = accountRegTicket.getProperty(AccountRegistrationUtils.PROPERTY_ACCOUNT_REGISTRATION_ACTIVATION_TOKEN, String.class);
            val registrationRequest = accountRegistrationService.validateToken(token);
            accountRegTicket.update();

            val username = accountRegistrationService.getAccountRegistrationUsernameBuilder().build(registrationRequest);
            AccountRegistrationUtils.putAccountRegistrationRequest(requestContext, registrationRequest);
            AccountRegistrationUtils.putAccountRegistrationRequestUsername(requestContext, username);

            return success(registrationRequest);
        } catch (final Exception e) {
            LoggingUtils.warn(LOGGER, e);
            requestContext.getFlashScope().put(CasWebflowConstants.ATTRIBUTE_ERROR_ROOT_CAUSE_EXCEPTION,
                RootCasException.withCode("screen.error.page.invalidrequest.desc"));
            return error(e);
        } finally {
            if (accountRegTicket != null && accountRegTicket.isExpired()) {
                ticketRegistry.deleteTicket(accountRegTicket);
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy