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.krad.service; 17 18 import org.kuali.rice.krad.maintenance.MaintenanceDocument; 19 import org.kuali.rice.krad.maintenance.MaintenanceLock; 20 import org.kuali.rice.krad.maintenance.Maintainable; 21 22 import java.util.List; 23 import java.util.Map; 24 25 /** 26 * Provides methods for working with {@link org.kuali.rice.krad.maintenance.MaintenanceDocument}. 27 * 28 * @author Kuali Rice Team (rice.collab@kuali.org) 29 */ 30 public interface MaintenanceDocumentService { 31 32 /** 33 * Prepares the <code>MaintenanceDocument</code> on initial request. 34 * 35 * <p>This includes retrieving the data object for edit or copy, clearing fields</p> 36 * 37 * @param objectClassName class name for the object being maintained 38 * @param docTypeName workflow doc type for the maintenance document requested 39 * @param maintenanceAction indicates whether this is a new, copy, or edit maintenance action 40 * @return MaintenanceDocument prepared document instance 41 */ 42 MaintenanceDocument setupNewMaintenanceDocument( 43 String objectClassName, String docTypeName, String maintenanceAction); 44 45 /** 46 * Called to setup the object being maintained. 47 * 48 * <p>For edit and copy actions, the old record is retrieved and prepared for 49 * editing (in the case of a copy some fields are cleared). In addition some 50 * authorization checks are performed and hooks for custom 51 * <code>Maintainble</code> implementations are invoked.</p> 52 * 53 * @param document document instance for the maintenance object 54 * @param maintenanceAction the requested maintenance action (new, new with existing, 55 * copy, edit) 56 * @param requestParameters Map of parameters from the request 57 */ 58 void setupMaintenanceObject(MaintenanceDocument document, String maintenanceAction, 59 Map<String, String[]> requestParameters); 60 61 /** 62 * Attempts to find any other active documents that are pending on the same 63 * maintenance record. 64 * 65 * <p>If any are pending and locked, thereby blocking this document, then the 66 * docHeaderId/documentNumber of the blocking locked document is returned. 67 * Otherwise, if nothing is blocking, then null is returned.</p> 68 * 69 * @param document document to test 70 * @return A String representing the docHeaderId of any blocking document, 71 * or null if none are blocking 72 * 73 */ 74 String getLockingDocumentId(MaintenanceDocument document); 75 76 /** 77 * Attempts to find any other active documents that are pending on the same 78 * maintenance record. 79 * 80 * <p>If any are pending and locked, thereby blocking this document, then the 81 * docHeaderId/documentNumber of the blocking locked document is returned. * 82 * Otherwise, if nothing is blocking, then null is returned.</p> 83 * 84 * @param maintainable maintainable representing the document to test 85 * @param documentNumber the documentNumber/docHeaderId of the document to test 86 * @return A String representing the docHeaderId of any blocking document, 87 * or null if none are blocking 88 */ 89 String getLockingDocumentId(Maintainable maintainable, 90 String documentNumber); 91 92 /** 93 * Call the same-named method in the Dao, since the service has access to 94 * the Dao, but the caller doesn't. 95 * 96 * <p>This method deletes the locks for the given document number. It is called 97 * when the document is final, thus it can be unlocked, or when the locks 98 * need to be regenerated (thus they get cleared first).</p> 99 * 100 * @param documentNumber document number whose locks should be deleted 101 */ 102 void deleteLocks(String documentNumber); 103 104 /** 105 * Call the same-named method in the Dao, since the service has access to 106 * the Dao, but the caller doesn't. 107 * 108 * <p>This method stores the given list of maintenance locks. Typically these 109 * will all be for the same document.</p> 110 * 111 * @param maintenanceLocks the list of maintenance locks to be stored 112 */ 113 void storeLocks(List<MaintenanceLock> maintenanceLocks); 114 115 }