backup.js 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. let express = require('express')
  2. let router = express.Router()
  3. let randomBytes = require('crypto').randomBytes
  4. let exec = require('child_process').exec
  5. let fs = require('fs')
  6. let { Sequelize, Backup } = require('../models')
  7. const Errors = require('../lib/errors')
  8. const Config = require('../config/config.json')
  9. function promiseFromChildProcess(child) {
  10. return new Promise((resolve, reject) => {
  11. child.addListener('error', reject)
  12. child.addListener('exit', resolve)
  13. })
  14. }
  15. router.post('/', async (req, res) => {
  16. try {
  17. let dev = Config.development
  18. let id = randomBytes(12).toString('base64')
  19. let backupName = id + '-' + (new Date()).toISOString() + '.sql'
  20. let sha256 = await promiseFromChildProcess(exec(`
  21. mkdir ../backups -p
  22. && mysqldump --lock-all-tables -u ${dev.username} -p${dev.password} ${dev.database} > ../backups/${backupName}
  23. && openssl dgst -sha256 ../backups/${backupName}
  24. `))
  25. let size = fs.statsSync('../backups/' + backupName).size
  26. let backup = await Backup.create({ sha256, size })
  27. res.json(backup.toJSON())
  28. } catch (e) {
  29. console.log(e)
  30. res.status(500)
  31. res.json({
  32. errors: [Errors.unknown]
  33. })
  34. }
  35. })
  36. module.exports = router