Skip to content

Spawn a child process to execute mongoimport/mongoexport

License

Notifications You must be signed in to change notification settings

otterthecat/spawngo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

spawngo

A wrapper to spawn mongoimport/export processes

usage

const Spawngo = require('spawngo')

// create a new instance
let spawngo = new Spawngo({
  user: 'foo',
  pw: 'bar',
  'collection': 'bang'
})
// call #import() function and pass a file to import into mongoDb
// this will return a child process object
let childProcess = spawngo.import('my.json')

// handle events as needed
childProcess.stdout.on('data', function (data) {
  // block to handle stdout
})

childProcess.stderr.on('data', function (data) {
  // block to handle stderr
})

childProcess.on('close', function (data) {
  // block to handle close
})

Note that mongoDb sends ALL status updates to stderr, so to better determine if your process was successful, you should ensure the status code from theclose event returned a 0, and not rely on stderr.

Exporting is nearly identical to the above, but instead of import(), you would call export() to export the collection as defined when spawngo was instantiated, or updated using .set()

let childProcess = spawngo.export()

If you wish to export a different collection, but not alter the internal configurated collection, you can pass a string of the target collection,:

let childProcess = spawngo.export('collectionName')

api

Constructor(options) options (Object): Configuration object. Allowed properties are as follows (displayed with default values)

  • host: 'localhost'
  • user: ''
  • pwd: ''
  • db: ''
  • collection: ''
  • jsonArray: true
  • upsertFields: undefined
  • cpus: [default is number of machine's cpu cores]
  • drop: false

Instead of passing options to constructor, you can also apply your settings by using the .set() function.

If no user and password are set, then the call to mongoimport will not use authentication.

import(fileName)

fileName (String): Path of the json/csv/tsv file to import

returns: ChildProcess of the spawned query.

export(collection)

collection (String [optional]): Name of the collection to export. The exported json file will be named after the collection (i.e collectionName.json).

The string aurgument is optional. Not passing a string will use the collect as defined internally either via the constructor settings, or from using .set().

Note that passsing a collection string in this manner will NOT alter the internal configuration.

returns: ChildProcess of the spawned query.

set(optsObj or key, value)

optsObj (Object): Configuration object. See Constructor above to see all available options.

key (String), value (String): to update a single congiguration property, you may pass a key/value pair of strings as an argument: spawngo.set('collection', 'myThings').

returns: The spawngo instance.

About

Spawn a child process to execute mongoimport/mongoexport

Resources

License

Stars

Watchers

Forks

Packages

No packages published