Skip to content

Commit

Permalink
Merge pull request #1383 from mozilla/paginate-pre-fxa-emails
Browse files Browse the repository at this point in the history
use knex-paginate to paginate pre-FXA query
  • Loading branch information
groovecoder authored Nov 20, 2019
2 parents ed0036e + 01715ad commit 845da27
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 31 deletions.
10 changes: 8 additions & 2 deletions db/DB.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
// eslint-disable-next-line node/no-extraneous-require
const uuidv4 = require("uuid/v4");
const Knex = require("knex");
const { attachPaginate } = require("knex-paginate");

const { FluentError } = require("../locale-utils");
const AppConstants = require("../app-constants");
Expand All @@ -16,6 +17,8 @@ const mozlog = require("../log");
const knexConfig = require("./knexfile");

let knex = Knex(knexConfig);
attachPaginate();

const log = mozlog("DB");


Expand Down Expand Up @@ -79,8 +82,11 @@ const DB = {
return subscriberAndEmails;
},

async getPreFxaSubscribers() {
return await knex("subscribers").whereRaw("(fxa_uid = '') IS NOT FALSE");
async getPreFxaSubscribersPage(pagination) {
return await knex("subscribers")
.whereRaw("(fxa_uid = '') IS NOT FALSE")
.paginate(pagination);

},

async getSubscriberByEmail(email) {
Expand Down
5 changes: 5 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
"intl-pluralrules": "^0.2.1",
"isemail": "^3.1.3",
"knex": "^0.19.5",
"knex-paginate": "^1.1.0",
"lodash": "^4.17.13",
"mozlog": "^2.2.0",
"nodemailer": "^4.6.4",
Expand Down
70 changes: 41 additions & 29 deletions scripts/send-email-to-pre-fxa-subscribers.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
"use strict";

/* eslint-disable no-process-env */

const { negotiateLanguages, acceptedLanguages } = require("fluent-langneg");

const AppConstants = require("../app-constants");
Expand All @@ -8,42 +10,52 @@ const EmailHelpers = require("../template-helpers/emails.js");
const EmailUtils = require("../email-utils");
const { LocaleUtils } = require ("../locale-utils");

const PAGE_SIZE = process.env.PAGE_SIZE;


(async (req) => {
const localeUtils = LocaleUtils.init();
EmailUtils.init();

const subscribers = await DB.getPreFxaSubscribers();
console.log(`Found ${subscribers.length} subscriber records with empty fxa_uid.`);
const notifiedSubscribers = [];
const utmID = "pre-fxa";
for (const subscriber of subscribers) {
const signupLanguage = subscriber.signup_language;
const subscriberEmail = subscriber.primary_email;
const requestedLanguage = signupLanguage ? acceptedLanguages(signupLanguage) : "";
const supportedLocales = negotiateLanguages(
requestedLanguage,
localeUtils.availableLanguages,
{defaultLocale: "en"}
);

if (!notifiedSubscribers.includes(subscriberEmail)) {
const sendInfo = await EmailUtils.sendEmail(
subscriberEmail,
LocaleUtils.fluentFormat(supportedLocales, "pre-fxa-subject"), // email subject
"default_email", // email template
{
supportedLocales,
SERVER_URL: AppConstants.SERVER_URL,
unsubscribeUrl: EmailUtils.getUnsubscribeUrl(subscriber, utmID), // need to test the flow for legacy users who want to unsubscribe
ctaHref: EmailHelpers.getPreFxaUtmParams(AppConstants.SERVER_URL, "create-account-button", subscriberEmail),
whichPartial: "email_partials/pre-fxa",
preFxaEmail: true,
email: subscriberEmail,
},

const subscribersResult = await DB.getPreFxaSubscribersPage({ perPage: PAGE_SIZE, currentPage: 1 });
console.log(`Found ${subscribersResult.pagination.total} subscriber records with empty fxa_uid.`);
console.log(`Will process ${subscribersResult.pagination.lastPage} pages of size ${PAGE_SIZE}.`);
const lastPage = subscribersResult.pagination.lastPage;


for (let currentPage = 1; currentPage <= lastPage; currentPage++) {
console.log(`Processing page ${currentPage} of ${lastPage}.`);
const subscribersPageResult = await DB.getPreFxaSubscribersPage({ perPage: PAGE_SIZE, currentPage });
for (const subscriber of subscribersPageResult.data) {
const signupLanguage = subscriber.signup_language;
const subscriberEmail = subscriber.primary_email;
const requestedLanguage = signupLanguage ? acceptedLanguages(signupLanguage) : "";
const supportedLocales = negotiateLanguages(
requestedLanguage,
localeUtils.availableLanguages,
{defaultLocale: "en"}
);
notifiedSubscribers.push(subscriberEmail);
console.log(`Sent email to ${subscriberEmail}, info: ${JSON.stringify(sendInfo)}`);

if (!notifiedSubscribers.includes(subscriberEmail)) {
const sendInfo = await EmailUtils.sendEmail(
subscriberEmail,
LocaleUtils.fluentFormat(supportedLocales, "pre-fxa-subject"), // email subject
"default_email", // email template
{
supportedLocales,
SERVER_URL: AppConstants.SERVER_URL,
unsubscribeUrl: EmailUtils.getUnsubscribeUrl(subscriber, utmID), // need to test the flow for legacy users who want to unsubscribe
ctaHref: EmailHelpers.getPreFxaUtmParams(AppConstants.SERVER_URL, "create-account-button", subscriberEmail),
whichPartial: "email_partials/pre-fxa",
preFxaEmail: true,
email: subscriberEmail,
},
);
notifiedSubscribers.push(subscriberEmail);
console.log(`Sent email to ${subscriberEmail}, info: ${JSON.stringify(sendInfo)}`);
}
}
}
console.log(`Notified subscribers: ${JSON.stringify(notifiedSubscribers)}`);
Expand Down

0 comments on commit 845da27

Please sign in to comment.