package org.apereo.cas.adaptors.authy.web.flow; import com.authy.api.Hash; import com.authy.api.User; import org.apereo.cas.adaptors.authy.AuthyClientInstance; import org.apereo.cas.authentication.principal.Principal; import org.apereo.cas.web.support.WebUtils; import org.springframework.webflow.action.AbstractAction; import org.springframework.webflow.execution.Event; import org.springframework.webflow.execution.RequestContext; /** * This is {@link AuthyAuthenticationRegistrationWebflowAction}. * * @author Misagh Moayyed * @since 5.0.0 */ public class AuthyAuthenticationRegistrationWebflowAction extends AbstractAction { private final AuthyClientInstance instance; public AuthyAuthenticationRegistrationWebflowAction(final AuthyClientInstance instance) { this.instance = instance; } @Override protected Event doExecute(final RequestContext context) throws Exception { final Principal principal = WebUtils.getAuthentication(context).getPrincipal(); final User user = instance.getOrCreateUser(principal); if (!user.isOk()) { throw new IllegalArgumentException(AuthyClientInstance.getErrorMessage(user.getError())); } final Hash h = instance.getAuthyUsers().requestSms(user.getId()); if (!h.isOk() || !h.isSuccess()) { throw new IllegalArgumentException(AuthyClientInstance.getErrorMessage(h.getError()).concat(h.getMessage())); } return success(); } }