001 /**
002 * Copyright 2005-2013 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016 package org.kuali.rice.krad.service.impl;
017
018 import org.kuali.rice.kim.api.group.Group;
019 import org.kuali.rice.kim.api.services.KimApiServiceLocator;
020 import org.kuali.rice.krad.bo.AdHocRoutePerson;
021 import org.kuali.rice.krad.bo.AdHocRouteWorkgroup;
022 import org.kuali.rice.krad.document.Document;
023 import org.kuali.rice.krad.service.BusinessObjectService;
024 import org.kuali.rice.krad.service.DocumentAdHocService;
025 import org.kuali.rice.krad.service.KRADServiceLocator;
026
027 import java.util.HashMap;
028 import java.util.List;
029
030 /**
031 * Implementation for {@link DocumentAdHocService}
032 *
033 * @author Kuali Rice Team (rice.collab@kuali.org)
034 *
035 */
036 public class DocumentAdHocServiceImpl implements DocumentAdHocService {
037
038 /**
039 * {@inheritDoc}
040 */
041 public void addAdHocs(Document document) {
042 /* Instead of reading the doc header to see if doc is in saved status
043 * its probably easier and faster to just do this all the time and
044 * store a null when appropriate.
045 */
046 List<AdHocRoutePerson> adHocRoutePersons;
047 List<AdHocRouteWorkgroup> adHocRouteWorkgroups;
048 HashMap criteriaPerson = new HashMap();
049 HashMap criteriaWorkgroup = new HashMap();
050
051 criteriaPerson.put("documentNumber", document.getDocumentNumber());
052 criteriaPerson.put("type", AdHocRoutePerson.PERSON_TYPE);
053 adHocRoutePersons = (List) getBusinessObjectService().findMatching(AdHocRoutePerson.class, criteriaPerson);
054 criteriaWorkgroup.put("documentNumber", document.getDocumentNumber());
055 criteriaWorkgroup.put("type", AdHocRouteWorkgroup.WORKGROUP_TYPE);
056 adHocRouteWorkgroups = (List) getBusinessObjectService().findMatching(AdHocRouteWorkgroup.class, criteriaWorkgroup);
057
058 //populate group namespace and names on adHocRoutWorkgroups
059 for (AdHocRouteWorkgroup adHocRouteWorkgroup : adHocRouteWorkgroups) {
060 Group group = KimApiServiceLocator.getGroupService().getGroup(adHocRouteWorkgroup.getId());
061 adHocRouteWorkgroup.setRecipientName(group.getName());
062 adHocRouteWorkgroup.setRecipientNamespaceCode(group.getNamespaceCode());
063 }
064 document.setAdHocRoutePersons(adHocRoutePersons);
065 document.setAdHocRouteWorkgroups(adHocRouteWorkgroups);
066 }
067
068 /**
069 * gets the {@link BusinessObjectService} from {@code KRADServiceLocator}
070 * @return
071 */
072 protected BusinessObjectService getBusinessObjectService() {
073 return KRADServiceLocator.getBusinessObjectService();
074 }
075
076 }