
Product
Introducing Socket Scanning for OpenVSX Extensions
Socket now scans OpenVSX extensions, giving teams early detection of risky behaviors, hidden capabilities, and supply chain threats in developer tools.
batch-mobile
Advanced tools
Asynchronous batched iterable for (mongo) cursors
A library when one is not enough and all is to much.
npm i batch-mobile
cursor, batchSize)cursor: Any iterable cursor which exposes an asynchronous next method
(best practice with mongo is to create the cursor with the "batchSize" option to
match the value passed in "batchSize" argument for optimal memory usage)batchSize: The size of the yielded batch. Defaults to 200 if unset.async function example() {
const { getBatchedIterableFromCursor } = require('batch-mobile')
for await (const batchOfItems of getBatchedIterableFromCursor(cursor)) {
await pushBatchToService(batchOfItems)
}
}();
const { MongoClient } = require('mongodb')
const client = await (new MongoClient(process.env.MONGO_URI)).connect()
const { getBatchedIterableFromCursor } = require('batch-mobile')
const BATCH_SIZE = 1000;
async function example() {
try {
const collection = client.db('application').collection('collection')
// By using the batch size option we make sure mongo driver pulls
// exactly the amount of documents into the process memory as we handle them.
// This will cause optimal memory usage and prevent unnecessary round trips to the mongo
// server
const options = {cursor: {batchSize: BATCH_SIZE}}
const cursor = collection
.find({ foo: 'bar' }, options)
for await (const batch of getBatchedIterableFromCursor(cursor, BATCH_SIZE)) {
await processItemsFrom(batch)
}
} finally {
await client.close(true)
}
}();
FAQs
Asynchronous batched iterable for (mongo) cursors
We found that batch-mobile demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

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.

Product
Socket now scans OpenVSX extensions, giving teams early detection of risky behaviors, hidden capabilities, and supply chain threats in developer tools.

Product
Bringing supply chain security to the next generation of JavaScript package managers

Product
A safer, faster way to eliminate vulnerabilities without updating dependencies