json-logic-java
This parser accepts JsonLogic rules and executes them in Java without Nashorn.
The JsonLogic format is designed to allow you to share rules (logic) between front-end and back-end code (regardless of language difference), even to store logic along with a record in a database. JsonLogic is documented extensively at JsonLogic.com, including examples of every supported operation and a place to try out rules in your browser.
Installation
<dependency>
<groupId>com.brunocesar</groupId>
<artifactId>json-logic-java</artifactId>
<version>1.0.0</version>
</dependency>
Examples
The public API for json-logic-java attempts to mimic the public API of the original Javascript implementation as close as possible. For this reason, the API is loosely typed in many places. This implementation relies on duck-typing for maps/dictionaries and arrays: if it looks and feels like an array, we treat it like an array.
// Create a new JsonLogic instance. JsonLogic is thread safe.
JsonLogic jsonLogic = new JsonLogic();
// Set up some JSON and some data.
String expression = "{\"*\": [{\"var\": \"x\"}, 2]}";
Map<String, Integer> data = new HashMap<>();
data.put("x", 10);
// Evaluate the result.
double result = (double) jsonLogic.apply(expression, data);
assert result == 20.0;
You can add your own operations like so:
// Register an operation.
jsonLogic.addOperation("greet", new com.google.common.base.Function<Object[], Object>() {
@Override
public String apply(Object[] args) {
return "Hello, " + args[0] + "!";
}
}
);
// Evaluate the result.
String result = (String) jsonLogic.apply("{\"greet\": [\"Sam\"]}", null);
assert "Hello, Sam!".equals(result);
There is a truthy
static method that mimics the truthy-ness rules of Javascript:
assert JsonLogic.truthy(0) == false;
assert JsonLogic.truthy(1) == true;
assert JsonLogic.truthy("") == false;
assert JsonLogic.truthy("Hello world!") == true;
// etc...
Building a Release
For now, there is no CI pipeline. Changes do not happen frequently enough to require them.
- Remove the
-SNAPSHOT
from the version inbuild.gradle
. - Update the
README.md
installation instructions to use the new version. - Add and commit the changes.
- Create a git tag (
git tag v{VERSION}
) and push:git push && git push --tags
. - Run
./gradlew clean build uploadArchives
to push to Sonatype. - Bump the version in the
build.gradle
file and add-SNAPSHOT
to it. - Add and commit the changes.