habitica/migrations/users/bulk-email.js

67 lines
1.8 KiB
JavaScript
Raw Normal View History

/* eslint-disable no-console */
import moment from 'moment';
import nconf from 'nconf';
2019-10-08 14:57:10 +00:00
import { sendTxn } from '../../website/server/libs/email';
import { model as User } from '../../website/server/models/user';
const BASE_URL = nconf.get('BASE_URL');
const EMAIL_SLUG = 'mandrill-email-slug'; // Set email template to send
const MIGRATION_NAME = 'bulk-email';
const progressCount = 250;
let count = 0;
2018-11-09 12:01:19 +00:00
async function updateUser (user) {
2019-10-08 16:36:55 +00:00
count += 1;
if (count % progressCount === 0) {
console.warn(`${count} ${user._id}`);
// eslint-disable-next-line no-promise-executor-return
await new Promise(resolve => setTimeout(resolve, 5000));
}
2019-11-19 18:53:21 +00:00
await sendTxn(
user,
EMAIL_SLUG,
2019-10-08 14:57:10 +00:00
[{ name: 'BASE_URL', content: BASE_URL }], // Add variables from template
2019-11-19 18:59:53 +00:00
);
return User.updateOne({ _id: user._id }, { $set: { migration: MIGRATION_NAME } }).exec();
}
2019-10-15 13:32:53 +00:00
export default async function processUsers () {
2019-10-08 14:57:10 +00:00
const query = {
migration: { $ne: MIGRATION_NAME },
'auth.timestamps.loggedin': { $gt: moment().subtract(2, 'weeks').toDate() }, // customize or remove to target different populations
};
const fields = {
2018-11-09 12:04:25 +00:00
_id: 1,
auth: 1,
preferences: 1,
profile: 1,
};
while (true) { // eslint-disable-line no-constant-condition
const users = await User // eslint-disable-line no-await-in-loop
.find(query)
2018-11-09 12:01:19 +00:00
.limit(250)
2019-10-08 14:57:10 +00:00
.sort({ _id: 1 })
.select(fields)
2018-11-09 12:10:55 +00:00
.lean()
.exec();
if (users.length === 0) {
console.warn('All appropriate users found and modified.');
console.warn(`\n${count} users processed\n`);
break;
} else {
query._id = {
$gt: users[users.length - 1],
};
}
await Promise.all(users.map(updateUser)); // eslint-disable-line no-await-in-loop
}
2019-10-15 13:32:53 +00:00
}