com.vaadin.server.

Class VaadinPortletSession

  • All Implemented Interfaces:

    Serializable, EventListener, javax.servlet.http.HttpSessionBindingListener


    public class VaadinPortletSession
    extends VaadinSession

    An implementation of VaadinSession for JSR-286 portlet environments. This is automatically registered as a HttpSessionBindingListener when PortletSession#setAttribute() is called with the context as value. Only the documented parts of this class should be considered as stable public API. Note also that some methods and/or nested interfaces might move to VaadinPortletService in future minor or major versions of Vaadin. In these cases, a deprecated redirection for backwards compatibility will be used in VaadinPortletSession for a transition period.

    Since:

    7.0

    See Also:

    Serialized Form

    • Constructor Detail

      • VaadinPortletSession

        public VaadinPortletSession(VaadinPortletService service)

        Create a portlet service session for the given portlet service

        Parameters:

        service - the portlet service to which the new session belongs

    • Method Detail

      • getPortletSession

        public PortletSession getPortletSession()

        Returns the underlying portlet session.

        Returns:

        portlet session

      • getPortletConfig

        public PortletConfig getPortletConfig()

        Returns the JSR-286 portlet configuration that provides access to the portlet context and init parameters.

        Returns:

        portlet configuration

      • addPortletListener

        public void addPortletListener(VaadinPortletSession.PortletListener listener)

        Adds a listener for various types of portlet requests.

        Parameters:

        listener - to add

      • firePortletRenderRequest

        public void firePortletRenderRequest(UI uI,
                                             RenderRequest request,
                                             RenderResponse response)

        For internal use by the framework only - API subject to change.

      • firePortletActionRequest

        public void firePortletActionRequest(UI uI,
                                             ActionRequest request,
                                             ActionResponse response)

        For internal use by the framework only - API subject to change.

      • firePortletEventRequest

        public void firePortletEventRequest(UI uI,
                                            EventRequest request,
                                            EventResponse response)

        For internal use by the framework only - API subject to change.

      • firePortletResourceRequest

        public void firePortletResourceRequest(UI uI,
                                               ResourceRequest request,
                                               ResourceResponse response)

        For internal use by the framework only - API subject to change.

      • generateActionURL

        public PortletURL generateActionURL(String action)

        Creates a new action URL. Creating an action URL is only supported when processing a suitable request (render or resource request, including normal Vaadin UIDL processing) and will return null if not processing a suitable request.

        Parameters:

        action - the action parameter (javax.portlet.action parameter value in JSR-286)

        Returns:

        action URL or null if called outside a MimeRequest (outside a UIDL request or similar)

      • sendPortletEvent

        public void sendPortletEvent(UI uI,
                                     QName name,
                                     Serializable value)
                              throws IllegalStateException

        Sends a portlet event to the indicated destination. Internally, an action may be created and opened, as an event cannot be sent directly from all types of requests. Sending portlet events from background threads is not supported. The event destinations and values need to be kept in the context until sent. Any memory leaks if the action fails are limited to the session. Event names for events sent and received by a portlet need to be declared in portlet.xml .

        Parameters:

        uI - a window in which a temporary action URL can be opened if necessary

        name - event name

        value - event value object that is Serializable and, if appropriate, has a valid JAXB annotation

        Throws:

        IllegalStateException

      • setSharedRenderParameter

        public void setSharedRenderParameter(UI uI,
                                             String name,
                                             String value)
                                      throws IllegalStateException

        Sets a shared portlet parameter. Internally, an action may be created and opened, as shared parameters cannot be set directly from all types of requests. Setting shared render parameters from background threads is not supported. The parameters and values need to be kept in the context until sent. Any memory leaks if the action fails are limited to the session. Shared parameters set or read by a portlet need to be declared in portlet.xml .

        Parameters:

        uI - a window in which a temporary action URL can be opened if necessary

        name - parameter identifier

        value - parameter value

        Throws:

        IllegalStateException

      • setPortletMode

        public void setPortletMode(UI uI,
                                   PortletMode portletMode)
                            throws IllegalStateException,
                                   PortletModeException

        Sets the portlet mode. This may trigger a new render request. Currently, this is only supported when working with a StateAwareResponse (an action request or an event request). Portlet mode change in background threads is not supported. Portlet modes used by a portlet need to be declared in portlet.xml .

        Parameters:

        uI - a window in which the render URL can be opened if necessary

        portletMode - the portlet mode to switch to

        Throws:

        PortletModeException - if the portlet mode is not allowed for some reason (configuration, permissions etc.)

        IllegalStateException - if not processing a request of the correct type