001 /**
002 * Copyright 2005-2014 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.actions;
017
018 import org.kuali.rice.kew.actiontaken.ActionTakenValue;
019 import org.kuali.rice.kew.api.WorkflowRuntimeException;
020 import org.kuali.rice.kew.api.exception.InvalidActionTakenException;
021 import org.kuali.rice.kew.api.exception.WorkflowException;
022 import org.kuali.rice.kew.doctype.bo.DocumentType;
023 import org.kuali.rice.kew.engine.BlanketApproveEngine;
024 import org.kuali.rice.kew.engine.OrchestrationConfig;
025 import org.kuali.rice.kew.engine.OrchestrationConfig.EngineCapability;
026 import org.kuali.rice.kew.exception.*;
027 import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue;
028 import org.kuali.rice.kew.service.KEWServiceLocator;
029 import org.kuali.rice.kew.api.KewApiConstants;
030 import org.kuali.rice.kim.api.identity.principal.PrincipalContract;
031
032
033 import java.util.ArrayList;
034 import java.util.Collections;
035 import java.util.List;
036
037
038 /**
039 * Does a node level super user approve action. All approve/complete requests outstanding for
040 * this node are satisfied by this action.
041 *
042 * @author Kuali Rice Team (rice.collab@kuali.org)
043 *
044 */
045 public class SuperUserNodeApproveEvent extends SuperUserActionTakenEvent {
046
047 private static final org.apache.log4j.Logger LOG = org.apache.log4j.Logger.getLogger(SuperUserNodeApproveEvent.class);
048 private String nodeName;
049
050 public SuperUserNodeApproveEvent(DocumentRouteHeaderValue routeHeader, PrincipalContract principal) {
051 super(KewApiConstants.ACTION_TAKEN_SU_ROUTE_LEVEL_APPROVED_CD, KewApiConstants.SUPER_USER_ROUTE_LEVEL_APPROVE, routeHeader, principal);
052 }
053
054 public SuperUserNodeApproveEvent(DocumentRouteHeaderValue routeHeader, PrincipalContract principal, String annotation, boolean runPostProcessor, String nodeName) {
055 super(KewApiConstants.ACTION_TAKEN_SU_ROUTE_LEVEL_APPROVED_CD, KewApiConstants.SUPER_USER_ROUTE_LEVEL_APPROVE, routeHeader, principal, annotation, runPostProcessor);
056 this.nodeName = nodeName;
057 }
058
059 public void recordAction() throws InvalidActionTakenException {
060
061 if (org.apache.commons.lang.StringUtils.isEmpty(nodeName)) {
062 throw new InvalidActionTakenException("No approval node name set");
063 }
064
065 DocumentType docType = getRouteHeader().getDocumentType();
066
067 String errorMessage = super.validateActionRules();
068 if (!org.apache.commons.lang.StringUtils.isEmpty(errorMessage)) {
069 LOG.info("User not authorized");
070 List<WorkflowServiceErrorImpl> errors = new ArrayList<WorkflowServiceErrorImpl>();
071 errors.add(new WorkflowServiceErrorImpl(errorMessage, SuperUserActionTakenEvent.AUTHORIZATION));
072 throw new WorkflowServiceErrorException(errorMessage, errors);
073 }
074
075 ActionTakenValue actionTaken = saveActionTaken();
076
077 notifyActionTaken(actionTaken);
078
079 if (getRouteHeader().isInException()) {
080 LOG.debug("Moving document back to Enroute from Exception");
081 String oldStatus = getRouteHeader().getDocRouteStatus();
082 getRouteHeader().markDocumentEnroute();
083 String newStatus = getRouteHeader().getDocRouteStatus();
084 notifyStatusChange(newStatus, oldStatus);
085 DocumentRouteHeaderValue routeHeaderValue = KEWServiceLocator.getRouteHeaderService().
086 saveRouteHeader(getRouteHeader());
087 setRouteHeader(routeHeaderValue);
088 }
089
090 OrchestrationConfig config = new OrchestrationConfig(EngineCapability.BLANKET_APPROVAL, Collections.singleton(nodeName), actionTaken, docType.getSuperUserApproveNotificationPolicy().getPolicyValue(), isRunPostProcessorLogic());
091 try {
092 BlanketApproveEngine blanketApproveEngine = KEWServiceLocator.getWorkflowEngineFactory().newEngine(config);
093 blanketApproveEngine.process(getRouteHeader().getDocumentId(), null);
094 } catch (Exception e) {
095 if (e instanceof RuntimeException) {
096 throw (RuntimeException)e;
097 } else {
098 throw new WorkflowRuntimeException(e.toString(), e);
099 }
100 }
101
102 //queueDocument();
103 }
104
105 protected void markDocument() throws WorkflowException {
106 // do nothing since we are overriding the entire behavior
107 }
108
109
110
111
112
113 }