[10:42:09 CST(-0600)] <Bananobot> I'm trying to get a portlet to read the client's GET request parameters to select the output. But it seems as though the output is being cached too heavily, so when I feed it a different value in the URL, the output isn't updated. Is there a way for the portlet to work around this without forcing all navigation to use POST?
[11:10:36 CST(-0600)] <holdorph> Bananobot, there are two things you need to look at. One, make sure the portlet.xml doesn't have caching turn on.
[11:11:16 CST(-0600)] <holdorph> Two, you must use the portlet container to create any URLs that the user can click on. Hand crafting URLs is not supported by the portlet spec
[11:11:46 CST(-0600)] <holdorph> that means, for example if you are using a .jsp file, using the portlet tag library and creating renderUrls
[11:11:49 CST(-0600)] <Bananobot> Caching is turned on in portlet.xml, but I would think that if a GET parameter is specified, targeting that specified portlet, the portal should know that it can't use the same cache as a request with a different GET parameter..
[11:12:30 CST(-0600)] <holdorph> you're right, assuming your following the second consideration i mention
[11:12:39 CST(-0600)] <Bananobot> Okay, I'll look into that
[11:13:45 CST(-0600)] <EricDalquist> If a portlet is targeted by a URL generated by the portlet API for that portlet the cache will be invalidated
[11:13:46 CST(-0600)] <Bananobot> Actually, hm... I'm using Spring's form tags, and I'm setting the "path" attributes for the form controls. The generated "name" attributes in the HTML are just being set to the literal value, rather than something translated for the portal..
[11:14:00 CST(-0600)] <EricDalquist> also all forms for portlets must use POST
[11:14:07 CST(-0600)] <EricDalquist> and the path must be set to a portlet API generated URL
[11:14:43 CST(-0600)] <Bananobot> EricDalquist: Why do they all have to be POST? The form isn't to post content, it's to request a resource.
[11:14:52 CST(-0600)] <EricDalquist> the portlet specification says so
[11:14:55 CST(-0600)] <Bananobot> :/
[11:15:09 CST(-0600)] <EricDalquist> if you want I can give you a 2 page technical explination as to why
[11:15:10 CST(-0600)] <holdorph> not true
[11:15:13 CST(-0600)] <Bananobot> Did the portlet specification authors read the HTTP specification before they wrote it?
[11:15:15 CST(-0600)] <holdorph> you can use render urls
[11:15:19 CST(-0600)] <EricDalquist> you can use render URLs
[11:15:21 CST(-0600)] <holdorph> and change the render parameters
[11:15:24 CST(-0600)] <EricDalquist> but they have to be POSTs
[11:15:38 CST(-0600)] <EricDalquist> there is a sound technical reason for this requirement
[11:15:51 CST(-0600)] <holdorph> hmm.... I didn't remember that part.
[11:16:09 CST(-0600)] <holdorph> i know if it's a form, it has to be a post, but I didn't know that render urls had to be posts too.
[11:16:20 CST(-0600)] <EricDalquist> if it is a form it has to be a post
[11:16:38 CST(-0600)] <EricDalquist> the reason is the portal can't appropriately namespace parameters defined as form <input> tags
[11:16:44 CST(-0600)] <holdorph> right, but if it's not a form and it's not a action url, i think it can be a get
[11:16:48 CST(-0600)] <EricDalquist> no
[11:16:50 CST(-0600)] <EricDalquist> it can;'t
[11:16:51 CST(-0600)] <EricDalquist> trust me
[11:16:57 CST(-0600)] <EricDalquist> let me find the spec reference
[11:17:02 CST(-0600)] <Bananobot> Okay.. from the jsp, how do I set a field's name attribute to be prefixed with the portal's stuff?
[11:17:14 CST(-0600)] <Bananobot> I have the action attribute all set up by the portal, but not the name attributes
[11:17:29 CST(-0600)] <holdorph> huh?
[11:17:33 CST(-0600)] <EricDalquist> PLT.7.1 PortletURL
[11:17:39 CST(-0600)] <holdorph> are you using a portlet url Bananobot ?
[11:17:42 CST(-0600)] <EricDalquist> Because some portal/portlet-containers implementations may encode internal state as part
[11:17:42 CST(-0600)] <EricDalquist> of the URL query string, portlet developers should not code forms using the HTTP GET
[11:17:42 CST(-0600)] <EricDalquist> method.
[11:17:56 CST(-0600)] <holdorph> that says 'forms'
[11:18:07 CST(-0600)] <EricDalquist> right
[11:18:15 CST(-0600)] <EricDalquist> so any <form> tag must use method="post"
[11:18:16 CST(-0600)] <Bananobot> holdorph: I have a <portlet:renderURL var="formRender">...</portlet:renderURL> thing, which I use for the form's action attribute.
[11:18:32 CST(-0600)] <Bananobot> In the generated HTML, I see action="/uPortal/render.userLayoutRootNode.target.n62.uP?pltc_target=81_n62_8.n62&pltc_type_81_n62_8.n62=RENDER&pltp_81_n62_8.n62_action=form"
[11:18:43 CST(-0600)] <EricDalquist> yup
[11:18:45 CST(-0600)] <Bananobot> But the "name" attributes for the inputs aren't prefixed with anything
[11:18:46 CST(-0600)] <EricDalquist> that looks right
[11:18:49 CST(-0600)] <holdorph> you don't do that stuff Bananobot
[11:18:57 CST(-0600)] <holdorph> that's done by the portal container
[11:19:18 CST(-0600)] <EricDalquist> ok so here is the reason the POST is required
[11:19:20 CST(-0600)] <Bananobot> I see <select id="Pluto_81_n62_8_n62_institution" name="institution" style="max-width:100%">
[11:19:27 CST(-0600)] <EricDalquist> yup
[11:19:34 CST(-0600)] <EricDalquist> that is correct as well
[11:20:04 CST(-0600)] <EricDalquist> when a browser submits a form using GET it simply appends the <input> parameters to the URL
[11:20:17 CST(-0600)] <EricDalquist> the problem with that is portal URLs are complex
[11:20:27 CST(-0600)] <EricDalquist> there is more than one portlet on a page plus other information the portal needs to track
[11:20:34 CST(-0600)] <EricDalquist> and these appended parameters are not namespaced
[11:21:01 CST(-0600)] <Bananobot> I just redeployed the portlet and reloaded it in Tomcat. When I go to the main uPortal page, I see the main portlet view. When I hit refresh in my browser, it suddenly looks like I had a GET parameter..
[11:21:11 CST(-0600)] <EricDalquist> there is no good way for the portal to track what is coming from the form and what isn;t
[11:21:25 CST(-0600)] <EricDalquist> when you do a POST the form <input> parameters are sent in the body of the HTTP request
[11:21:43 CST(-0600)] <Bananobot> BRB
[11:21:51 CST(-0600)] <EricDalquist> this allows the portal to know that these parameters were submitted in a form for the portlet targeted by the requested URL
[11:21:57 CST(-0600)] <EricDalquist> that is why the POST requirement is there
[11:30:16 CST(-0600)] <Bananobot> Why would request.getParameter("institution") (for a RenderRequest) return non-null if my client URL is just http://localhost:8080/uPortal/render.userLayoutRootNode.uP ?
[11:30:48 CST(-0600)] <EricDalquist> portlets are re-rendered with their last request parameters unless directly targeted by a URL they generated
[11:30:51 CST(-0600)] <EricDalquist> again part of the portlet spec
[11:31:36 CST(-0600)] <Bananobot> How would I manually reset that, for testing purposes?
[11:31:46 CST(-0600)] <EricDalquist> you need to click on a link generated by your portlet
[11:35:25 CST(-0600)] <Bananobot> If forms have to be POST, then how would I use a simple link to point to a different "page" of the portlet?
[11:35:44 CST(-0600)] <Bananobot> Since links are always GET
[11:35:57 CST(-0600)] <EricDalquist> links as get are fine
[11:36:04 CST(-0600)] <EricDalquist> since you add parameters to them using the portlet:param tag
[11:36:07 CST(-0600)] <holdorph> that's what I was trying to say earlier
[11:36:16 CST(-0600)] <holdorph> when you kept telling me i was wrong
[11:36:49 CST(-0600)] <EricDalquist> sorry I thought you were refering to forms still
[11:37:02 CST(-0600)] <holdorph> no
[11:37:04 CST(-0600)] <Bananobot> Then it seems like it should be possible to use a similar method to set up the name attributes for the inputs. If that isn't possible, it seems like that's just an oversight of the portlet standard rather than a real technical limitation.
[11:37:27 CST(-0600)] <EricDalquist> so why is using a POST for a form a problem?
[11:38:02 CST(-0600)] <EricDalquist> and also that is true, the portlet spec could have provided a portlet tag to generate <input> names
[11:38:06 CST(-0600)] <EricDalquist> they didn't though
[11:38:19 CST(-0600)] <EricDalquist> so we're stuck with having to use method="POST" for forms
[11:38:47 CST(-0600)] <EricDalquist> if you want to user to end up at a "GET" URL you can POST to an ActionUrl and have the processAction code simply copy the parameters over to renderParameters
General
Content
Integrations