#json #serde-json #deserialize-json #canonical #specification #tuf #olpc

bin+lib olpc-cjson

serde_json Formatter to serialize as OLPC-style canonical JSON

5 releases

0.1.4 Oct 10, 2024
0.1.3 Mar 3, 2023
0.1.2 Oct 3, 2022
0.1.1 Jul 30, 2021
0.1.0 Nov 9, 2019

#122 in Encoding

Download history 13414/week @ 2024-08-18 14522/week @ 2024-08-25 12317/week @ 2024-09-01 14419/week @ 2024-09-08 13433/week @ 2024-09-15 15178/week @ 2024-09-22 14260/week @ 2024-09-29 17378/week @ 2024-10-06 16651/week @ 2024-10-13 20566/week @ 2024-10-20 18375/week @ 2024-10-27 17328/week @ 2024-11-03 12769/week @ 2024-11-10 17987/week @ 2024-11-17 15288/week @ 2024-11-24 14954/week @ 2024-12-01

62,706 downloads per month
Used in 77 crates (7 directly)

MIT/Apache

23KB
353 lines

olpc-cjson provides a serde_json::Formatter to serialize data as canonical JSON, as defined by OLPC and used in TUF. It is developed as part of tough, a Rust library for using TUF repositories.

OLPC's canonical JSON specification is subtly different from other "canonical JSON" specifications, and is also not a strict subset of JSON (specifically, ASCII control characters 0x00–0x1f are printed literally, which is not valid JSON). Therefore, serde_json cannot necessarily deserialize JSON produced by this formatter.

This crate is not developed or endorsed by OLPC; use of the term is solely to distinguish this specification of canonical JSON from other specifications of canonical JSON.

use olpc_cjson::CanonicalFormatter;
use serde::Serialize;
use serde_json::json;

let value = json!({"b": 12, "a": "qwerty"});
let mut buf = Vec::new();
let mut ser = serde_json::Serializer::with_formatter(&mut buf, CanonicalFormatter::new());
value.serialize(&mut ser).unwrap();
assert_eq!(buf, br#"{"a":"qwerty","b":12}"#);

Dependencies

~1.3–2MB
~54K SLoC