mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Merge pull request #6889 from kirrg001/improvement/general
improvement: general fixes
This commit is contained in:
commit
45226bcaaa
5 changed files with 62 additions and 21 deletions
|
@ -28,27 +28,27 @@ logger = {
|
||||||
init = function init(tablesOnly) {
|
init = function init(tablesOnly) {
|
||||||
tablesOnly = tablesOnly || false;
|
tablesOnly = tablesOnly || false;
|
||||||
|
|
||||||
// There are 4 possibilities:
|
// There are 4 possible cases:
|
||||||
// 1. The database exists and is up-to-date
|
// CASE 1: The database exists and is up-to-date
|
||||||
// 2. The database exists but is out of date
|
// CASE 2: The database exists but is out of date
|
||||||
// 3. The database exists but the currentVersion setting does not or cannot be understood
|
// CASE 3: The database exists but the currentVersion setting does not or cannot be understood
|
||||||
// 4. The database has not yet been created
|
// CASE 4: The database has not yet been created
|
||||||
return versioning.getDatabaseVersion().then(function (databaseVersion) {
|
return versioning.getDatabaseVersion().then(function (databaseVersion) {
|
||||||
var defaultVersion = versioning.getDefaultDatabaseVersion();
|
var defaultVersion = versioning.getDefaultDatabaseVersion();
|
||||||
|
|
||||||
// Update goes first, to allow for FORCE_MIGRATION
|
// Update goes first, to allow for FORCE_MIGRATION
|
||||||
// 2. The database exists but is out of date
|
// CASE 2: The database exists but is out of date
|
||||||
if (databaseVersion < defaultVersion || process.env.FORCE_MIGRATION) {
|
if (databaseVersion < defaultVersion || process.env.FORCE_MIGRATION) {
|
||||||
// Migrate to latest version
|
// Migrate to latest version
|
||||||
logger.info('Database upgrade required from version ' + databaseVersion + ' to ' + defaultVersion);
|
logger.info('Database upgrade required from version ' + databaseVersion + ' to ' + defaultVersion);
|
||||||
return update(databaseVersion, defaultVersion, logger);
|
return update(databaseVersion, defaultVersion, logger);
|
||||||
|
|
||||||
// 1. The database exists and is up-to-date
|
// CASE 1: The database exists and is up-to-date
|
||||||
} else if (databaseVersion === defaultVersion) {
|
} else if (databaseVersion === defaultVersion) {
|
||||||
logger.info('Up-to-date at version ' + databaseVersion);
|
logger.info('Up-to-date at version ' + databaseVersion);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// 3. The database exists but the currentVersion setting does not or cannot be understood
|
// CASE 3: The database exists but the currentVersion setting does not or cannot be understood
|
||||||
} else {
|
} else {
|
||||||
// In this case we don't understand the version because it is too high
|
// In this case we don't understand the version because it is too high
|
||||||
errors.logErrorAndExit(
|
errors.logErrorAndExit(
|
||||||
|
@ -58,14 +58,14 @@ init = function init(tablesOnly) {
|
||||||
}
|
}
|
||||||
}, function (err) {
|
}, function (err) {
|
||||||
if (err && err.message === 'Settings table does not exist') {
|
if (err && err.message === 'Settings table does not exist') {
|
||||||
// 4. The database has not yet been created
|
// CASE 4: The database has not yet been created
|
||||||
// Bring everything up from initial version.
|
// Bring everything up from initial version.
|
||||||
logger.info('Database initialisation required for version ' + versioning.getDefaultDatabaseVersion());
|
logger.info('Database initialisation required for version ' + versioning.getDefaultDatabaseVersion());
|
||||||
return populate(logger, tablesOnly);
|
return populate(logger, tablesOnly);
|
||||||
}
|
}
|
||||||
// 3. The database exists but the currentVersion setting does not or cannot be understood
|
// CASE 3: the database exists but the currentVersion setting does not or cannot be understood
|
||||||
// In this case the setting was missing or there was some other problem
|
// In this case the setting was missing or there was some other problem
|
||||||
errors.logErrorAndExit('There is a problem with the database', err.message);
|
errors.logErrorAndExit(err, 'Problem occurred during migration initialisation!');
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -155,7 +155,9 @@ errors = {
|
||||||
|
|
||||||
// TODO: Logging framework hookup
|
// TODO: Logging framework hookup
|
||||||
// Eventually we'll have better logging which will know about envs
|
// Eventually we'll have better logging which will know about envs
|
||||||
if ((process.env.NODE_ENV === 'development' ||
|
// you can use DEBUG=true when running tests and need error stdout
|
||||||
|
if ((process.env.NODE_LEVEL === 'DEBUG' ||
|
||||||
|
process.env.NODE_ENV === 'development' ||
|
||||||
process.env.NODE_ENV === 'staging' ||
|
process.env.NODE_ENV === 'staging' ||
|
||||||
process.env.NODE_ENV === 'production')) {
|
process.env.NODE_ENV === 'production')) {
|
||||||
msgs = [chalk.red(i18n.t('errors.errors.error'), err), '\n'];
|
msgs = [chalk.red(i18n.t('errors.errors.error'), err), '\n'];
|
||||||
|
|
|
@ -84,7 +84,15 @@ I18n = {
|
||||||
init: function init() {
|
init: function init() {
|
||||||
// read file for current locale and keep its content in memory
|
// read file for current locale and keep its content in memory
|
||||||
blos = fs.readFileSync(__dirname + '/translations/' + currentLocale + '.json');
|
blos = fs.readFileSync(__dirname + '/translations/' + currentLocale + '.json');
|
||||||
blos = JSON.parse(blos);
|
|
||||||
|
// if translation file is not valid, you will see an error
|
||||||
|
try {
|
||||||
|
blos = JSON.parse(blos);
|
||||||
|
} catch (err) {
|
||||||
|
blos = undefined;
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
if (global.Intl) {
|
if (global.Intl) {
|
||||||
// Determine if the built-in `Intl` has the locale data we need.
|
// Determine if the built-in `Intl` has the locale data we need.
|
||||||
var hasBuiltInLocaleData,
|
var hasBuiltInLocaleData,
|
||||||
|
|
|
@ -1,12 +1,19 @@
|
||||||
var _ = require('lodash'),
|
var _ = require('lodash'),
|
||||||
|
Promise = require('bluebird'),
|
||||||
Models = require('../models'),
|
Models = require('../models'),
|
||||||
errors = require('../errors'),
|
errors = require('../errors'),
|
||||||
|
i18n = require('../i18n'),
|
||||||
effective;
|
effective;
|
||||||
|
|
||||||
effective = {
|
effective = {
|
||||||
user: function (id) {
|
user: function (id) {
|
||||||
return Models.User.findOne({id: id, status: 'all'}, {include: ['permissions', 'roles', 'roles.permissions']})
|
return Models.User.findOne({id: id, status: 'all'}, {include: ['permissions', 'roles', 'roles.permissions']})
|
||||||
.then(function (foundUser) {
|
.then(function (foundUser) {
|
||||||
|
// CASE: {context: {user: id}} where the id is not in our database
|
||||||
|
if (!foundUser) {
|
||||||
|
return Promise.reject(new errors.NotFoundError(i18n.t('errors.models.user.userNotFound')));
|
||||||
|
}
|
||||||
|
|
||||||
var seenPerms = {},
|
var seenPerms = {},
|
||||||
rolePerms = _.map(foundUser.related('roles').models, function (role) {
|
rolePerms = _.map(foundUser.related('roles').models, function (role) {
|
||||||
return role.related('permissions').models;
|
return role.related('permissions').models;
|
||||||
|
|
|
@ -327,6 +327,11 @@ fixtures = {
|
||||||
Owner: 4
|
Owner: 4
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// CASE: if empty db will throw SQLITE_MISUSE, hard to debug
|
||||||
|
if (_.isEmpty(permsToInsert)) {
|
||||||
|
return Promise.reject(new Error('no permission found:' + obj));
|
||||||
|
}
|
||||||
|
|
||||||
permsToInsert = _.map(permsToInsert, function (perms) {
|
permsToInsert = _.map(permsToInsert, function (perms) {
|
||||||
actions.push(perms.action_type);
|
actions.push(perms.action_type);
|
||||||
return DataGenerator.forKnex.createBasic(perms);
|
return DataGenerator.forKnex.createBasic(perms);
|
||||||
|
@ -347,12 +352,18 @@ fixtures = {
|
||||||
});
|
});
|
||||||
|
|
||||||
return db.knex('permissions').insert(permsToInsert).then(function () {
|
return db.knex('permissions').insert(permsToInsert).then(function () {
|
||||||
|
if (_.isEmpty(permissionsRoles)) {
|
||||||
|
return Promise.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
return db.knex('permissions_roles').insert(permissionsRoles);
|
return db.knex('permissions_roles').insert(permissionsRoles);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
insertClients: function insertClients() {
|
insertClients: function insertClients() {
|
||||||
return db.knex('clients').insert(DataGenerator.forKnex.clients);
|
return db.knex('clients').insert(DataGenerator.forKnex.clients);
|
||||||
},
|
},
|
||||||
|
|
||||||
insertAccessToken: function insertAccessToken(override) {
|
insertAccessToken: function insertAccessToken(override) {
|
||||||
return db.knex('accesstokens').insert(DataGenerator.forKnex.createToken(override));
|
return db.knex('accesstokens').insert(DataGenerator.forKnex.createToken(override));
|
||||||
}
|
}
|
||||||
|
@ -438,10 +449,15 @@ getFixtureOps = function getFixtureOps(toDos) {
|
||||||
// Go through our list of things to do, and add them to an array
|
// Go through our list of things to do, and add them to an array
|
||||||
_.each(toDos, function (value, toDo) {
|
_.each(toDos, function (value, toDo) {
|
||||||
var tmp;
|
var tmp;
|
||||||
|
|
||||||
if (toDo !== 'perms:init' && toDo.indexOf('perms:') !== -1) {
|
if (toDo !== 'perms:init' && toDo.indexOf('perms:') !== -1) {
|
||||||
tmp = toDo.split(':');
|
tmp = toDo.split(':');
|
||||||
fixtureOps.push(toDoList[tmp[0]](tmp[1]));
|
fixtureOps.push(toDoList[tmp[0]](tmp[1]));
|
||||||
} else {
|
} else {
|
||||||
|
if (!toDoList[toDo]) {
|
||||||
|
throw new Error('setup todo does not exist - spell mistake?');
|
||||||
|
}
|
||||||
|
|
||||||
fixtureOps.push(toDoList[toDo]);
|
fixtureOps.push(toDoList[toDo]);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -470,12 +486,16 @@ setup = function setup() {
|
||||||
var self = this,
|
var self = this,
|
||||||
args = arguments;
|
args = arguments;
|
||||||
|
|
||||||
return function (done) {
|
return function setup(done) {
|
||||||
Models.init();
|
Models.init();
|
||||||
|
|
||||||
return initFixtures.apply(self, args).then(function () {
|
if (done) {
|
||||||
done();
|
return initFixtures.apply(self, args).then(function () {
|
||||||
}).catch(done);
|
done();
|
||||||
|
}).catch(done);
|
||||||
|
} else {
|
||||||
|
return initFixtures.apply(self, args);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -556,9 +576,13 @@ togglePermalinks = function togglePermalinks(request, toggle) {
|
||||||
};
|
};
|
||||||
|
|
||||||
teardown = function teardown(done) {
|
teardown = function teardown(done) {
|
||||||
migration.reset().then(function () {
|
if (done) {
|
||||||
done();
|
migration.reset().then(function () {
|
||||||
}).catch(done);
|
done();
|
||||||
|
}).catch(done);
|
||||||
|
} else {
|
||||||
|
return migration.reset();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
|
Loading…
Reference in a new issue