Guicing up Dropwizard

Dropwizard is a lightweight RESTful web service framework built by Yammer. It incorporates a collection of mature Java libraries including Jetty, Jersey, Jackson, and Metrics to provide performant and reliable production-ready services.

At my current client, we’ve been implementing an entire micro-service backend using Dropwizard to drive content to Grails and AngularJS applications. One of the things that Dropwizard lacks is a succinct dependency injection implementation for your code. The latest released version of Dropwizard (0.6.2) uses Jersey v1.17.1 which had it’s own complicated DI framework (Jersey 2.x integrates HK2 which is a JSR-330 compliant framework).

We quickly found ourselves having to configure a substantial amount of code in our services just to wire classes together while allowing us to effectively and logically separate our business logic. So we’ve started exploring DI in Dropwizard. Guice is a lightweight DI framework. It also supports JSR-330 since v3.0.

We started integration Guice by utilizing the Dropwizard-Guice library from Hubspot. Simply add the dependency to your Dropwizard project and register the module:

This simple configuration does a couple things. First, it registers the Guice bundle with Dropwizard. This is turn will automatically register the following items with Jersey from your package:

  • HealthChecks (extends HealthCheck)
  • Tasks (extends Task)
  • Resources (has a @Path annotation)
  • Managed classes (extends Managed)
  • Injectable Providers (extends InjectableProvider)
  • Providers (extends Provider)
  • Bundles (extends Bundle)

During this process, Guice will inject any necessary dependencies into these classes (for those it has to instantiate at this point). Second, it registers a providers for both the Dropwizard Environment instance and the service’s Configuration instance. Finally, it registers a GuiceComponentProviderFactory with the Jersey IoC container.

One of the big wins with Guice is that it is capable of injecting any class that either has a no-arg constructor or has a constructor that is annotated with @Inject. This can help to quickly break up logic without having a proliferation of annotations to describe how your classes are wired up.

At this point, we had Guice wired into our services but we needed a way to inject the SessionFactory from the Dropwizard-Hibernate bundle into our DAOs. If you want to see how this was accomplished, check out my Dropwizard-Guice example project on Github.

About the Author

Object Partners profile.
Leave a Reply

Your email address will not be published.

Related Blog Posts
A security model for developers
Software security is more important than ever, but developing secure applications is more confusing than ever. TLS, mTLS, RBAC, SAML, OAUTH, OWASP, GDPR, SASL, RSA, JWT, cookie, attack vector, DDoS, firewall, VPN, security groups, exploit, […]
Building Better Data Visualization Experiences: Part 1 of 2
Through direct experience with data scientists, business analysts, lab technicians, as well as other UX professionals, I have found that we need a better understanding of the people who will be using our data visualization products in order to build them. Creating a product utilizing data with the goal of providing insight is fundamentally different from a typical user-centric web experience, although traditional UX process methods can help.
Kafka Schema Evolution With Java Spring Boot and Protobuf
In this blog I will be demonstrating Kafka schema evolution with Java, Spring Boot and Protobuf.  This app is for tutorial purposes, so there will be instances where a refactor could happen. I tried to […]
Redis Bitmaps: Storing state in small places
Redis is a popular open source in-memory data store that supports all kinds of abstract data structures. In this post and in an accompanying example Java project, I am going to explore two great use […]