package org.apereo.cas.impl.notify;
import org.apereo.cas.authentication.principal.Principal;
import org.apereo.cas.configuration.model.core.authentication.RiskBasedAuthenticationProperties;
import org.apereo.cas.util.io.CommunicationsManager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* This is {@link AuthenticationRiskEmailNotifier}.
*
* @author Misagh Moayyed
* @since 5.1.0
*/
public class AuthenticationRiskEmailNotifier extends BaseAuthenticationRiskNotifier {
private static final Logger LOGGER = LoggerFactory.getLogger(AuthenticationRiskEmailNotifier.class);
private final CommunicationsManager communicationsManager;
public AuthenticationRiskEmailNotifier(final CommunicationsManager communicationsManager) {
this.communicationsManager = communicationsManager;
}
@Override
public void publish() {
final RiskBasedAuthenticationProperties.Response.Mail mail =
casProperties.getAuthn().getAdaptive().getRisk().getResponse().getMail();
final Principal principal = authentication.getPrincipal();
if (!principal.getAttributes().containsKey(mail.getAttributeName())) {
LOGGER.debug("Could not send email [{}] because either no addresses could be found or email settings are not configured.",
principal.getId());
return;
}
final String to = principal.getAttributes().get(mail.getAttributeName()).toString();
this.communicationsManager.email(mail.getText(), mail.getFrom(), mail.getSubject(), to, mail.getCc(), mail.getBcc());
}
}