2016-03-14 17:39:00 +00:00
|
|
|
var Promise = require('bluebird'),
|
|
|
|
commands = require('../../schema').commands,
|
|
|
|
db = require('../../db'),
|
|
|
|
|
|
|
|
table = 'clients',
|
|
|
|
columns = ['redirection_uri', 'logo', 'status', 'type', 'description'];
|
|
|
|
|
2016-03-21 12:44:23 +00:00
|
|
|
module.exports = function addManyColumnsToClients(logger) {
|
2016-03-14 17:39:00 +00:00
|
|
|
return db.knex.schema.hasTable(table).then(function (exists) {
|
|
|
|
if (exists) {
|
|
|
|
return Promise.mapSeries(columns, function (column) {
|
2016-03-21 12:44:23 +00:00
|
|
|
var message = 'Adding column: ' + table + '.' + column;
|
2016-03-14 17:39:00 +00:00
|
|
|
return db.knex.schema.hasColumn(table, column).then(function (exists) {
|
|
|
|
if (!exists) {
|
2016-03-21 12:44:23 +00:00
|
|
|
logger.info(message);
|
2016-03-14 17:39:00 +00:00
|
|
|
return commands.addColumn(table, column);
|
2016-03-21 12:44:23 +00:00
|
|
|
} else {
|
|
|
|
logger.warn(message);
|
2016-03-14 17:39:00 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
2016-03-21 12:44:23 +00:00
|
|
|
} else {
|
|
|
|
// @TODO: this should probably be an error
|
|
|
|
logger.warn('Adding columns to table: ' + table);
|
2016-03-14 17:39:00 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|