#json #serde-json #nan #infinity #python #parse-json #deserialize-json

json-forensics

A crate that adds a read adapter to deal with bad Python caused JSON payloads (NaNs and Infinities)

1 unstable release

0.1.1 Mar 30, 2023

#5 in #infinity

Download history 170/week @ 2024-07-26 152/week @ 2024-08-02 88/week @ 2024-08-09 135/week @ 2024-08-16 112/week @ 2024-08-23 332/week @ 2024-08-30 111/week @ 2024-09-06 96/week @ 2024-09-13 296/week @ 2024-09-20 194/week @ 2024-09-27 154/week @ 2024-10-04 102/week @ 2024-10-11 100/week @ 2024-10-18 141/week @ 2024-10-25 114/week @ 2024-11-01 172/week @ 2024-11-08

545 downloads per month

BSD-3-Clause

10KB
178 lines

rust-json-forensics

This crate exposes a function that takes a byteslice and:

  • Converts the invalid JSON tokens NaN and Infinity into 0
  • Replaces all integers that would cause an overflow in serde-json with 0

This is just to get the JSON to parse. All operations happen in-place.

This is useful because the Python JSON library traditionally emits invalid JSON if NaN and Infinity values are encountered. If you have to support clients like this, this wrapper can be used to still deserialize such a JSON document.

Successor of python-json-read-adapter


lib.rs:

This crate implements a Read adapter that converts the invalid JSON tokens NaN and Infinity into other tokens without otherwise distorting the stream. It achieves this by converting NaN and Infinity into 0.0.

This is useful because the Python JSON library traditionally emits invalid JSON if NaN and Infinity values are encountered. If you have to support clients like this, this wrapper can be used to still deserialize such a JSON document.

This is just a way to get this to parse and 0 is a value that can be inserted in a standardized way that fits without changing any of the positions.

Example Conversion

The following JSON document:

{"nan":NaN,"inf":Infinity,"-inf":-Infinity}

is thus converted to:

{"nan":0  ,"inf":0       ,"-inf":-0       }

serde support

If the serde feature is enabled then the crate provides some basic wrappers around serde_json to deserialize quickly and also by running the conversions.

Dependencies

~0–300KB