2013-09-24 12:46:30 +02:00
|
|
|
var when = require('when'),
|
|
|
|
_ = require('underscore'),
|
2013-09-15 17:04:42 +01:00
|
|
|
migration = require('../migration'),
|
2013-09-24 12:46:30 +02:00
|
|
|
client = require('../../models/base').client,
|
2013-09-22 18:20:08 -04:00
|
|
|
knex = require('../../models/base').knex,
|
2013-06-15 20:52:03 +00:00
|
|
|
|
2013-09-15 17:04:42 +01:00
|
|
|
exporter;
|
2013-06-15 20:52:03 +00:00
|
|
|
|
2013-09-15 17:04:42 +01:00
|
|
|
function getTablesFromSqlite3() {
|
2013-09-22 18:20:08 -04:00
|
|
|
return knex.raw("select * from sqlite_master where type = 'table'").then(function (response) {
|
|
|
|
return _.reject(_.pluck(response[0], 'tbl_name'), function (name) {
|
2013-09-15 17:04:42 +01:00
|
|
|
return name === 'sqlite_sequence';
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2013-08-03 16:11:16 +01:00
|
|
|
|
2013-09-15 17:04:42 +01:00
|
|
|
function getTablesFromMySQL() {
|
2013-09-22 18:20:08 -04:00
|
|
|
return knex.raw("show tables").then(function (response) {
|
|
|
|
return _.flatten(_.map(response[0], function (entry) {
|
2013-09-15 17:04:42 +01:00
|
|
|
return _.values(entry);
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
}
|
2013-06-15 20:52:03 +00:00
|
|
|
|
2013-09-15 17:04:42 +01:00
|
|
|
exporter = function () {
|
|
|
|
var tablesToExport;
|
|
|
|
|
|
|
|
if (client === 'sqlite3') {
|
|
|
|
tablesToExport = getTablesFromSqlite3();
|
|
|
|
} else if (client === 'mysql') {
|
|
|
|
tablesToExport = getTablesFromMySQL();
|
|
|
|
} else {
|
|
|
|
return when.reject("No exporter for database client " + client);
|
2013-06-25 12:43:15 +01:00
|
|
|
}
|
2013-06-15 20:52:03 +00:00
|
|
|
|
2013-09-15 17:04:42 +01:00
|
|
|
return when.join(migration.getDatabaseVersion(), tablesToExport).then(function (results) {
|
|
|
|
var version = results[0],
|
|
|
|
tables = results[1],
|
|
|
|
selectOps = _.map(tables, function (name) {
|
|
|
|
return knex(name).select();
|
|
|
|
});
|
|
|
|
|
|
|
|
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 12:43:15 +01:00
|
|
|
};
|
2013-09-15 17:04:42 +01:00
|
|
|
|
|
|
|
module.exports = exporter;
|