mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
🐛 Ensured import does not override private setting (#10882)
closes #10788 This adds an extra filter to the preImport method of the settings importer to removes settings with the key `is_private` This message is specifically only for when an import has privacy mode ON and the current site has privacy mode OFF.
This commit is contained in:
parent
13b1a9e7ef
commit
373627223c
2 changed files with 123 additions and 0 deletions
|
@ -6,6 +6,33 @@ const debug = require('ghost-ignition').debug('importer:settings'),
|
||||||
defaultSettings = require('../../../schema').defaultSettings,
|
defaultSettings = require('../../../schema').defaultSettings,
|
||||||
labsDefaults = JSON.parse(defaultSettings.blog.labs.defaultValue);
|
labsDefaults = JSON.parse(defaultSettings.blog.labs.defaultValue);
|
||||||
|
|
||||||
|
const isFalse = (value) => {
|
||||||
|
// Catches false, null, undefined, empty string
|
||||||
|
if (!value) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (value === 'false') {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (value === '0') {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
const isTrue = (value) => {
|
||||||
|
if (value === true) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (value === 'true') {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (value === '1') {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
class SettingsImporter extends BaseImporter {
|
class SettingsImporter extends BaseImporter {
|
||||||
constructor(allDataFromFile) {
|
constructor(allDataFromFile) {
|
||||||
super(allDataFromFile, {
|
super(allDataFromFile, {
|
||||||
|
@ -80,6 +107,26 @@ class SettingsImporter extends BaseImporter {
|
||||||
return ['core', 'theme'].indexOf(data.type) === -1;
|
return ['core', 'theme'].indexOf(data.type) === -1;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const newIsPrivate = _.find(this.dataToImport, {key: 'is_private'});
|
||||||
|
const oldIsPrivate = _.find(this.existingData, {key: 'is_private'});
|
||||||
|
|
||||||
|
this.dataToImport = _.filter(this.dataToImport, (data) => {
|
||||||
|
return data.key !== 'is_private';
|
||||||
|
});
|
||||||
|
|
||||||
|
this.dataToImport = _.filter(this.dataToImport, (data) => {
|
||||||
|
return data.key !== 'password';
|
||||||
|
});
|
||||||
|
|
||||||
|
// Only show warning if we are importing a private site into a non-private site.
|
||||||
|
if (oldIsPrivate && newIsPrivate && isFalse(oldIsPrivate.value) && isTrue(newIsPrivate.value)) {
|
||||||
|
this.problems.push({
|
||||||
|
message: 'IMPORTANT: Content in this import was previously published on a private Ghost install, but the current site is public. Are your privacy settings up to date?',
|
||||||
|
help: this.modelName,
|
||||||
|
context: JSON.stringify(newIsPrivate)
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
_.each(this.dataToImport, (obj) => {
|
_.each(this.dataToImport, (obj) => {
|
||||||
if (obj.key === 'labs' && obj.value) {
|
if (obj.key === 'labs' && obj.value) {
|
||||||
// Overwrite the labs setting with our current defaults
|
// Overwrite the labs setting with our current defaults
|
||||||
|
@ -108,6 +155,13 @@ class SettingsImporter extends BaseImporter {
|
||||||
return super.beforeImport();
|
return super.beforeImport();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fetchExisting(modelOptions) {
|
||||||
|
return models.Settings.findAll(modelOptions)
|
||||||
|
.then((existingData) => {
|
||||||
|
this.existingData = existingData.toJSON();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
generateIdentifier() {
|
generateIdentifier() {
|
||||||
this.stripProperties(['id']);
|
this.stripProperties(['id']);
|
||||||
return Promise.resolve();
|
return Promise.resolve();
|
||||||
|
|
69
core/test/unit/data/importer/importers/data/settings_spec.js
Normal file
69
core/test/unit/data/importer/importers/data/settings_spec.js
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
const find = require('lodash/find');
|
||||||
|
const should = require('should');
|
||||||
|
const SettingsImporter = require('../../../../../../server/data/importer/importers/data/settings');
|
||||||
|
|
||||||
|
describe('SettingsImporter', function () {
|
||||||
|
describe('#beforeImport', function () {
|
||||||
|
it('Removes the password setting', function () {
|
||||||
|
const fakeSettings = [{
|
||||||
|
key: 'password',
|
||||||
|
value: 'hunter2'
|
||||||
|
}, {
|
||||||
|
key: 'is_private',
|
||||||
|
value: true
|
||||||
|
}];
|
||||||
|
|
||||||
|
const importer = new SettingsImporter({settings: fakeSettings}, {dataKeyToImport: 'settings'});
|
||||||
|
|
||||||
|
importer.beforeImport();
|
||||||
|
|
||||||
|
const passwordSetting = find(importer.dataToImport, {key: 'password'});
|
||||||
|
|
||||||
|
should.equal(passwordSetting, undefined);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Removes the is_private setting', function () {
|
||||||
|
const fakeSettings = [{
|
||||||
|
key: 'password',
|
||||||
|
value: 'hunter2'
|
||||||
|
}, {
|
||||||
|
key: 'is_private',
|
||||||
|
value: true
|
||||||
|
}];
|
||||||
|
|
||||||
|
const importer = new SettingsImporter({settings: fakeSettings}, {dataKeyToImport: 'settings'});
|
||||||
|
|
||||||
|
importer.beforeImport();
|
||||||
|
|
||||||
|
const passwordSetting = find(importer.dataToImport, {key: 'is_private'});
|
||||||
|
|
||||||
|
should.equal(passwordSetting, undefined);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Adds a problem if the existing data is_private is false, and new data is_private is true', function () {
|
||||||
|
const fakeSettings = [{
|
||||||
|
key: 'password',
|
||||||
|
value: 'hunter2'
|
||||||
|
}, {
|
||||||
|
key: 'is_private',
|
||||||
|
value: true
|
||||||
|
}];
|
||||||
|
|
||||||
|
const fakeExistingSettings = [{
|
||||||
|
key: 'is_private',
|
||||||
|
value: false
|
||||||
|
}];
|
||||||
|
|
||||||
|
const importer = new SettingsImporter({settings: fakeSettings}, {dataKeyToImport: 'settings'});
|
||||||
|
|
||||||
|
importer.existingData = fakeExistingSettings;
|
||||||
|
importer.beforeImport();
|
||||||
|
|
||||||
|
const problem = find(importer.problems, {
|
||||||
|
message: 'IMPORTANT: Content in this import was previously published on a private Ghost install, but the current site is public. Are your privacy settings up to date?'
|
||||||
|
});
|
||||||
|
|
||||||
|
should.exist(problem);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
Loading…
Add table
Reference in a new issue