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.kew.actionrequest.dao.impl; 017 018 import java.io.Serializable; 019 import java.sql.Timestamp; 020 import java.util.Collection; 021 import java.util.Collections; 022 import java.util.List; 023 024 import javax.persistence.EntityManager; 025 import javax.persistence.PersistenceContext; 026 import javax.persistence.Query; 027 028 import org.apache.commons.lang.StringUtils; 029 import org.kuali.rice.core.framework.persistence.jpa.OrmUtils; 030 import org.kuali.rice.kew.actionrequest.ActionRequestValue; 031 import org.kuali.rice.kew.actionrequest.dao.ActionRequestDAO; 032 import org.kuali.rice.kew.api.action.ActionRequestStatus; 033 import org.kuali.rice.kew.api.action.RecipientType; 034 import org.kuali.rice.kew.api.KewApiConstants; 035 import org.kuali.rice.kim.api.group.Group; 036 037 /** 038 * This is a description of what this class does - sgibson don't forget to fill this in. 039 * 040 * @author Kuali Rice Team (rice.collab@kuali.org) 041 */ 042 public class ActionRequestDAOJpaImpl implements ActionRequestDAO { 043 044 @PersistenceContext(name = "kew-unit") 045 private EntityManager entityManager; 046 047 /** 048 * @return the entityManager 049 */ 050 public EntityManager getEntityManager() { 051 return this.entityManager; 052 } 053 054 /** 055 * @param entityManager the entityManager to set 056 */ 057 public void setEntityManager(EntityManager entityManager) { 058 this.entityManager = entityManager; 059 } 060 061 public void delete(String actionRequestId) { 062 ActionRequestValue actionRequestValue = (ActionRequestValue) entityManager.find(ActionRequestValue.class, actionRequestId); 063 entityManager.remove(actionRequestValue); 064 } 065 066 public void deleteByDocumentId(String documentId) { 067 // FIXME should be jpa bulk update? 068 Query query = entityManager.createNamedQuery("ActionRequestValue.FindByDocumentId"); 069 query.setParameter("documentId", documentId); 070 List<ActionRequestValue> actionRequestValues = (List<ActionRequestValue>) query.getSingleResult(); 071 for(ActionRequestValue arv : actionRequestValues) { 072 entityManager.remove(arv); 073 } 074 } 075 076 public boolean doesDocumentHaveUserRequest(String principalId, String documentId) { 077 Query query = entityManager.createNamedQuery("ActionRequestValue.GetUserRequestCount"); 078 query.setParameter("principalId", principalId); 079 query.setParameter("documentId", documentId); 080 query.setParameter("recipientTypeCd", RecipientType.PRINCIPAL.getCode()); 081 query.setParameter("currentIndicator", Boolean.TRUE); 082 083 return ((Long)query.getSingleResult()) > 0; 084 } 085 086 public List<?> findActivatedByGroup(Group group) { 087 088 Query query = entityManager.createNamedQuery("ActionRequestValue.FindActivatedByGroup"); 089 query.setParameter("groupId", group.getId()); 090 query.setParameter("currentIndicator", Boolean.TRUE); 091 query.setParameter("status", ActionRequestStatus.ACTIVATED.getCode()); 092 093 return query.getResultList(); 094 } 095 096 public List<ActionRequestValue> findAllByDocId(String documentId) { 097 Query query = entityManager.createNamedQuery("ActionRequestValue.FindAllByDocId"); 098 query.setParameter("documentId", documentId); 099 query.setParameter("currentIndicator", Boolean.TRUE); 100 101 return query.getResultList(); 102 } 103 104 public List<ActionRequestValue> findAllPendingByDocId(String documentId) { 105 Query query = entityManager.createNamedQuery("ActionRequestValue.FindAllPendingByDocId"); 106 query.setParameter("documentId", documentId); 107 query.setParameter("currentIndicator", Boolean.TRUE); 108 query.setParameter("actionRequestStatus1", ActionRequestStatus.INITIALIZED.getCode()); 109 query.setParameter("actionRequestStatus2", ActionRequestStatus.ACTIVATED.getCode()); 110 111 return query.getResultList(); 112 } 113 114 @SuppressWarnings("unchecked") 115 public List<ActionRequestValue> findAllRootByDocId(String documentId) { 116 Query query = entityManager.createNamedQuery("ActionRequestValue.FindAllRootByDocId"); 117 query.setParameter("documentId", documentId); 118 query.setParameter("currentIndicator", Boolean.TRUE); 119 120 return (List<ActionRequestValue>) query.getResultList(); 121 } 122 123 public List<ActionRequestValue> findByDocumentIdIgnoreCurrentInd(String documentId) { 124 Query query = entityManager.createNamedQuery("ActionRequestValue.FindByDocumentId"); 125 query.setParameter("documentId", documentId); 126 127 return query.getResultList(); 128 } 129 130 @SuppressWarnings("unchecked") 131 public List<ActionRequestValue> findByStatusAndDocId(String statusCd, String documentId) { 132 Query query = entityManager.createNamedQuery("ActionRequestValue.FindByStatusAndDocId"); 133 query.setParameter("documentId", documentId); 134 query.setParameter("status", statusCd); 135 query.setParameter("currentIndicator", Boolean.TRUE); 136 137 return (List<ActionRequestValue>)query.getResultList(); 138 } 139 140 public List<ActionRequestValue> findPendingByActionRequestedAndDocId(String actionRequestedCd, String documentId) { 141 Query query = entityManager.createNamedQuery("ActionRequestValue.FindPendingByActionRequestedAndDocId"); 142 query.setParameter("documentId", documentId); 143 query.setParameter("currentIndicator", Boolean.TRUE); 144 query.setParameter("actionRequested", actionRequestedCd); 145 query.setParameter("actionRequestStatus1", ActionRequestStatus.INITIALIZED.getCode()); 146 query.setParameter("actionRequestStatus2", ActionRequestStatus.ACTIVATED.getCode()); 147 148 return query.getResultList(); 149 } 150 151 public List<ActionRequestValue> findPendingByDocIdAtOrBelowRouteLevel(String documentId, Integer routeLevel) { 152 Query query = entityManager.createNamedQuery("ActionRequestValue.FindPendingByDocIdAtOrBelowRouteLevel"); 153 query.setParameter("documentId", documentId); 154 query.setParameter("currentIndicator", Boolean.TRUE); 155 query.setParameter("routeLevel", routeLevel); 156 query.setParameter("status", ActionRequestStatus.DONE.getCode()); 157 158 return query.getResultList(); 159 } 160 161 public List<ActionRequestValue> findPendingByResponsibilityIds(Collection responsibilityIds) { 162 if (responsibilityIds == null || responsibilityIds.size() == 0) 163 return Collections.emptyList(); 164 165 Query query = entityManager.createNamedQuery("ActionRequestValue.FindPendingByDocIdAtOrBelowRouteLevel"); 166 query.setParameter("responsibilityIds", responsibilityIds); 167 168 return query.getResultList(); 169 } 170 171 public List<ActionRequestValue> findPendingRootRequestsByDocIdAtOrBelowRouteLevel(String documentId, Integer routeLevel) { 172 Query query = entityManager.createNamedQuery("ActionRequestValue.FindPendingRootRequestsByDocIdAtOrBelowRouteLevel"); 173 query.setParameter("documentId", documentId); 174 query.setParameter("currentIndicator", Boolean.TRUE); 175 query.setParameter("status", ActionRequestStatus.DONE.getCode()); 176 query.setParameter("routeLevel", routeLevel); 177 178 return query.getResultList(); 179 } 180 181 public List<ActionRequestValue> findPendingRootRequestsByDocIdAtRouteLevel(String documentId, Integer routeLevel) { 182 Query query = entityManager.createNamedQuery("ActionRequestValue.FindPendingRootRequestsByDocIdAtRouteLevel"); 183 query.setParameter("documentId", documentId); 184 query.setParameter("currentIndicator", Boolean.TRUE); 185 query.setParameter("status", ActionRequestStatus.DONE.getCode()); 186 query.setParameter("routeLevel", routeLevel); 187 188 return query.getResultList(); 189 } 190 191 public List<ActionRequestValue> findPendingRootRequestsByDocIdAtRouteNode(String documentId, String nodeInstanceId) { 192 Query query = entityManager.createNamedQuery("ActionRequestValue.FindPendingRootRequestsByDocIdAtRouteNode"); 193 query.setParameter("documentId", documentId); 194 query.setParameter("currentIndicator", Boolean.TRUE); 195 query.setParameter("routeNodeInstanceId", nodeInstanceId); 196 query.setParameter("actionRequestStatus1", ActionRequestStatus.INITIALIZED.getCode()); 197 query.setParameter("actionRequestStatus2", ActionRequestStatus.ACTIVATED.getCode()); 198 199 return query.getResultList(); 200 } 201 202 public List<ActionRequestValue> findPendingRootRequestsByDocumentType(String documentTypeId) { 203 Query query = entityManager.createNamedQuery("ActionRequestValue.FindPendingRootRequestsByDocumentType"); 204 query.setParameter("documentTypeId", documentTypeId); 205 query.setParameter("currentIndicator", Boolean.TRUE); 206 query.setParameter("actionRequestStatus1", ActionRequestStatus.INITIALIZED.getCode()); 207 query.setParameter("actionRequestStatus2", ActionRequestStatus.ACTIVATED.getCode()); 208 209 return query.getResultList(); 210 } 211 212 public List<ActionRequestValue> findRootRequestsByDocIdAtRouteNode(String documentId, String nodeInstanceId) { 213 Query query = entityManager.createNamedQuery("ActionRequestValue.FindRootRequestsByDocIdAtRouteNode"); 214 query.setParameter("documentId", documentId); 215 query.setParameter("currentIndicator", Boolean.TRUE); 216 query.setParameter("routeNodeInstanceId", nodeInstanceId); 217 218 return query.getResultList(); 219 } 220 221 public ActionRequestValue getActionRequestByActionRequestId(String actionRequestId) { 222 return entityManager.find(ActionRequestValue.class, actionRequestId); 223 } 224 225 @SuppressWarnings("unchecked") 226 public List<String> getRequestGroupIds(String documentId) { 227 Query query = entityManager.createNamedQuery("ActionRequestValue.GetRequestGroupIds"); 228 query.setParameter("documentId", documentId); 229 query.setParameter("currentIndicator", Boolean.TRUE); 230 query.setParameter("recipientTypeCd", RecipientType.GROUP.getCode()); 231 232 return query.getResultList(); 233 } 234 235 public void saveActionRequest(ActionRequestValue actionRequest) { 236 if ( actionRequest.getAnnotation() != null && actionRequest.getAnnotation().length() > 2000 ) { 237 actionRequest.setAnnotation( StringUtils.abbreviate(actionRequest.getAnnotation(), 2000) ); 238 } 239 if(actionRequest.getActionRequestId() == null) { 240 loadDefaultValues(actionRequest); 241 entityManager.persist(actionRequest); 242 }else{ 243 OrmUtils.merge(entityManager, actionRequest); 244 } 245 } 246 private void loadDefaultValues(ActionRequestValue actionRequest) { 247 checkNull(actionRequest.getActionRequested(), "action requested"); 248 checkNull(actionRequest.getResponsibilityId(), "responsibility ID"); 249 checkNull(actionRequest.getRouteLevel(), "route level"); 250 checkNull(actionRequest.getDocVersion(), "doc version"); 251 if (actionRequest.getForceAction() == null) { 252 actionRequest.setForceAction(Boolean.FALSE); 253 } 254 if (actionRequest.getStatus() == null) { 255 actionRequest.setStatus(ActionRequestStatus.INITIALIZED.getCode()); 256 } 257 if (actionRequest.getPriority() == null) { 258 actionRequest.setPriority(KewApiConstants.ACTION_REQUEST_DEFAULT_PRIORITY); 259 } 260 if (actionRequest.getCurrentIndicator() == null) { 261 actionRequest.setCurrentIndicator(true); 262 } 263 actionRequest.setCreateDate(new Timestamp(System.currentTimeMillis())); 264 } 265 //TODO Runtime might not be the right thing to do here... 266 private void checkNull(Serializable value, String valueName) throws RuntimeException { 267 if (value == null) { 268 throw new RuntimeException("Null value for " + valueName); 269 } 270 } 271 272 public List<ActionRequestValue> findActivatedByGroup(String groupId) { 273 Query query = entityManager.createNamedQuery("ActionRequestValue.FindByStatusAndGroupId"); 274 query.setParameter("status", ActionRequestStatus.ACTIVATED.getCode()); 275 query.setParameter("currentIndicator", Boolean.TRUE); 276 query.setParameter("groupId", groupId); 277 278 return query.getResultList(); 279 } 280 281 @Override 282 public ActionRequestValue getRoleActionRequestByActionTakenId(String actionTakenId) { 283 throw new UnsupportedOperationException("not yet implemented"); 284 } 285 }