I have a client interface with a method like:

public interface INSP {
   @PUT
   @Path("/{domain}/subscriptions/{endpoint}{resourcePath}")
   @Produces("application/json")
   public String subscribeEndpointResource(@PathParam("domain") String domain,
                    @PathParam("endpoint") String endpoint,
                    @PathParam("resourcePath") String resourcePath);
}

A call like:

   nsp.subscribeEndpointResource("domain", "mbed-ethernet-1DE41", 
"/303/0/5700");

results in a request with the resourcePath component of the request URI being 
encoded:

16:14:55,173 INFO  [org.jboss.devnation.iotbof.ejbs.NSPConnector] (default 
task-11) mbed-ethernet-1DE41(/303/0/5700)=32.12, observable=true

16:14:55,174 INFO  [stdout] (default task-11) +++ Request(PUT) to: 
http://red-hat-summit.cloudapp.net:8080/domain/subscriptions/mbed-ethernet-1DE41%2F303%2F0%2F5700
16:14:55,174 INFO  [stdout] (default task-11) --- Headers:
16:14:55,174 INFO  [stdout] (default task-11)   Accept: application/json
16:14:55,174 INFO  [stdout] (default task-11)   Authorization: Basic 
YWRtaW46c2VjcmV0
16:14:55,174 INFO  [stdout] (default task-11)   Accept-Encoding: gzip, deflate
16:14:55,174 INFO  [stdout] (default task-11) --- End Headers:
16:14:55,175 INFO  [stdout] (default task-11) null
16:14:55,175 INFO  [stdout] (default task-11) --- End Body:
16:14:55,209 INFO  [stdout] (default task-11) +++ Response from: 
http://red-hat-summit.cloudapp.net:8080/domain/subscriptions/mbed-ethernet-1DE41%2F303%2F0%2F5700,
 status=Method Not Allowed
16:14:55,209 INFO  [stdout] (default task-11) --- Headers:
16:14:55,209 INFO  [stdout] (default task-11)   Content-Type: 
application/octet-stream
16:14:55,210 INFO  [stdout] (default task-11)   Content-Length: 62
16:14:55,210 INFO  [stdout] (default task-11)   Server: NSP/1.11.0-2
16:14:55,210 INFO  [stdout] (default task-11) --- End Headers:
16:14:55,210 WARN  [org.jboss.devnation.iotbof.ejbs.NSPConnector] (default 
task-11) Failed to load mbed-ethernet-1DE41/303/0/5700 resource
: javax.ws.rs.NotAllowedException: HTTP 405 Method Not Allowed
        at 
org.jboss.resteasy.client.jaxrs.internal.ClientInvocation.handleErrorStatus(ClientInvocation.java:183)
 [resteasy-client-3.0.6.Final.jar:]
        at 
org.jboss.resteasy.client.jaxrs.internal.ClientInvocation.extractResult(ClientInvocation.java:154)
 [resteasy-client-3.0.6.Final.jar:]
        at 
org.jboss.resteasy.client.jaxrs.internal.proxy.extractors.BodyEntityExtractor.extractEntity(BodyEntityExtractor.java:58)
 [resteasy-client-3.0.6.Final.jar:]
        at 
org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invoke(ClientInvoker.java:104)
 [resteasy-client-3.0.6.Final.jar:]
        at 
org.jboss.resteasy.client.jaxrs.internal.proxy.ClientProxy.invoke(ClientProxy.java:62)
 [resteasy-client-3.0.6.Final.jar:]
        at com.sun.proxy.$Proxy71.subscribeEndpointResource(Unknown Source)
        at 
org.jboss.devnation.iotbof.ejbs.NSPConnector.reload(NSPConnector.java:179) 
[iotbof-ejb.jar:]


The server is barfing on this because it is not uri decoding its incoming 
request uris. I don't have any control over it, so is there a way to prevent 
the resourcePath from being encoded?

Its easy enough to work around by coding my own subscribeEndpointResource 
utility method using the rest easy client classes, but it would be nice to 
simply be able to use the generated
web target proxy.

------------------------------------------------------------------------------
Put Bad Developers to Shame
Dominate Development with Jenkins Continuous Integration
Continuously Automate Build, Test & Deployment 
Start a new project now. Try Jenkins in the cloud.
http://p.sf.net/sfu/13600_Cloudbees
_______________________________________________
Resteasy-users mailing list
Resteasy-users@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/resteasy-users

Reply via email to