View Javadoc

1   /*
2    * Copyright 2007 The Kuali Foundation
3    * 
4    * Licensed under the Educational Community License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    * 
8    * http://www.opensource.org/licenses/ecl2.php
9    * 
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  package org.kuali.rice.ken.service;
17  
18  import java.io.IOException;
19  import java.util.Collection;
20  
21  import org.kuali.rice.ken.bo.Notification;
22  import org.kuali.rice.ken.bo.NotificationResponse;
23  import org.kuali.rice.ken.exception.InvalidXMLException;
24  
25  /**
26   * The NotificationService class is responsible for processing notification messages 
27   * that come into the system.  It also is able to retrieve notifications that have 
28   * already been entered/processed by the system.
29   * 
30   * @author Kuali Rice Team (rice.collab@kuali.org)
31   */
32  public interface NotificationService {
33      /**
34       * This method allows consumers to send notification messages.  This particular service 
35       * accepts the XML format of the notification and then marshals it out into the actual 
36       * business object construct, for further processing.  The response is also sent back as 
37       * a String of XML.
38       * @param notificationMessageAsXml
39       * @return NotificationResponse response object
40       */
41      public NotificationResponse sendNotification(String notificationMessageAsXml) throws IOException, InvalidXMLException;
42      
43      /**
44       * This method allows consumers to send notification messages.  This particular service 
45       * accepts the actual business object.
46       * @param notification
47       * @return NotificationResponse
48       */
49      public NotificationResponse sendNotification(Notification notification);
50      
51      /**
52       * This method will retrieve a Notification object from the system, given the id of the 
53       * actual notification record.
54       * @param id
55       * @return Notification
56       */
57      public Notification getNotification(Long id);
58      
59      /**
60       * This method will retrieve a collection of notifications given a contentTypeName and recipientId.
61       * @param contentTypeName the name of the content type
62       * @param recipientId the recipient id
63       * @return Collection of notifications
64       */
65      public Collection<Notification> getNotificationsForRecipientByType(String contentTypeName, String recipientId);
66      
67      /**
68       * This method will "dismiss"/remove a NotificationMessageDelivery with the specified cause.
69       * @param id the id of the NotificationMessageDelivery that was acted upon
70       * @param user the user or entity that performed the dismissal
71       * @param cause the cause of the dismissal (e.g. an end user action or auto-removal by the system)
72       */
73      public void dismissNotificationMessageDelivery(Long id, String user, String cause);
74      
75      
76      /**
77       * This method is responsible for atomically finding all untaken, unresolved notifications that are ready to be sent,
78       * marking them as taken and returning them to the caller for processing.
79       * NOTE: it is important that this method execute in a SEPARATE dedicated transaction; either the caller should
80       * NOT be wrapped by Spring declarative transaction and this service should be wrapped (which is the case), or
81       * the caller should arrange to invoke this from within a newly created transaction).
82       * @return a list of notifications to be resolved that have been marked as taken by the caller
83       */
84      public Collection<Notification> takeNotificationsForResolution();
85      
86      /**
87       * Unlocks specified notification
88       * @param notification the notification object to unlock
89       */
90      public void unlockNotification(Notification notification);
91  }