#json #patch #document #serde-json #rfc #merge #path

json-patch

RFC 6902, JavaScript Object Notation (JSON) Patch

15 releases (5 stable)

new 2.0.0 May 6, 2024
1.4.0 May 6, 2024
1.2.0 Oct 9, 2023
1.0.0 Mar 31, 2023
0.2.1 Nov 3, 2017

#46 in Encoding

Download history 140765/week @ 2024-01-19 114762/week @ 2024-01-26 133686/week @ 2024-02-02 131257/week @ 2024-02-09 133899/week @ 2024-02-16 147160/week @ 2024-02-23 148353/week @ 2024-03-01 154835/week @ 2024-03-08 156873/week @ 2024-03-15 155160/week @ 2024-03-22 167761/week @ 2024-03-29 157271/week @ 2024-04-05 161774/week @ 2024-04-12 171858/week @ 2024-04-19 169874/week @ 2024-04-26 170431/week @ 2024-05-03

701,749 downloads per month
Used in 259 crates (45 directly)

MIT/Apache

39KB
685 lines

crates.io crates.io Build Codecov

json-patch

A JSON Patch (RFC 6902) and JSON Merge Patch (RFC 7396) implementation for Rust.

Usage

Add this to your Cargo.toml:

[dependencies]
json-patch = "*"

Examples

Create and patch document using JSON Patch:

#[macro_use]
use json_patch::{Patch, patch};
use serde_json::{from_value, json};

let mut doc = json!([
    { "name": "Andrew" },
    { "name": "Maxim" }
]);

let p: Patch = from_value(json!([
  { "op": "test", "path": "/0/name", "value": "Andrew" },
  { "op": "add", "path": "/0/happy", "value": true }
])).unwrap();

patch(&mut doc, &p).unwrap();
assert_eq!(doc, json!([
  { "name": "Andrew", "happy": true },
  { "name": "Maxim" }
]));

Create and patch document using JSON Merge Patch:

#[macro_use]
use json_patch::merge;
use serde_json::json;

let mut doc = json!({
  "title": "Goodbye!",
  "author" : {
    "givenName" : "John",
    "familyName" : "Doe"
  },
  "tags":[ "example", "sample" ],
  "content": "This will be unchanged"
});

let patch = json!({
  "title": "Hello!",
  "phoneNumber": "+01-123-456-7890",
  "author": {
    "familyName": null
  },
  "tags": [ "example" ]
});

merge(&mut doc, &patch);
assert_eq!(doc, json!({
  "title": "Hello!",
  "author" : {
    "givenName" : "John"
  },
  "tags": [ "example" ],
  "content": "This will be unchanged",
  "phoneNumber": "+01-123-456-7890"
}));

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0.8–1.8MB
~39K SLoC