1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.kuali.rice.ken.service.impl;
17
18 import org.kuali.rice.core.framework.persistence.dao.GenericDao;
19 import org.kuali.rice.ken.bo.Notification;
20 import org.kuali.rice.ken.bo.NotificationMessageDelivery;
21 import org.kuali.rice.ken.bo.NotificationRecipient;
22 import org.kuali.rice.ken.bo.NotificationRecipientList;
23 import org.kuali.rice.ken.bo.UserChannelSubscription;
24 import org.kuali.rice.ken.deliverer.impl.KEWActionListMessageDeliverer;
25 import org.kuali.rice.ken.exception.NotificationMessageDeliveryException;
26 import org.kuali.rice.ken.service.NotificationMessageDeliveryResolverService;
27 import org.kuali.rice.ken.service.NotificationRecipientService;
28 import org.kuali.rice.ken.service.NotificationService;
29 import org.kuali.rice.ken.service.ProcessingResult;
30 import org.kuali.rice.ken.service.UserPreferenceService;
31 import org.kuali.rice.ken.util.NotificationConstants;
32 import org.kuali.rice.kim.api.KimConstants.KimGroupMemberTypes;
33 import org.kuali.rice.kim.api.identity.principal.Principal;
34 import org.kuali.rice.kim.api.services.KimApiServiceLocator;
35 import org.springframework.transaction.PlatformTransactionManager;
36
37 import java.sql.Timestamp;
38 import java.util.ArrayList;
39 import java.util.Collection;
40 import java.util.HashSet;
41 import java.util.Iterator;
42 import java.util.List;
43 import java.util.concurrent.ExecutorService;
44
45
46
47
48
49
50
51 public class NotificationMessageDeliveryResolverServiceImpl extends ConcurrentJob<Notification> implements NotificationMessageDeliveryResolverService {
52 private static org.apache.log4j.Logger LOG = org.apache.log4j.Logger
53 .getLogger(NotificationMessageDeliveryResolverServiceImpl.class);
54
55 private NotificationRecipientService notificationRecipientService;
56 private GenericDao businessObjectDao;
57 private UserPreferenceService userPreferenceService;
58 private NotificationService notificationService;
59
60
61
62
63
64
65
66
67
68 public NotificationMessageDeliveryResolverServiceImpl(NotificationService notificationService, NotificationRecipientService notificationRecipientService,
69 GenericDao businessObjectDao, PlatformTransactionManager txManager, ExecutorService executor,
70 UserPreferenceService userPreferenceService) {
71 super(txManager, executor);
72 this.notificationService = notificationService;
73 this.notificationRecipientService = notificationRecipientService;
74 this.businessObjectDao = businessObjectDao;
75 this.userPreferenceService = userPreferenceService;
76 }
77
78
79
80
81
82 @Override
83 protected Collection<Notification> takeAvailableWorkItems() {
84 Collection<Notification> nots = notificationService.takeNotificationsForResolution();
85
86
87
88
89
90 return nots;
91 }
92
93
94
95
96
97
98
99
100 private HashSet<String> buildCompleteRecipientList(Notification notification) {
101 HashSet<String> completeRecipientList = new HashSet<String>(notification.getRecipients().size());
102
103
104 for (int i = 0; i < notification.getRecipients().size(); i++) {
105 NotificationRecipient recipient = notification.getRecipient(i);
106 if (KimGroupMemberTypes.GROUP_MEMBER_TYPE.getCode().equals(recipient.getRecipientType())) {
107
108 String[] groupMembers = notificationRecipientService.getGroupMembers(recipient.getRecipientId());
109 for(int j = 0; j < groupMembers.length; j++) {
110 completeRecipientList.add(groupMembers[j]);
111 }
112 } else {
113 Principal principal = KimApiServiceLocator.getIdentityService().getPrincipal(recipient.getRecipientId());
114 completeRecipientList.add(principal.getPrincipalId());
115 }
116 }
117
118
119 Iterator<NotificationRecipientList> i = notification.getChannel().getRecipientLists().iterator();
120 while (i.hasNext()) {
121 NotificationRecipientList listRecipient = i.next();
122 if (KimGroupMemberTypes.GROUP_MEMBER_TYPE.getCode().equals(listRecipient.getRecipientType())) {
123
124 String[] groupMembers = notificationRecipientService.getGroupMembers(listRecipient.getRecipientId());
125 for (int j = 0; j < groupMembers.length; j++) {
126 completeRecipientList.add(groupMembers[j]);
127 }
128 } else {
129 Principal principal = KimApiServiceLocator.getIdentityService().getPrincipalByPrincipalName(listRecipient.getRecipientId());
130 completeRecipientList.add(principal.getPrincipalId());
131 }
132 }
133
134
135 List<UserChannelSubscription> subscriptions = notification.getChannel().getSubscriptions();
136 for (UserChannelSubscription subscription: subscriptions) {
137
138
139
140 completeRecipientList.add(subscription.getUserId());
141 }
142
143 return completeRecipientList;
144 }
145
146
147
148
149
150
151
152
153
154 @Override
155 protected Collection<Object> processWorkItems(Collection<Notification> notifications) {
156 List<Object> successes = new ArrayList<Object>();
157
158
159
160 for (Notification notification: notifications) {
161
162 HashSet<String> uniqueRecipients = buildCompleteRecipientList(notification);
163
164
165 Iterator<String> j = uniqueRecipients.iterator();
166 while(j.hasNext()) {
167 String userRecipientId = j.next();
168
169 NotificationMessageDelivery defaultMessageDelivery = new NotificationMessageDelivery();
170 defaultMessageDelivery.setMessageDeliveryStatus(NotificationConstants.MESSAGE_DELIVERY_STATUS.UNDELIVERED);
171 defaultMessageDelivery.setNotification(notification);
172 defaultMessageDelivery.setUserRecipientId(userRecipientId);
173
174
175 businessObjectDao.save(defaultMessageDelivery);
176
177 try {
178 new KEWActionListMessageDeliverer().deliverMessage(defaultMessageDelivery);
179 } catch (NotificationMessageDeliveryException e) {
180 throw new RuntimeException(e);
181 }
182
183
184
185 defaultMessageDelivery.setMessageDeliveryStatus(NotificationConstants.MESSAGE_DELIVERY_STATUS.DELIVERED);
186 businessObjectDao.save(defaultMessageDelivery);
187
188 successes.add(defaultMessageDelivery);
189
190
191 notification.setProcessingFlag(NotificationConstants.PROCESSING_FLAGS.RESOLVED);
192
193 notification.setLockedDate(null);
194 businessObjectDao.save(notification);
195 }
196
197 }
198
199 return successes;
200 }
201
202
203
204
205 @Override
206 protected void unlockWorkItem(Notification notification) {
207 LOG.debug("Unlocking notification: " + notification.getId() + " " + notification.getTitle());
208 notificationService.unlockNotification(notification);
209 }
210
211
212
213
214
215
216 public ProcessingResult resolveNotificationMessageDeliveries() {
217 LOG.debug("[" + new Timestamp(System.currentTimeMillis()).toString() + "] STARTING RESOLUTION OF NOTIFICATION MESSAGE DELIVERIES");
218
219 ProcessingResult result = run();
220
221 LOG.debug("[" + new Timestamp(System.currentTimeMillis()).toString() + "] FINISHED RESOLUTION OF NOTIFICATION MESSAGE DELIVERIES - " +
222 "Message Delivery End Points Resolved = " + result.getSuccesses().size());
223
224 return result;
225 }
226 }