Home » Archived » Eclipse Communications Framework (ECF) » Setting endpoint URL context - JAX-RS, Jersey, Jetty(A "1" is being appended to the URI definition which I want to replace)
Setting endpoint URL context - JAX-RS, Jersey, Jetty [message #1793089] |
Tue, 31 July 2018 03:21 |
Eclipse User |
|
|
|
There is a "1" being appended to the Jetty context definition. I don't know where that is coming from and I'd like to replace it with a context name of my choice. As it stands, I have to enter: http://localhost:8080/1/helloworld/hello to access my service.
I'm on Photon, with the following ECF bundles installed:
ECF Remote Services Examples Developer Resources 1.0.100.v20180502-2137
ECF Distributed EventAdmin Examples Developer Resources 1.0.100.v20180302-1843
ECF Remote Services Examples Developer Resources 1.5.100.v20180502-2137
ECF Remote Services SDK 3.14.0.v20180518-0149
ECF Discovery 1.0.100.v20180306-0211
ECF Discovery SLP (RFC 2608) Provider 1.0.0.v20180426-1936
ECF Discovery Zeroconf Provider 1.0.0.v20180306-0429
ECF Discovery Zookeeper Provider 1.0.0.v20180302-2006
ECF Distributed EventAdmin 2.0.100.v20180426-2032
ECF Generic Provider Feature 1.0.100.v20180402-2103
ECF Generic Provider RemoteService Feature 1.1.100.v20180516-2213
ECF Generic Server 1.1.100.v20180302-2006
ECF Remote Services 2.5.0.v20180409-2248
ECF Remote Services Admin 2.3.1.v20180518-0149
ECF Remote Services R-OSGi Provider 1.1.0.v20180516-2213
ECF Remote Services REST Support 1.0.100.v20180302-2006
ECF Remote Services Servlet API Feature 1.0.100.v20180302-2006
ECF SharedObject Feature 1.0.100.v20180404-2345
ECF Remote Services SDK Developer Resources 3.14.0.v20180518-0149
ECF Discovery Developer Resources 1.0.100.v20180306-0211
ECF Discovery SLP (RFC 2608) Provider Developer Resources 1.0.0.v20180426-1936
ECF Discovery Zeroconf Provider Developer Resources 1.0.0.v20180306-0429
ECF Discovery Zookeeper Provider Developer Resources 1.0.0.v20180302-2006
ECF Distributed EventAdmin Developer Resources 2.0.100.v20180426-2032
ECF Generic Provider Feature Developer Resources 1.0.100.v20180402-2103
ECF Generic Provider RemoteService Feature Developer Resources 1.1.100.v20180516-2213
ECF Generic Server Developer Resources 1.1.100.v20180302-2006
ECF Remote Services Admin Developer Resources 2.3.1.v20180518-0149
ECF Remote Services Developer Resources 2.5.0.v20180409-2248
ECF Remote Services R-OSGi Provider Developer Resources 1.1.0.v20180516-2213
ECF Remote Services REST Support Developer Resources 1.0.100.v20180302-2006
ECF Remote Services Servlet API Feature Developer Resources 1.0.100.v20180302-2006
ECF SharedObject Feature Developer Resources 1.0.100.v20180404-2345
ECF SDK for Eclipse 3.14.0.v20180302-2126
ECF Remote Services Examples 1.0.100.v20180502-2137
ECF SDK for Eclipse Developer Resources 3.14.0.v20180302-2126
My configuration file looks like this:
# Required OSGi Remote Service Property indicating that the StudentService should
# be exported
service.exported.interfaces=*
service.intents=osgi.async
# this one surprises me - ??
service.intents=jaxrs
# Optional OSGi Remote Service Property indicating that the ecf.jaxrs.jersey.server
# distribution provider should be used to export this service
service.exported.configs=ecf.jaxrs.jersey.server
# Distribution-provider property defining the alias prefix for the Jersey server
ecf.jaxrs.jersey.server.alias=/jersey
# this one I got from reading the code - it does change the separator
ecf.jaxrs.jersey.server.pathPrefix=/
# this seems to do nothing
ecf.jaxrs.jersey.server.urlPrefix=/server
# Other Jersey properties that could be defined
# got this one from reading code - it seems to do nothing
ecf.jaxrs.jersey.server.urlContext=/urlctx
# I think this might be a spelling mistake in the examples?
osgi.basic.timeoute=50000
However, the resulting exported registration looks as follows - notice the URL: http://localhost:8080/1
My question is - how to replace the "1" with a context of my choice?
19:10:08.955;EXPORT_REGISTRATION;exportedSR={com.dsct.test.jaxrs.IHelloWorld}={service.intents=jaxrs, service.exported.configs=ecf.jaxrs.jersey.server, ecf.jaxrs.jersey.server.alias=/jersey, service.id=37, service.bundleid=2, service.scope=bundle, ecf.jaxrs.jersey.server.urlPrefix=/server, ecf.jaxrs.jersey.server.urlContext=/urlctx, ecf.jaxrs.jersey.server.pathPrefix=/, component.name=com.dsct.test.jaxrs.HelloWorldImpl, service.exported.interfaces=*, component.id=2, osgi.basic.timeoute=50000};cID=URIID [uri=http://localhost:8080/1]; rsId=1
--Endpoint Description---
<endpoint-descriptions xmlns="http://www.osgi.org/xmlns/rsa/v1.0.0">
<endpoint-description>
<property name="ecf.endpoint.id" value-type="String" value="http://localhost:8080/1"/>
<property name="ecf.endpoint.id.ns" value-type="String" value="ecf.namespace.jaxrs"/>
<property name="ecf.endpoint.ts" value-type="Long" value="1533003003466"/>
<property name="ecf.jaxrs.jersey.server.alias" value-type="String" value="/jersey"/>
<property name="ecf.jaxrs.jersey.server.pathPrefix" value-type="String" value="/"/>
<property name="ecf.jaxrs.jersey.server.urlContext" value-type="String" value="/urlctx"/>
<property name="ecf.jaxrs.jersey.server.urlPrefix" value-type="String" value="/server"/>
<property name="ecf.rsvc.id" value-type="Long" value="1"/>
<property name="endpoint.framework.uuid" value-type="String" value="f083dcba-3d98-4a20-8643-d340bb28f4d3"/>
<property name="endpoint.id" value-type="String" value="636bdd3b-db26-41ec-af53-735ccad02385"/>
<property name="endpoint.service.id" value-type="Long" value="37"/>
<property name="objectClass" value-type="String">
<array>
<value>com.dsct.test.jaxrs.IHelloWorld</value>
</array>
</property>
<property name="osgi.basic.timeoute" value-type="String" value="50000"/>
<property name="remote.configs.supported" value-type="String">
<array>
<value>ecf.jaxrs.jersey.server</value>
</array>
</property>
<property name="remote.intents.supported" value-type="String">
<array>
<value>passByValue</value>
<value>exactlyOnce</value>
<value>ordered</value>
<value>osgi.async</value>
<value>osgi.private</value>
<value>osgi.confidential</value>
<value>jaxrs</value>
</array>
</property>
<property name="service.imported" value-type="String" value="true"/>
<property name="service.imported.configs" value-type="String">
<array>
<value>ecf.jaxrs.jersey.server</value>
</array>
</property>
<property name="service.intents" value-type="String" value="jaxrs"/>
</endpoint-description>
</endpoint-descriptions>
---End Endpoint Description
Any help appreciated. I'm an ECF noobe so this may be a trivial question but I've spent hours trying to find docs or a combo of properties that work.
|
|
|
Re: Setting endpoint URL context - JAX-RS, Jersey, Jetty [message #1793155 is a reply to message #1793089] |
Tue, 31 July 2018 17:21 |
Scott Lewis Messages: 1038 Registered: July 2009 |
Senior Member |
|
|
Dale Smith wrote on Mon, 30 July 2018 23:21There is a "1" being appended to the Jetty context definition. I don't know where that is coming from and I'd like to replace it with a context name of my choice. As it stands, I have to enter: http://localhost:8080/1/helloworld/hello to access my service.
I'm on Photon, with the following ECF bundles installed:
ECF Remote Services Examples Developer Resources 1.0.100.v20180502-2137
ECF Distributed EventAdmin Examples Developer Resources 1.0.100.v20180302-1843
ECF Remote Services Examples Developer Resources 1.5.100.v20180502-2137
ECF Remote Services SDK 3.14.0.v20180518-0149
ECF Discovery 1.0.100.v20180306-0211
ECF Discovery SLP (RFC 2608) Provider 1.0.0.v20180426-1936
ECF Discovery Zeroconf Provider 1.0.0.v20180306-0429
ECF Discovery Zookeeper Provider 1.0.0.v20180302-2006
ECF Distributed EventAdmin 2.0.100.v20180426-2032
ECF Generic Provider Feature 1.0.100.v20180402-2103
ECF Generic Provider RemoteService Feature 1.1.100.v20180516-2213
ECF Generic Server 1.1.100.v20180302-2006
ECF Remote Services 2.5.0.v20180409-2248
ECF Remote Services Admin 2.3.1.v20180518-0149
ECF Remote Services R-OSGi Provider 1.1.0.v20180516-2213
ECF Remote Services REST Support 1.0.100.v20180302-2006
ECF Remote Services Servlet API Feature 1.0.100.v20180302-2006
ECF SharedObject Feature 1.0.100.v20180404-2345
ECF Remote Services SDK Developer Resources 3.14.0.v20180518-0149
ECF Discovery Developer Resources 1.0.100.v20180306-0211
ECF Discovery SLP (RFC 2608) Provider Developer Resources 1.0.0.v20180426-1936
ECF Discovery Zeroconf Provider Developer Resources 1.0.0.v20180306-0429
ECF Discovery Zookeeper Provider Developer Resources 1.0.0.v20180302-2006
ECF Distributed EventAdmin Developer Resources 2.0.100.v20180426-2032
ECF Generic Provider Feature Developer Resources 1.0.100.v20180402-2103
ECF Generic Provider RemoteService Feature Developer Resources 1.1.100.v20180516-2213
ECF Generic Server Developer Resources 1.1.100.v20180302-2006
ECF Remote Services Admin Developer Resources 2.3.1.v20180518-0149
ECF Remote Services Developer Resources 2.5.0.v20180409-2248
ECF Remote Services R-OSGi Provider Developer Resources 1.1.0.v20180516-2213
ECF Remote Services REST Support Developer Resources 1.0.100.v20180302-2006
ECF Remote Services Servlet API Feature Developer Resources 1.0.100.v20180302-2006
ECF SharedObject Feature Developer Resources 1.0.100.v20180404-2345
ECF SDK for Eclipse 3.14.0.v20180302-2126
ECF Remote Services Examples 1.0.100.v20180502-2137
ECF SDK for Eclipse Developer Resources 3.14.0.v20180302-2126
My configuration file looks like this:
# Required OSGi Remote Service Property indicating that the StudentService should
# be exported
service.exported.interfaces=*
service.intents=osgi.async
# this one surprises me - ??
service.intents=jaxrs
I added this intent to this distribution provider, since this distribution provider requires usage of the jaxrs annotations.
It's basically saying: This remote service needs a jaxrs distribution provider because of the annotations. It's currently satisfied by both Jersey and CXF distribution providers.
It's not standardized like osgi.async, but it does allow a constraint to be placed upon the export such that either Jersey or CXF (or other, potentially) can be selected.
Quote:
# Optional OSGi Remote Service Property indicating that the ecf.jaxrs.jersey.server
# distribution provider should be used to export this service
service.exported.configs=ecf.jaxrs.jersey.server
# Distribution-provider property defining the alias prefix for the Jersey server
ecf.jaxrs.jersey.server.alias=/jersey
This alias property is no longer valid. In an older version of the JaxRSDistributionProvider I had used '.alias' and I decided that it would be better to a) standardize the property names for both Jersey and CXF; b) move the code for those properties into a common superclass. That superclass is:
https://github.com/ECF/JaxRSProviders/blob/master/bundles/org.eclipse.ecf.provider.jaxrs.server/src/org/eclipse/ecf/provider/jaxrs/server/JaxRSServerContainerInstantiator.java
The public static final *_PROP are the prop names (relative to the <config id>.<propname>...e.g. ecf.jaxrs.jersey.server.pathPrefix. I need to document these fully:
https://github.com/ECF/JaxRSProviders/issues/11
Quote:
# this one I got from reading the code - it does change the separator
ecf.jaxrs.jersey.server.pathPrefix=/
Yes. It adds a path prefix e.g. http://localhost:8080<pathPrefix>/1
For example if ecf.jaxrs.jersey.server.pathPrefix=/foo, the servlet will be registered under:
http://localhost:8080/foo/1
However...there is a bug:
https://github.com/ECF/JaxRSProviders/issues/10
That puts the wrong endpoint id in the endpoint description...e.g. with the example above it puts:
http://localhost:8080/foo/foo/1
into the endpoint description even though it actually is exported at: http://localhost:8080/foo/1
Quote:
# this seems to do nothing
ecf.jaxrs.jersey.server.urlPrefix=/server
This is a bug. I've opened this issue:
https://github.com/ECF/JaxRSProviders/issues/9
If you can live with it temporarily, it will work if the System property with same name is set...e.g.
-Decf.jaxrs.jersey.server.urlPrefix=http://myhost:2222
What this does is replace the *entire* urlPrefix with the string value...no matter how the HttpService is configured. The other properties (protocol, hostname, port, pathPrefix) are ignored if this is set.
It's usually going to be desirable to set the protocol, hostname and port separately using the appropriate props, but urlPrefix is present to allow certain edge cases.
Quote:
# Other Jersey properties that could be defined
# got this one from reading code - it seems to do nothing
ecf.jaxrs.jersey.server.urlContext=/urlctx
urlContext was also previously used, and is no longer valid for the same reasons given above.
Quote:
# I think this might be a spelling mistake in the examples?
osgi.basic.timeoute=50000
Yes you are right. I think this has already been fixed, though, so if you create a new workspace with the latest bndtools template (I assume you are using the bndtools example project templates?), the extra 'e' should be gone.
For reference, the bndtools example templates are in this repo:
https://github.com/ECF/bndtools.templates
[quote]
However, the resulting exported registration looks as follows - notice the URL: [url]http://localhost:8080/1[/url]
My question is - how to replace the "1" with a context of my choice?
So...with the pathPrefix handling fixed as per issue
https://github.com/ECF/JaxRSProviders/issues/10
this will create an endpoint/url:
http://localhost:8080<pathPrefix>/<remoteserviceid>
e.g.
http://localhost:8080<pathPrefix>/<remoteserviceid>
The reason the remoteserviceid is currently required is that with the CXF distribution provider, there does not currently seem to be a way (I've asked on mailing list) to *remove* a path->resource mapping in the servlet class I'm using:
org.apache.cxf.jaxrs.servlet.CXFNonSpringJaxrsServlet
To work around this, and still support OSGi Remote Service dynamics (where multiple service instances can come and go dynamically) it currently registers/unregisters a Servlet instance for each separate service instance. The remoteserviceid uniquely identifies these service instances and so is the most natural/shortest to use.
I would be willing to create a CXF servlet class to fix this, but would need some more information wrt CXF on how this would be done.
I don't think Jersey jaxrs impl has the same issues, but just for simplicity I wanted to use the same strategy for both providers.
I will plan on fixing these two issues this week and producing a new release of JaxRS distribution providers (v1.5.1) by this coming weekend.
Quote:
<stuff deleted>
Any help appreciated. I'm an ECF noobe so this may be a trivial question but I've spent hours trying to find docs or a combo of properties that work.
My apologies about the properties. The JaxRSDistribution provider is quite new (as opposed to ECF Remote Services), and I still haven't been able to document all the configuration properties, but I have now opened an issue to that effect:
https://github.com/ECF/JaxRSProviders/issues/11
I will, however, fix these issues and update the JaxRSDistributionProvider as quickly as possible.
|
|
| | | | |
|
|
Goto Forum:
Current Time: Thu Sep 19 12:13:44 GMT 2024
Powered by FUDForum. Page generated in 0.06808 seconds
|