View Javadoc
1   /**
2    * Copyright 2005-2015 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.krad.service;
17  
18  import java.util.List;
19  import java.util.Map;
20  import java.util.Properties;
21  
22  import org.kuali.rice.krad.bo.BusinessObject;
23  import org.kuali.rice.krad.bo.ExternalizableBusinessObject;
24  import org.kuali.rice.krad.bo.ModuleConfiguration;
25  import org.kuali.rice.krad.datadictionary.BusinessObjectEntry;
26  import org.springframework.beans.factory.InitializingBean;
27  import org.springframework.context.ApplicationContextAware;
28  
29  /**
30   * Defines service methods for module services
31   *
32   * @author Kuali Rice Team (rice.collab@kuali.org)
33   */
34  public interface ModuleService extends InitializingBean, ApplicationContextAware {
35  
36      /**
37       * This method returns the module configuration.
38       *
39       * @return module configuration
40       */
41      public ModuleConfiguration getModuleConfiguration();
42  
43      /**
44       * This method determines whether this service is responsible for the business object class passed in, or not.
45       *
46       * @param businessObjectClass
47       * @return true if this module is responsible for the business object
48       */
49      public boolean isResponsibleFor(Class businessObjectClass);
50  
51      /**
52       * This method returns the list of primary keys for the EBO.
53       *
54       * @param businessObjectInterfaceClass
55       * @return list of primary key field names
56       */
57      public List listPrimaryKeyFieldNames(Class businessObjectInterfaceClass);
58  
59      /**
60       * This method returns a list of alternate primary keys.  This is used when the "real" primary
61       * key is not the only one that can be used.  For example, documentType has "documentTypeId"
62       * as its primary key, but the "name" could also be used.
63       * A List of Lists is returned because because there can be component keys:
64       * Ex:
65       * {name, date}
66       * {department, personId}
67       *
68       * @param businessObjectInterfaceClass
69       * @return List of List of Strings.
70       */
71      public List<List<String>> listAlternatePrimaryKeyFieldNames(Class businessObjectInterfaceClass);
72  
73      /**
74       * This method gets the business object dictionary entry for the passed in externalizable business object class.
75       *
76       * @param businessObjectInterfaceClass
77       * @return business object
78       */
79      public BusinessObjectEntry getExternalizableBusinessObjectDictionaryEntry(Class businessObjectInterfaceClass);
80  
81      /**
82       * This method gets the externalizable business object, given its type and a map of primary keys and values
83       *
84       * @param businessObjectClass
85       * @param fieldValues
86       * @return business object
87       */
88      public <T extends ExternalizableBusinessObject> T getExternalizableBusinessObject(Class<T> businessObjectClass,
89              Map<String, Object> fieldValues);
90  
91      /**
92       * This method gets the list of externalizable business objects, given its type and a map of primary keys and
93       * values.
94       *
95       * @param businessObjectClass
96       * @param fieldValues
97       * @return list of business objects
98       */
99      public <T extends ExternalizableBusinessObject> List<T> getExternalizableBusinessObjectsList(
100             Class<T> businessObjectClass, Map<String, Object> fieldValues);
101 
102     /**
103      * This method gets the list of externalizable business objects for lookup, given its type and a map of primary keys
104      * and values.
105      *
106      * @param <T>
107      * @param businessObjectClass
108      * @param fieldValues
109      * @param unbounded
110      * @return list of business objects
111      */
112     public <T extends ExternalizableBusinessObject> List<T> getExternalizableBusinessObjectsListForLookup(
113             Class<T> businessObjectClass, Map<String, Object> fieldValues, boolean unbounded);
114 
115     /**
116      * Returns a URL so that the inquiry framework may redirect a user to the appropriate (possibly
117      * external) website at which to view inquiry information
118      *
119      * @param inquiryDataObjectClass - a {@link ExternalizableBusinessObject} managed by this module
120      * @param parameters - any inquiry parameters, and the primary key values of the inquiry class would be
121      * in here
122      * @return String URL where externalizable object information may be viewed
123      */
124     public String getExternalizableDataObjectInquiryUrl(Class<?> inquiryDataObjectClass, Properties parameters);
125 
126     /**
127      * Returns a URL so that the lookup framework may redirect a user to the appropriate (possibly
128      * external) website at which to the data for the object may be searched
129      *
130      * @param inquiryDataObjectClass - a {@link ExternalizableBusinessObject} managed by this module
131      * @param parameters - any parameters for the lookup call
132      * @return String URL where externalizable object information may be searched
133      */
134     public String getExternalizableDataObjectLookupUrl(Class<?> inquiryDataObjectClass, Properties parameters);
135 
136     /**
137      * This method returns a URL so that the inquiry framework may redirect a user to the appropriate (possibly
138      * external) website
139      * at which to view inquiry information.
140      *
141      * @param inquiryBusinessObjectClass a {@link ExternalizableBusinessObject} managed by this module
142      * @param parameters any inquiry parameters, and the primary key values of the inquiryBusinessObjectClass would be
143      * in here
144      * @return a URL where externalizable business object information may be viewed.
145      * @deprecated legacy KNS call, replaced by {@link #getExternalizableDataObjectInquiryUrl(Class, java.util.Properties)}
146      * in KRAD
147      */
148     @Deprecated
149     public String getExternalizableBusinessObjectInquiryUrl(Class inquiryBusinessObjectClass,
150             Map<String, String[]> parameters);
151 
152     /**
153      * This method gets the lookup url for the given externalizable business object properties.
154      *
155      * @param parameters
156      * @return lookup url
157      * @deprecated legacy KNS call, replaced by {@link #getExternalizableDataObjectLookupUrl(Class, java.util.Properties)}
158      * in KRAD
159      */
160     @Deprecated
161     public String getExternalizableBusinessObjectLookupUrl(Class inquiryBusinessObjectClass,
162             Map<String, String> parameters);
163 
164     /**
165      * This method retrieves the externalizable business object, if it is not already populated
166      * with the matching primary key values.
167      *
168      * @param businessObject
169      * @param currentInstanceExternalizableBO
170      * @param externalizableRelationshipName
171      * @return business object
172      */
173     public <T extends ExternalizableBusinessObject> T retrieveExternalizableBusinessObjectIfNecessary(
174             BusinessObject businessObject, T currentInstanceExternalizableBO, String externalizableRelationshipName);
175 
176     /**
177      * This method retrieves a list of externalizable business objects given a business object,
178      * name of the relationship between the business object and the externalizable business object, and
179      * the externalizable business object class.
180      *
181      * @param businessObject
182      * @param externalizableRelationshipName
183      * @param externalizableClazz
184      * @return list of externalizable business objects
185      */
186     public <T extends ExternalizableBusinessObject> List<T> retrieveExternalizableBusinessObjectsList(
187             BusinessObject businessObject, String externalizableRelationshipName, Class<T> externalizableClazz);
188 
189     /**
190      * This method determines whether or not a bo class is externalizable.
191      *
192      * @param boClass
193      * @return true if the class is externalizable
194      */
195     public boolean isExternalizable(Class boClass);
196 
197     /**
198      * @param boClass
199      * @return true if the class is lookupable and externalizable
200      */
201     public boolean isExternalizableBusinessObjectLookupable(Class boClass);
202 
203     /**
204      * @param boClass
205      * @return true if the class is inquirable and externalizable
206      */
207     public boolean isExternalizableBusinessObjectInquirable(Class boClass);
208 
209     /**
210      * @param <T> business object type
211      * @param boClass business object class
212      * @return business object
213      */
214     public <T extends ExternalizableBusinessObject> T createNewObjectFromExternalizableClass(Class<T> boClass);
215 
216     /**
217      * For a given ExternalizableBusinessObject interface, return the implementation class provided by this module.
218      */
219     public <E extends ExternalizableBusinessObject> Class<E> getExternalizableBusinessObjectImplementation(
220             Class<E> externalizableBusinessObjectInterface);
221 
222     /**
223      * This method determines whether or not this module is currently locked
224      */
225     public boolean isLocked();
226 
227     /**
228      * This method determines whether or not the central rice server should be used for lookups.
229      *
230      * @return true if the central rice server should be used for lookups
231      */
232     public boolean goToCentralRiceForInquiry();
233 }
234