Java
The Unleash Java SDK lets you evaluate feature flags in Java applications. It connects to Unleash or Unleash Edge to fetch flag configurations and evaluates them locally against an Unleash context.
You can use this SDK with Unleash Enterprise or Unleash Open Source.
For an overview of how Unleash SDKs work, including offline behavior, feature compatibility across SDKs, and default refresh and metrics intervals, refer to the SDK overview.
Requirements
Installation
You need to add the Unleash SDK as a dependency for your project. Here’s how you would add it to your pom.xml and build.gradle file:
pom.xml
build.gradle
Initialization
In almost every case, you only want a single, shared instance of the Unleash class (a singleton) in your application. You would typically use a dependency injection framework (such as Spring or Guice) to inject it where you need it. Having multiple instances of the client in your application could lead to inconsistencies and performance degradation.
The SDK synchronizes with the Unleash API on initialization. By default this happens asynchronously in the background. If you need to block until the SDK has synchronized, use the synchronousFetchOnInitialisation option.
For a full overview of options, see configuration options.
Asynchronous initialization:
Synchronous initialization:
Check flags
With the SDK initialized, you can use the isEnabled method to check the state of your feature toggles. The method returns a boolean indicating whether a feature is enabled for the current request.
The isEnabled method also accepts a second boolean argument. The SDK uses this as a fallback value if it can’t find the feature you’re trying to check. For example, if unleash.isEnabled("non-existing-toggle") returns false when "non-existing-toggle" doesn’t exist, calling unleash.isEnabled("non-existing-toggle", true), will return true.
You can also pass an Unleash context to evaluate flags for a specific user, session, or other properties required by strategies, constraints, and stickiness. Refer to the Unleash context section for details.
Custom strategies
The Java client comes with implementations for the built-in activation strategies provided by Unleash. Read more about the strategies in the activation strategies reference documentation.
To add a custom strategy, implement the Strategy interface and register it when you set up Unleash:
Unleash context
In order to use some of the common activation strategies you must provide an Unleash context. This client SDK provides two ways of providing the Unleash context:
Inline context
Pass the context directly as an argument to the isEnabled call:
Context provider
For a more advanced approach, configure an UnleashContextProvider so you don’t need to pass the context to every isEnabled call.
The provider typically binds the context to the same thread as the request.
If you use Spring, the UnleashContextProvider will typically be a request-scoped bean.
Custom HTTP headers
If you want the client to send custom HTTP Headers with all requests to the Unleash API
you can define that by setting them via the UnleashConfig.
Dynamic custom HTTP headers
If you need custom HTTP headers that change during the lifetime of the client, a provider can be defined via the UnleashConfig.
Events
Introduced in 3.2.2
Sometimes you want to know when Unleash updates internally. This can be achieved by registering a subscriber. An example on how to configure a custom subscriber is shown below. Have a look at UnleashSubscriber.java to get a complete overview of all methods you can override.
Polling options
- appName - Required. Should be a unique name identifying the client application using Unleash.
- synchronousFetchOnInitialisation - Allows the user to specify that the Unleash client should do one synchronous fetch to the
unleash-apiat initialisation. This will slow down the initialisation (the client must wait for an HTTP response). If theunleash-apiis unavailable the client will silently move on and assume the api will be available later. - disablePolling - Stops the client from polling. If used without synchronousFetchOnInitialisation will cause the client to never fetch toggles from the
unleash-api. - fetchTogglesInterval - Sets the interval (in seconds) between each poll to the
unleash-api. Set this to0to do a single fetch and then stop refreshing while the process lives.
Outbound network proxy
The Unleash Java client uses HttpURLConnection as its HTTP client, which automatically recognizes common JVM proxy settings such as http.proxyHost and
http.proxyPort. If your proxy does not require authentication, it works without additional configuration. However, if you have to use Basic Authentication, settings such as http.proxyUser and http.proxyPassword are not recognized by default.
To enable Basic Authentication for an HTTP proxy, enable the following option on the configuration builder:
Custom toggle fetcher
The Unleash Java client supports using your own toggle fetcher.
The Config builder has been expanded to accept an io.getunleash.util.UnleashFeatureFetcherFactory which should be a Function<UnleashConfig, FeatureFetcher>.
If you want to use OkHttp instead of HttpURLConnection you’ll need a dependency on okhttp
Then you can change your config to
This will then start using OkHttp instead of HttpURLConnection.
Custom metrics sender
The Unleash Java client supports using your own metrics sender.
The Config builder has been expanded to accept a io.getunleash.util.MetricsSenderFactory which should be a Function<UnleashConfig, MetricsSender>.
If you want to use OkHttp instead of HttpURLConnection you’ll need a dependency on okhttp
Then you can change your config to
This will then start using OkHttp instead of HttpURLConnection to send metrics.
Local caching and offline behavior
By default unleash-client fetches the feature flags from unleash-server every 15s, and stores the
result in unleash-repo.json which is located in the java.io.tmpdir directory. This means that if
the unleash-server becomes unavailable, the unleash-client will still be able to toggle the features
based on the values stored in unleash-repo.json.
As a result of this, the second argument of isEnabled will be returned in two cases:
- When
unleash-repo.jsondoes not exist. - When the named feature toggle does not exist in
unleash-repo.json.
Bootstrap
Unleash supports bootstrapping from a JSON string. You can configure your own custom provider implementing the ToggleBootstrapProvider interface’s single method String read(). This should return a JSON string in the same format returned from /api/client/features.
Example bootstrap files can be found in the JSON files located in src/test/resources.
This setup can be useful for applications deployed to ephemeral containers or restricted file systems where Unleash’s need to write the backup file is not desirable or possible.
ToggleBootstrapFileProvider
Unleash comes configured with a ToggleBootstrapFileProvider which implements the ToggleBootstrapProvider interface. This is the default implementation used if not overridden via the setToggleBootstrapProvider on UnleashConfig.
Configure ToggleBootstrapFileProvider
The ToggleBootstrapFileProvider reads the file located at the path defined by the UNLEASH_BOOTSTRAP_FILE environment variable. It supports both classpath: paths and absolute file paths.
Unit testing
You might want to control the state of the toggles during unit testing. Unleash comes with a FakeUnleash implementation for doing this.
Example usage:
See more in FakeUnleashTest.java
Configuration options
The UnleashConfig$Builder class (created via UnleashConfig.builder()) exposes a set of builder methods to configure your Unleash client. The available options are listed below with a description of what they do. For the full signatures, take a look at the UnleashConfig class definition.
When you have set all the desired options, initialize the configuration with the build method.
You can then pass the configuration to the Unleash client constructor.
As an example:
Migrating to v10
If you’re using MoreOperations, custom or fallback strategies, subscribers or bootstrapping, see the full v10 migration guide. If you use GraalVM or Quarkus, hold off on upgrading to v10 — support is planned but not yet implemented.