You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
168 lines
5.5 KiB
168 lines
5.5 KiB
'use strict';
|
|
const request = require('superagent')
|
|
const moment = require('moment');
|
|
function getBackupsList(opts) {
|
|
return async function (ctx, next) {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
const { page, limit, name } = ctx.query;
|
|
const Op = ctx.fs.dc.ORM.Op;
|
|
let errMsg = { message: '获取数据备份失败' }
|
|
try {
|
|
let searchWhere = {
|
|
|
|
}
|
|
let option = {
|
|
where: searchWhere,
|
|
order: [["id", "desc"]],
|
|
attributes: { exclude: ['password'] },
|
|
}
|
|
|
|
if (name) {
|
|
searchWhere.note = { $like: '%' + name + '%' };
|
|
}
|
|
|
|
|
|
option.where = searchWhere
|
|
let limit_ = limit || 10;
|
|
let page_ = page || 1;
|
|
let offset = (page_ - 1) * limit_;
|
|
if (limit && page) {
|
|
option.limit = limit_
|
|
option.offset = offset
|
|
}
|
|
|
|
const res = await models.Backups.findAndCount(option);
|
|
res.time = moment()
|
|
ctx.status = 200;
|
|
ctx.body = res;
|
|
} catch (error) {
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
ctx.status = 400;
|
|
ctx.body = errMsg
|
|
}
|
|
}
|
|
}
|
|
|
|
// 新增数据备份
|
|
function addBackups(opts) {
|
|
return async function (ctx, next) {
|
|
const { backupsUrl } = opts;
|
|
const models = ctx.fs.dc.models;
|
|
try {
|
|
let rslt = ctx.request.body;
|
|
const { database, host, password, port, user } = ctx.request.body.databases
|
|
let backup = await models.Backups.create(Object.assign({}, rslt))
|
|
|
|
//调用后端备份接口
|
|
// const url = '10.8.30.160:8085/dumpDB?dbHost=10.8.30.75&dbPort=5432&user=postgres&password=1234&dbName=Anxinyun0916'//测试使用
|
|
const url = backupsUrl + `/dumpDB?dbHost=${host}&dbPort=${port}&user=${user}&password=${password}&dbName=${database}`;
|
|
request.post(url).then(res => {
|
|
const { fileInfo: { name, size }, code, message } = res.body
|
|
models.Backups.update({
|
|
size, source: name, state: code == 200 ? '备份成功' : '备份失败', completeTime: moment(),
|
|
log: code == 200 ? '' : message
|
|
}, { where: { id: backup.id } })
|
|
if (code != 200) ctx.fs.logger.error(`path: ${ctx.path}, error: ${message}`);
|
|
})
|
|
|
|
ctx.status = 204;
|
|
ctx.body = { message: '新建数据备份成功' }
|
|
} catch (error) {
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
ctx.status = 400;
|
|
ctx.body = { message: '新建数据备份失败' }
|
|
}
|
|
}
|
|
}
|
|
|
|
// 修改数据备份
|
|
function editBackups(opts) {
|
|
return async function (ctx, next) {
|
|
|
|
try {
|
|
const models = ctx.fs.dc.models;
|
|
const { id } = ctx.params;
|
|
const body = ctx.request.body;
|
|
|
|
|
|
await models.Backups.update(
|
|
body,
|
|
{ where: { id: id, } }
|
|
)
|
|
ctx.status = 204;
|
|
ctx.body = { message: '修改数据备份成功' }
|
|
|
|
} catch (error) {
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
ctx.status = 400;
|
|
ctx.body = { message: '修改数据备份失败' }
|
|
}
|
|
}
|
|
}
|
|
|
|
// 删除数据备份
|
|
function deleteBackups(opts) {
|
|
return async function (ctx, next) {
|
|
|
|
try {
|
|
const models = ctx.fs.dc.models;
|
|
const { id } = ctx.params;
|
|
|
|
await models.Backups.destroy({
|
|
where: {
|
|
id: id
|
|
}
|
|
})
|
|
ctx.status = 204;
|
|
ctx.body = { message: '删除数据备份成功' }
|
|
} catch (error) {
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
ctx.status = 400;
|
|
ctx.body = { message: '删除数据备份失败' }
|
|
}
|
|
}
|
|
}
|
|
|
|
//备份恢复
|
|
function restore(opts) {
|
|
return async function (ctx, next) {
|
|
const { backupsUrl } = opts;
|
|
const models = ctx.fs.dc.models;
|
|
try {
|
|
let rslt = ctx.request.body;
|
|
const { id, source, databases: { database, host, password, port, user } } = ctx.request.body
|
|
await models.Backups.update({
|
|
state: '恢复中',
|
|
restoreStart: moment()
|
|
}, { where: { id: id } })
|
|
//调用后端备份接口
|
|
const url = backupsUrl + `/restoreDB?dbHost=${host}&dbPort=${port}&user=${user}&password=${password}&dbName=${database}&backFileName=${source}`;
|
|
request.post(url).then(res => {
|
|
const { code, message } = res.body
|
|
models.Backups.update({
|
|
state: code == 200 ? '恢复成功' : '恢复失败',
|
|
log: code == 200 ? '' : message,
|
|
restoreEnd: moment(),
|
|
restoreDatabases: ctx.request.body.databases
|
|
}, { where: { id: id } })
|
|
if (code != 200) ctx.fs.logger.error(`path: ${ctx.path}, error: ${message}`);
|
|
})
|
|
|
|
ctx.status = 204;
|
|
ctx.body = { message: '备份恢复成功' }
|
|
} catch (error) {
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
ctx.status = 400;
|
|
ctx.body = { message: '备份还原失败' }
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = {
|
|
getBackupsList,
|
|
addBackups,
|
|
editBackups,
|
|
deleteBackups,
|
|
restore
|
|
}
|