JAX-RS and CDI have slightly different scopes so that by default there is no way to mix them and use CDI bean as JAX-RS resource, so
@Inject and other CDI magic tools are not available. To get it working you normally need to annotate your class with
@RequestScoped like below
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
So every time you create endpoint you need to write that extra line to switch this CDI magic on.
Recently when implementing I forgot to put this
@RequestScoped thing on my class and guess what? It actually worked fine! I spotted lack of that annotation accidentally some time later when I had all my tests passing and the whole feature working correctly.
JBoss extras to the rescue
So I started digging deeper into that. I tried it on two 7.x versions of JBoss AS and on Glassfish 22.214.171.124. It turned out that on Glassfish there is
NullPointerException when accessing injected field. So this is what expected. But on both JBoss servers it was all fine with no exception thrown and with work done.
It turns out that JBoss has its own extra module called
resteasy-cdi for integration of RESTEasy and CDI that you can read about here. TL;DR (from the doc):
The resteasy-cdi module is a bridge that allows RESTEasy to work with class instances obtained from the CDI container. During a web service invocation, resteasy-cdi asks the CDI container for the managed instance of a JAX-RS component. Then, this instance is passed to RESTEasy (…) As a result, CDI services like injection, lifecycle management, events, decoration and interceptor bindings can be used in JAX-RS components.
This is a tiny trick that can save you from writing some boilerplate code. It is actually only one line, but shouldn’t we apply DRY where possible? Just remember, this is something extra from JBoss and is available only when using RESTEasy with CDI, and that’s why Glassfish can’t do that.