aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-server-common
diff options
context:
space:
mode:
Diffstat (limited to 'server/sonar-server-common')
-rw-r--r--server/sonar-server-common/src/main/java/org/sonar/server/notification/NotificationService.java12
-rw-r--r--server/sonar-server-common/src/main/java/org/sonar/server/notification/email/EmailNotificationChannel.java16
2 files changed, 16 insertions, 12 deletions
diff --git a/server/sonar-server-common/src/main/java/org/sonar/server/notification/NotificationService.java b/server/sonar-server-common/src/main/java/org/sonar/server/notification/NotificationService.java
index 754380cbbae..56a5794dd20 100644
--- a/server/sonar-server-common/src/main/java/org/sonar/server/notification/NotificationService.java
+++ b/server/sonar-server-common/src/main/java/org/sonar/server/notification/NotificationService.java
@@ -59,7 +59,7 @@ public class NotificationService {
this(dbClient, new NotificationDispatcher[0]);
}
- public void deliver(Notification notification) {
+ public int deliver(Notification notification) {
SetMultimap<String, NotificationChannel> recipients = HashMultimap.create();
for (NotificationDispatcher dispatcher : dispatchers) {
NotificationDispatcher.Context context = new ContextImpl(recipients);
@@ -70,23 +70,27 @@ public class NotificationService {
LOG.warn(String.format("Unable to dispatch notification %s using %s", notification, dispatcher), e);
}
}
- dispatch(notification, recipients);
+ return dispatch(notification, recipients);
}
- private static void dispatch(Notification notification, SetMultimap<String, NotificationChannel> recipients) {
+ private static int dispatch(Notification notification, SetMultimap<String, NotificationChannel> recipients) {
+ int count = 0;
for (Map.Entry<String, Collection<NotificationChannel>> entry : recipients.asMap().entrySet()) {
String username = entry.getKey();
Collection<NotificationChannel> userChannels = entry.getValue();
LOG.debug("For user {} via {}", username, userChannels);
for (NotificationChannel channel : userChannels) {
try {
- channel.deliver(notification, username);
+ if (channel.deliver(notification, username)) {
+ count++;
+ }
} catch (Exception e) {
// catch all exceptions in order to deliver via other channels
LOG.warn("Unable to deliver notification " + notification + " for user " + username + " via " + channel, e);
}
}
}
+ return count;
}
@VisibleForTesting
diff --git a/server/sonar-server-common/src/main/java/org/sonar/server/notification/email/EmailNotificationChannel.java b/server/sonar-server-common/src/main/java/org/sonar/server/notification/email/EmailNotificationChannel.java
index 671a507ac83..87235eecceb 100644
--- a/server/sonar-server-common/src/main/java/org/sonar/server/notification/email/EmailNotificationChannel.java
+++ b/server/sonar-server-common/src/main/java/org/sonar/server/notification/email/EmailNotificationChannel.java
@@ -95,17 +95,18 @@ public class EmailNotificationChannel extends NotificationChannel {
}
@Override
- public void deliver(Notification notification, String username) {
+ public boolean deliver(Notification notification, String username) {
User user = findByLogin(username);
if (user == null || StringUtils.isBlank(user.email())) {
LOG.debug("User does not exist or has no email: {}", username);
- return;
+ return false;
}
EmailMessage emailMessage = format(notification);
if (emailMessage != null) {
emailMessage.setTo(user.email());
- deliver(emailMessage);
+ return deliver(emailMessage);
}
+ return false;
}
@CheckForNull
@@ -127,18 +128,17 @@ public class EmailNotificationChannel extends NotificationChannel {
return null;
}
- /**
- * Visibility has been relaxed for tests.
- */
- void deliver(EmailMessage emailMessage) {
+ boolean deliver(EmailMessage emailMessage) {
if (StringUtils.isBlank(configuration.getSmtpHost())) {
LOG.debug("SMTP host was not configured - email will not be sent");
- return;
+ return false;
}
try {
send(emailMessage);
+ return true;
} catch (EmailException e) {
LOG.error("Unable to send email", e);
+ return false;
}
}