loose-json

1.1.2 • Public • Published

loose-json

a very loose yet safe json parser.

Typically, JSON literally should follow a very strict set of rules:

  • all the keys and strings must be surrounded with double quotes.
  • trailing comma is not allowed.

It is very easy to break the law if we write the JSON object as config file without IDE syntax checker. If you want your user utilize JSON as configuration object and wont expect JSON syntax annoying them, loose-json is just what you want.

install

npm install loose-json

example:

var parse = require('loose-json');
var x = parse("{abc: 'hello'}"); // You dont have to use double quotes
console.log(JSON.stringify(x)); // {"abc": "hello"}

// comments are ok, it is safe enough
var x = parse(`
{
    a : [1, 2, 3], // comments here
    b : "//this is string"
}
`);
console.log(JSON.stringify(x)); // {"a":[1,2,3], "b": "//this is string"}

// no problem with literal
var x = parse('true');
assert.equal(x, true);; // passed

// throw error if it contains evil thing
// and never allow function call in it
parse(`
{
    abc: require('something-evil')
}
`);

// throw error
parse(`
    [do_some_thing_evil(), eval('abc')]
`);

License

MIT

Dependencies (1)

Dev Dependencies (2)

Package Sidebar

Install

npm i loose-json

Weekly Downloads

3,181

Version

1.1.2

License

MIT

Last publish

Collaborators

  • ssnau