On Nov 21, 2012 9:25 AM, "Max Rydahl Andersen" <max.andersen@redhat.com> wrote:
>
> > we've seen a few issues with the browsersim not working all smooth with WebKit, but I guess for VPV this is less of a concern since we will simply just
> > be using whatever built-into-eclipse browser is enabled by the user on his platform, correct?
> > Yeah, it will use any browser. But of course, each browser, has its own features/bugs which should be taken into account when creating the viewer.
>
> I guess those changes will actually leak into the various templates ? i.e. the code would have to do "if browser=ie do X else do Y" ?
I hope none or only several of them will be affected, like rich:calendar, which is very complicated and really 'rich'.
>
> > > If it is a rewrite we should make sure to move everything that is not public api into internal packages.
> > > Will do it.
> >
> > Would also be good to make an effort on making the API to add support for other libraries more approachable than previous VPE.
> > i.e. documented API's, example of how to do it etc.
> > Agree. We could also make creation of templates more approachable by creating a simpler templating system. Now in VPE only Java and XML tamples are allowed. But we could allow also something like javascript micro-templating.
>
> interesting idea.
>
> > > How is that handled?
> > > One http server for one eclipse instance. Pages on the server will be available under paths like localhost:xxxx/project/pathtopage/page.jsp. We could also dispose the server when no VPE editor is opened.
> >
> > How about absolute relative paths like "/images/funky.png" - I guess that will be handled the same way as before where the href's are rewritten to have a proper "root" ?
>
> > Good question. I just forget about this root-relative case.
> > It looks like one server per viewer or at least one server per workspace is needed to handle it. I assume, that our users may have several editors opened, so one server with changing root directory is not an option.
> > Obvious drawbacks of multiple servers are:
> > - we have to manage their creation/disposal
> > - these servers will consume more resources (not much, but at least a port and a connection-waiting thread per each)
> > - pages from different projects will not be able communicate with each other, because of same-origin policy. (Anyway, now I am not planning that they will communicate even on one server per workspace.)
> > These seem to be not very big problems, probably it is worth it to create a server per editor, which should be pretty easy to maintain.
>
> well multiple open ports for an app is not exactly awesome.
>
> Especially not if these threads aren't fast to shutdown (i.e. instantly)
>
> How about multiplexing these somehow - can you control part of the useragent or other parts of the browser which you could use in the request to make the server respond differently ?
>
> i.e. useragent set to "VPV-root: xxxx/project/" and let the server respond accordingly?
>
> Someway to expose the properties the visual page editor already have in context of "root" and "absolute root" settings already.
I wouldn't like to change the user agent, because client logic may depend on it. Changing/adding of another request headers won't work in WebKit.

Today we found that the following approach may work.

If we set URL as http://localhost:1234/index.jsp?root=xxxx/project/, then all linked resources will be requested with the 'Referer' header set to this URL. This header may be used on the server to return right resources.

What I like in this approach is that it will also work for any browser, a SWT embedded browser or a stand alone browser.

Redirects/clicks from one page to another should be handled separately, but it is possible in SWT to do URL rewrite before the page requests are sent.

Another drawback we found is that html frames won't work this way.
>
> > btw. who's github branch are you doing this work in ? Would be nice to take a look and try run it from time to time.
> > Now it scaterred locally and in old svn workspaces. I will create a vpv branch in github/yradtsevich/jbosstools-vpe.
>
> okey - let us know when something to look at.
>
> /max