overleaf/services/web/scripts/wfh_2020/wfh_2020_export.js

49 lines
1.1 KiB
JavaScript
Raw Normal View History

const mongojs = require('../../app/src/infrastructure/mongojs')
const { db } = mongojs
const async = require('async')
db.subscriptions.aggregate(
{ $match: { teamName: /(Work From Home|Work from Home)/ } },
{ $unwind: '$member_ids' },
{ $group: { _id: null, memberIds: { $addToSet: '$member_ids' } } },
function(err, results) {
if (err) {
console.error(err)
process.exit(1)
}
if (!results.length) {
console.error('No users found')
process.exit(1)
}
const userIds = results[0].memberIds
console.log('Id,First Name,Last Name,Sign Up Date,Emails')
async.eachLimit(
userIds,
10,
function(userId, callback) {
db.users.findOne(userId, function(err, user) {
const emails = user.emails.map(email => email.email)
console.log(
`${user._id},${user.first_name || ''},${user.last_name || ''},${
user.signUpDate
},${emails.join(',')}`
)
callback(err)
})
},
function(err) {
if (err) {
console.error(err)
process.exit(1)
}
process.exit(0)
}
)
}
)