NOTE: THIS PROJECT IS DEPRECATED. This projects is no longer maintained. It is deprecated for dropwizard-bundles maintained fork. Users of this project should update their project dependencies appropriately.
A Dropwizard bundle that makes it a lot easier to work with WebJars.
Regular java code doesn't need to know or care about what version of a dependency it is using. It simply imports the class by name and goes on about its business. Why shouldn't your front-end development work the same way? This bundle automatically injects version information for you.
Just add this maven dependency to get started:
<dependency>
<groupId>com.bazaarvoice.dropwizard</groupId>
<artifactId>dropwizard-webjars-bundle</artifactId>
<version>0.2.1</version>
</dependency>
- For Dropwizard 0.6.2: use version < 0.2.0
- For Dropwizard 0.7.0: use version >= 0.2.0
Add the resource to your environment:
public class SampleApplication extends Application<Configuration> {
public static void main(String[] args) throws Exception {
new SampleApplication().run(args);
}
@Override
public void initialize(Bootstrap<Configuration> bootstrap) {
bootstrap.addBundle(new WebJarBundle());
}
@Override
public void run(Configuration cfg, Environment env) throws Exception {
// ...
}
}
Now reference your WebJar omitting version information:
<script src="/webjars/bootstrap/js/bootstrap.min.js"></script>
By default the WebJar bundle has conservative, but reasonable, cache settings
to ensure that WebJar resources are returned quickly to your clients. If for
some reason the built-in settings aren't suitable for your application they can
be overidden by invoking the WebJarBundle
constructor with a
com.google.common.cache.CacheBuilder
instance that is configured with
your desired caching settings.
The cache that is built by the WebJarBundle
will include a
com.google.common.cache.Weigher
as part of it that indicates how many bytes
each resource is taking up in the cache. If desired you can include a maximum
weight in your CacheBuilder
to limit the amount of memory used by the cache.
Custom WebJars artifacts often appear in a maven group other than org.webjars
.
In order to support these custom WebJars, just invoke the WebJarBundle
constructor with a list of the group names you would like to be considered by
the bundle.
Don't forget to also include org.webjars
in your list if you want standard
WebJars to be found as well.