2013-09-24 05:46:30 -05:00
|
|
|
var when = require('when'),
|
|
|
|
_ = require('underscore'),
|
2013-09-15 11:04:42 -05:00
|
|
|
migration = require('../migration'),
|
2013-09-22 17:20:08 -05:00
|
|
|
knex = require('../../models/base').knex,
|
2014-01-02 19:37:21 -05:00
|
|
|
schema = require('../schema').tables,
|
2013-06-15 15:52:03 -05:00
|
|
|
|
2013-11-24 09:29:36 -05:00
|
|
|
excludedTables = ['sessions'],
|
2013-09-15 11:04:42 -05:00
|
|
|
exporter;
|
2013-06-15 15:52:03 -05:00
|
|
|
|
2013-09-15 11:04:42 -05:00
|
|
|
exporter = function () {
|
2013-11-18 09:21:15 -05:00
|
|
|
var tablesToExport = _.keys(schema);
|
2013-06-15 15:52:03 -05:00
|
|
|
|
2013-09-15 11:04:42 -05:00
|
|
|
return when.join(migration.getDatabaseVersion(), tablesToExport).then(function (results) {
|
|
|
|
var version = results[0],
|
|
|
|
tables = results[1],
|
|
|
|
selectOps = _.map(tables, function (name) {
|
2013-11-24 09:29:36 -05:00
|
|
|
if (excludedTables.indexOf(name) < 0) {
|
|
|
|
return knex(name).select();
|
|
|
|
}
|
2013-09-15 11:04:42 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
return when.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 when.resolve(exportData);
|
|
|
|
}, function (err) {
|
|
|
|
console.log("Error exporting data: " + err);
|
|
|
|
});
|
|
|
|
});
|
2013-06-25 06:43:15 -05:00
|
|
|
};
|
2013-09-15 11:04:42 -05:00
|
|
|
|
|
|
|
module.exports = exporter;
|