json-predicate

Crates.iojson-predicate
lib.rsjson-predicate
version0.1.16
sourcesrc
created_at2023-12-26 17:20:02.476335
updated_at2024-03-29 16:50:59.640818
descriptionJSON Predicate lib based on draft-snell-json-07
homepage
repositoryhttps://github.com/Miaxos/json-predicate
max_upload_size
id1081068
size230,673
Anthony Griffon (Miaxos)

documentation

https://docs.rs/json-predicate/latest/json_predicate/

README

JSON Predicate

release Crates.io version dependency status docs.rs docs PRs Welcome

Partial implementation of Snell Json Predicate Draft 07.

Even if this Draft is Expired, it's still a pretty good draft of predicate over JSON.

Introduction

This specification defines JSON Predicates, a JSON-based RFC4627 syntax for the description and serialization of logical boolean predicate operations intended to be used in conjunction with other JSON-based mechanisms, such as JSON Patch RFC6902, as a means of incorporating conditional processing.

JSON Predicates can be used, for instance, to extend a JSON Patch RFC6902 document to provide for a broader range of conditional processing options not currently supported by JSON Patch.

Example

Given this JSON:

{
    "a": {
        "b": {
            "c": "ABC!XYZ"
        }
    }
}

We could have a predicate like this:

{
    "op": "and",
    "path": "/a/b/c",
    "apply": [
        {
            "op": "type",
            "value": "string"
        },
        {
            "op": "contains",
            "value": "ABC"
        }
    ]
}

which would evaluate as true if evaluated against the previous JSON.

Rust Example

let predicate = Predicate::deserialize(serde_json::json!({
    "op": "and",
    "path": "/objA",
    "apply": [
      {
        "op": "defined",
        "path": "/stringX"
      },
      {
        "op": "defined",
        "path": "/stringXYZ"
      }
    ],
}))?;

let evaluted_predicate: bool = predicate
    .test(&ENTRY, PredicateContext::default());

JSON Patch

The JSON Patch methods described in draft-snell-json-test-07 are not implemented yet.

Features

First order predicate

  • "contains"
  • "contains-"
  • "defined"
  • "undefined"
  • "starts"
  • "starts-"
  • "ends"
  • "ends-"
  • "type"
  • "in"
  • "in-"
  • "matches"
  • "matches-"
  • "test"
  • "test-"
  • "less"
  • "more"

Second order predicate

  • "and"
  • "not"
  • "or"

References

License

Licensed under either of

Commit count: 91

cargo fmt