const mongojs = require('../app/js/infrastructure/mongojs') const { db } = mongojs const async = require('async') const minilist = require('minimist') const updateUser = function (user, callback) { console.log(`Updating user ${user._id}`) const update = { $set: { emails: [{ email: user.email, createdAt: new Date() }] } } db.users.update({_id: user._id}, update, callback) } const updateUsers = (users, callback) => async.eachLimit(users, ASYNC_LIMIT, updateUser, function (error) { if (error) { callback(error) return } counter += users.length console.log(`${counter} users updated`) loopForUsers(callback) }) var loopForUsers = callback => db.users.find( { emails: {$exists: false} }, { email: 1 } ).limit(FETCH_LIMIT, function (error, users) { if (error) { callback(error) return } if (users.length === 0) { console.log(`DONE (${counter} users updated)`) return callback() } updateUsers(users, callback) }) var counter = 0 var run = () => loopForUsers(function (error) { if (error) { throw error } process.exit() }) let FETCH_LIMIT, ASYNC_LIMIT var setup = function () { let args = minilist(process.argv.slice(2)) FETCH_LIMIT = (args.fetch) ? args.fetch : 100 ASYNC_LIMIT = (args.async) ? args.async : 10 } setup() run()