001    /**
002     * Copyright 2005-2012 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        protected BusinessObjectService getBusinessObjectService() {
069            return KRADServiceLocator.getBusinessObjectService();
070        }
071    
072    }