Ghost/core/server/data/export/index.js

63 lines
2.0 KiB
JavaScript
Raw Normal View History

var _ = require('lodash'),
Promise = require('bluebird'),
versioning = require('../versioning'),
config = require('../../config'),
utils = require('../utils'),
serverUtils = require('../../utils'),
errors = require('../../errors'),
settings = require('../../api/settings'),
excludedTables = ['accesstokens', 'refreshtokens', 'clients'],
exporter,
exportFileName;
exportFileName = function () {
var datetime = (new Date()).toJSON().substring(0, 10),
title = '';
return settings.read({key: 'title', context: {internal: true}}).then(function (result) {
if (result) {
title = serverUtils.safeString(result.settings[0].value) + '.';
}
return title + 'ghost.' + datetime + '.json';
}).catch(function (err) {
errors.logError(err);
return 'ghost.' + datetime + '.json';
});
};
2013-06-16 00:52:03 +04:00
exporter = function () {
return Promise.join(versioning.getDatabaseVersion(), utils.getTables()).then(function (results) {
var version = results[0],
tables = results[1],
selectOps = _.map(tables, function (name) {
if (excludedTables.indexOf(name) < 0) {
return config.database.knex(name).select();
}
});
return Promise.all(selectOps).then(function (tableData) {
var exportData = {
meta: {
exported_on: new Date().getTime(),
version: version
},
data: {
// Filled below
}
};
_.each(tables, function (name, i) {
exportData.data[name] = tableData[i];
});
return exportData;
}).catch(function (err) {
errors.logAndThrowError(err, 'Error exporting data', '');
});
});
};
module.exports = exporter;
module.exports.fileName = exportFileName;