1   
2   
3   
4   
5   
6   
7   
8   
9   
10  
11  
12  
13  
14  
15  
16  package org.kuali.rice.kew.actions;
17  
18  import org.apache.log4j.Logger;
19  import org.kuali.rice.kew.actionrequest.ActionRequestFactory;
20  import org.kuali.rice.kew.actionrequest.ActionRequestValue;
21  import org.kuali.rice.kew.actiontaken.ActionTakenValue;
22  import org.kuali.rice.kew.api.exception.InvalidActionTakenException;
23  import org.kuali.rice.kew.api.exception.WorkflowException;
24  import org.kuali.rice.kew.doctype.bo.DocumentType;
25  import org.kuali.rice.kew.engine.BlanketApproveEngine;
26  import org.kuali.rice.kew.engine.OrchestrationConfig;
27  import org.kuali.rice.kew.engine.RouteContext;
28  import org.kuali.rice.kew.engine.OrchestrationConfig.EngineCapability;
29  import org.kuali.rice.kew.engine.node.RequestsNode;
30  import org.kuali.rice.kew.exception.WorkflowServiceErrorException;
31  import org.kuali.rice.kew.exception.WorkflowServiceErrorImpl;
32  import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue;
33  import org.kuali.rice.kew.service.KEWServiceLocator;
34  import org.kuali.rice.kew.api.KewApiConstants;
35  import org.kuali.rice.kim.api.identity.principal.PrincipalContract;
36  
37  
38  import java.util.ArrayList;
39  import java.util.HashSet;
40  import java.util.List;
41  
42  
43  
44  
45  
46  
47  
48  
49  public class SuperUserApproveEvent extends SuperUserActionTakenEvent {
50  
51  	private static final Logger LOG = Logger.getLogger(SuperUserApproveEvent.class);
52  
53      public SuperUserApproveEvent(DocumentRouteHeaderValue routeHeader, PrincipalContract principal) {
54          super(KewApiConstants.ACTION_TAKEN_SU_APPROVED_CD, routeHeader, principal);
55          this.superUserAction = KewApiConstants.SUPER_USER_APPROVE;
56      }
57  
58      public SuperUserApproveEvent(DocumentRouteHeaderValue routeHeader, PrincipalContract principal, String annotation, boolean runPostProcessor) {
59          super(KewApiConstants.ACTION_TAKEN_SU_APPROVED_CD, routeHeader, principal, annotation, runPostProcessor);
60          this.superUserAction = KewApiConstants.SUPER_USER_APPROVE;
61      }
62  
63  	public void recordAction() throws InvalidActionTakenException {
64  		
65          
66  		setRouteHeader(KEWServiceLocator.getRouteHeaderService().getRouteHeader(getDocumentId(), true));
67  
68  		DocumentType docType = getRouteHeader().getDocumentType();
69  
70          String errorMessage = super.validateActionRules();
71          if (!org.apache.commons.lang.StringUtils.isEmpty(errorMessage)) {
72              LOG.info("User not authorized");
73              List<WorkflowServiceErrorImpl> errors = new ArrayList<WorkflowServiceErrorImpl>();
74              errors.add(new WorkflowServiceErrorImpl(errorMessage, AUTHORIZATION));
75              throw new WorkflowServiceErrorException(errorMessage, errors);
76          }
77  
78          ActionTakenValue actionTaken = saveActionTaken();
79  
80  	        notifyActionTaken(actionTaken);
81  
82  		if (getRouteHeader().isInException() || getRouteHeader().isStateInitiated()) {
83  			LOG.debug("Moving document back to Enroute");
84  			String oldStatus = getRouteHeader().getDocRouteStatus();
85  			getRouteHeader().markDocumentEnroute();
86  			String newStatus = getRouteHeader().getDocRouteStatus();
87  			notifyStatusChange(newStatus, oldStatus);
88  			KEWServiceLocator.getRouteHeaderService().saveRouteHeader(getRouteHeader());
89  		}
90  
91  		OrchestrationConfig config = new OrchestrationConfig(EngineCapability.BLANKET_APPROVAL, new HashSet<String>(), actionTaken, docType.getSuperUserApproveNotificationPolicy().getPolicyValue(), isRunPostProcessorLogic());
92  		RequestsNode.setSupressPolicyErrors(RouteContext.getCurrentRouteContext());
93  		try {
94  			completeAnyOutstandingCompleteApproveRequests(actionTaken, docType.getSuperUserApproveNotificationPolicy().getPolicyValue());
95  			BlanketApproveEngine blanketApproveEngine = KEWServiceLocator.getWorkflowEngineFactory().newEngine(config);
96  			blanketApproveEngine.process(getRouteHeader().getDocumentId(), null);
97  		} catch (Exception e) {
98  			LOG.error("Failed to orchestrate the document to SuperUserApproved.", e);
99  			throw new InvalidActionTakenException("Failed to orchestrate the document to SuperUserApproved.", e);
100 		}
101 
102 	}
103 
104 	@SuppressWarnings("unchecked")
105 	protected void completeAnyOutstandingCompleteApproveRequests(ActionTakenValue actionTaken, boolean sendNotifications) throws Exception {
106 		List<ActionRequestValue> actionRequests = KEWServiceLocator.getActionRequestService().findPendingByActionRequestedAndDocId(KewApiConstants.ACTION_REQUEST_APPROVE_REQ, getDocumentId());
107 		actionRequests.addAll(KEWServiceLocator.getActionRequestService().findPendingByActionRequestedAndDocId(KewApiConstants.ACTION_REQUEST_COMPLETE_REQ, getDocumentId()));
108 		for (ActionRequestValue actionRequest : actionRequests) {
109 			KEWServiceLocator.getActionRequestService().deactivateRequest(actionTaken, actionRequest);
110 		}
111 		if (sendNotifications) {
112 			new ActionRequestFactory(this.getRouteHeader()).generateNotifications(actionRequests, getPrincipal(), this.findDelegatorForActionRequests(actionRequests), KewApiConstants.ACTION_REQUEST_ACKNOWLEDGE_REQ, KewApiConstants.ACTION_TAKEN_SU_APPROVED_CD);
113 		}
114 	}
115 
116 	protected void markDocument() throws WorkflowException {
117 		
118 	}
119 }