|
|
@ -552,6 +552,80 @@ let indexHTML = fs.readFileSync("./dist/index.html").toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
socket.on("uploadBackup", async (uploadedJSON, callback) => {
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
checkLogin(socket)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
console.log(`Import Backup User ID: ${socket.userID}`)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let notificationList = uploadedJSON[0];
|
|
|
|
|
|
|
|
let monitorList = uploadedJSON[1];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
monitorList = JSON.stringify(monitorList);
|
|
|
|
|
|
|
|
monitorList = JSON.parse(monitorList);
|
|
|
|
|
|
|
|
monitorList = Object.values(monitorList);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (notificationList.length >= 1) {
|
|
|
|
|
|
|
|
for (let i = 0; i < notificationList.length; i++) {
|
|
|
|
|
|
|
|
let notification = JSON.parse(notificationList[i].config);
|
|
|
|
|
|
|
|
await Notification.save(notification, null, socket.userID)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (monitorList.length >= 1) {
|
|
|
|
|
|
|
|
for (let i = 0; i < monitorList.length; i++) {
|
|
|
|
|
|
|
|
let monitor = {
|
|
|
|
|
|
|
|
name: monitorList[i].name,
|
|
|
|
|
|
|
|
type: monitorList[i].type,
|
|
|
|
|
|
|
|
url: monitorList[i].url,
|
|
|
|
|
|
|
|
interval: monitorList[i].interval,
|
|
|
|
|
|
|
|
hostname: monitorList[i].hostname,
|
|
|
|
|
|
|
|
maxretries: monitorList[i].maxretries,
|
|
|
|
|
|
|
|
port: monitorList[i].port,
|
|
|
|
|
|
|
|
keyword: monitorList[i].keyword,
|
|
|
|
|
|
|
|
ignoreTls: monitorList[i].ignoreTls,
|
|
|
|
|
|
|
|
upsideDown: monitorList[i].upsideDown,
|
|
|
|
|
|
|
|
maxredirects: monitorList[i].maxredirects,
|
|
|
|
|
|
|
|
accepted_statuscodes: monitorList[i].accepted_statuscodes,
|
|
|
|
|
|
|
|
dns_resolve_type: monitorList[i].dns_resolve_type,
|
|
|
|
|
|
|
|
dns_resolve_server: monitorList[i].dns_resolve_server,
|
|
|
|
|
|
|
|
notificationIDList: {},
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let bean = R.dispense("monitor")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let notificationIDList = monitor.notificationIDList;
|
|
|
|
|
|
|
|
delete monitor.notificationIDList;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
monitor.accepted_statuscodes_json = JSON.stringify(monitor.accepted_statuscodes);
|
|
|
|
|
|
|
|
delete monitor.accepted_statuscodes;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bean.import(monitor)
|
|
|
|
|
|
|
|
bean.user_id = socket.userID
|
|
|
|
|
|
|
|
await R.store(bean)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await updateMonitorNotification(bean.id, notificationIDList)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await startMonitor(socket.userID, bean.id);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await sendNotificationList(socket)
|
|
|
|
|
|
|
|
await sendMonitorList(socket);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
callback({
|
|
|
|
|
|
|
|
ok: true,
|
|
|
|
|
|
|
|
msg: "Backup successfully restored.",
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} catch (e) {
|
|
|
|
|
|
|
|
callback({
|
|
|
|
|
|
|
|
ok: false,
|
|
|
|
|
|
|
|
msg: e.message,
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
debug("added all socket handlers")
|
|
|
|
debug("added all socket handlers")
|
|
|
|
|
|
|
|
|
|
|
|
// ***************************
|
|
|
|
// ***************************
|
|
|
|