/**
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.scheduler.tasks;
import java.util.Collection;
import java.util.HashSet;
import org.openmrs.User;
import org.openmrs.api.context.Context;
import org.openmrs.notification.Alert;
import org.openmrs.notification.AlertRecipient;
import org.openmrs.notification.Message;
import org.openmrs.notification.MessageException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Sample implementation of task that shows how to send emails to users/roles via message service.
*/
public class AlertReminderTask extends AbstractTask {
// Logger
private Logger log = LoggerFactory.getLogger(AlertReminderTask.class);
/**
* Send alert reminder email to user(s) associated with the alert.
*/
@Override
public void execute() {
try {
// Get all unread alerts
// TODO Change to getAllAlerts(Boolean includeRead, Boolean includeExpired);
Collection<Alert> alerts = Context.getAlertService().getAllAlerts(false);
// Send alert notifications to users who have unread alerts
sendAlertNotifications(alerts);
}
catch (Exception e) {
log.error("Failed to send alert notifications", e);
}
}
/**
* Send alerts
*
* @param alerts the unread alerts
* @param users the users who have not read the alerts
*/
private void sendAlertNotifications(Collection<Alert> alerts) {
try {
// Create a new message
Message message = Context.getMessageService().createMessage("Alert Reminder", "You have unread alerts.");
// Get all recipients
Collection<User> users = getRecipients(alerts);
// Send a message to each person only once
Context.getMessageService().sendMessage(message, users);
}
catch (MessageException e) {
log.error("Failed to send message", e);
}
}
/**
* Get the recipients of all unread alerts.
*
* @param alerts
* @return
*/
private Collection<User> getRecipients(Collection<Alert> alerts) {
Collection<User> users = new HashSet<User>();
for (Alert alert : alerts) {
log.debug("Send email to alert recipient(s) ...");
if (!alert.isAlertRead() && alert.getRecipients() != null) {
for (AlertRecipient recipient : alert.getRecipients()) {
if (!recipient.isAlertRead() && recipient.getRecipient() != null) {
users.add(recipient.getRecipient());
}
}
}
}
return users;
}
}