40 lines
1.3 KiB
JavaScript
40 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
if (process.env.NODE_ENV === 'production') {
|
|
console.log('This script does not run in production'); // eslint-disable-line no-console
|
|
process.exit(1);
|
|
}
|
|
|
|
let config = require('config');
|
|
let spawn = require('child_process').spawn;
|
|
let log = require('npmlog');
|
|
|
|
log.level = 'verbose';
|
|
|
|
function createDump(callback) {
|
|
let cmd = spawn('mysqldump', ['-h', config.mysql.host || 'localhost', '-P', config.mysql.port || 3306, '-u', config.mysql.user, '-p' + config.mysql.password, '--skip-opt', '--quick', '--compact', '--complete-insert', '--create-options', '--tz-utc', '--no-set-names', '--skip-set-charset', '--skip-comments', config.mysql.database]);
|
|
|
|
process.stdout.write('SET UNIQUE_CHECKS=0;\nSET FOREIGN_KEY_CHECKS=0;\n\n');
|
|
|
|
cmd.stdout.pipe(process.stdout);
|
|
cmd.stderr.pipe(process.stderr);
|
|
|
|
cmd.on('close', code => {
|
|
if (code) {
|
|
return callback(new Error('mysqldump command exited with code ' + code));
|
|
}
|
|
|
|
process.stdout.write('\nSET UNIQUE_CHECKS=1;\nSET FOREIGN_KEY_CHECKS=1;\n');
|
|
|
|
return callback(null, true);
|
|
});
|
|
}
|
|
|
|
createDump(err => {
|
|
if (err) {
|
|
log.error('sqldump', err);
|
|
process.exit(1);
|
|
}
|
|
log.info('sqldump', 'MySQL Dump Completed');
|
|
process.exit(0);
|
|
});
|