Skip to content

stream-utils/promise-transform-streams

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

promise-transform-streams

NPM version Build status Test coverage Dependency Status License Downloads Gittip

Creates promise-based transform streams. .map() creates a stream that converts objects to promises. .resolve() resolves all these promises.

The main use-case for this is to create "concurrent" transform that preserve order. This module does not apply any concurrent limits! However, you could play with the buffer sizes, which indirectly relate to concurrency in this context.

Example

Suppose you have MongoDB documents that look like this:

var post = {
  creator_id: ObjectId('123412341234123412341234'),
  title: 'some title',
  markdown: 'blah'
}

You want to grab all the .creators, but you still want to stream all the results. Here's how to do it:

var PStream = require('promise-transform-stream')

db.posts.find({}).stream()
// get the creator of each post, returns a stream of promises
.pipe(PStream.map(getCreator))
// resolves each promise in the stream in order
.pipe(PStream.resolve())
// no we can serialize the results and send it to the client!
.pipe(JSONStream.stringify())
.pipe(zlib.createGzip())
.pipe(res)

function getCreator(post) {
  return new Promise(function (resolve, reject) {
    db.users.findOne({
      _id: post.creator_id
    }, function (err, user) {
      if (err) return reject(err)
      post.creator = user
      resolve(post)
    })
  })
}

To be more efficient, you'd probably want to query each creator_id once per request.

API

.create(transform, [flush])

Create a new Transform constructor with ._transform and ._flush methods. transform should resolve to the mapped document. flush should not have any arguments.

var Transform = PStream.create(function (doc) {
  return Promise.resolve(doc)
})

db.posts.find({}).stream()
.pipe(Transform())

.map(transform, [flush])

The same as .create(), except it returns the transform instance immediately, through2-style. This is not recommended!

.resolve([options])

Returns a resolving transform stream.

About

Create and resolve a promise of streams

Resources

License

Stars

Watchers

Forks

Packages

No packages published