View Javadoc

1   /**
2    *
3    * Copyright 2003-2004 The Apache Software Foundation
4    *
5    *  Licensed under the Apache License, Version 2.0 (the "License");
6    *  you may not use this file except in compliance with the License.
7    *  You may obtain a copy of the License at
8    *
9    *     http://www.apache.org/licenses/LICENSE-2.0
10   *
11   *  Unless required by applicable law or agreed to in writing, software
12   *  distributed under the License is distributed on an "AS IS" BASIS,
13   *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   *  See the License for the specific language governing permissions and
15   *  limitations under the License.
16   */
17  
18  package org.apache.geronimo.interceptor;
19  
20  /**
21   * The result of an Invocation.
22   * There are two types of result:
23   * <ul>
24   * <li>normal - indicating the operation completed normally (e.g. the method returned)</li>
25   * <li>exception - indicating the operation completed abnormally (e.g. the method threw a checked exception)</li>
26   * </ul>
27   * <p>Note that these should both be considered a normal completion of the operation by the container. Abnormal
28   * completions, such as a RuntimeException or Error from the invocation, or any problem in the interceptor
29   * chain itself, should result in a Throwable being thrown up the chain rather than being contained in this
30   * result.</p>
31   * <p>This distinction mirrors the semantics for EJB invocations, where a business method is considered to have
32   * completed successfuly even if it throws declared Exception - the Exception there is indicating a business level
33   * issue and not a system problem.</p>
34   *
35   * @version $Rev: 417891 $ $Date: 2006-06-28 15:45:07 -0700 (Wed, 28 Jun 2006) $
36   */
37  public interface InvocationResult {
38      /**
39       * Was this a normal completion (return)?
40       * @return true if the invocation returned; false if a declared exception was thrown
41       */
42      boolean isNormal();
43  
44      /**
45       * Get the return value from the invocation.
46       * It is an error to call this method if the invocation is not complete normally.
47       * @return the return value from the invocation; null if the operation was void
48       */
49      Object getResult();
50  
51      /**
52       * Was an application exception raised by the invocation?
53       * Note, this indicates a checked application exception was thrown; this will never contain
54       * a system exception
55       * @return true if a declared exception was thrown; false if the invocation returned
56       */
57      boolean isException();
58  
59      /**
60       * Get the application exception raised by the invocation.
61       * It is an error to call this method if the invocation did not raise an exception
62       * @return the checked Exception raised by the application
63       */
64      Exception getException();
65  }