@oresoftware/json-stream-parser
TypeScript icon, indicating that this package has built-in type declarations

0.0.124 • Public • Published

@oresoftware/json-stream-parser

Version

Transform stream

Transforms JSON stream to JS Objects

Installation

$ npm install '@oresoftware/json-stream-parser'

Import

import {JSONParser} from '@oresoftware/json-stream-parser';

Usage

Right now, the library assumes each separate chunk of json is separated by newline characters.
In the future, we could attempt to use a different delimiting character, as a user-provided input variable.
Recommendations welcome.

Examples

Simple Node.js example:

Reading from stdin
process.stdin.resume().pipe(new JSONParser()).on('data', d => {
  // now we got some POJSOs!
});
Reading/writing to a tcp socket
import * as net from 'net';
const [port,host] = [6970,'localhost'];
const ws = net.createConnection(port, host);

ws.setEncoding('utf8')
  .pipe(new JSONParser())   // tcp connection is bidirection/full-duplex .. we send JSON strings each way
  .on('data', onData);    // we receive data coming from the tcp server here


// and we send data like this:
ws.write(JSON.stringify({'some':'data'}) + '\n', 'utf8', cb); // make sure to include the newline char when you write

Using bash shell

Simple bash example:
const k = cp.spawn('bash');
k.stdin.end(`echo '{"foo":"bar"}\n'`);  // make sure to include the newline char when you write

k.stdout.pipe(new JSONParser()).on('data', d => {
  // => {foo: 'bar'}
});
Bash example with bash variables:
const k = cp.spawn('bash');

k.stdin.end(`

  foo="medicine"
  cat <<EOF\n{"foo":"$foo"}\nEOF  # make sure to include the newline char when you write

`);

k.stdout.pipe(new JSONParser()).on('data', d => {
    assert.deepStrictEqual(d, {foo: 'medicine'});  // should pass
});

If your JSON has white space (newlines etc)

If you JSON has unescaped newlines, or the JSON is separated by some other character, then use the delimiter option.

new JSONParser({delimiter: '∆∆∆'});  // use 3 alt-j's to separate json chunks, since newlines won't work

For other solutions to parsing JSON from CLIs, see: https://stackoverflow.com/questions/56014438/get-single-line-json-from-aws-cli

Other options

  1. delayEvery: integer

every x chunks, will use setImmediate to delay processing, good for not blocking the event loop too much.

  1. emitNonJSON: boolean

if there is a line of input that cannot be JSON parsed, it will be emitted as "string", but it will not pushed to output

  1. there are some secret options in the code, have a look in lib/main.ts

Package Sidebar

Install

npm i @oresoftware/json-stream-parser

Weekly Downloads

37

Version

0.0.124

License

SEE LICENSE IN license.md

Unpacked Size

13 kB

Total Files

10

Last publish

Collaborators

  • oresoftware