1 /** 2 * Copyright 2005-2016 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.ksb.messaging.service; 17 18 import java.util.List; 19 import java.util.Map; 20 21 import javax.xml.namespace.QName; 22 23 import org.kuali.rice.ksb.api.bus.ServiceConfiguration; 24 import org.kuali.rice.ksb.api.messaging.AsynchronousCall; 25 import org.kuali.rice.ksb.messaging.PersistedMessageBO; 26 import org.kuali.rice.ksb.messaging.PersistedMessagePayload; 27 28 /** 29 * Service for interfacing with the queue of asynchronous messages. 30 * 31 * @see org.kuali.rice.ksb.messaging.PersistedMessageBO 32 * 33 * @author Kuali Rice Team (rice.collab@kuali.org) 34 */ 35 public interface MessageQueueService { 36 37 List<PersistedMessageBO> findByServiceName(QName serviceName, String methodName); 38 39 void delete(PersistedMessageBO routeQueue); 40 41 PersistedMessageBO save(PersistedMessageBO routeQueue); 42 43 List<PersistedMessageBO> findAll(); 44 45 List<PersistedMessageBO> findAll(int maxRows); 46 47 /** 48 * Finds the PersistedMessageBO identified by the passed-in primary key, if one is 49 * available, otherwise returns a null object. 50 * 51 * @param routeQueueId The primary key routeQueueId of the message desired. 52 * @return A populated PersistedMessageBO instance, if the routeQueueId exists, otherwise 53 * a null object. 54 */ 55 PersistedMessageBO findByRouteQueueId(Long routeQueueId); 56 57 // public List getNextDocuments(); 58 59 /** 60 * Returns a List of RouteQueue documents which are queued for routing. Will not 61 * return more RouteQueues than the value of maxDocuments. 62 */ 63 List<PersistedMessageBO> getNextDocuments(Integer maxDocuments); 64 65 PersistedMessagePayload findByPersistedMessageByRouteQueueId(Long routeQueueId); 66 67 /** 68 * Finds the persisted messages that match the values passed into the 69 * criteriaValues Map, with an auto-wildcard function, if no wildcard 70 * is passed in. 71 * 72 * @param criteriaValues A Map of Key/Value pairs, where the Key is a string holding the field 73 * name, and the Value is a string holding the value to match. 74 * @param maxRows the maximum number of rows to return from the query. If -1, then all rows will be returned. 75 * @return A populated (or empty) list containing the results of the search. If no matches are made, 76 * an empty list will be returned. 77 */ 78 List<PersistedMessageBO> findByValues(Map<String, String> criteriaValues, int maxRows); 79 80 /** 81 * Used to determine the maximum number of retries allowed by the system before the 82 * message goes into Exception. 83 * 84 * @return The max retry attempts set in the system. 85 */ 86 Integer getMaxRetryAttempts(); 87 88 }