mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
8687772604
refs #5940, #5923 - make read-directory ignore invalid package.json files - display a warning about invalid package.json files on startup - add tests to ensure read-directory continues, even with invalid package.json files
64 lines
1.8 KiB
JavaScript
64 lines
1.8 KiB
JavaScript
/**
|
|
* Dependencies
|
|
*/
|
|
|
|
var readThemes = require('./read-themes'),
|
|
Promise = require('bluebird'),
|
|
_ = require('lodash');
|
|
|
|
/**
|
|
* Validate themes:
|
|
*
|
|
* 1. Check if theme has package.json
|
|
*/
|
|
|
|
function validateThemes(dir) {
|
|
var result = {
|
|
warnings: [],
|
|
errors: []
|
|
};
|
|
|
|
return readThemes(dir)
|
|
.tap(function (themes) {
|
|
_.each(themes, function (theme, name) {
|
|
var hasPackageJson, warning;
|
|
|
|
hasPackageJson = theme['package.json'] !== undefined;
|
|
|
|
if (!hasPackageJson) {
|
|
warning = {
|
|
message: 'Found a theme with no package.json file',
|
|
context: 'Theme name: ' + name,
|
|
help: 'This will be required in future. Please see http://docs.ghost.org/themes/'
|
|
};
|
|
|
|
result.warnings.push(warning);
|
|
}
|
|
|
|
// if package.json is `null`, it means that it exists
|
|
// but JSON.parse failed (invalid json syntax)
|
|
if (hasPackageJson && theme['package.json'] === null) {
|
|
warning = {
|
|
message: 'Found a malformed package.json',
|
|
context: 'Theme name: ' + name,
|
|
help: 'Valid package.json will be required in future. Please see http://docs.ghost.org/themes/'
|
|
};
|
|
|
|
result.warnings.push(warning);
|
|
}
|
|
});
|
|
})
|
|
.then(function () {
|
|
var hasNotifications = result.warnings.length || result.errors.length;
|
|
|
|
if (hasNotifications) {
|
|
return Promise.reject(result);
|
|
}
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Expose `validateThemes`
|
|
*/
|
|
|
|
module.exports = validateThemes;
|