1 /**
2 * Copyright 2005-2016 The Kuali Foundation
3 *
4 * Licensed under the Educational Community License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.opensource.org/licenses/ecl2.php
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16 package org.kuali.rice.krms.impl.repository;
17
18 import java.util.List;
19
20 import org.kuali.rice.krms.api.repository.action.ActionDefinition;
21 import org.kuali.rice.krms.api.repository.agenda.AgendaDefinition;
22 import org.kuali.rice.krms.api.repository.rule.RuleDefinition;
23 import org.springframework.cache.annotation.CacheEvict;
24 import org.springframework.cache.annotation.Cacheable;
25
26 /**
27 * This is the interface for accessing KRMS repository Action related
28 * business objects.
29 *
30 * @author Kuali Rice Team (rice.collab@kuali.org)
31 *
32 */
33 public interface ActionBoService {
34
35 /**
36 * This will create a {@link ActionDefinition} exactly like the parameter passed in.
37 *
38 * @param action The Action to create
39 * @throws IllegalArgumentException if the action is null
40 * @throws IllegalStateException if the action already exists in the system
41 */
42 @CacheEvict(value={ActionDefinition.Cache.NAME, RuleDefinition.Cache.NAME}, allEntries = true)
43 public ActionDefinition createAction(ActionDefinition action);
44
45 /**
46 * This will update an existing {@link ActionDefinition}.
47 *
48 * @param action The Action to update
49 * @throws IllegalArgumentException if the Action is null
50 * @throws IllegalStateException if the Action does not exists in the system
51 */
52 @CacheEvict(value={ActionDefinition.Cache.NAME, RuleDefinition.Cache.NAME}, allEntries = true)
53 public ActionDefinition updateAction(ActionDefinition action);
54
55 /**
56 * Retrieves an Action from the repository based on the given action id.
57 *
58 * @param actionId the id of the Action to retrieve
59 * @return an {@link ActionDefinition} identified by the given actionId.
60 * A null reference is returned if an invalid or non-existent id is supplied.
61 * @throws IllegalArgumentException if the actionId is null or blank.
62 */
63 @Cacheable(value= ActionDefinition.Cache.NAME, key="'actionId=' + #p0")
64 public ActionDefinition getActionByActionId(String actionId);
65
66 /**
67 * Retrieves an Action from the repository based on the provided action name
68 * and namespace.
69 *
70 * @param name the name of the Action to retrieve.
71 * @param namespace the namespace that the action is under.
72 * @return an {@link ActionDefinition} identified by the given name and namespace.
73 * A null reference is returned if an invalid or non-existent name and
74 * namespace combination is supplied.
75 * @throws IllegalArgumentException if the either the name or the namespace
76 * is null or blank.
77 */
78 @Cacheable(value= ActionDefinition.Cache.NAME, key="'name=' + #p0 + '|' + 'namespace=' + #p1")
79 public ActionDefinition getActionByNameAndNamespace(String name, String namespace);
80
81 /**
82 * Retrieves an ordered List of Actions associated with a
83 * {@link org.kuali.rice.krms.api.repository.rule.RuleDefinition}.
84 * The order of the list is determined by the sequenceNumber property
85 * of the Actions.
86 *
87 * @param ruleId the id of the rule
88 * @return a list of {@link ActionDefinition} associated with the given rule.
89 * A null reference is returned if an invalid or ruleId is supplied.
90 * @throws IllegalArgumentException if the ruleId is null or blank.
91 */
92 @Cacheable(value= ActionDefinition.Cache.NAME, key="'ruleId=' + #p0")
93 public List<ActionDefinition> getActionsByRuleId(String ruleId);
94
95 /**
96 * Retrieves an specific Action associated with a Rule.
97 *
98 * @param ruleId the id of the rule
99 * @param sequenceNumber an Integer that represents the sequence number of the action.
100 * @return an {@link ActionDefinition} identified associated with the
101 * Rule and identified by the given sequenceNumber
102 * A null reference is returned if an invalid or non-existent name and
103 * namespace combination is supplied.
104 * @throws IllegalArgumentException if the ruleId is null or blank. Or
105 * if the sequenceNumber is null.
106 */
107 @Cacheable(value= ActionDefinition.Cache.NAME, key="'ruleId=' + #p0 + '|' + 'sequenceNumber=' + #p1")
108 public ActionDefinition getActionByRuleIdAndSequenceNumber(String ruleId, Integer sequenceNumber);
109
110 // public ActionAttribute createActionAttribute(ActionAttribute actionAttribute);
111 // public void updateActionAttribute(ActionAttribute actionAttribute);
112
113 }