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.kew.quicklinks.dao.impl;
017    
018    import org.kuali.rice.core.api.delegation.DelegationType;
019    import org.kuali.rice.core.api.util.KeyValue;
020    import org.kuali.rice.coreservice.framework.CoreFrameworkServiceLocator;
021    import org.kuali.rice.kew.api.WorkflowRuntimeException;
022    import org.kuali.rice.kew.docsearch.service.DocumentSearchService;
023    import org.kuali.rice.kew.doctype.DocumentTypePolicy;
024    import org.kuali.rice.kew.doctype.bo.DocumentType;
025    import org.kuali.rice.kew.doctype.service.DocumentTypeService;
026    import org.kuali.rice.kew.quicklinks.ActionListStats;
027    import org.kuali.rice.kew.quicklinks.InitiatedDocumentType;
028    import org.kuali.rice.kew.quicklinks.WatchedDocument;
029    import org.kuali.rice.kew.quicklinks.dao.QuickLinksDAO;
030    import org.kuali.rice.kew.service.KEWServiceLocator;
031    import org.kuali.rice.kew.api.KewApiConstants;
032    import org.kuali.rice.krad.util.KRADConstants;
033    
034    import javax.persistence.EntityManager;
035    import javax.persistence.PersistenceContext;
036    import java.util.ArrayList;
037    import java.util.Collections;
038    import java.util.List;
039    import java.util.StringTokenizer;
040    
041    public class QuickLinksDAOJpaImpl implements QuickLinksDAO {
042    
043        @PersistenceContext(unitName = "kew-unit")
044        private EntityManager entityManager;
045    
046        @Override
047            @SuppressWarnings("unchecked")
048        public List<ActionListStats> getActionListStats(final String principalId) {
049            try {
050                final List<Object[]> stats = entityManager.createNamedQuery("ActionItem.QuickLinks.FindActionListStatsByPrincipalId").setParameter("principalId", principalId).setParameter("delegationType", DelegationType
051                        .SECONDARY.getCode()).getResultList();
052                final List<ActionListStats> docTypes = new ArrayList<ActionListStats>(stats.size());
053                for (Object[] res : stats) {
054                    final String docTypeName = (String) res[0];
055                    final Long count = (Long) res[1];
056    
057                    final List<String> docTypeLabel = entityManager.createNamedQuery("DocumentType.QuickLinks.FindLabelByTypeName").setParameter("docTypeName", docTypeName).getResultList();
058                    if (docTypeLabel.size() > 0) {
059                        docTypes.add(new ActionListStats(docTypeName, docTypeLabel.get(0), count.intValue()));
060                    }
061                }
062                Collections.sort(docTypes);
063                return docTypes;
064            } catch (Exception e) {
065                throw new WorkflowRuntimeException("Error getting action list stats for user: " + principalId, e);
066            }
067        }
068    
069        @Override
070            @SuppressWarnings("unchecked")
071        public List<InitiatedDocumentType> getInitiatedDocumentTypesList(final String principalId) {
072            String documentNames = CoreFrameworkServiceLocator.getParameterService().getParameterValueAsString(KewApiConstants.KEW_NAMESPACE, KRADConstants.DetailTypes.QUICK_LINK_DETAIL_TYPE, KewApiConstants.QUICK_LINKS_RESTRICT_DOCUMENT_TYPES);
073            if (documentNames != null) {
074                documentNames = documentNames.trim();
075            }
076            if (documentNames == null || "none".equals(documentNames)) {
077                documentNames = "";
078            }
079    
080            final StringTokenizer st = new StringTokenizer(documentNames, ",");
081            final List<String> docTypesToRestrict = new ArrayList<String>();
082            while (st.hasMoreTokens()) {
083                docTypesToRestrict.add(st.nextToken());
084            }
085    
086            try {
087                final List<Object[]> list = entityManager.createNamedQuery("DocumentType.QuickLinks.FindInitiatedDocumentTypesListByInitiatorWorkflowId").setParameter("initiatorWorkflowId", principalId).getResultList();
088                final List<InitiatedDocumentType> documentTypesByName = new ArrayList<InitiatedDocumentType>(list.size());
089                for (Object[] doc : list) {
090                    final String docTypeName = (String) doc[0];
091                    final String label = (String) doc[1];
092    
093                    final String docTypeTopParent;
094                    final int firstPeriod = docTypeName.indexOf(".");
095                    if (firstPeriod == -1) {
096                        docTypeTopParent = docTypeName.substring(0);
097                    } else {
098                        docTypeTopParent = docTypeName.substring(0, firstPeriod);
099                    }
100                    if (!docTypesToRestrict.contains(docTypeTopParent)) {
101                        // the document types should be cached so this should be pretty quick
102                        final DocumentType docType = KEWServiceLocator.getDocumentTypeService().findByName(docTypeName);
103                        final DocumentTypePolicy quickInitiatePolicy = docType.getSupportsQuickInitiatePolicy();
104                        if (quickInitiatePolicy.getPolicyValue().booleanValue()) {
105                            documentTypesByName.add(new InitiatedDocumentType(docTypeName, label));
106                        }
107                    }
108                }
109                return documentTypesByName;
110            } catch (Exception e) {
111                throw new WorkflowRuntimeException("Error getting initiated document types for user: " + principalId, e);
112            }
113        }
114    
115        @Override
116            public List<KeyValue> getNamedSearches(String principalId) {
117            return getDocumentSearchService().getNamedSearches(principalId);
118        }
119    
120        @Override
121            public List<KeyValue> getRecentSearches(String principalId) {
122            return getDocumentSearchService().getMostRecentSearches(principalId);
123        }
124    
125        @Override
126            @SuppressWarnings("unchecked")
127        public List<WatchedDocument> getWatchedDocuments(final String principalId) {
128            try {
129                return entityManager.createNamedQuery("DocumentRouteHeaderValue.QuickLinks.FindWatchedDocumentsByInitiatorWorkflowId").setParameter("initiatorWorkflowId", principalId).getResultList();
130            } catch (Exception e) {
131                throw new WorkflowRuntimeException("Error getting watched documents for user: " + principalId, e);
132            }
133        }
134    
135        public DocumentTypeService getDocumentTypeService() {
136            return ((DocumentTypeService) KEWServiceLocator.getService(KEWServiceLocator.DOCUMENT_TYPE_SERVICE));
137        }
138    
139        public DocumentSearchService getDocumentSearchService() {
140            return ((DocumentSearchService) KEWServiceLocator.getService(KEWServiceLocator.DOCUMENT_SEARCH_SERVICE));
141        }
142    
143        public EntityManager getEntityManager() {
144            return this.entityManager;
145        }
146    
147        public void setEntityManager(EntityManager entityManager) {
148            this.entityManager = entityManager;
149        }
150    }