2013-07-27 19:41:10 +00:00
|
|
|
|
|
|
|
var _ = require('underscore'),
|
|
|
|
when = require('when'),
|
|
|
|
series = require('when/sequence'),
|
|
|
|
errors = require('../../errorHandling'),
|
|
|
|
knex = require('../../models/base').Knex,
|
2013-09-14 20:01:46 +01:00
|
|
|
initialVersion = '000',
|
2013-09-14 22:13:59 +01:00
|
|
|
// This databaseVersion string should always be the current version of Ghost,
|
2013-07-27 19:41:10 +00:00
|
|
|
// we could probably load it from the config file.
|
2013-09-02 02:49:08 +01:00
|
|
|
// - Will be possible after default-settings.json restructure
|
2013-09-14 22:13:59 +01:00
|
|
|
databaseVersion = '000';
|
2013-07-27 19:41:10 +00:00
|
|
|
|
2013-09-14 22:13:59 +01:00
|
|
|
function getDatabaseVersion() {
|
2013-08-03 16:11:16 +01:00
|
|
|
return knex.Schema.hasTable('settings').then(function () {
|
2013-09-14 22:13:59 +01:00
|
|
|
// Check for the databaseVersion from the settings table
|
2013-08-03 16:11:16 +01:00
|
|
|
return knex('settings')
|
2013-09-14 22:13:59 +01:00
|
|
|
.where('key', 'databaseVersion')
|
2013-08-03 16:11:16 +01:00
|
|
|
.select('value')
|
2013-09-14 22:13:59 +01:00
|
|
|
.then(function (databaseVersionSetting) {
|
|
|
|
if (databaseVersionSetting && databaseVersionSetting.length > 0) {
|
|
|
|
databaseVersionSetting = databaseVersionSetting[0].value;
|
2013-08-03 16:11:16 +01:00
|
|
|
} else {
|
|
|
|
// we didn't get a response we understood, assume initialVersion
|
2013-09-14 22:13:59 +01:00
|
|
|
databaseVersionSetting = initialVersion;
|
2013-08-03 16:11:16 +01:00
|
|
|
}
|
2013-09-14 22:13:59 +01:00
|
|
|
return databaseVersionSetting;
|
2013-08-03 16:11:16 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-07-27 19:41:10 +00:00
|
|
|
module.exports = {
|
2013-09-14 22:13:59 +01:00
|
|
|
databaseVersion: databaseVersion,
|
2013-07-27 19:41:10 +00:00
|
|
|
// Check for whether data is needed to be bootstrapped or not
|
|
|
|
init: function () {
|
2013-08-03 16:11:16 +01:00
|
|
|
var self = this;
|
2013-07-27 19:41:10 +00:00
|
|
|
|
2013-09-14 22:13:59 +01:00
|
|
|
return getDatabaseVersion().then(function (databaseVersionSetting) {
|
|
|
|
// We are assuming here that the databaseVersionSetting will
|
|
|
|
// always be less than the databaseVersion value.
|
|
|
|
if (databaseVersionSetting === databaseVersion) {
|
2013-08-03 16:11:16 +01:00
|
|
|
return when.resolve();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bring the data up to the latest version
|
2013-09-14 22:13:59 +01:00
|
|
|
return self.migrateUpFromVersion(databaseVersion);
|
2013-07-27 19:41:10 +00:00
|
|
|
}, function () {
|
|
|
|
// If the settings table doesn't exist, bring everything up from initial version.
|
2013-08-03 16:11:16 +01:00
|
|
|
return self.migrateUpFromVersion(initialVersion);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
// ### Reset
|
|
|
|
// Migrate from where we are down to nothing.
|
|
|
|
reset: function () {
|
|
|
|
var self = this;
|
|
|
|
|
2013-09-14 22:13:59 +01:00
|
|
|
return getDatabaseVersion().then(function (databaseVersionSetting) {
|
|
|
|
// bring everything down from the databaseVersion
|
|
|
|
return self.migrateDownFromVersion(databaseVersionSetting);
|
2013-08-03 16:11:16 +01:00
|
|
|
}, function () {
|
|
|
|
// If the settings table doesn't exist, bring everything down from initial version.
|
|
|
|
return self.migrateDownFromVersion(initialVersion);
|
2013-07-27 19:41:10 +00:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
// Migrate from a specific version to the latest
|
2013-08-03 16:11:16 +01:00
|
|
|
migrateUpFromVersion: function (version, max) {
|
2013-07-27 19:41:10 +00:00
|
|
|
var versions = [],
|
2013-09-14 22:13:59 +01:00
|
|
|
maxVersion = max || this.getVersionAfter(databaseVersion),
|
2013-07-27 19:41:10 +00:00
|
|
|
currVersion = version,
|
|
|
|
tasks = [];
|
|
|
|
|
|
|
|
// Aggregate all the versions we need to do migrations for
|
|
|
|
while (currVersion !== maxVersion) {
|
|
|
|
versions.push(currVersion);
|
|
|
|
currVersion = this.getVersionAfter(currVersion);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Aggregate all the individual up calls to use in the series(...) below
|
|
|
|
tasks = _.map(versions, function (taskVersion) {
|
|
|
|
return function () {
|
|
|
|
try {
|
|
|
|
var migration = require('./' + taskVersion);
|
|
|
|
return migration.up();
|
|
|
|
} catch (e) {
|
|
|
|
errors.logError(e);
|
|
|
|
return when.reject(e);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
// Run each migration in series
|
|
|
|
return series(tasks);
|
|
|
|
},
|
|
|
|
|
2013-08-03 16:11:16 +01:00
|
|
|
migrateDownFromVersion: function (version) {
|
|
|
|
var versions = [],
|
|
|
|
minVersion = this.getVersionBefore(initialVersion),
|
|
|
|
currVersion = version,
|
|
|
|
tasks = [];
|
|
|
|
|
|
|
|
// Aggregate all the versions we need to do migrations for
|
|
|
|
while (currVersion !== minVersion) {
|
|
|
|
versions.push(currVersion);
|
|
|
|
currVersion = this.getVersionBefore(currVersion);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Aggregate all the individual up calls to use in the series(...) below
|
|
|
|
tasks = _.map(versions, function (taskVersion) {
|
|
|
|
return function () {
|
|
|
|
try {
|
|
|
|
var migration = require('./' + taskVersion);
|
|
|
|
return migration.down();
|
|
|
|
} catch (e) {
|
|
|
|
errors.logError(e);
|
|
|
|
return when.reject(e);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
// Run each migration in series
|
|
|
|
return series(tasks);
|
|
|
|
},
|
|
|
|
|
2013-07-27 19:41:10 +00:00
|
|
|
// Get the following version based on the current
|
|
|
|
getVersionAfter: function (currVersion) {
|
|
|
|
|
|
|
|
var currVersionNum = parseInt(currVersion, 10),
|
|
|
|
nextVersion;
|
|
|
|
|
|
|
|
// Default to initialVersion if not parsed
|
|
|
|
if (isNaN(currVersionNum)) {
|
|
|
|
currVersionNum = parseInt(initialVersion, 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
currVersionNum += 1;
|
|
|
|
|
|
|
|
nextVersion = String(currVersionNum);
|
|
|
|
// Pad with 0's until 3 digits
|
|
|
|
while (nextVersion.length < 3) {
|
|
|
|
nextVersion = "0" + nextVersion;
|
|
|
|
}
|
|
|
|
|
|
|
|
return nextVersion;
|
2013-08-03 16:11:16 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
getVersionBefore: function (currVersion) {
|
|
|
|
var currVersionNum = parseInt(currVersion, 10),
|
|
|
|
prevVersion;
|
|
|
|
|
|
|
|
if (isNaN(currVersionNum)) {
|
|
|
|
currVersionNum = parseInt(initialVersion, 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
currVersionNum -= 1;
|
|
|
|
|
|
|
|
prevVersion = String(currVersionNum);
|
|
|
|
// Pad with 0's until 3 digits
|
|
|
|
while (prevVersion.length < 3) {
|
|
|
|
prevVersion = "0" + prevVersion;
|
|
|
|
}
|
|
|
|
|
|
|
|
return prevVersion;
|
2013-07-27 19:41:10 +00:00
|
|
|
}
|
|
|
|
};
|