Skip to main content



      Home
Home » Eclipse Projects » Equinox » serlvet bridge HTTP service and supported methods
serlvet bridge HTTP service and supported methods [message #66046] Wed, 03 May 2006 15:15 Go to next message
Eclipse UserFriend
Hi,
trying to use the HTTP bundle and the servlet bridge in order to deploy
a Wicket servlet in Tomcat, it seems that servlet.getServletName() is
not supported.
How is the strategy on supporting later servlet API's for the time
being? I'm not able to change the Wicket code according to Simons
recommendations on not using these things as it is central in there.
/peter

--
Re: serlvet bridge HTTP service and supported methods [message #66127 is a reply to message #66046] Wed, 03 May 2006 23:23 Go to previous messageGo to next message
Eclipse UserFriend
Originally posted by: skaegi.sympatico.ca

Hi Peter,

I'm definitely ok with being pragmatic in the servlet bridge in terms of
providing support for later versions of the Servlet API in some manner.

--
getServletName() support can be added easily enough through a specially
named init parameter.
getNamedDispatcher(...) can then also be added although it's a bit more
work.
getResourcesPaths() I think I've mentioned I'd like to support perhaps using
reflection to make the call when the relevant HttpContext has an
implementation of the method.

Would adding a useful implementation for these methods cover your
requirements?
Are there any other parts of the servlet API that you'll need to complete
your integration?
--

In terms of strategy I think we can look to more fully support the methods
on existing parts of the Servlet API exposed in the Http Service. That said,
I am a little wary of new objects. I think we can experiment with adding
Filter and Listener support in the incubator however at some point I suspect
a new spec is required.

-Simon

"Peter Neubauer" <peter@neubauer.se> wrote in message
news:e3avhe$3sr$2@utils.eclipse.org...
>
> Hi,
> trying to use the HTTP bundle and the servlet bridge in order to deploy
> a Wicket servlet in Tomcat, it seems that servlet.getServletName() is
> not supported.
> How is the strategy on supporting later servlet API's for the time
> being? I'm not able to change the Wicket code according to Simons
> recommendations on not using these things as it is central in there.
> /peter
>
> --
>
>
Re: serlvet bridge HTTP service and supported methods [message #66168 is a reply to message #66127] Thu, 04 May 2006 00:34 Go to previous messageGo to next message
Eclipse UserFriend
Simon,
"Simon Kaegi" <skaegi@sympatico.ca> wrote:
>Would adding a useful implementation for these methods cover your
>requirements?
>Are there any other parts of the servlet API that you'll need to complete
>your integration?
Not sure, my focus right now is to integrate Wicket as a backend for
RSP-UI, and we have Wicket running with the OBR Jetty (4.2 I think) bundle.
So I guess there is not terribly more then this to expect, but I'm not
sure. At least I can check the Wicket source for more.
If you could add support for getName that would be great. Meanwhile I
will try the other way round and deploy your newer Jetty bundle to give it
some testing. is it checked in anywhere?
/peter
Re: serlvet bridge HTTP service and supported methods [message #66383 is a reply to message #66168] Wed, 10 May 2006 17:45 Go to previous messageGo to next message
Eclipse UserFriend
Originally posted by: simon.kaegi.cognos.com

Hi Peter,

I've added getServletName() support for tonight's build and later.
You can use a "servlet-name" init param when you register or an <init-param
name="servlet-name" value="Your Servlet Name"/> if you're using the
equinox.http.registry

-Simon

"Peter Neubauer" <peter@neubauer.se> wrote in message
news:e3c08e$96a$1@utils.eclipse.org...
>
> Simon,
> "Simon Kaegi" <skaegi@sympatico.ca> wrote:
>>Would adding a useful implementation for these methods cover your
>>requirements?
>>Are there any other parts of the servlet API that you'll need to complete
>>your integration?
> Not sure, my focus right now is to integrate Wicket as a backend for
> RSP-UI, and we have Wicket running with the OBR Jetty (4.2 I think)
> bundle.
> So I guess there is not terribly more then this to expect, but I'm not
> sure. At least I can check the Wicket source for more.
> If you could add support for getName that would be great. Meanwhile I
> will try the other way round and deploy your newer Jetty bundle to give it
> some testing. is it checked in anywhere?
> /peter
>
Re: serlvet bridge HTTP service and supported methods [message #67329 is a reply to message #66383] Sun, 14 May 2006 05:32 Go to previous messageGo to next message
Eclipse UserFriend
"Simon Kaegi" <simon.kaegi@cognos.com> wrote:
>Hi Peter,
>
>I've added getServletName() support for tonight's build and later.
>You can use a "servlet-name" init param when you register or an <init-param
>name="servlet-name" value="Your Servlet Name"/> if you're using the
>equinox.http.registry
Cool, good to know, will try it next time I try the tomcat integration.
Right now using your Jetty bundle which works great!
/peter
Re: serlvet bridge HTTP service and supported methods [message #67362 is a reply to message #67329] Sun, 14 May 2006 12:11 Go to previous messageGo to next message
Eclipse UserFriend
Originally posted by: skaegi.sympatico.ca

Hi Peter,
You can use it with the Jetty Bundle (assuming you're referring to
https://bugs.eclipse.org/bugs/show_bug.cgi?id=132555)
getServletName() was added in the http service implementation that the Jetty
bundle and regular servlet bridge share.
e.g. org.eclipse.equinox.servlet.bridge.http
-Simon

"Peter Neubauer" <peter@neubauer.se> wrote in message
news:e46teu$ndd$1@utils.eclipse.org...
>
> "Simon Kaegi" <simon.kaegi@cognos.com> wrote:
> >Hi Peter,
> >
> >I've added getServletName() support for tonight's build and later.
> >You can use a "servlet-name" init param when you register or an
<init-param
> >name="servlet-name" value="Your Servlet Name"/> if you're using the
> >equinox.http.registry
> Cool, good to know, will try it next time I try the tomcat integration.
> Right now using your Jetty bundle which works great!
> /peter
>
Re: serlvet bridge HTTP service and supported methods [message #67740 is a reply to message #66127] Fri, 19 May 2006 13:52 Go to previous message
Eclipse UserFriend
Originally posted by: simon.kaegi.cognos.com

Update on supported methods.

--



I've added ServletContext.getResourcePaths(...) support in
"org.eclipse.equinox.servlet.bridge.http". (e.g. adds support for embedded
jetty and the regular servlet bridge). Previously this method always
returned null.



Keep in mind that the OSGi HttpService currently does not provide direct
support for this method. (Perhaps this is because it was specified in the
Servlet 2.1 timeframe and this method was added for 2.3(?))



The OSGi HttpContext interface does have a getResource(...) method and
advises that ServletContext.getResource(...) and
ServletContext.getResourceStream(...) should be supported by using it.



To support "getResourcePaths(...) this implementation uses reflection to
check for and then call the associated HttpContext.getResourcePaths(...)
method opportunistically. As before null is returned if the method is not
present or fails.



--

Further Note:

The OSGi HttpService specifies that the "Default Http Context" should use
Bundle.getResource(...) as the implementation for
HttpContext.getResource(...). Bundle.getResource(...) uses the bundle's
classloader to support the call and makes it very difficult to support
"getResourcePaths(...) in a consistent manner. Subsequently, the "Default
Http Context" as implemented "does not" support
ServletContext.getResourcePaths(...) and will simply return null.



R4 added Bundle.getEntry(...) and Bundle.getEntryPaths(...) which will only
search the immediate bundle however are frequently all that's really needed
and also allow consistent support for a getResourcePaths(...) method. The
HttpContext implementations for "org.eclipse.equinox.http.registry" uses
this approach (and as a result support getResourcePaths(...)).



If you're registering Servlets and Resources manually here's an example that
you can use or customize.



--

public class EntryBasedHttpContext implements HttpContext {
private Bundle bundle;
private HttpContext delegate;



public EntryBasedHttpContext(Bundle bundle, HttpService httpService) {
this.bundle = bundle;
delegate = httpService.createDefaultHttpContext();
}



public String getMimeType(String arg0) {
return delegate.getMimeType(arg0);
}



public boolean handleSecurity(HttpServletRequest arg0, HttpServletResponse
arg1) throws IOException {
return delegate.handleSecurity(arg0, arg1);
}



public URL getResource(String resourceName) {
return bundle.getEntry(resourceName);
}



public Set getResourcePaths(String path) {
Enumeration entryPaths = bundle.getEntryPaths(path);
if (entryPaths == null)
return null;



Set result = new HashSet();
while (entryPaths.hasMoreElements())
result.add(entryPaths.nextElement());
return result;
}
}

--



I'll eventually put this up on the website or perhaps the Wiki.

-Simon









"Simon Kaegi" <skaegi@sympatico.ca> wrote in message
news:e3bs2s$prl$1@utils.eclipse.org...

> Hi Peter,
>
> I'm definitely ok with being pragmatic in the servlet bridge in terms of
> providing support for later versions of the Servlet API in some manner.
>
> --
> getServletName() support can be added easily enough through a specially
> named init parameter.
> getNamedDispatcher(...) can then also be added although it's a bit more
> work.
> getResourcesPaths() I think I've mentioned I'd like to support perhaps
> using
> reflection to make the call when the relevant HttpContext has an
> implementation of the method.
>
> Would adding a useful implementation for these methods cover your
> requirements?
> Are there any other parts of the servlet API that you'll need to complete
> your integration?
> --
>
> In terms of strategy I think we can look to more fully support the methods
> on existing parts of the Servlet API exposed in the Http Service. That
> said,
> I am a little wary of new objects. I think we can experiment with adding
> Filter and Listener support in the incubator however at some point I
> suspect
> a new spec is required.
>
> -Simon
>
> "Peter Neubauer" <peter@neubauer.se> wrote in message
> news:e3avhe$3sr$2@utils.eclipse.org...
>>
>> Hi,
>> trying to use the HTTP bundle and the servlet bridge in order to deploy
>> a Wicket servlet in Tomcat, it seems that servlet.getServletName() is
>> not supported.
>> How is the strategy on supporting later servlet API's for the time
>> being? I'm not able to change the Wicket code according to Simons
>> recommendations on not using these things as it is central in there.
>> /peter
>>
>> --
>>
>>
>
>
Previous Topic:OSGI Services... LogReaderService ...
Next Topic:Equinox Planning - Provisioning - obr ?
Goto Forum:
  


Current Time: Sat Oct 25 04:51:08 EDT 2025

Powered by FUDForum. Page generated in 0.04697 seconds
.:: Contact :: Home ::.

Powered by: FUDforum 3.0.2.
Copyright ©2001-2010 FUDforum Bulletin Board Software

Back to the top