🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

mongo-fetcher

A helper that allows fetching data concurrently from mongodb

1.0.0
beta
latest
Version published
Weekly downloads
0
-100%
Maintainers
1
Weekly downloads
 
Created

MongoFetcher

It exposes a function mongoForeach() which, given a collection and a query, will perform an async task for every document matching the query. For example, let's assume we want to remove all our archives in a S3 bucket, which are referenced in mongo.

Our File collection contains documents which look like this :

{
  documentType: string,
  name: string,
  ... [other fields]
}

We could use our mongoForeach to upload them with a high throughput :

  const { mongoForeach } = require('@payfit/mongo-fetcher')
  const db = require('./db') // here we assume that ./db exposes a valid mongodb connection
  const s3service = require('./s3service')

  await mongoForeach(
    db.collection('File'),
    { documentType: 'archive' }, // we want only archives
    async file => { // we can use our db document and do any task we want with it
      try {
        await s3service.deleteFile(file.name)
        await db.collection('File').removeOne({ _id: file._id })
      } catch (err) {
        // handle error
      }
    },
    {
      batchSize: 150, // we fetch items from mongo 150 by 150
      concurrency: 20, // we want to have maximum 20 promises running in parallel that process the task
    }
  )

FAQs

Package last updated on 12 Jun 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts