json-fingerprint
v1.1.2
Published
JSON fingerprint - create an unique hash for JSON data based on structure and value types
Downloads
15
Readme
json-fingerprint
Fingerprint JSON by calculating the hash (default: sha256) based on the shape of the JSON and its value types.
Install
npm install json-fingerprint
Usage
import {fingerprintJSON} from 'json-fingerprint';
const {hash, jsonPaths} = fingerprintJSON(`{"foo":"bar"}`)
// hash = 3e61d854042bcd6273a8e18589eb53a37e4cdc111bd2dc717413951637c11e2d
// jsonPaths = ['$:object', '$.foo:string']
const {hash, jsonPaths} = fingerprintJSON(`{"foo":"some string"}`)
// hash = 3e61d854042bcd6273a8e18589eb53a37e4cdc111bd2dc717413951637c11e2d
// jsonPaths = ['$:object', '$.foo:string']
Options
// JSON input
fingerprintJSON(`{"foo":"bar"}`)
// object input
fingerprintJSON({"foo":"bar"})
// custom hash function
fingerprintJSON(`{"foo":"bar"}`, myCustomHashFn)
Result
const {hash, jsonPaths, source} = fingerprintJSON(`{"foo":"bar"}`)
hash
: fingerprint hash of the JSONjsonPaths
: internal JSON meta data (hash is calculated based on stringified jsonPaths)source
: original JSON provided as input
Custom hash function
import { createHash } from 'node:crypto';
function sha512(data) {
/**
* https://nodejs.org/api/crypto.html#cryptocreatehashalgorithm-options
* `openssl list -digest-algorithms` to display the available digest algorithms
*/
return createHash('sha512').update(data).digest('hex');
}
fingerprintJSON(`{"foo":"bar"}`, sha512);
CLI
hash a JSON file
npx json-fingerprint --file=package.json
$ c0f87b9c30f33f44e9723c192d1797c161fb53e22ce06615cb6738d2bfb7b25d
pipe to json-fingerprint
cat package.json | npx json-fingerprint
$ c0f87b9c30f33f44e9723c192d1797c161fb53e22ce06615cb6738d2bfb7b25d
wget -qO - https://github.com/chimurai/json-fingerprint/raw/main/package.json | npx json-fingerprint
$ c0f87b9c30f33f44e9723c192d1797c161fb53e22ce06615cb6738d2bfb7b25d