KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > apache > jetspeed > portlet > event > Event


1 /* ====================================================================
2  * The Apache Software License, Version 1.1
3  *
4  * Copyright (c) 2000-2001 The Apache Software Foundation. All rights
5  * reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * 1. Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  *
14  * 2. Redistributions in binary form must reproduce the above copyright
15  * notice, this list of conditions and the following disclaimer in
16  * the documentation and/or other materials provided with the
17  * distribution.
18  *
19  * 3. The end-user documentation included with the redistribution,
20  * if any, must include the following acknowledgment:
21  * "This product includes software developed by the
22  * Apache Software Foundation (http://www.apache.org/)."
23  * Alternately, this acknowledgment may appear in the software itself,
24  * if and wherever such third-party acknowledgments normally appear.
25  *
26  * 4. The names "Apache" and "Apache Software Foundation" and
27  * "Apache Jetspeed" must not be used to endorse or promote products
28  * derived from this software without prior written permission. For
29  * written permission, please contact apache@apache.org.
30  *
31  * 5. Products derived from this software may not be called "Apache" or
32  * "Apache Jetspeed", nor may "Apache" appear in their name, without
33  * prior written permission of the Apache Software Foundation.
34  *
35  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38  * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
39  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46  * SUCH DAMAGE.
47  * ====================================================================
48  *
49  * This software consists of voluntary contributions made by many
50  * individuals on behalf of the Apache Software Foundation. For more
51  * information on the Apache Software Foundation, please see
52  * <http://www.apache.org/>.
53  */

54
55 package org.apache.jetspeed.portlet.event;
56
57 import org.apache.jetspeed.portlet.Portlet;
58 import org.apache.jetspeed.portlet.PortletRequest;
59 import org.apache.jetspeed.portlet.PortletConfig;
60
61 /**
62  * The <CODE>Event</CODE> is the base interface for all events
63  * that can occur whithin the portlet container. To be informed
64  * of events, a listener has to be registered with the respective
65  * event source.
66  *
67  * <P>
68  * The portlet container delivers all events to the respective
69  * event listeners (and thereby the portlets) before the content
70  * generation is started. Should a listener, while processing the
71  * event, find that another event needs to be generated, that
72  * event will be queued by the portlet container and delivered
73  * at a point of time that is at the discretion of the portlet
74  * container. It is only guarantued that it will be deliverd
75  * and that it will happen before the content generation phase.
76  * </P>
77  * <P>
78  * This also means, that no further events will be delivered
79  * once the content generation phase has started. For example,
80  * message cannot be sent from within the service() methods.
81  * The resulting message event will not be delivered and
82  * essentially discarded.
83  * </P>
84  * <P>
85  * Intelligent portlet containers should provide a cyclic event
86  * detection mechanism, so that the portlet container does not
87  * come to a screaming halt, if two or more portlets happen
88  * to send each other events that are triggered by each other.
89  * </P>
90  *
91  * @author <A HREF="mailto:tboehme@us.ibm.com">Thomas F. Boehme</A>
92  */

93 public interface Event
94 {
95     /**
96      ** Returns the portlet request that has caused this event.
97      ** If this event is not triggered by a request,
98      ** this methods returns <CODE>null</CODE>.
99      **
100      ** @return the portlet request
101      **/

102
103     public PortletRequest getRequest ();
104
105     /**
106      ** Returns the virtual instance of the portlet
107      ** that receives this event.
108      **
109      ** @return the virtual instance of the portlet
110      **/

111
112     public Portlet getPortlet ();
113
114     /**
115      ** Returns the portlet config of the virtual instance
116      ** that receives this event.
117      **
118      ** @return the portlet config
119      **/

120
121     public PortletConfig getConfig ();
122
123 }
Popular Tags