Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
AtpService |
|
| 1.0;1 |
1 | /** | |
2 | * Copyright 2010 The Kuali Foundation Licensed under the | |
3 | * Educational Community License, Version 2.0 (the "License"); you may | |
4 | * not use this file except in compliance with the License. You may | |
5 | * obtain a copy of the License at | |
6 | * | |
7 | * http://www.osedu.org/licenses/ECL-2.0 | |
8 | * | |
9 | * Unless required by applicable law or agreed to in writing, | |
10 | * software distributed under the License is distributed on an "AS IS" | |
11 | * BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express | |
12 | * or implied. See the License for the specific language governing | |
13 | * permissions and limitations under the License. | |
14 | */ | |
15 | ||
16 | package org.kuali.student.core.atp.service; | |
17 | ||
18 | import java.util.Date; | |
19 | import java.util.List; | |
20 | ||
21 | import javax.jws.WebParam; | |
22 | import javax.jws.WebService; | |
23 | import javax.jws.soap.SOAPBinding; | |
24 | ||
25 | import org.kuali.student.core.atp.dto.AtpDurationTypeInfo; | |
26 | import org.kuali.student.core.atp.dto.AtpInfo; | |
27 | import org.kuali.student.core.atp.dto.AtpSeasonalTypeInfo; | |
28 | import org.kuali.student.core.atp.dto.AtpTypeInfo; | |
29 | import org.kuali.student.core.atp.dto.DateRangeInfo; | |
30 | import org.kuali.student.core.atp.dto.DateRangeTypeInfo; | |
31 | import org.kuali.student.core.atp.dto.MilestoneInfo; | |
32 | import org.kuali.student.core.atp.dto.MilestoneTypeInfo; | |
33 | import org.kuali.student.core.dictionary.service.DictionaryService; | |
34 | import org.kuali.student.core.dto.StatusInfo; | |
35 | import org.kuali.student.core.exceptions.AlreadyExistsException; | |
36 | import org.kuali.student.core.exceptions.DataValidationErrorException; | |
37 | import org.kuali.student.core.exceptions.DoesNotExistException; | |
38 | import org.kuali.student.core.exceptions.InvalidParameterException; | |
39 | import org.kuali.student.core.exceptions.MissingParameterException; | |
40 | import org.kuali.student.core.exceptions.OperationFailedException; | |
41 | import org.kuali.student.core.exceptions.PermissionDeniedException; | |
42 | import org.kuali.student.core.exceptions.VersionMismatchException; | |
43 | import org.kuali.student.core.search.service.SearchService; | |
44 | import org.kuali.student.core.validation.dto.ValidationResultInfo; | |
45 | ||
46 | ||
47 | /** | |
48 | * <b>Academic Time Period Service Description and Assumptions</b> | |
49 | * <p>This service supports the management of Academic Time Periods and their associated Date Ranges and Milestones. The intent is to provide a flexible but structured way to define the various time frames that are used throughout the definition, offering and scheduling of Learning Units. This is a catalogue service with basic operations.</p> | |
50 | * | |
51 | */ | |
52 | @WebService(name = "AtpService", targetNamespace = "http://student.kuali.org/wsdl/atp") | |
53 | @SOAPBinding(style = SOAPBinding.Style.DOCUMENT, use = SOAPBinding.Use.LITERAL, parameterStyle = SOAPBinding.ParameterStyle.WRAPPED) | |
54 | public interface AtpService extends SearchService, DictionaryService { | |
55 | /** | |
56 | * Retrieves the list of academic time period types known by this service | |
57 | * @return list of academic time period types | |
58 | * @throws OperationFailedException unable to complete request | |
59 | */ | |
60 | public List<AtpTypeInfo> getAtpTypes() throws OperationFailedException; | |
61 | ||
62 | /** | |
63 | * Retrieves information about a particular academic time period type | |
64 | * @param atpTypeKey academic time period type identifier | |
65 | * @return academic time period type information | |
66 | * @throws DoesNotExistException specified atp type not found | |
67 | * @throws InvalidParameterException invalid atpTypeKey | |
68 | * @throws MissingParameterException atpTypeKey not specified | |
69 | * @throws OperationFailedException unable to complete request | |
70 | */ | |
71 | public AtpTypeInfo getAtpType(@WebParam(name="atpTypeKey")String atpTypeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
72 | ||
73 | /** | |
74 | * Retrieves the list of Academic Time Period Seasonal Types known by this service | |
75 | * @return List of academic time period seasonal types | |
76 | * @throws OperationFailedException unable to complete request | |
77 | */ | |
78 | public List<AtpSeasonalTypeInfo> getAtpSeasonalTypes() throws OperationFailedException; | |
79 | ||
80 | /** | |
81 | * Retrieves information about a particular academic time period seasonal type | |
82 | * @param atpSeasonalTypeKey academic time period seasonal type identifier | |
83 | * @return academic time period seasonal type information | |
84 | * @throws DoesNotExistException specified atp seasonal type not found | |
85 | * @throws InvalidParameterException invalid atpSeasonalTypeKey | |
86 | * @throws MissingParameterException atpSeasonalTypeKey not specified | |
87 | * @throws OperationFailedException unable to complete request | |
88 | */ | |
89 | public AtpSeasonalTypeInfo getAtpSeasonalType(@WebParam(name="atpSeasonalTypeKey")String atpSeasonalTypeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
90 | ||
91 | /** | |
92 | * Retrieves the list of Academic Time Period Duration Types known by this service | |
93 | * @return List of academic time period duration types | |
94 | * @throws OperationFailedException unable to complete request | |
95 | */ | |
96 | public List<AtpDurationTypeInfo> getAtpDurationTypes() throws OperationFailedException; | |
97 | ||
98 | /** | |
99 | * Retrieves information about a particular academic time period duration type | |
100 | * @param atpDurationTypeKey academic time period duration type identifier | |
101 | * @return academic time period duration type information | |
102 | * @throws DoesNotExistException specified atp duration type not found | |
103 | * @throws InvalidParameterException invalid atpDurationTypeKey | |
104 | * @throws MissingParameterException atpDurationTypeKey not specified | |
105 | * @throws OperationFailedException unable to complete request | |
106 | */ | |
107 | public AtpDurationTypeInfo getAtpDurationType(@WebParam(name="atpDurationTypeKey")String atpDurationTypeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
108 | ||
109 | /** | |
110 | * Retrieves the list of milestone types known by this service | |
111 | * @return List of milestone types | |
112 | * @throws OperationFailedException unable to complete request | |
113 | */ | |
114 | public List<MilestoneTypeInfo> getMilestoneTypes() throws OperationFailedException; | |
115 | ||
116 | /** | |
117 | * Retrieves information about a particular milestone type | |
118 | * @param milestoneTypeKey milestone type identifier | |
119 | * @return milestone type information | |
120 | * @throws DoesNotExistException specified milestone type not found | |
121 | * @throws InvalidParameterException invalid milestoneTypeKey | |
122 | * @throws MissingParameterException milestoneTypeKey not specified | |
123 | * @throws OperationFailedException unable to complete request | |
124 | */ | |
125 | public MilestoneTypeInfo getMilestoneType(@WebParam(name="milestoneTypeKey")String milestoneTypeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
126 | ||
127 | /** | |
128 | * Retrieves the list of milestone types that are defined for a particular Atp Type | |
129 | * @param atpTypeKey atpTypeKey | |
130 | * @return List of milestone types | |
131 | * @throws DoesNotExistException specified atpTypeKey not found | |
132 | * @throws InvalidParameterException invalid atpTypeKey | |
133 | * @throws MissingParameterException atpTypeKey not specified | |
134 | * @throws OperationFailedException unable to complete request | |
135 | */ | |
136 | public List<MilestoneTypeInfo> getMilestoneTypesForAtpType(@WebParam(name="atpTypeKey")String atpTypeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
137 | ||
138 | /** | |
139 | * Retrieves the list of date range types known by this service | |
140 | * @return List of date range types | |
141 | * @throws OperationFailedException unable to complete request | |
142 | */ | |
143 | public List<DateRangeTypeInfo> getDateRangeTypes() throws OperationFailedException; | |
144 | ||
145 | /** | |
146 | * Retrieves information about a particular date range type | |
147 | * @param dateRangeTypeKey date range type identifier | |
148 | * @return date range type information | |
149 | * @throws DoesNotExistException specified date range type not found | |
150 | * @throws InvalidParameterException invalid dateRangeTypeKey | |
151 | * @throws MissingParameterException dateRangeTypeKey not specified | |
152 | * @throws OperationFailedException unable to complete request | |
153 | */ | |
154 | public DateRangeTypeInfo getDateRangeType(@WebParam(name="dateRangeTypeKey")String dateRangeTypeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
155 | ||
156 | /** | |
157 | * Retrieves the list of dateRange types that are defined for a particular Atp Type | |
158 | * @param atpTypeKey atpTypeKey | |
159 | * @return List of milestone types | |
160 | * @throws DoesNotExistException specified atpTypeKey not found | |
161 | * @throws InvalidParameterException invalid atpTypeKey | |
162 | * @throws MissingParameterException atpTypeKey not specified | |
163 | * @throws OperationFailedException unable to complete request | |
164 | */ | |
165 | public List<DateRangeTypeInfo> getDateRangeTypesForAtpType(@WebParam(name="atpTypeKey")String atpTypeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
166 | ||
167 | /** | |
168 | * Validates an academic time period. Depending on the value of validationType, this validation could be limited to tests on just the current object and its directly contained subobjects or expanded to perform all tests related to this object. If an identifier is present for the academic time period and a record is found for that identifier, the validation checks if the academic time period can be shifted to the new values. If a record cannot be found for the identifier, it is assumed that the record does not exist and as such, the checks performed will be much shallower, typically mimicking those performed by setting the validationType to the current object. This is a slightly different pattern from the standard validation as the caller provides the identifier in the create statement instead of the server assigning an identifier. | |
169 | * @param validationType Identifier of the extent of validation | |
170 | * @param atpInfo The academic time period information to be tested. | |
171 | * @return Results from performing the validation | |
172 | * @throws DoesNotExistException validationTypeKey not found | |
173 | * @throws InvalidParameterException invalid validationTypeKey, atpInfo | |
174 | * @throws MissingParameterException missing validationTypeKey, atpInfo | |
175 | * @throws OperationFailedException unable to complete request | |
176 | */ | |
177 | public List<ValidationResultInfo> validateAtp(@WebParam(name="validationType")String validationType, @WebParam(name="atpInfo")AtpInfo atpInfo) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
178 | ||
179 | /** | |
180 | * Validates a milestone. Depending on the value of validationType, this validation could be limited to tests on just the current object and its directly contained subobjects or expanded to perform all tests related to this object. If an identifier is present for the milestone and a record is found for that identifier, the validation checks if the milestone can be shifted to the new values. If a record cannot be found for the identifier, it is assumed that the record does not exist and as such, the checks performed will be much shallower, typically mimicking those performed by setting the validationType to the current object. This is a slightly different pattern from the standard validation as the caller provides the identifier in the create statement instead of the server assigning an identifier. | |
181 | * @param validationType Identifier of the extent of validation | |
182 | * @param milestoneInfo The milestone information to be tested. | |
183 | * @return Results from performing the validation | |
184 | * @throws DoesNotExistException validationTypeKey not found | |
185 | * @throws InvalidParameterException invalid validationTypeKey, milestoneInfo | |
186 | * @throws MissingParameterException missing validationTypeKey, milestoneInfo | |
187 | * @throws OperationFailedException unable to complete request | |
188 | */ | |
189 | public List<ValidationResultInfo> validateMilestone(@WebParam(name="validationType")String validationType, @WebParam(name="milestoneInfo")MilestoneInfo milestoneInfo) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
190 | ||
191 | /** | |
192 | * Validates a date range. Depending on the value of validationType, this validation could be limited to tests on just the current object and its directly contained subobjects or expanded to perform all tests related to this object. If an identifier is present for the date range and a record is found for that identifier, the validation checks if the academic time period can be shifted to the new values. If a record cannot be found for the identifier, it is assumed that the record does not exist and as such, the checks performed will be much shallower, typically mimicking those performed by setting the validationType to the current object. This is a slightly different pattern from the standard validation as the caller provides the identifier in the create statement instead of the server assigning an identifier. | |
193 | * @param validationType Identifier of the extent of validation | |
194 | * @param dateRangeInfo The date range information to be tested. | |
195 | * @return Results from performing the validation | |
196 | * @throws DoesNotExistException validationTypeKey not found | |
197 | * @throws InvalidParameterException invalid validationTypeKey, dateRangeInfo | |
198 | * @throws MissingParameterException missing validationTypeKey, dateRangeInfo | |
199 | * @throws OperationFailedException unable to complete request | |
200 | */ | |
201 | public List<ValidationResultInfo> validateDateRange(@WebParam(name="validationType")String validationType, @WebParam(name="dateRangeInfo")DateRangeInfo dateRangeInfo) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
202 | ||
203 | /** | |
204 | * Retrieves the details of a single Academic Time Period by atpKey | |
205 | * @param atpKey Unique key of the Academic Time Period to be retrieved | |
206 | * @return Details of the Academic Time Period requested | |
207 | * @throws DoesNotExistException atpKey not found | |
208 | * @throws InvalidParameterException invalid atpKey | |
209 | * @throws MissingParameterException invalid atpKey | |
210 | * @throws OperationFailedException unable to complete request | |
211 | */ | |
212 | public AtpInfo getAtp(@WebParam(name="atpKey")String atpKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
213 | ||
214 | /** | |
215 | * Retrieves the list of Academic Time Periods that the supplied date falls within | |
216 | * @param searchDate Timestamp to be matched | |
217 | * @return List of Academic Time Periods that contain the supplied searchDate | |
218 | * @throws InvalidParameterException invalid searchDate | |
219 | * @throws MissingParameterException invalid searchDate | |
220 | * @throws OperationFailedException unable to complete request | |
221 | */ | |
222 | public List<AtpInfo> getAtpsByDate(@WebParam(name="searchDate")Date searchDate) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
223 | ||
224 | /** | |
225 | * Retrieves the list of Academic Time Periods that are totally contained within the supplied dates. The entire Atp falls within the supplied dates | |
226 | * @param startDate Earliest Timestamp | |
227 | * @param endDate Latest Timestamp | |
228 | * @return List of Academic Time Periods that contain the supplied searchDate | |
229 | * @throws InvalidParameterException invalid searchDate | |
230 | * @throws MissingParameterException invalid searchDate | |
231 | * @throws OperationFailedException unable to complete request | |
232 | */ | |
233 | public List<AtpInfo> getAtpsByDates(@WebParam(name="startDate")Date startDate, @WebParam(name="endDate")Date endDate) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
234 | ||
235 | /** | |
236 | * Retrieves a list of Academic Time Periods of the specified type | |
237 | * @param atpTypeKey ATP type to be retrieved | |
238 | * @return List of Academic Time Periods that contain the supplied date | |
239 | * @throws InvalidParameterException invalid atpTypeKey | |
240 | * @throws MissingParameterException invalid atpTypeKey | |
241 | * @throws OperationFailedException unable to complete request | |
242 | */ | |
243 | public List<AtpInfo> getAtpsByAtpType(@WebParam(name="atpTypeKey")String atpTypeKey) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
244 | ||
245 | /** | |
246 | * Retrieves the details of the specified milestone | |
247 | * @param milestoneKey Unique id of the milestone to be retrieved | |
248 | * @return Details of requested milestone | |
249 | * @throws DoesNotExistException milestoneKey not found | |
250 | * @throws InvalidParameterException invalid milestoneKey | |
251 | * @throws MissingParameterException invalid milestoneKey | |
252 | * @throws OperationFailedException unable to complete request | |
253 | */ | |
254 | public MilestoneInfo getMilestone(@WebParam(name="milestoneKey")String milestoneKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
255 | ||
256 | /** | |
257 | * Retrieves the list of milestones for a specified Academic Time Period | |
258 | * @param atpKey Unique key of the Academic Time Period to be retieved | |
259 | * @return List of milestones for this Academic Time Period | |
260 | * @throws InvalidParameterException invalid atpKey | |
261 | * @throws MissingParameterException invalid atpKey | |
262 | * @throws OperationFailedException unable to complete request | |
263 | */ | |
264 | public List<MilestoneInfo> getMilestonesByAtp(@WebParam(name="atpKey")String atpKey) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
265 | ||
266 | /** | |
267 | * Retrieves the list of milestones that fall within a specified set of dates | |
268 | * @param startDate Start Date for date span | |
269 | * @param endDate End Date for date span | |
270 | * @return List of milestones that fall within this set of dates | |
271 | * @throws InvalidParameterException One or more parameters invalid | |
272 | * @throws MissingParameterException One or more parameter(s) missing | |
273 | * @throws OperationFailedException unable to complete request | |
274 | */ | |
275 | public List<MilestoneInfo> getMilestonesByDates(@WebParam(name="startDate")Date startDate, @WebParam(name="endDate")Date endDate) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
276 | ||
277 | /** | |
278 | * Retrieves a list of milestones of a specified type that fall within a specified set of dates | |
279 | * @param milestoneTypeKey Milestone type to be retrieved | |
280 | * @param startDate Start Date for date range | |
281 | * @param endDate End Date for date range | |
282 | * @return List of milestones of this milestone type within this set of dates | |
283 | * @throws InvalidParameterException One or more parameters invalid | |
284 | * @throws MissingParameterException One or more parameters missing | |
285 | * @throws OperationFailedException unable to complete request | |
286 | */ | |
287 | public List<MilestoneInfo> getMilestonesByDatesAndType(@WebParam(name="milestoneTypeKey")String milestoneTypeKey, @WebParam(name="startDate")Date startDate, @WebParam(name="endDate")Date endDate) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
288 | ||
289 | /** | |
290 | * Retrieves the details of the specified daterange | |
291 | * @param dateRangeKey Unique id of the date range to be retrieved | |
292 | * @return Details of requested daterange | |
293 | * @throws DoesNotExistException dateRangeKey not found | |
294 | * @throws InvalidParameterException invalid dateRangeKey | |
295 | * @throws MissingParameterException missing dateRangeKey | |
296 | * @throws OperationFailedException unable to complete request | |
297 | */ | |
298 | public DateRangeInfo getDateRange(@WebParam(name="dateRangeKey")String dateRangeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException; | |
299 | ||
300 | /** | |
301 | * Retrieves the list of DateRanges for a specified Academic Time Period | |
302 | * @param atpKey Unique key of the Academic Time Period to be retieved | |
303 | * @return List of dateRanges for this Academic Time Period | |
304 | * @throws InvalidParameterException invalid atpKey | |
305 | * @throws MissingParameterException invalid atpKey | |
306 | * @throws OperationFailedException unable to complete request | |
307 | */ | |
308 | public List<DateRangeInfo> getDateRangesByAtp(@WebParam(name="atpKey")String atpKey) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
309 | ||
310 | /** | |
311 | * Retrieves the list of DateRanges which encompass the specified date | |
312 | * @param searchDate Timestamp to be matched | |
313 | * @return List of dateRanges that contain the supplied searchDate | |
314 | * @throws InvalidParameterException invalid searchDate | |
315 | * @throws MissingParameterException invalid searchDate | |
316 | * @throws OperationFailedException unable to complete request | |
317 | */ | |
318 | public List<DateRangeInfo> getDateRangesByDate(@WebParam(name="searchDate")Date searchDate) throws InvalidParameterException, MissingParameterException, OperationFailedException; | |
319 | ||
320 | /** | |
321 | * Creates a new Academic Time Period | |
322 | * @param atpTypeKey Type of ATP to be created | |
323 | * @param atpKey Key of ATP to be created | |
324 | * @param atpInfo Details of ATP to be created | |
325 | * @return Details of ATP just created | |
326 | * @throws AlreadyExistsException ATP being created already exists | |
327 | * @throws DataValidationErrorException One or more values invalid for this operation | |
328 | * @throws InvalidParameterException One or more parameters invalid | |
329 | * @throws MissingParameterException One or more parameters missing | |
330 | * @throws OperationFailedException unable to complete request | |
331 | * @throws PermissionDeniedException authorization failure | |
332 | */ | |
333 | public AtpInfo createAtp(@WebParam(name="atpTypeKey")String atpTypeKey, @WebParam(name="atpKey")String atpKey, @WebParam(name="atpInfo")AtpInfo atpInfo) throws AlreadyExistsException, DataValidationErrorException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException; | |
334 | ||
335 | /** | |
336 | * Updates an existing Academic Time Period | |
337 | * @param atpKey Key of ATP to be updated | |
338 | * @param atpInfo Details of updates to ATP being updated | |
339 | * @return Details of ATP just updated | |
340 | * @throws DataValidationErrorException One or more values invalid for this operation | |
341 | * @throws DoesNotExistException ATP being updated does not exist | |
342 | * @throws InvalidParameterException One or more parameters invalid | |
343 | * @throws MissingParameterException One or more parameters missing | |
344 | * @throws OperationFailedException unable to complete request | |
345 | * @throws PermissionDeniedException authorization failure | |
346 | * @throws VersionMismatchException The action was attempted on an out of date version. | |
347 | */ | |
348 | public AtpInfo updateAtp(@WebParam(name="atpKey")String atpKey, @WebParam(name="atpInfo")AtpInfo atpInfo) throws DataValidationErrorException, DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException, VersionMismatchException; | |
349 | ||
350 | /** | |
351 | * Deletes an existing Academic Time Period | |
352 | * @param atpKey Key of ATP to be deleted | |
353 | * @return status of the operation (success, failed) | |
354 | * @throws DoesNotExistException ATP being deleted does not exist | |
355 | * @throws InvalidParameterException One or more parameters invalid | |
356 | * @throws MissingParameterException One or more parameters missing | |
357 | * @throws OperationFailedException unable to complete request | |
358 | * @throws PermissionDeniedException authorization failure | |
359 | */ | |
360 | public StatusInfo deleteAtp(@WebParam(name="atpKey")String atpKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException; | |
361 | ||
362 | /** | |
363 | * Add a new milestone to an existing Academic Time Period | |
364 | * @param atpKey Key of ATP to be updated | |
365 | * @param milestoneKey Id of milestone to be added | |
366 | * @param milestoneInfo Details of milestone to be added | |
367 | * @return Details of the newly created milestone | |
368 | * @throws AlreadyExistsException Milestone being added already exists | |
369 | * @throws DataValidationErrorException One or more values invalid for this operation | |
370 | * @throws InvalidParameterException One or more parameters invalid | |
371 | * @throws MissingParameterException One or more parameters missing | |
372 | * @throws OperationFailedException unable to complete request | |
373 | * @throws PermissionDeniedException authorization failure | |
374 | */ | |
375 | public MilestoneInfo addMilestone(@WebParam(name="atpKey")String atpKey, @WebParam(name="milestoneKey")String milestoneKey, @WebParam(name="milestoneInfo")MilestoneInfo milestoneInfo) throws AlreadyExistsException, DataValidationErrorException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException; | |
376 | ||
377 | /** | |
378 | * Updates an existing milestone. | |
379 | * @param milestoneKey ID of milestone to be updated | |
380 | * @param milestoneInfo Details of milestone to be updated | |
381 | * @return Details of the updated milestone | |
382 | * @throws DataValidationErrorException One or more values invalid for this operation | |
383 | * @throws DoesNotExistException Milestone being updated does not exist | |
384 | * @throws InvalidParameterException One or more parameters invalid | |
385 | * @throws MissingParameterException One or more parameters missing | |
386 | * @throws OperationFailedException unable to complete request | |
387 | * @throws PermissionDeniedException authorization failure | |
388 | * @throws VersionMismatchException The action was attempted on an out of date version. | |
389 | */ | |
390 | public MilestoneInfo updateMilestone(@WebParam(name="milestoneKey")String milestoneKey, @WebParam(name="milestoneInfo")MilestoneInfo milestoneInfo) throws DataValidationErrorException, DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException, VersionMismatchException; | |
391 | ||
392 | /** | |
393 | * Removes an existing milestone. | |
394 | * @param milestoneKey Id of milestone to be removed | |
395 | * @return Status of the operation (success, failed) | |
396 | * @throws DoesNotExistException Milestone being removed does not exist | |
397 | * @throws InvalidParameterException One or more parameters invalid | |
398 | * @throws MissingParameterException One or more parameters missing | |
399 | * @throws OperationFailedException unable to complete request | |
400 | * @throws PermissionDeniedException authorization failure | |
401 | */ | |
402 | public StatusInfo removeMilestone(@WebParam(name="milestoneKey")String milestoneKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException; | |
403 | ||
404 | /** | |
405 | * Adds a new dateRange to an existing Academic Time Period | |
406 | * @param atpKey key of the ATP to be associated with the dateRange | |
407 | * @param dateRangeKey identifier of the dateRange to be added | |
408 | * @param dateRangeInfo details of the dateRange to be added | |
409 | * @return details of the newly created dateRange | |
410 | * @throws AlreadyExistsException dateRange being added already exists | |
411 | * @throws DataValidationErrorException one or more values invalid for this operation | |
412 | * @throws InvalidParameterException one or more parameters invalid | |
413 | * @throws MissingParameterException one or more parameters missing | |
414 | * @throws OperationFailedException unable to complete request | |
415 | * @throws PermissionDeniedException authorization failure | |
416 | */ | |
417 | public DateRangeInfo addDateRange(@WebParam(name="atpKey")String atpKey, @WebParam(name="dateRangeKey")String dateRangeKey, @WebParam(name="dateRangeInfo")DateRangeInfo dateRangeInfo) throws AlreadyExistsException, DataValidationErrorException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException; | |
418 | ||
419 | /** | |
420 | * Updates an existing daterange | |
421 | * @param dateRangeKey identifier of daterange to be updated | |
422 | * @param dateRangeInfo details of daterange to be updated | |
423 | * @return details of the updated dateRange | |
424 | * @throws DataValidationErrorException One or more values invalid for this operation | |
425 | * @throws DoesNotExistException dateRange being updated does not exist | |
426 | * @throws InvalidParameterException one or more parameters invalid | |
427 | * @throws MissingParameterException one or more parameters missing | |
428 | * @throws OperationFailedException unable to complete request | |
429 | * @throws PermissionDeniedException authorization failure | |
430 | * @throws VersionMismatchException action was attempted on an out of date version. | |
431 | */ | |
432 | public DateRangeInfo updateDateRange(@WebParam(name="dateRangeKey")String dateRangeKey, @WebParam(name="dateRangeInfo")DateRangeInfo dateRangeInfo) throws DataValidationErrorException, DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException, VersionMismatchException; | |
433 | ||
434 | /** | |
435 | * Removes an existing daterange. | |
436 | * @param dateRangeKey key of daterange to be removed | |
437 | * @return status of the operation (success, failed) | |
438 | * @throws DoesNotExistException DateRange being removed does not exist | |
439 | * @throws InvalidParameterException One or more parameters invalid | |
440 | * @throws MissingParameterException One or more parameters missing | |
441 | * @throws OperationFailedException unable to complete request | |
442 | * @throws PermissionDeniedException authorization failure | |
443 | */ | |
444 | public StatusInfo removeDateRange(@WebParam(name="dateRangeKey")String dateRangeKey) throws DoesNotExistException, InvalidParameterException, MissingParameterException, OperationFailedException, PermissionDeniedException; | |
445 | ||
446 | } |