1 /** 2 * Copyright 2005-2012 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.kew.api.action; 17 18 import java.util.List; 19 import java.util.Set; 20 21 import javax.jws.WebMethod; 22 import javax.jws.WebParam; 23 import javax.jws.WebResult; 24 import javax.jws.WebService; 25 import javax.jws.soap.SOAPBinding; 26 import javax.xml.bind.annotation.XmlElement; 27 import javax.xml.bind.annotation.XmlElementWrapper; 28 29 import org.kuali.rice.core.api.exception.RiceIllegalArgumentException; 30 import org.kuali.rice.core.api.uif.RemotableAttributeError; 31 import org.kuali.rice.kew.api.KewApiConstants; 32 import org.kuali.rice.kew.api.WorkflowDocument; 33 import org.kuali.rice.kew.api.doctype.IllegalDocumentTypeException; 34 import org.kuali.rice.kew.api.document.Document; 35 import org.kuali.rice.kew.api.document.DocumentContentUpdate; 36 import org.kuali.rice.kew.api.document.DocumentDetail; 37 import org.kuali.rice.kew.api.document.DocumentStatus; 38 import org.kuali.rice.kew.api.document.DocumentUpdate; 39 import org.kuali.rice.kew.api.document.InvalidDocumentContentException; 40 import org.kuali.rice.kew.api.document.attribute.WorkflowAttributeDefinition; 41 import org.kuali.rice.kew.api.document.WorkflowDocumentService; 42 43 /** 44 * This service defines various operations which are used to perform actions against a workflow 45 * {@link Document}. These actions include creation, routing, approval, acknowledgment, saving, 46 * updating document data, etc. 47 * 48 * <p> 49 * It also includes operations that allow for loading of information about which actions a given 50 * principal is permitted to execute against a given document ({@link ValidActions}), as well as 51 * providing information about what actions a particular principal has been requested to execute 52 * against a given document ({@link RequestedActions}). 53 * 54 * <p> 55 * This service can be used in conjunction with the {@link WorkflowDocumentService} which provides 56 * additional operations that relate to documents (but not document actions). 57 * 58 * <p> 59 * Unless otherwise specified, all parameters to all methods must not be null. If the argument is a 60 * string value it must also not be "blank" (either the empty string or a string of only 61 * whitespace). In the cases where this is violated, a {@link RiceIllegalArgumentException} will be 62 * thrown. Additionally, unless otherwise specified, all methods will return non-null return values. 63 * In the case of collections, an empty collection will be returned in preference to a null 64 * collection value. All collections which are returned from methods on this service will be 65 * unmodifiable collections. 66 * 67 * <p> 68 * Many of the actions trigger processing by the workflow engine. Unless otherwise specified, any 69 * method on this service which performs an action against the document will also submit the 70 * document to the workflow engine after performing the action. This may trigger the workflow 71 * document to transition to the next node in the workflow process or activate additional action 72 * requests depending on what the current state of the active node instance(s) is on the document. 73 * 74 * <p> 75 * Workflow engine processing may happen either asynchronously or synchronously depending on 76 * configuration and capabilities of the back end workflow engine implementation. However, 77 * asynchronous operation is suggested for most use cases. This means that when operating in 78 * asynchronous mode, after an action is submitted against the document there may be a delay in 79 * state changes to the document. For example, if a principal submits an approve against a document 80 * that triggers transition to the next node in the workflow process (generating new action requests 81 * in the process) those new actions requests will not be represented in the information returned in 82 * the {@link DocumentActionResult} result object. Though future invocations of 83 * {@link #determineRequestedActions(String, String)} and similar methods may yield such 84 * information, though it may do so after an non-deterministic amount of time since the workflow 85 * engine makes no guarantees about how quickly it will complete processing. Additionally, 86 * asynchronous workflow processing is scheduled in a work queue and therefore it may not be picked 87 * up for processing immediately depending on system load and other factors. 88 * 89 * <p> 90 * If there is an error during asynchronous workflow processing then the document will be put into 91 * exception routing (which can be executed in various ways depending on how the document type 92 * defines it's exception policy). Regardless of the exact process that gets triggered during 93 * exception routing, the end result is a set of {@link ActionRequestType#COMPLETE} requests to 94 * those principals who are capable of resolving the exception scenario as well as the document's 95 * status being transitioned to {@link DocumentStatus#EXCEPTION}. Once they have resolved any 96 * barriers to successful processing of the document, they can take the 97 * {@link #complete(DocumentActionParameters)} action against the document in order to satisfy the 98 * outstanding exception request(s) and send the document back through the workflow engine. 99 * 100 * <p> 101 * In contrast, when operating the workflow engine in synchronous mode, processing will happen 102 * immediately and control will not be returned to the caller until all outstanding processing has 103 * completed. As a result, the information returned in the {@link DocumentActionResult} will always 104 * be in a consistent state after each action is performed. When operating in synchronous mode, the 105 * process of exception routing does not occur when failures are encountered during workflow engine 106 * processing, rather any exceptions that are raised during processing will instead be thrown back 107 * to the calling code. 108 * 109 * <p> 110 * Implementations of this service are required to be thread-safe and should be able to be invoked 111 * either locally or remotely. 112 * 113 * @see WorkflowDocumentService 114 * @see WorkflowDocument 115 * 116 * @author Kuali Rice Team (rice.collab@kuali.org) 117 * 118 */ 119 @WebService(name = "workflowDocumentActionsService", targetNamespace = KewApiConstants.Namespaces.KEW_NAMESPACE_2_0) 120 @SOAPBinding(style = SOAPBinding.Style.DOCUMENT, use = SOAPBinding.Use.LITERAL, parameterStyle = SOAPBinding.ParameterStyle.WRAPPED) 121 public interface WorkflowDocumentActionsService { 122 123 /** 124 * Creates a new document instance from the given document type. The initiator of the resulting 125 * document will be the same as the initiator that is passed to this method. Optional 126 * {@link DocumentUpdate} and {@link DocumentContentUpdate} parameters can be supplied in order 127 * to create the document with these additional pieces of data already set. 128 * 129 * <p> 130 * By default, if neither the {@link DocumentUpdate} or {@link DocumentContentUpdate} is passed 131 * to this method, the document that is created and returned from this operation will have the 132 * following initial state: 133 * 134 * <ul> 135 * <ol> 136 * {@code status} set to {@link DocumentStatus#INITIATED} 137 * </ol> 138 * <ol> 139 * {@code createDate} and {@code dateLastModified} set to the current date and time 140 * </ol> 141 * <ol> 142 * {@code current} set to 'true' 143 * </ol> 144 * <ol> 145 * {@code documentContent} set to the default and empty content 146 * </ol> 147 * </ul> 148 * 149 * <p> 150 * Additionally, the initial {@link org.kuali.rice.kew.api.document.node.RouteNodeInstance} for the workflow process on the document 151 * will be created and linked to the document as it's initial node. Once the document is 152 * created, the {@link #route(DocumentActionParameters)} operation must be invoked in order to 153 * submit it to the workflow engine for initial processing. 154 * 155 * <p> 156 * In certain situations, the given principal may not be permitted to initiate documents of the 157 * given type. In these cases an {@link InvalidActionTakenException} will be thrown. 158 * 159 * @param documentTypeName the name of the document type from which to create this document 160 * @param initiatorPrincipalId the id of the principal who is initiating this document 161 * @param documentUpdate specifies additional document to set on the document upon creation, 162 * this is optional and if null is passed then the document will be created with the 163 * default document state 164 * @param documentContentUpdate defines what the initial document content for the document 165 * should be, this is optional if null is passed then the document will be created with 166 * the default empty document content 167 * 168 * @return the document that was created 169 * 170 * @throws RiceIllegalArgumentException if {@code principalId} is null or blank 171 * @throws RiceIllegalArgumentException if {@code principalId} does not identify a valid 172 * principal 173 * @throws RiceIllegalArgumentException if {@code documentTypeName} is null or blank 174 * @throws RiceIllegalArgumentException if {@code documentTypeName} does not identify an 175 * existing document type 176 * @throws IllegalDocumentTypeException if the specified document type is not active 177 * @throws IllegalDocumentTypeException if the specified document type does not support document 178 * creation (in other words, it's a document type that is only used as a parent) 179 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 180 * action 181 */ 182 @WebMethod(operationName = "create") 183 @WebResult(name = "document") 184 @XmlElement(name = "document", required = true) 185 Document create( 186 @WebParam(name = "documentTypeName") String documentTypeName, 187 @WebParam(name = "initiatorPrincipalId") String initiatorPrincipalId, 188 @WebParam(name = "documentUpdate") DocumentUpdate documentUpdate, 189 @WebParam(name = "documentContentUpdate") DocumentContentUpdate documentContentUpdate) 190 throws RiceIllegalArgumentException, IllegalDocumentTypeException, InvalidActionTakenException; 191 192 /** 193 * Determines which actions against the document with the given id are valid for the principal 194 * with the given id. 195 * 196 * @param documentId the id of the document for which to determine valid actions 197 * @param principalId the id of the principal for which to determine valid actions against the 198 * given document 199 * 200 * @return a {@link ValidActions} object which contains the valid actions for the given 201 * principal against the given document 202 * 203 * @throws RiceIllegalArgumentException if {@code documentId} is null or blank 204 * @throws RiceIllegalArgumentException if document with the given {@code documentId} does not 205 * exist 206 * @throws RiceIllegalArgumentException if {@code principalId} is null or blank 207 * @throws RiceIllegalArgumentException if principal with the given {@code principalId} does not 208 * exist 209 */ 210 @WebMethod(operationName = "determineValidActions") 211 @WebResult(name = "validActions") 212 @XmlElement(name = "validActions", required = true) 213 ValidActions determineValidActions( 214 @WebParam(name = "documentId") String documentId, 215 @WebParam(name = "principalId") String principalId) 216 throws RiceIllegalArgumentException; 217 218 /** 219 * Determines which actions are requested against the document with the given id for the 220 * principal with the given id. These are generally derived based on action requests that are 221 * currently pending against the document. 222 * 223 * <p> 224 * This method is distinguished from {@link #determineValidActions(String, String)} in that fact 225 * that valid actions are the actions that the principal is permitted to take, while requested 226 * actions are those that the principal is specifically being asked to take. Note that the 227 * actions that are requested are used when assembling valid actions but are not necessarily the 228 * only authoritative source for determination of valid actions for the principal, as 229 * permissions and other configuration can also come into play. 230 * 231 * @param documentId the id of the document for which to determine requested actions 232 * @param principalId the id of the principal for which to determine requested actions against 233 * the given document 234 * 235 * @return a {@link RequestedActions} object which contains the actions that are being requested 236 * from the given principal against the given document 237 * 238 * @throws RiceIllegalArgumentException if {@code documentId} is null or blank 239 * @throws RiceIllegalArgumentException if document with the given {@code documentId} does not 240 * exist 241 * @throws RiceIllegalArgumentException if {@code principalId} is null or blank 242 * @throws RiceIllegalArgumentException if principal with the given {@code principalId} does not 243 * exist 244 */ 245 @WebMethod(operationName = "determineRequestedActions") 246 @WebResult(name = "requestedActions") 247 @XmlElement(name = "requestedActions", required = true) 248 RequestedActions determineRequestedActions( 249 @WebParam(name = "documentId") String documentId, 250 @WebParam(name = "principalId") String principalId) 251 throws RiceIllegalArgumentException; 252 253 /** 254 * Executes an {@link ActionType#ACKNOWLEDGE} action for the given principal and document 255 * specified in the supplied parameters. When a principal acknowledges a document, any of the 256 * principal's pending action requests at or below the acknowledge level (which includes fyi 257 * requests as well) will be satisfied by the principal's action. The principal's action should 258 * be recorded with the document as an {@link ActionTaken}. 259 * 260 * <p> 261 * Depending on document type policy, a pending action request at or below the acknowledge level 262 * may have to exist on the document in order for the principal to take this action. Otherwise 263 * an {@link InvalidActionTakenException} may be thrown. In order to determine if an acknowledge 264 * action is valid, the {@link ValidActions} or {@link RequestedActions} for the document can be 265 * checked. 266 * 267 * @param parameters the parameters which indicate which principal is executing the action 268 * against which document, as well as additional operations to take against the document, 269 * such as updating document data 270 * 271 * @return the result of executing the action, including a view on the updated state of the 272 * document and related actions 273 * 274 * @throws RiceIllegalArgumentException if {@code parameters} is null 275 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 276 * {@code parameters} exists 277 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 278 * in {@code parameters} exists 279 * @throws InvalidDocumentContentException if the document content on the 280 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 281 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 282 * action 283 */ 284 @WebMethod(operationName = "acknowledge") 285 @WebResult(name = "documentActionResult") 286 @XmlElement(name = "documentActionResult", required = true) 287 DocumentActionResult acknowledge(@WebParam(name = "parameters") DocumentActionParameters parameters) 288 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 289 290 /** 291 * Executes an {@link ActionType#APPROVE} action for the given principal and document specified 292 * in the supplied parameters. When a principal approves a document, any of the principal's 293 * pending action requests at or below the approve level (which includes complete, acknowledge, 294 * and fyi requests as well) will be satisfied by the principal's action. The principal's action 295 * should be recorded with the document as an {@link ActionTaken}. 296 * 297 * <p> 298 * Depending on document type policy, a pending action request at or below the approve level may 299 * have to exist on the document in order for the principal to take this action. Otherwise an 300 * {@link InvalidActionTakenException} may be thrown. In order to determine if an approve action 301 * is valid, the {@link ValidActions} or {@link RequestedActions} for the document can be 302 * checked. 303 * 304 * @param parameters the parameters which indicate which principal is executing the action 305 * against which document, as well as additional operations to take against the document, 306 * such as updating document data 307 * 308 * @return the result of executing the action, including a view on the updated state of the 309 * document and related actions 310 * 311 * @throws RiceIllegalArgumentException if {@code parameters} is null 312 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 313 * {@code parameters} exists 314 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 315 * in {@code parameters} exists 316 * @throws InvalidDocumentContentException if the document content on the 317 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 318 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 319 * action 320 */ 321 @WebMethod(operationName = "approve") 322 @WebResult(name = "documentActionResult") 323 @XmlElement(name = "documentActionResult", required = true) 324 DocumentActionResult approve(@WebParam(name = "parameters") DocumentActionParameters parameters) 325 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 326 327 /** 328 * Executes an {@link ActionType#ADHOC_REQUEST} action for the given principal and document 329 * specified in the supplied parameters to create an ad hoc action request to the target 330 * principal specified in the {@code AdHocToPrincipal}. 331 * 332 * <p> 333 * Operates as per {@link #adHocToGroup(DocumentActionParameters, AdHocToGroup)} with the 334 * exception that this method is used to send an adhoc request to principal instead of a group. 335 * 336 * <p> 337 * Besides this difference, the same rules that are in play for sending ad hoc requests to group 338 * apply for sending ad hoc requests to principals. 339 * 340 * @param parameters the parameters which indicate which principal is executing the action 341 * against which document, as well as additional operations to take against the document, 342 * such as updating document data 343 * @param adHocToPrincipal defines various pieces of information that informs what type of ad 344 * hoc request should be created 345 * 346 * @return the result of executing the action, including a view on the updated state of the 347 * document and related actions 348 * 349 * @throws RiceIllegalArgumentException if {@code parameters} is null 350 * @throws RiceIllegalArgumentException if {@code adHocToPrincipal} is null 351 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 352 * {@code parameters} exists 353 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 354 * in {@code parameters} exists 355 * @throws InvalidDocumentContentException if the document content on the 356 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 357 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 358 * action 359 * @throws InvalidActionTakenException if the target principal is not permitted to receive ad 360 * hoc requests on documents of this type 361 * @throws InvalidActionTakenException if the specified ad hoc request cannot be generated 362 * because the current state of the document would result in an illegal request being 363 * generated 364 * 365 * @see #adHocToGroup(DocumentActionParameters, AdHocToGroup) 366 */ 367 @WebMethod(operationName = "adHocToPrincipal") 368 @WebResult(name = "documentActionResult") 369 @XmlElement(name = "documentActionResult", required = true) 370 DocumentActionResult adHocToPrincipal( 371 @WebParam(name = "parameters") DocumentActionParameters parameters, 372 @WebParam(name = "adHocToPrincipal") AdHocToPrincipal adHocToPrincipal) 373 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 374 375 /** 376 * Executes an {@link ActionType#ADHOC_REQUEST} action for the given group and document 377 * specified in the supplied parameters to create an ad hoc action request to the target group 378 * specified in the {@code AdHocToGroup}. The {@code AdHocToGroup} contains additional 379 * information on how the ad hoc action request should be created, including the type of request 380 * to generate, at which node it should generated, etc. 381 * 382 * <p> 383 * The policy for how ad hoc actions handle request generation and interact with the workflow 384 * engine is different depending on the state of the document when the request to generate the 385 * ad hoc is submitted. There are also different scenarios under which certain types of ad hoc 386 * actions are allowed to be executed (throwing {@link InvalidActionTakenException} in 387 * situations where the actions are not permitted). The rules are defined as follows: 388 * 389 * <ol> 390 * <li>If the status of the document is {@link DocumentStatus#INITIATED} then the action request 391 * will be generated with a status of {@link ActionRequestStatus#INITIALIZED} and no processing 392 * directives will be submitted to the workflow engine. When the document is routed, these ad 393 * hoc requests will get activated</li> 394 * <li>If the ad hoc request being created is an {@link ActionRequestType#COMPLETE} or 395 * {@link ActionRequestType#APPROVE} and the document is in a "terminal" state (either 396 * {@link DocumentStatus#CANCELED}, {@link DocumentStatus#DISAPPROVED}, 397 * {@link DocumentStatus#PROCESSED}, {@link DocumentStatus#FINAL}) or is in 398 * {@link DocumentStatus#EXCEPTION} status, then an {@link InvalidActionTakenException} will be 399 * thrown. This is because submitting such an action with a document in that state would result 400 * in creation of an illegal action request.</li> 401 * <li>If the document is in a "terminal" state (see above for definition) then the request will 402 * be immediately (and synchronously) activated.</li> 403 * <li>Otherwise, after creating the ad hoc request it will be in the 404 * {@link ActionRequestStatus#INITIALIZED} status, and the document will be immediately 405 * forwarded to the workflow engine for processing at which point the ad hoc request will 406 * activated at the appropriate time.</li> 407 * </ol> 408 * 409 * <p> 410 * Unlink other actions, ad hoc actions don't result in the recording of an {@link ActionTaken} 411 * against the document. Instead, only the requested ad hoc {@link ActionRequest} is created. 412 * 413 * @param parameters the parameters which indicate which principal is executing the action 414 * against which document, as well as additional operations to take against the document, 415 * such as updating document data 416 * @param adHocToGroup defines various pieces of information that informs what type of ad hoc 417 * request should be created 418 * 419 * @return the result of executing the action, including a view on the updated state of the 420 * document and related actions 421 * 422 * @throws RiceIllegalArgumentException if {@code parameters} is null 423 * @throws RiceIllegalArgumentException if {@code adHocToGroup} is null 424 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 425 * {@code parameters} exists 426 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 427 * in {@code parameters} exists 428 * @throws InvalidDocumentContentException if the document content on the 429 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 430 * @throws InvalidActionTakenException if the supplied principals i is not allowed to execute 431 * this action 432 * @throws InvalidActionTakenException if any of the principals in the target group are not 433 * permitted to receive ad hoc requests on documents of this type 434 * @throws InvalidActionTakenException if the specified ad hoc request cannot be generated 435 * because the current state of the document would result in an illegal request being 436 * generated 437 */ 438 @WebMethod(operationName = "adHocToGroup") 439 @WebResult(name = "documentActionResult") 440 @XmlElement(name = "documentActionResult", required = true) 441 DocumentActionResult adHocToGroup( 442 @WebParam(name = "parameters") DocumentActionParameters parameters, 443 @WebParam(name = "adHocToGroup") AdHocToGroup adHocToGroup) 444 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 445 446 /** 447 * Executes an {@link ActionType#ADHOC_REQUEST_REVOKE} action for the given principal and 448 * document specified in the supplied parameters against the action request with the given id. 449 * The process of revoking an ad hoc request simply deactivates the request associating the 450 * generated {@link ActionTaken} of the revoke action with the deactivated request (this allows 451 * for it to be determined what caused the ad hoc request to be deactivated). As with other 452 * actions, this action taken is then recorded with the document. 453 * 454 * @param parameters the parameters which indicate which principal is executing the action 455 * against which document, as well as additional operations to take against the document, 456 * such as updating document data 457 * @param actionRequestId the id of the action request to revoke 458 * 459 * @return the result of executing the action, including a view on the updated state of the 460 * document and related actions 461 * 462 * @throws RiceIllegalArgumentException if {@code parameters} is null 463 * @throws RiceIllegalArgumentException if {@code actionRequestId} is null or blank 464 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 465 * {@code parameters} exists 466 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 467 * in {@code parameters} exists 468 * @throws InvalidDocumentContentException if the document content on the 469 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 470 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 471 * action 472 * @throws InvalidActionTakenException if a pending ad hoc request with the given 473 * {@code actionRequestId} does not exist on the specified document, this could mean 474 * that the action request id is invalid, or that the action request has already been 475 * deactivated and is no longer pending 476 */ 477 @WebMethod(operationName = "revokeAdHocRequestById") 478 @WebResult(name = "documentActionResult") 479 @XmlElement(name = "documentActionResult", required = true) 480 DocumentActionResult revokeAdHocRequestById( 481 @WebParam(name = "parameters") DocumentActionParameters parameters, 482 @WebParam(name = "actionRequestId") String actionRequestId) 483 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 484 485 /** 486 * Executes an {@link ActionType#ADHOC_REQUEST_REVOKE} action which revokes all pending ad hoc 487 * action requests that match the supplied {@link AdHocRevoke} criteria for the given principal 488 * and document specified in the supplied parameters. The process of revoking an ad hoc requests 489 * simply deactivates all ad hoc requests that match the given {@code AdHocRevoke} criteria, 490 * associating the generated {@link ActionTaken} of the revoke action with the deactivated 491 * requests (this allows for it to be determined what caused the ad hoc request to be 492 * deactivated). As with other actions, this action taken is then recorded with the document. 493 * 494 * <p> 495 * It's possible that the given ad hoc revoke command will match no action requests on the 496 * document, in which case this method will complete successfully but no requests will be 497 * deactivated. 498 * 499 * @param parameters the parameters which indicate which principal is executing the action 500 * against which document, as well as additional operations to take against the document, 501 * such as updating document data 502 * @param revoke the criteria for matching ad hoc action requests on the specified document that 503 * should be revoked 504 * 505 * @return the result of executing the action, including a view on the updated state of the 506 * document and related actions 507 * 508 * @throws RiceIllegalArgumentException if {@code parameters} is null 509 * @throws RiceIllegalArgumentException if {@code revoke} is null 510 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 511 * {@code parameters} exists 512 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 513 * in {@code parameters} exists 514 * @throws InvalidDocumentContentException if the document content on the 515 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 516 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 517 * action 518 */ 519 @WebMethod(operationName = "revokeAdHocRequests") 520 @WebResult(name = "documentActionResult") 521 @XmlElement(name = "documentActionResult", required = true) 522 DocumentActionResult revokeAdHocRequests( 523 @WebParam(name = "parameters") DocumentActionParameters parameters, 524 @WebParam(name = "revoke") AdHocRevoke revoke) 525 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 526 527 /** 528 * Executes an {@link ActionType#ADHOC_REQUEST_REVOKE} action which revokes all pending ad hoc 529 * action requests for the given principal and document specified in the supplied parameters. 530 * This process of revoking all ad hoc requests will simply deactivate all ad hoc requests on 531 * the specified document, associating the generated {@link ActionTaken} of the revoke action 532 * with the deactivated requests (this allows for it to be determined what caused the ad hoc 533 * request to be deactivated). As with other actions, this action taken is then recorded with 534 * the document. 535 * 536 * <p> 537 * It's possible that the specified document will have no pending adhoc requests, in which case 538 * this method will complete successfully but no requests will be deactivated. 539 * 540 * @param parameters the parameters which indicate which principal is executing the action 541 * against which document, as well as additional operations to take against the document, 542 * such as updating document data 543 * 544 * @return the result of executing the action, including a view on the updated state of the 545 * document and related actions 546 * 547 * @throws RiceIllegalArgumentException if {@code parameters} is null 548 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 549 * {@code parameters} exists 550 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 551 * in {@code parameters} exists 552 * @throws InvalidDocumentContentException if the document content on the 553 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 554 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 555 * action 556 */ 557 @WebMethod(operationName = "revokeAllAdHocRequests") 558 @WebResult(name = "documentActionResult") 559 @XmlElement(name = "documentActionResult", required = true) 560 DocumentActionResult revokeAllAdHocRequests(@WebParam(name = "parameters") DocumentActionParameters parameters) 561 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 562 563 /** 564 * Executes a {@link ActionType#CANCEL} action for the given principal and document specified in 565 * the supplied parameters. When a principal cancels a document, all pending action requests on 566 * the document are deactivated and the the principal's action will be recorded on the document 567 * as an {@link ActionTaken}. Additionally, the document will be (synchronously) transitioned to 568 * the {@link DocumentStatus#CANCELED} status. 569 * 570 * <p> 571 * In order to cancel a document, the principal must have permission to cancel documents of the 572 * appropriate type, and one of the following must hold true: 573 * 574 * <ol> 575 * <li>The document must have a status of {@link DocumentStatus#INITIATED} <strong>or</strong></li> 576 * <li>The document must have a status of {@link DocumentStatus#SAVED} <strong>or</strong></li> 577 * <li>The principal must have a pending "complete" or "approve" request on the document. 578 * 579 * @param parameters the parameters which indicate which principal is executing the action 580 * against which document, as well as additional operations to take against the document, 581 * such as updating document data 582 * 583 * @return the result of executing the action, including a view on the updated state of the 584 * document and related actions 585 * 586 * @throws RiceIllegalArgumentException if {@code parameters} is null 587 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 588 * {@code parameters} exists 589 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 590 * in {@code parameters} exists 591 * @throws InvalidDocumentContentException if the document content on the 592 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 593 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 594 * action 595 */ 596 @WebMethod(operationName = "cancel") 597 @WebResult(name = "documentActionResult") 598 @XmlElement(name = "documentActionResult", required = true) 599 DocumentActionResult cancel(@WebParam(name = "parameters") DocumentActionParameters parameters) 600 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 601 602 /** 603 * Executes a {@link ActionType#RECALL} action for the given principal and document specified in 604 * the supplied parameters. When a principal cancels a document, all pending action requests on 605 * the document are deactivated and the the principal's action will be recorded on the document 606 * as an {@link ActionTaken}. Additionally, the document will be (synchronously) transitioned to 607 * the {@link DocumentStatus#RECALLED} status. 608 * 609 * TODO: FILL IN DOCS FOR RECALL ACTION 610 * <p> 611 * In order to cancel a document, the principal must have permission to cancel documents of the 612 * appropriate type, and one of the following must hold true: 613 * 614 * <ol> 615 * <li>The document must have a status of {@link DocumentStatus#INITIATED} <strong>or</strong></li> 616 * <li>The document must have a status of {@link DocumentStatus#SAVED} <strong>or</strong></li> 617 * <li>The principal must have a pending "complete" or "approve" request on the document. 618 * 619 * @since 2.1 620 * @param parameters the parameters which indicate which principal is executing the action 621 * against which document, as well as additional operations to take against the document, 622 * such as updating document data 623 * @param cancel whether to recall & cancel or recall & return to action list 624 * 625 * @return the result of executing the action, including a view on the updated state of the 626 * document and related actions 627 * 628 * @throws RiceIllegalArgumentException if {@code parameters} is null 629 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 630 * {@code parameters} exists 631 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 632 * in {@code parameters} exists 633 * @throws InvalidDocumentContentException if the document content on the 634 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 635 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 636 * action 637 */ 638 @WebMethod(operationName = "recall") 639 @WebResult(name = "documentActionResult") 640 @XmlElement(name = "documentActionResult", required = true) 641 DocumentActionResult recall(@WebParam(name = "parameters") DocumentActionParameters parameters, 642 @WebParam(name = "cancel") boolean cancel) 643 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 644 645 /** 646 * Executes an {@link ActionType#FYI} action for the given principal and document specified in 647 * the supplied parameters. When a principal clears fyis on a document, any of the principal's 648 * pending fyis will be satisfied by the principal's action. The principal's action should be 649 * recorded with the document as an {@link ActionTaken}. 650 * 651 * <p> 652 * Depending on document type policy, a pending fyi request may have to exist on the document in 653 * order for the principal to take this action. Otherwise an {@link InvalidActionTakenException} 654 * may be thrown. In order to determine if an fyi action is valid, the {@link ValidActions} or 655 * {@link RequestedActions} for the document can be checked. 656 * 657 * @param parameters the parameters which indicate which principal is executing the action 658 * against which document, as well as additional operations to take against the document, 659 * such as updating document data 660 * 661 * @return the result of executing the action, including a view on the updated state of the 662 * document and related actions 663 * 664 * @throws RiceIllegalArgumentException if {@code parameters} is null 665 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 666 * {@code parameters} exists 667 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 668 * in {@code parameters} exists 669 * @throws InvalidDocumentContentException if the document content on the 670 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 671 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 672 * action 673 */ 674 @WebMethod(operationName = "clearFyi") 675 @WebResult(name = "documentActionResult") 676 @XmlElement(name = "documentActionResult", required = true) 677 DocumentActionResult clearFyi(@WebParam(name = "parameters") DocumentActionParameters parameters) 678 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 679 680 /** 681 * Executes an {@link ActionType#COMPLETE} action for the given principal and document specified 682 * in the supplied parameters. When a principal completes a document, any of the principal's 683 * pending action requests at or below the complete level (which includes approve, acknowledge, 684 * and fyi requests as well) will be satisfied by the principal's action. The principal's action 685 * should be recorded with the document as an {@link ActionTaken}. 686 * 687 * <p> 688 * Depending on document type policy, a pending action request at or below the complete level 689 * may have to exist on the document in order for the principal to take this action. Otherwise 690 * an {@link InvalidActionTakenException} may be thrown. In order to determine if an complete 691 * action is valid, the {@link ValidActions} or {@link RequestedActions} for the document can be 692 * checked. 693 * 694 * @param parameters the parameters which indicate which principal is executing the action 695 * against which document, as well as additional operations to take against the document, 696 * such as updating document data 697 * 698 * @return the result of executing the action, including a view on the updated state of the 699 * document and related actions 700 * 701 * @throws RiceIllegalArgumentException if {@code parameters} is null 702 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 703 * {@code parameters} exists 704 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 705 * in {@code parameters} exists 706 * @throws InvalidDocumentContentException if the document content on the 707 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 708 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 709 * action 710 */ 711 @WebMethod(operationName = "complete") 712 @WebResult(name = "documentActionResult") 713 @XmlElement(name = "documentActionResult", required = true) 714 DocumentActionResult complete(@WebParam(name = "parameters") DocumentActionParameters parameters) 715 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 716 717 /** 718 * Executes a {@link ActionType#DISAPPROVE} action for the given principal and document 719 * specified in the supplied parameters. When a principal disapproves a document, all pending 720 * action requests on the document are deactivated and the the principal's action will be 721 * recorded on the document as an {@link ActionTaken}. Additionally, the document will be 722 * (synchronously) transitioned to the {@link DocumentStatus#DISAPPROVED} status. 723 * 724 * <p> 725 * Depending on document type policy and configuration, notifications may be sent to past 726 * approvers of the document. By default, an "acknowledge" request will be sent to each 727 * principal who took an "approve" or "complete" action on the document previously. 728 * 729 * <p> 730 * In order to disapprove a document, the principal must have a pending approve or complete 731 * request on the document. 732 * 733 * @param parameters the parameters which indicate which principal is executing the action 734 * against which document, as well as additional operations to take against the document, 735 * such as updating document data 736 * 737 * @return the result of executing the action, including a view on the updated state of the 738 * document and related actions 739 * 740 * @throws RiceIllegalArgumentException if {@code parameters} is null 741 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 742 * {@code parameters} exists 743 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 744 * in {@code parameters} exists 745 * @throws InvalidDocumentContentException if the document content on the 746 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 747 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 748 * action 749 */ 750 @WebMethod(operationName = "disapprove") 751 @WebResult(name = "documentActionResult") 752 @XmlElement(name = "documentActionResult", required = true) 753 DocumentActionResult disapprove(@WebParam(name = "parameters") DocumentActionParameters parameters) 754 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 755 756 /** 757 * Submits a document that is in either the "initiated" or "saved" state to the workflow engine 758 * for processing. The route action triggers the beginning of the routing process and 759 * (synchronously) switches the status of the document to {@link DocumentStatus#ENROUTE}. It 760 * then queues up a request to the workflow engine to process the document. 761 * 762 * <p> 763 * When the route action is executed, an {@link ActionType#COMPLETE} action is recorded on the 764 * document for the principal who executed the route action. At this point in time, any action 765 * requests that are currently on the document in an "initialized" state will be activated. 766 * Requests of this nature can commonly exist if ad hoc requests have been attached to the 767 * document prior to execution of the route action. 768 * 769 * <p> 770 * By default, the principal who initiated the document is the same principal who must submit 771 * the route command. However, a document type policy can be set which will relax this 772 * constraint. 773 * 774 * <p> 775 * The route action should ideally only ever be executed once for a given document. Depending on 776 * document type policy, attempting to execute a "route" action against a document which is 777 * already enroute or in a terminal state may result in an {@link InvalidActionTakenException} 778 * being thrown. 779 * 780 * @param parameters the parameters which indicate which principal is executing the action 781 * against which document, as well as additional operations to take against the document, 782 * such as updating document data 783 * 784 * @return the result of executing the action, including a view on the updated state of the 785 * document and related actions 786 * 787 * @throws RiceIllegalArgumentException if {@code parameters} is null 788 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 789 * {@code parameters} exists 790 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 791 * in {@code parameters} exists 792 * @throws InvalidDocumentContentException if the document content on the 793 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 794 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 795 * action 796 */ 797 @WebMethod(operationName = "route") 798 @WebResult(name = "documentActionResult") 799 @XmlElement(name = "documentActionResult", required = true) 800 DocumentActionResult route(@WebParam(name = "parameters") DocumentActionParameters parameters) 801 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 802 803 /** 804 * Triggers the execution of a full {@link ActionType#BLANKET_APPROVE} action for the given 805 * principal and document specified in the supplied parameters. Blanket approval will 806 * orchestrate a document from it's current node all the way to the end of the document's 807 * workflow process. During this process, it will automatically act on all "approve" and 808 * "complete" requests, effectively bypassing them. When it does this, it will notify the 809 * original recipients of these requests by routing acknowledge requests to them. 810 * 811 * <p> 812 * Blanket approve processing is handled by a special mode of the workflow engine which runs the 813 * document through it's full processing lifecycle, ensuring that it makes it's way to the end 814 * of it's route path (by bypassing any steps that would cause the process to halt, such as 815 * approval requests). Because of this nature, blanket approve processing behavior is governed 816 * by the same configuration as the rest of the workflow engine. So depending on whether the 817 * engine is configured or synchronous or asynchronous operation, the blanket approve processing 818 * will behave in the same manner. 819 * 820 * <p> 821 * In order to execute a blanket approve operation, the principal must have permissions to do 822 * so. 823 * 824 * @param parameters the parameters which indicate which principal is executing the action 825 * against which document, as well as additional operations to take against the document, 826 * such as updating document data 827 * 828 * @return the result of executing the action, including a view on the updated state of the 829 * document and related actions 830 * 831 * @throws RiceIllegalArgumentException if {@code parameters} is null 832 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 833 * {@code parameters} exists 834 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 835 * in {@code parameters} exists 836 * @throws InvalidDocumentContentException if the document content on the 837 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 838 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 839 * action 840 */ 841 @WebMethod(operationName = "blanketApprove") 842 @WebResult(name = "documentActionResult") 843 @XmlElement(name = "documentActionResult", required = true) 844 DocumentActionResult blanketApprove(@WebParam(name = "parameters") DocumentActionParameters parameters) 845 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 846 847 /** 848 * Triggers the execution of a {@link ActionType#BLANKET_APPROVE} action which orchestrates the 849 * document to the given set of node names for the given principal and document specified in the 850 * supplied parameters. This method functions the same as 851 * {@link #blanketApprove(DocumentActionParameters)} with the exception that the blanket approve 852 * process will be halted once all node names in the given set have been reached. 853 * 854 * <p> 855 * If null or an empty set is passed for {@code nodeNames} on this method, it's behavior will be 856 * equivalent to {@link #blanketApprove(DocumentActionParameters)}. 857 * 858 * @param parameters the parameters which indicate which principal is executing the action 859 * against which document, as well as additional operations to take against the document, 860 * such as updating document data 861 * @param nodeNames a set of node names to which to blanket approve the given document 862 * 863 * @return the result of executing the action, including a view on the updated state of the 864 * document and related actions 865 * 866 * @throws RiceIllegalArgumentException if {@code parameters} is null 867 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 868 * {@code parameters} exists 869 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 870 * in {@code parameters} exists 871 * @throws InvalidDocumentContentException if the document content on the 872 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 873 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 874 * action 875 */ 876 @WebMethod(operationName = "blanketApproveToNodes") 877 @WebResult(name = "documentActionResult") 878 @XmlElement(name = "documentActionResult", required = true) 879 DocumentActionResult blanketApproveToNodes( 880 @WebParam(name = "parameters") DocumentActionParameters parameters, 881 @WebParam(name = "nodeName") Set<String> nodeNames) 882 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 883 884 /** 885 * Triggers the execution of a {@link ActionType#RETURN_TO_PREVIOUS} action for the given 886 * principal and document specified in the supplied parameters. Return a document to a previous 887 * node will allow for the document to be pushed back to an earlier node in the process based on 888 * the criteria present in the {@link ReturnPoint} that is passed to this method. 889 * 890 * <p> 891 * The document is synchronously returned to the suggested return point (assuming the desired 892 * return point can be identified for the given document), and then the document will be 893 * submitted to the engine for further processing (effectively, re-establishing the flow of the 894 * document from the target return point). 895 * 896 * <p> 897 * Return the document to the first node in the document is treated as a special case and, 898 * rather then transitioning the document back to the "initiated" status, will route a 899 * "complete" request to the initiator of the document. The effectively enacts a return to the 900 * document initiator in these cases. 901 * 902 * @param parameters the parameters which indicate which principal is executing the action 903 * against which document, as well as additional operations to take against the document, 904 * such as updating document data 905 * 906 * @return the result of executing the action, including a view on the updated state of the 907 * document and related actions 908 * 909 * @throws RiceIllegalArgumentException if {@code parameters} is null 910 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 911 * {@code parameters} exists 912 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 913 * in {@code parameters} exists 914 * @throws InvalidDocumentContentException if the document content on the 915 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 916 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 917 * action 918 */ 919 @WebMethod(operationName = "returnToPreviousNode") 920 @WebResult(name = "documentActionResult") 921 @XmlElement(name = "documentActionResult", required = true) 922 DocumentActionResult returnToPreviousNode( 923 @WebParam(name = "parameters") DocumentActionParameters parameters, 924 @WebParam(name = "returnPoint") ReturnPoint returnPoint) 925 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 926 927 928 /** 929 * Triggers the execution of a {@link ActionType#MOVE} action for the given 930 * principal and document specified in the supplied parameters. Move a document to a 931 * node will allow for the document to be pushed to a different node in the process based on 932 * the criteria present in the {@link MovePoint} that is passed to this method. 933 * 934 * <p /> 935 * The document is synchronously moved to the suggested move point (assuming the desired 936 * move point can be identified for the given document), and then the document will be 937 * submitted to the engine for further processing (effectively, re-establishing the flow of the 938 * document from the target return point). 939 * 940 * 941 * @param parameters the parameters which indicate which principal is executing the action 942 * against which document, as well as additional operations to take against the document, 943 * such as updating document data 944 * @param movePoint the point to move the document 945 * 946 * @return the result of executing the action, including a view on the updated state of the 947 * document and related actions 948 * 949 * @throws RiceIllegalArgumentException if {@code parameters} is null 950 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 951 * {@code parameters} exists 952 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 953 * in {@code parameters} exists 954 * @throws InvalidDocumentContentException if the document content on the 955 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 956 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 957 * action 958 */ 959 @WebMethod(operationName = "move") 960 @WebResult(name = "documentActionResult") 961 @XmlElement(name = "documentActionResult", required = true) 962 DocumentActionResult move( 963 @WebParam(name = "parameters") DocumentActionParameters parameters, 964 @WebParam(name = "movePoint") MovePoint movePoint) 965 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 966 967 /** 968 * Triggers the execution of a {@link ActionType#TAKE_GROUP_AUTHORITY} action for the given 969 * principal and document specified in the supplied parameters. Takes authority of a group by a 970 * member of that group. 971 * 972 * @param parameters the parameters which indicate which principal is executing the action 973 * against which document, as well as additional operations to take against the document, 974 * such as updating document data 975 * @param groupId the group id to take authority of 976 * 977 * @return the result of executing the action, including a view on the updated state of the 978 * document and related actions 979 * 980 * @throws RiceIllegalArgumentException if {@code parameters} is null 981 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 982 * {@code parameters} exists 983 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 984 * in {@code parameters} exists 985 * @throws InvalidDocumentContentException if the document content on the 986 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 987 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 988 * action 989 */ 990 @WebMethod(operationName = "takeGroupAuthority") 991 @WebResult(name = "documentActionResult") 992 @XmlElement(name = "documentActionResult", required = true) 993 DocumentActionResult takeGroupAuthority( 994 @WebParam(name = "parameters") DocumentActionParameters parameters, 995 @WebParam(name = "groupId") String groupId) 996 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 997 998 /** 999 * Triggers the execution of a {@link ActionType#RELEASE_GROUP_AUTHORITY} action for the given 1000 * principal and document specified in the supplied parameters. Releases authority of a group by a 1001 * member of that group. 1002 * 1003 * @param parameters the parameters which indicate which principal is executing the action 1004 * against which document, as well as additional operations to take against the document, 1005 * such as updating document data 1006 * @param groupId the group id to take authority of 1007 * 1008 * @return the result of executing the action, including a view on the updated state of the 1009 * document and related actions 1010 * 1011 * @throws RiceIllegalArgumentException if {@code parameters} is null 1012 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1013 * {@code parameters} exists 1014 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1015 * in {@code parameters} exists 1016 * @throws InvalidDocumentContentException if the document content on the 1017 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1018 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1019 * action 1020 */ 1021 @WebMethod(operationName = "releaseGroupAuthority") 1022 @WebResult(name = "documentActionResult") 1023 @XmlElement(name = "documentActionResult", required = true) 1024 DocumentActionResult releaseGroupAuthority( 1025 @WebParam(name = "parameters") DocumentActionParameters parameters, 1026 @WebParam(name = "groupId") String groupId) 1027 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1028 1029 /** 1030 * Triggers the execution of a {@link ActionType#SAVE} action for the given 1031 * principal and document specified in the supplied parameters. Saves a document to a 1032 * at the current point. 1033 * 1034 * @param parameters the parameters which indicate which principal is executing the action 1035 * against which document, as well as additional operations to take against the document, 1036 * such as updating document data 1037 * 1038 * @return the result of executing the action, including a view on the updated state of the 1039 * document and related actions 1040 * 1041 * @throws RiceIllegalArgumentException if {@code parameters} is null 1042 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1043 * {@code parameters} exists 1044 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1045 * in {@code parameters} exists 1046 * @throws InvalidDocumentContentException if the document content on the 1047 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1048 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1049 * action 1050 */ 1051 @WebMethod(operationName = "save") 1052 @WebResult(name = "documentActionResult") 1053 @XmlElement(name = "documentActionResult", required = true) 1054 DocumentActionResult save(@WebParam(name = "parameters") DocumentActionParameters parameters) 1055 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1056 1057 /** 1058 * Triggers the execution of a {@link ActionType#SAVE} action for the given 1059 * principal and document specified in the supplied parameters. Saves the current document data for 1060 * the document. Note that passing an annotation to this will have no effect because it is not 1061 * recorded in the route log 1062 * 1063 * @param parameters the parameters which indicate which principal is executing the action 1064 * against which document, as well as additional operations to take against the document, 1065 * such as updating document data 1066 * 1067 * @return the result of executing the action, including a view on the updated state of the 1068 * document and related actions 1069 * 1070 * @throws RiceIllegalArgumentException if {@code parameters} is null 1071 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1072 * {@code parameters} exists 1073 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1074 * in {@code parameters} exists 1075 * @throws InvalidDocumentContentException if the document content on the 1076 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1077 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1078 * action 1079 */ 1080 @WebMethod(operationName = "saveDocumentData") 1081 @WebResult(name = "documentActionResult") 1082 @XmlElement(name = "documentActionResult", required = true) 1083 DocumentActionResult saveDocumentData(@WebParam(name = "parameters") DocumentActionParameters parameters) 1084 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1085 1086 /** 1087 * Deletes the document. 1088 * 1089 * @param documentId the unique id of the document to delete 1090 * @param principalId 1091 * 1092 * @return the document that was removed from the system 1093 * 1094 * @throws RiceIllegalArgumentException if {@code documentId} is null 1095 * @throws RiceIllegalArgumentException if {@code principalId} is null 1096 * @throws RiceIllegalArgumentException if no document with the {@code documentId} exists 1097 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1098 * action 1099 */ 1100 @WebMethod(operationName = "delete") 1101 @WebResult(name = "document") 1102 @XmlElement(name = "document", required = true) 1103 Document delete( 1104 @WebParam(name = "documentId") String documentId, 1105 @WebParam(name = "principalId") String principalId) 1106 throws RiceIllegalArgumentException, InvalidActionTakenException; 1107 1108 /** 1109 * Records the non-routed document action. - Checks to make sure the document status 1110 * allows the action. Records the action. 1111 * 1112 * @param documentId the unique id of the document to delete 1113 * @param principalId 1114 * 1115 * @return the document that was removed from the system 1116 * 1117 * @throws RiceIllegalArgumentException if {@code documentId} is null 1118 * @throws RiceIllegalArgumentException if {@code principalId} is null 1119 * @throws RiceIllegalArgumentException if {@code annotation} is null 1120 * @throws RiceIllegalArgumentException if no document with the {@code documentId} exists 1121 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1122 * action 1123 */ 1124 @WebMethod(operationName = "logAnnotation") 1125 void logAnnotation( 1126 @WebParam(name = "documentId") String documentId, 1127 @WebParam(name = "principalId") String principalId, 1128 @WebParam(name = "annotation") String annotation) 1129 throws RiceIllegalArgumentException, InvalidActionTakenException; 1130 1131 // TODO finish javadoc 1132 /** 1133 * 1134 * 1135 * @param documentId the unique id of the document to delete 1136 * 1137 * @throws RiceIllegalArgumentException if {@code documentId} is null 1138 */ 1139 @WebMethod(operationName = "initiateIndexing") 1140 void initiateIndexing(@WebParam(name = "documentId") String documentId) 1141 throws RiceIllegalArgumentException; 1142 1143 1144 /** 1145 * Triggers the execution of a {@link ActionType#SU_BLANKET_APPROVE} action for the given 1146 * principal and document specified in the supplied parameters. Does a blanket approve for a super user 1147 * and runs post-processing depending on {@code executePostProcessor} 1148 * 1149 * @param parameters the parameters which indicate which principal is executing the action 1150 * against which document, as well as additional operations to take against the document, 1151 * such as updating document data 1152 * @param executePostProcessor boolean value determining if the post-processor should be run or not 1153 * 1154 * @return the result of executing the action, including a view on the updated state of the 1155 * document and related actions 1156 * 1157 * @throws RiceIllegalArgumentException if {@code parameters} is null 1158 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1159 * {@code parameters} exists 1160 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1161 * in {@code parameters} exists 1162 * @throws InvalidDocumentContentException if the document content on the 1163 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1164 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1165 * action 1166 */ 1167 @WebMethod(operationName = "superUserBlanketApprove") 1168 @WebResult(name = "documentActionResult") 1169 @XmlElement(name = "documentActionResult", required = true) 1170 DocumentActionResult superUserBlanketApprove( 1171 @WebParam(name = "parameters") DocumentActionParameters parameters, 1172 @WebParam(name = "executePostProcessor") boolean executePostProcessor) 1173 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1174 1175 /** 1176 * Triggers the execution of a {@link ActionType#SU_APPROVE} action for the given 1177 * principal and document specified in the supplied parameters. Does an approve for a super user 1178 * on a node and runs post-processing depending on {@code executePostProcessor} 1179 * 1180 * @param parameters the parameters which indicate which principal is executing the action 1181 * against which document, as well as additional operations to take against the document, 1182 * such as updating document data 1183 * @param executePostProcessor boolean value determining if the post-processor should be run or not 1184 * 1185 * @return the result of executing the action, including a view on the updated state of the 1186 * document and related actions 1187 * 1188 * @throws RiceIllegalArgumentException if {@code parameters} is null 1189 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1190 * {@code parameters} exists 1191 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1192 * in {@code parameters} exists 1193 * @throws InvalidDocumentContentException if the document content on the 1194 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1195 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1196 * action 1197 */ 1198 @WebMethod(operationName = "superUserNodeApprove") 1199 @WebResult(name = "documentActionResult") 1200 @XmlElement(name = "documentActionResult", required = true) 1201 DocumentActionResult superUserNodeApprove( 1202 @WebParam(name = "parameters") DocumentActionParameters parameters, 1203 @WebParam(name = "executePostProcessor") boolean executePostProcessor, 1204 @WebParam(name = "nodeName") String nodeName) 1205 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1206 1207 /** 1208 * Triggers the execution of a {@link ActionType#SU_APPROVE} action for the given 1209 * actionRequestId and principal and document specified in the supplied parameters. Does an approve for a super user 1210 * on a node and runs post-processing depending on {@code executePostProcessor} 1211 * 1212 * @param parameters the parameters which indicate which principal is executing the action 1213 * against which document, as well as additional operations to take against the document, 1214 * such as updating document data 1215 * @param actionRequestId unique Id of an action request to take action on 1216 * @param executePostProcessor boolean value determining if the post-processor should be run or not 1217 * 1218 * @return the result of executing the action, including a view on the updated state of the 1219 * document and related actions 1220 * 1221 * @throws RiceIllegalArgumentException if {@code parameters} is null 1222 * @throws RiceIllegalArgumentException if (@code actionRequestId} 1223 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1224 * {@code parameters} exists 1225 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1226 * in {@code parameters} exists 1227 * @throws InvalidDocumentContentException if the document content on the 1228 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1229 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1230 * action 1231 */ 1232 @WebMethod(operationName = "superUserTakeRequestedAction") 1233 @WebResult(name = "documentActionResult") 1234 @XmlElement(name = "documentActionResult", required = true) 1235 DocumentActionResult superUserTakeRequestedAction( 1236 @WebParam(name = "parameters") DocumentActionParameters parameters, 1237 @WebParam(name = "executePostProcessor") boolean executePostProcessor, 1238 @WebParam(name = "actionRequestId") String actionRequestId) 1239 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1240 1241 /** 1242 * Triggers the execution of a {@link ActionType#SU_DISAPPROVE} action for the given 1243 * principal and document specified in the supplied parameters. Does a disapprove for a super user 1244 * on a node and runs post-processing depending on {@code executePostProcessor} 1245 * 1246 * @param parameters the parameters which indicate which principal is executing the action 1247 * against which document, as well as additional operations to take against the document, 1248 * such as updating document data 1249 * @param executePostProcessor boolean value determining if the post-processor should be run or not 1250 * 1251 * @return the result of executing the action, including a view on the updated state of the 1252 * document and related actions 1253 * 1254 * @throws RiceIllegalArgumentException if {@code parameters} is null 1255 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1256 * {@code parameters} exists 1257 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1258 * in {@code parameters} exists 1259 * @throws InvalidDocumentContentException if the document content on the 1260 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1261 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1262 * action 1263 */ 1264 @WebMethod(operationName = "superUserDisapprove") 1265 @WebResult(name = "documentActionResult") 1266 @XmlElement(name = "documentActionResult", required = true) 1267 DocumentActionResult superUserDisapprove( 1268 @WebParam(name = "parameters") DocumentActionParameters parameters, 1269 @WebParam(name = "executePostProcessor") boolean executePostProcessor) 1270 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1271 1272 /** 1273 * Triggers the execution of a {@link ActionType#SU_CANCEL} action for the given 1274 * principal and document specified in the supplied parameters. Does an cancel for a super user 1275 * on a node and runs post-processing depending on {@code executePostProcessor} 1276 * 1277 * @param parameters the parameters which indicate which principal is executing the action 1278 * against which document, as well as additional operations to take against the document, 1279 * such as updating document data 1280 * @param executePostProcessor boolean value determining if the post-processor should be run or not 1281 * 1282 * @return the result of executing the action, including a view on the updated state of the 1283 * document and related actions 1284 * 1285 * @throws RiceIllegalArgumentException if {@code parameters} is null 1286 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1287 * {@code parameters} exists 1288 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1289 * in {@code parameters} exists 1290 * @throws InvalidDocumentContentException if the document content on the 1291 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1292 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1293 * action 1294 */ 1295 @WebMethod(operationName = "superUserCancel") 1296 @WebResult(name = "documentActionResult") 1297 @XmlElement(name = "documentActionResult", required = true) 1298 DocumentActionResult superUserCancel( 1299 @WebParam(name = "parameters") DocumentActionParameters parameters, 1300 @WebParam(name = "executePostProcessor") boolean executePostProcessor) 1301 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1302 1303 /** 1304 * Triggers the execution of a {@link ActionType#SU_RETURN_TO_PREVIOUS} action for the given 1305 * principal and document specified in the supplied parameters. Returns the document to the 1306 * previous node for a super user on a node and runs post-processing depending on {@code executePostProcessor} 1307 * 1308 * @param parameters the parameters which indicate which principal is executing the action 1309 * against which document, as well as additional operations to take against the document, 1310 * such as updating document data 1311 * @param executePostProcessor boolean value determining if the post-processor should be run or not 1312 * @param returnPoint point to return to 1313 * 1314 * @return the result of executing the action, including a view on the updated state of the 1315 * document and related actions 1316 * 1317 * @throws RiceIllegalArgumentException if {@code parameters} is null 1318 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1319 * {@code parameters} exists 1320 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1321 * in {@code parameters} exists 1322 * @throws InvalidDocumentContentException if the document content on the 1323 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1324 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1325 * action 1326 */ 1327 @WebMethod(operationName = "superUserReturnToPreviousNode") 1328 @WebResult(name = "documentActionResult") 1329 @XmlElement(name = "documentActionResult", required = true) 1330 DocumentActionResult superUserReturnToPreviousNode( 1331 @WebParam(name = "parameters") DocumentActionParameters parameters, 1332 @WebParam(name = "executePostProcessor") boolean executePostProcessor, 1333 @WebParam(name = "returnPoint") ReturnPoint returnPoint) 1334 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1335 1336 /** 1337 * Places a document in exception routing or the given principal and document specified in the supplied parameters. 1338 * 1339 * @param parameters the parameters which indicate which principal is executing the action 1340 * against which document, as well as additional operations to take against the document, 1341 * such as updating document data 1342 * 1343 * @return the result of executing the action, including a view on the updated state of the 1344 * document and related actions 1345 * 1346 * @throws RiceIllegalArgumentException if {@code parameters} is null 1347 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1348 * {@code parameters} exists 1349 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1350 * in {@code parameters} exists 1351 * @throws InvalidDocumentContentException if the document content on the 1352 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1353 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1354 * action 1355 */ 1356 @WebMethod(operationName = "placeInExceptionRouting") 1357 @WebResult(name = "documentActionResult") 1358 @XmlElement(name = "documentActionResult", required = true) 1359 DocumentActionResult placeInExceptionRouting(@WebParam(name = "parameters") DocumentActionParameters parameters) 1360 throws RiceIllegalArgumentException, InvalidDocumentContentException, InvalidActionTakenException; 1361 1362 /** 1363 * Validates a workflow attribute definition and returns a list of validation errors 1364 * 1365 * @param definition WorkflowAttributeDefinition to validate 1366 * 1367 * @return a list of RemotableAttributeErrors caused by validation of the passed in {@code definition} 1368 * 1369 * @throws RiceIllegalArgumentException if {@code parameters} is null 1370 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1371 * {@code parameters} exists 1372 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1373 * in {@code parameters} exists 1374 * @throws InvalidDocumentContentException if the document content on the 1375 * {@link DocumentContentUpdate} supplied with the {@code parameters} is invalid. 1376 * @throws InvalidActionTakenException if the supplied principal is not allowed to execute this 1377 * action 1378 */ 1379 @WebMethod(operationName = "validateWorkflowAttributeDefinition") 1380 @WebResult(name = "validationErrors") 1381 @XmlElementWrapper(name = "validationErrors", required = true) 1382 @XmlElement(name = "validationError", required = true) 1383 List<RemotableAttributeError> validateWorkflowAttributeDefinition( 1384 @WebParam(name = "definition") WorkflowAttributeDefinition definition) 1385 throws RiceIllegalArgumentException; 1386 1387 // TODO add, annotate, and javadoc the following methods to this service 1388 /** 1389 * Determines if a passed in user exists in a document's route log or future route depending on the passed in 1390 * {@code lookFuture} value 1391 * 1392 * @param documentId unique Id of document 1393 * @param principalId unique Id of Principal to look for in document's route log 1394 * @param lookFuture boolean value determines whether or not to look at the future route log 1395 * 1396 * @return boolean value representing if a principal exists in a Document's route log 1397 * 1398 * @throws RiceIllegalArgumentException if {@code documentId} is null 1399 * @throws RiceIllegalArgumentException if {@code principalId} is null 1400 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1401 * {@code parameters} exists 1402 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1403 * in {@code parameters} exists 1404 */ 1405 @WebMethod(operationName = "isUserInRouteLog") 1406 @WebResult(name = "userInRouteLog") 1407 boolean isUserInRouteLog( 1408 @WebParam(name = "documentId") String documentId, 1409 @WebParam(name = "principalId") String principalId, 1410 @WebParam(name = "lookFuture") boolean lookFuture) 1411 throws RiceIllegalArgumentException; 1412 1413 /** 1414 * Determines if a passed in user exists in a document's route log or future route depending on the passed in 1415 * {@code lookFuture} value and {@code flattenNodes} 1416 * 1417 * @param documentId unique Id of document 1418 * @param principalId unique Id of Principal to look for in document's route log 1419 * @param lookFuture boolean value determines whether or not to look at the future route log 1420 * 1421 * @return boolean value representing if a principal exists in a Document's route log 1422 * 1423 * @throws RiceIllegalArgumentException if {@code documentId} is null 1424 * @throws RiceIllegalArgumentException if {@code principalId} is null 1425 * @throws RiceIllegalArgumentException if no document with the {@code documentId} specified in 1426 * {@code parameters} exists 1427 * @throws RiceIllegalArgumentException if no principal with the {@code principalId} specified 1428 * in {@code parameters} exists 1429 */ 1430 @WebMethod(operationName = "isUserInRouteLogWithOptionalFlattening") 1431 @WebResult(name = "userInRouteLogWithOptionalFlattening") 1432 boolean isUserInRouteLogWithOptionalFlattening( 1433 @WebParam(name = "documentId") String documentId, 1434 @WebParam(name = "principalId") String principalId, 1435 @WebParam(name = "lookFuture") boolean lookFuture, 1436 @WebParam(name = "flattenNodes") boolean flattenNodes) 1437 throws RiceIllegalArgumentException; 1438 1439 /** 1440 * Re-resolves the given role for all documents for the given document type (including children). 1441 * 1442 * @param documentTypeName documentTypeName of DocuemntType for role 1443 * @param roleName name of Role to reresolve 1444 * @param qualifiedRoleNameLabel qualified role name label 1445 * 1446 * @throws RiceIllegalArgumentException if {@code documentTypeName} is null 1447 * @throws RiceIllegalArgumentException if {@code roleName} is null 1448 * @throws RiceIllegalArgumentException if {@code qualifiedRoleNameLable} is null 1449 */ 1450 @WebMethod(operationName = "reResolveRoleByDocTypeName") 1451 void reResolveRoleByDocTypeName( 1452 @WebParam(name = "documentTypeName") String documentTypeName, 1453 @WebParam(name = "roleName") String roleName, 1454 @WebParam(name = "qualifiedRoleNameLabel") String qualifiedRoleNameLabel) 1455 throws RiceIllegalArgumentException; 1456 1457 /** 1458 * Re-resolves the given role for all documents for the given document id (including children). 1459 * 1460 * @param documentId documentId of Docuemnt for role 1461 * @param roleName name of Role to reresolve 1462 * @param qualifiedRoleNameLabel qualified role name label 1463 * 1464 * @throws RiceIllegalArgumentException if {@code documentTypeName} is null 1465 * @throws RiceIllegalArgumentException if {@code roleName} is null 1466 * @throws RiceIllegalArgumentException if {@code qualifiedRoleNameLable} is null 1467 */ 1468 @WebMethod(operationName = "reResolveRoleByDocumentId") 1469 void reResolveRoleByDocumentId( 1470 @WebParam(name = "documentId") String documentId, 1471 @WebParam(name = "roleName") String roleName, 1472 @WebParam(name = "qualifiedRoleNameLabel") String qualifiedRoleNameLabel) 1473 throws RiceIllegalArgumentException; 1474 1475 /** 1476 * Executes a simulation of a document to get all previous and future route information 1477 * 1478 * @param reportCriteria criteria for the simulation to follow 1479 * 1480 * @return DocumentDetail object representing the results of the simulation 1481 * 1482 * @throws RiceIllegalArgumentException if {@code reportCriteria} is null 1483 */ 1484 @WebMethod(operationName = "executeSimulation") 1485 @WebResult(name = "documentDetail") 1486 DocumentDetail executeSimulation( 1487 @WebParam(name = "reportCriteria") RoutingReportCriteria reportCriteria) 1488 throws RiceIllegalArgumentException; 1489 1490 /** 1491 * Determines if a passed in user is the final approver for a document 1492 * 1493 * @param documentId unique Id of the document 1494 * @param principalId unique Id of Principal to look for in document's route log 1495 * 1496 * @return boolean value representing if a principal is the final approver for a document 1497 * 1498 * @throws RiceIllegalArgumentException if {@code documentId} is null 1499 * @throws RiceIllegalArgumentException if {@code principalId} is null 1500 */ 1501 @WebMethod(operationName = "isFinalApprover") 1502 @WebResult(name = "finalApprover") 1503 boolean isFinalApprover( 1504 @WebParam(name = "documentId") String documentId, 1505 @WebParam(name = "principalId") String principalId) 1506 throws RiceIllegalArgumentException; 1507 1508 /** 1509 * Determines if a passed in user is the last approver at a specified route node 1510 * 1511 * @param documentId unique Id of the document 1512 * @param principalId unique Id of Principal to look for in document's route log 1513 * @param nodeName name of route node to determine last approver for 1514 * 1515 * @return boolean value representing if a principal is the last approver at the specified route node 1516 * 1517 * @throws RiceIllegalArgumentException if {@code documentId} is null 1518 * @throws RiceIllegalArgumentException if {@code principalId} is null 1519 * @throws RiceIllegalArgumentException if {@code nodeName} is null 1520 */ 1521 @WebMethod(operationName = "isLastApproverAtNode") 1522 @WebResult(name = "lastApproverAtNode") 1523 boolean isLastApproverAtNode( 1524 @WebParam(name = "documentId") String documentId, 1525 @WebParam(name = "principalId") String principalId, 1526 @WebParam(name = "nodeName") String nodeName) 1527 throws RiceIllegalArgumentException; 1528 1529 /** 1530 * Determines if a route node has an 'approve action' request 1531 * 1532 * @param docType document type of document 1533 * @param docContent string representing content of document 1534 * @param nodeName name of route node to determine if approve action request exists 1535 * 1536 * @return boolean value representing if a route node has an 'approve action' request 1537 * 1538 * @throws RiceIllegalArgumentException if {@code docType} is null 1539 * @throws RiceIllegalArgumentException if {@code docContent} is null 1540 * @throws RiceIllegalArgumentException if {@code nodeName} is null 1541 */ 1542 @WebMethod(operationName = "routeNodeHasApproverActionRequest") 1543 @WebResult(name = "routeNodeHasApproverActionRequest") 1544 boolean routeNodeHasApproverActionRequest( 1545 @WebParam(name = "docType") String docType, 1546 @WebParam(name = "docContent") String docContent, 1547 @WebParam(name = "nodeName") String nodeName) 1548 throws RiceIllegalArgumentException; 1549 1550 /** 1551 * Determines if a document has at least one action request 1552 * 1553 * @param reportCriteria criteria for routing report 1554 * @param actionRequestedCodes list of action request codes to see if they exist for the document 1555 * @param ignoreCurrentActionRequests boolean value to determine if current action requests should be ignored 1556 * 1557 * @return boolean value representing if a document will have at least one action request 1558 * 1559 * @throws RiceIllegalArgumentException if {@code docType} is null 1560 * @throws RiceIllegalArgumentException if {@code docContent} is null 1561 * @throws RiceIllegalArgumentException if {@code nodeName} is null 1562 */ 1563 @WebMethod(operationName = "documentWillHaveAtLeastOneActionRequest") 1564 @WebResult(name = "documentWillHaveAtLeastOneActionRequest") 1565 boolean documentWillHaveAtLeastOneActionRequest( 1566 @WebParam(name = "reportCriteria") RoutingReportCriteria reportCriteria, 1567 @WebParam(name = "actionRequestedCodes") List<String> actionRequestedCodes, 1568 @WebParam(name = "ignoreCurrentActionRequests") boolean ignoreCurrentActionRequests) 1569 throws RiceIllegalArgumentException; 1570 1571 /** 1572 * Returns a list of principal Ids that exist in a route log 1573 * 1574 * @param documentId unique id of the document to get the route log for 1575 * @param lookFuture boolean value that determines if the method should look at future action requests 1576 * 1577 * @return list of principal ids that exist in a route log 1578 * 1579 * @throws RiceIllegalArgumentException if {@code documentId} is null 1580 */ 1581 @WebMethod(operationName = "getPrincipalIdsInRouteLog") 1582 @WebResult(name = "principalIds") 1583 @XmlElementWrapper(name = "principalIds", required = true) 1584 @XmlElement(name = "principalId", required = true) 1585 List<String> getPrincipalIdsInRouteLog( 1586 @WebParam(name = "documentId") String documentId, 1587 @WebParam(name = "lookFuture") boolean lookFuture) 1588 throws RiceIllegalArgumentException; 1589 1590 }