1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.kuali.rice.kew.impl.action;
17
18 import java.util.ArrayList;
19 import java.util.List;
20
21 import org.apache.commons.lang.StringUtils;
22 import org.apache.log4j.Logger;
23 import org.kuali.rice.core.api.exception.RiceIllegalArgumentException;
24 import org.kuali.rice.core.api.reflect.DataDefinition;
25 import org.kuali.rice.kew.actions.ActionTakenEvent;
26 import org.kuali.rice.kew.api.WorkflowRuntimeException;
27 import org.kuali.rice.kew.api.action.ActionInvocation;
28 import org.kuali.rice.kew.api.action.ActionInvocationQueue;
29 import org.kuali.rice.kew.api.action.ActionType;
30 import org.kuali.rice.kew.api.exception.InvalidActionTakenException;
31 import org.kuali.rice.kew.api.exception.ResourceUnavailableException;
32 import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue;
33 import org.kuali.rice.kew.service.KEWServiceLocator;
34 import org.kuali.rice.kim.api.identity.principal.Principal;
35
36
37
38
39
40
41 public class ActionInvocationQueueImpl implements ActionInvocationQueue {
42
43 private static final Logger LOG = Logger.getLogger(ActionInvocationQueueImpl.class);
44
45 @Override
46 public void invokeAction(String principalId, String documentId, ActionInvocation invocation) {
47 if (StringUtils.isBlank(principalId)) {
48 throw new RiceIllegalArgumentException("principalId is null or blank");
49 }
50
51 if (StringUtils.isBlank(documentId)) {
52 throw new RiceIllegalArgumentException("documentId is null");
53 }
54
55 if (invocation == null) {
56 throw new RiceIllegalArgumentException("invocation is null");
57 }
58
59
60 KEWServiceLocator.getRouteHeaderService().lockRouteHeader(documentId);
61 DocumentRouteHeaderValue document = KEWServiceLocator.getRouteHeaderService().getRouteHeader(documentId);
62
63 Principal principal = KEWServiceLocator.getIdentityHelperService().getPrincipal(principalId);
64 List<DataDefinition> parameters = new ArrayList<DataDefinition>();
65 parameters.add(new DataDefinition(document));
66 parameters.add(new DataDefinition(principal));
67 parameters.add(new DataDefinition(""));
68
69 try {
70 final ActionTakenEvent action = KEWServiceLocator.getActionRegistry().createAction(invocation.getAction().getCode(), parameters);
71 if (!document.isValidActionToTake(invocation.getAction().getCode())) {
72 LOG.warn("Action "
73 + invocation.getAction()
74 + " is not a valid action to take against document "
75 + document.getDocumentId()
76 + " by principal with name '"
77 + principal.getPrincipalName()
78 + "'");
79 return;
80 } else if (!KEWServiceLocator.getActionRegistry().getValidActions(principal, document).getValidActions()
81 .contains(ActionType.fromCode(action.getActionTakenCode()))) {
82 LOG.warn("Action "
83 + action.getActionTakenCode()
84 + " is not valid for document "
85 + document.getDocumentId()
86 + " by principal with name '"
87 + principal.getPrincipalName()
88 + "'");
89 return;
90 }
91 action.performAction();
92 } catch (ResourceUnavailableException e) {
93 throw new WorkflowRuntimeException(e);
94 } catch (InvalidActionTakenException e) {
95 throw new WorkflowRuntimeException(e);
96 }
97
98 }
99
100 }