Neil Griffin created PLUTO-727:
----------------------------------

             Summary: PortletSession invalidated in the HEADER_PHASE gets 
recycled and reused in the RENDER_PHASE
                 Key: PLUTO-727
                 URL: https://issues.apache.org/jira/browse/PLUTO-727
             Project: Pluto
          Issue Type: Bug
          Components: portlet container
    Affects Versions: 3.0.1, 3.0.0
            Reporter: Neil Griffin
            Assignee: Neil Griffin
             Fix For: 3.0.2


As shown in the following example, session attributes set in the 
{{HEADER_PHASE}} should not be available in the subsequent {{RENDER_PHASE}} if 
the {{PortletSession}} is invalidated in the {{HEADER_PHASE}}:

{code:java|title=MyPortlet.java}
public class MyPortlet extends GenericPortlet {

    @Override
    public void renderHeaders(HeaderRequest headerRequest, HeaderResponse 
headerResponse) {
        PortletSesson portletSession = headerRequest.getPortletSession();
        portletSession.setAttribute("foo", "1234");
        portletSession.invalidate();
    }

    @Override
    public void doView(RenderRequest renderRequest, RenderResponse 
renderResponse) {
        PortletSesson portletSession = headerRequest.getPortletSession();
        String foo = (String) portletSession.getAttribute("foo");
        if (foo == null) {
            // Correct
        }
        else {
            // Incorrect
        }
    }
}
{code}

However, due to a cross-context issue incompatibility between Apache Pluto and 
Apache Tomcat, the PortletSession invalidated in the {{HEADER_PHASE}} gets 
recycled and reused in the {{RENDER_PHASE}}.

The problem stems from a [special cross-context case found in Tomcat's 
ApplicationHttpRequest.java 
class|https://github.com/apache/tomcat/blob/TOMCAT_8_0_0/java/org/apache/catalina/core/ApplicationHttpRequest.java#L541-L542]
 that recycles {{HttpSession}} objects even if they were previously invalidated.

The workaround is to keep track of invalidated {{HttpSession}} identifiers in 
Apache Pluto and to clear the session attributes if Tomcat produces an 
invalidated/recycled {{HttpSession}.

A similar problem of was reported in PLUTO-436 which required caused the 
developer to add [comments in 
PortletRequestContextImpl.java|https://github.com/apache/portals-pluto/blob/pluto-3.0.1/pluto-portal-driver-impl/src/main/java/org/apache/pluto/driver/services/container/PortletRequestContextImpl.java#L370-L377]
 that describe the workaround.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to