Merge pull request #2673 from overleaf/ta-resync-subscriptions-fix

Resync Recurly Subscriptions Script Improvements

GitOrigin-RevId: b042465b7bffcbb73b40d1a7f23de784185d53ef
This commit is contained in:
Eric Mc Sween 2020-03-16 07:30:38 -04:00 committed by Copybot
parent c0049d8b67
commit d772dbaceb

View file

@ -4,6 +4,10 @@ const SubscriptionUpdater = require('../../app/src/Features/Subscription/Subscri
const async = require('async')
const minimist = require('minimist')
// make sure all `allMismatchReasons` are displayed in the output
const util = require('util')
util.inspect.defaultOptions.maxArrayLength = null
const ScriptLogger = {
checkedSubscriptionsCount: 0,
mismatchSubscriptionsCount: 0,
@ -55,11 +59,16 @@ const ScriptLogger = {
const slowCallback = callback => setTimeout(callback, 80)
const handleAPIError = (subscriptionId, error, callback) => {
console.warn(`Errors with subscription id=${subscriptionId}:`, error)
const handleSyncSubscriptionError = (subscription, error, callback) => {
console.warn(`Errors with subscription id=${subscription._id}:`, error)
if (typeof error === 'string' && error.match(/429$/)) {
return setTimeout(callback, 1000 * 60 * 5)
}
if (typeof error === 'string' && error.match(/5\d\d$/)) {
return setTimeout(() => {
syncSubscription(subscription, callback)
}, 1000 * 60)
}
slowCallback(callback)
}
@ -68,7 +77,7 @@ const syncSubscription = (subscription, callback) => {
subscription.recurlySubscription_id,
(error, recurlySubscription) => {
if (error) {
return handleAPIError(subscription._id, error, callback)
return handleSyncSubscriptionError(subscription, error, callback)
}
ScriptLogger.recordMismatch(subscription, recurlySubscription)
@ -83,7 +92,7 @@ const syncSubscription = (subscription, callback) => {
{},
error => {
if (error) {
return handleAPIError(subscription._id, error, callback)
return handleSyncSubscriptionError(subscription, error, callback)
}
slowCallback(callback)
}
@ -97,7 +106,9 @@ const syncSubscriptions = (subscriptions, callback) => {
}
const loopForSubscriptions = (skip, callback) => {
Subscription.find({ recurlySubscription_id: { $exists: true } })
Subscription.find({
recurlySubscription_id: { $exists: true, $ne: '' }
})
.sort('_id')
.skip(skip)
.limit(FETCH_LIMIT)