npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

stream-transform-nested-json

v1.0.0

Published

Transform Node.js streams with nested JSON arrays into separate objects

Downloads

4

Readme

Stream transformer for nested objects in JSON arrays

No dependencies License MIT

A huge thanks to Say Media, Inc. for the highland-find-json package where we could copy most of the code and docs from. They wrote it for Highland, we ported it to native Node.js Streams. Their license is MIT and this port as well.

stream-transform-nested-json is a library for locating JSON objects in a stream of buffers.

The primary use-case for this library is for dealing with very large (or infinite) streams containing many relatively-small JSON objects, such as JSON-based logging.

It expects as input a stream of buffers. It emits another stream of buffers, but in the output each buffer exactly frames a JSON object from the input stream.

For example, imagine the following buffers show up in a stream:

  • [{"user":"
  • bert"},{"user
  • ":null}]

stream-transform-nested-json would transform the above and produce a stream with two buffers as follows:

  • {"user":"bert"}
  • {"user":null}

This library does not actually parse the JSON; instead, it counts open and close braces so it can find object boundaries with minimal overhead. As long as its input is valid JSON, each of the buffers it emits will contain a valid JSON object.

Usage

const { Transform, Readable } = require("stream");
const Transformer = require("stream-transform-nested-json");

const transform = new Transformer();
const readable = Readable.from([
  Buffer.from('{"name":{'),
  Buffer.from('"first":"Adriaan"'),
  Buffer.from('}},{"name":'),
  Buffer.from('"Bert"}'),
]);
readable.pipe(transform).on("data", (chunk) => {
  console.log("=> Object:", chunk.toString());
  // Output:
  // => Object: {"name":{"first":"Adriaan"}}
  // => Object: {"name":"Bert"}
});

const transformNested = new Transformer({ nestingLevel: 1 });
const readableNested = Readable.from([
  Buffer.from('{"items":[{"name":'),
  Buffer.from('"Adriaan"},{"name"'),
  Buffer.from(':"Bert"}]}'),
]);
readableNested.pipe(transformNested).on("data", (chunk) => {
  console.log("=> Object:", chunk.toString());
  // Output:
  // => Object: {"name":"Adriaan"}
  // => Object: {"name":"Bert"}
});

The transformer optionally takes a single options object as an argument, which can contain the following optional properties:

  • nestingLevel: controls how many levels of braces to "skip" when locating objects. The default is 0, which treates the first level of braces as the objects of interest. If the input stream contains an array of objects that are nested inside another object, such as {"items":[{...},{...}]} then you can pass 1 here to skip the outer braces and find the ones within the array instead. Do note that if you have multiple arrays on the same level you will get all elements from those arrays.

  • maxObjectSize controls the size of an internal buffer (in bytes) used to accumulate the parts of a JSON object until the closing brace is found. Objects that consist of more bytes than this will be dropped and an error will be emitted into the output stream, so it's important to set this larger than your expected maximum object size. By default it is 8 kilobytes. Changing this value will increase or decrease the size of a chunk of memory that is allocated for the duration of the stream.

Installation

As usual:

npm install --save stream-transform-nested-json

License

This library may be distributed under the terms of the MIT license. For full details, see LICENSE.