This is a OSGi Whiteboard implementation for Jakarta RESTful Web Services based on Eclipse Jersey.
https://docs.osgi.org/specification/osgi.cmpn/8.1.0/service.jakartars.html
https://eclipse-ee4j.github.io/jersey/
This implementation is compliant in respect to the corresponding OSGi Whiteboard specification.
It uses:
- Jersey 3.1.3
- HK2 3.0.5
When you want to run it, you currently have the choice between two different adapters / connectors:
- org.eclipse.osgitech.rest.jetty - The adapter to run the implementation with Jetty or
- org.eclipse.osgitech.rest.servlet.whiteboard - An adapter to run the implementation with the OSGi Servlet Whiteboard
To use it, you will need the following bundles:
- org.eclipse.osgitech.rest - The whiteboard implementation
- org.eclipse.osgitech.rest.config - The whiteboard implementation default configuration, when you want to use it
- org.eclipse.osgitech.rest.sse - An optional fragment for the use of server sent events
You will find the Release and Snapshot artifacts at Maven Central, respectively the snapshots at https://oss.sonatype.org.
<dependency>
<groupId>org.eclipse.osgi-technology.rest</groupId>
<artifactId>org.eclipse.osgitech.rest</artifactId>
<version>${version}</version>
</dependency>
<dependency>
<groupId>org.eclipse.osgi-technology.rest</groupId>
<artifactId>org.eclipse.osgitech.rest.config</artifactId>
<version>${version}</version>
</dependency>
<dependency>
<groupId>org.eclipse.osgi-technology.rest</groupId>
<artifactId>org.eclipse.osgitech.rest.sse</artifactId>
<version>${version}</version>
</dependency>
<dependency>
<groupId>org.eclipse.osgi-technology.rest</groupId>
<artifactId>org.eclipse.osgitech.rest.jetty</artifactId>
<version>${version}</version>
</dependency>
<dependency>
<groupId>org.eclipse.osgi-technology.rest</groupId>
<artifactId>org.eclipse.osgitech.rest.servlet.whiteboard</artifactId>
<version>${version}</version>
</dependency>
For those, who use Gradle:
org.eclipse.osgi-technology.rest:org.eclipse.osgitech.rest:${version}
org.eclipse.osgi-technology.rest:org.eclipse.osgitech.rest.config:${version}
org.eclipse.osgi-technology.rest:org.eclipse.osgitech.rest.sse:${version}
The Jakarta REST whiteboard can use the Eclipse Jetty. To run a simple example you'll need:
- org.eclipse.osgitech.rest
- org.eclipse.osgitech.rest.config - The default configuration
- org.eclipse.osgitech.rest.jetty - The Jetty Adapter
You can change various server setting by using the OSGi Configurator or the Configuration Admin like this:
{
":configurator:resource-version": 1,
"JakartarsWhiteboardComponent":
{
"jersey.port": 8081,
"jersey.jakartars.whiteboard.name" : "demo",
"jersey.context.path" : "demo"
}
}
This would run the server at
Please note, that the Felix Jetty implementation runs the OSGi HTTP Service by default at port 8080.
It may come to an conflict, with the port in your configuration.
Therefore you may set the system property org.osgi.service.http.port=-1
to deactivate the HTTP Service under port 8080.
To take profit from an eventually running servlet whiteboard, there is an adapter / connector the attach your Jersey Jakarta REST applications to this whiteboard.
To run this you'll need:
- org.eclipse.osgitech.rest
- org.eclipse.osgitech.rest.servlet.whiteboard - The OSGi Servlet Whiteboard Adapter
You can change various setting by using the OSGi Configurator or the Configuration Admin like this:
{
"org.apache.felix.http~demo":
{
"org.osgi.service.http.port": 8081,
"org.osgi.service.http.host": "localhost",
"org.apache.felix.http.context_path": "demo",
"org.apache.felix.http.name": "Demo HTTP Whiteboard",
"org.apache.felix.http.runtime.init.id": "demowb"
},
"JakartarsServletWhiteboardRuntimeComponent~demo":
{
"jersey.jakartars.whiteboard.name" : "Demo Jakarta REST Whiteboard",
"jersey.context.path" : "rest",
"osgi.http.whiteboard.target" : "(id=demowb)"
}
}
This would run the Jakarta REST Whiteboard implementation at:
http://localhost:8081/demo/rest
Please note, that the Felix Jetty implementation runs the OSGi HTTP Service by default at port 8080.
It may come to an conflict, with the port in your configuration.
Therefore you may set the system property org.osgi.service.http.port=-1
to deactivate the HTTP Service under port 8080.
When using the Jakarta REST Whiteboard, you just have to register your REST resources and extensions as a service. There are some useful Meta-Annotations, that create component properties for you.
@RequireJakartarsWhiteboard
@JakartarsResource
@JakartarsName("demo")
@Component(service = DemoResource.class, scope = ServiceScope.PROTOTYPE)
@Path("/")
public class DemoResource {
@GET
@Path("/hello")
public String hello() {
return "Hello World!";
}
}
With the @RequireJakartarsWhiteboard
annotation, you define the requirement to the Jakarta REST Whiteboard implementation. In our case it is Jersey. You then need the Whiteboard dependencies in you workspace.
Please note, that you only need to define @RequireJakartarsWhiteboard
once in your bundle!
The module org.eclipse.osgitech.rest.archetype contains a Maven template to create a sample project.
To create a sample project call:
mvn archetype:generate
-DarchetypeGroupId=org.eclipse.osgi-technology.rest
-DarchetypeArtifactId=org.eclipse.osgitech.rest.archetype
-DarchetypeVersion=1.0.0-SNAPSHOT
-DgroupId=<your-group-id>
-DartifactId=<your-artifact-id>
The generated project contains a ready to run example.
When adding the Jakarta REST Library to you dependencies:
org.eclipse.osgi-technology.rest:org.eclipse.osgitech.rest.bnd.library:${version}
you can simply but the instruction -library: jakartaREST
and you will find a repository in you bnd workspace after reloading the workspace.
It brings you all dependencies, you need to run Jersey. In addition to that it also brings a dependency to:
org.eclipse.osgi-technology.rest:org.eclipse.osgitech.rest.bnd.project.library:${version}
This library adds support for bndrun files. Calling the instruction -library: enableJakartaREST
within a bndrun adds automatically all Jersey and Jakarta REST Whiteboard dependencies to the runbundles section.
If you use the library instruction within a bnd.bnd file, it adds the JakartaRs API to the buildpath.
Furthermore this dependency brings three bndtools project templates:
- Jakarta REST Resource with a default configuration
- Jakarta REST Resource with Jetty Runtime and a corresponding configuration file
- Jakarta REST Resource with a configuration for the use with the OSGI Servlet Whiteboard
All these projects can be imported using the bndtools project wizard.