mirror of https://github.com/TryGhost/Ghost.git
69 lines
2.3 KiB
JavaScript
69 lines
2.3 KiB
JavaScript
const _ = require('lodash');
|
|
const Promise = require('bluebird');
|
|
const logging = require('../../../../../shared/logging');
|
|
const debug = require('ghost-ignition').debug('migrations');
|
|
|
|
module.exports.config = {
|
|
transaction: true
|
|
};
|
|
|
|
module.exports.up = (options) => {
|
|
let localOptions = _.merge({
|
|
context: {internal: true}
|
|
}, options);
|
|
const settingsKey = 'members_subscription_settings';
|
|
|
|
return localOptions
|
|
.transacting('settings')
|
|
.then((response) => {
|
|
if (!response) {
|
|
logging.warn('Cannot find settings.');
|
|
return;
|
|
}
|
|
|
|
let subscriptionSettingsEntry = response.find((entry) => {
|
|
return entry.key === settingsKey;
|
|
});
|
|
|
|
if (!subscriptionSettingsEntry) {
|
|
logging.warn('Cannot find members subscription settings.');
|
|
return;
|
|
}
|
|
|
|
let subscriptionSettings = JSON.parse(subscriptionSettingsEntry.value);
|
|
|
|
debug('before cleanup');
|
|
debug(JSON.stringify(subscriptionSettings, null, 2));
|
|
|
|
const stripePaymentProcessor = subscriptionSettings.paymentProcessors.find(
|
|
paymentProcessor => paymentProcessor.adapter === 'stripe'
|
|
);
|
|
|
|
// Remove "broken" complimentary plans that were introduced with 3.10.0, they didn't have
|
|
// interval property defined unlike regular plans
|
|
if (stripePaymentProcessor && stripePaymentProcessor.config.public_token && stripePaymentProcessor.config.secret_token) {
|
|
stripePaymentProcessor.config.plans = stripePaymentProcessor.config.plans.filter((plan) => {
|
|
return plan.interval !== undefined;
|
|
});
|
|
}
|
|
|
|
debug('after cleanup');
|
|
debug(JSON.stringify(subscriptionSettings, null, 2));
|
|
|
|
return localOptions
|
|
.transacting('settings')
|
|
.where('key', settingsKey)
|
|
.update({
|
|
value: JSON.stringify(subscriptionSettings)
|
|
});
|
|
});
|
|
};
|
|
|
|
// `up` is only run to fix a problem that is introduced with 3.10.0,
|
|
// it doesn't make sense to "reintroduced" broken state with down migration
|
|
module.exports.down = () => Promise.resolve();
|
|
|
|
module.exports.config = {
|
|
transaction: true
|
|
};
|