Merge pull request #469 from chakflying/patch-1

Fix: Fix importing tag if tag doesn't exist
pull/427/head^2
Louis Lam 3 years ago committed by GitHub
commit c669e7eaba
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -945,17 +945,17 @@ exports.entryPage = "dashboard";
socket.on("uploadBackup", async (uploadedJSON, importHandle, callback) => { socket.on("uploadBackup", async (uploadedJSON, importHandle, callback) => {
try { try {
checkLogin(socket) checkLogin(socket);
let backupData = JSON.parse(uploadedJSON); let backupData = JSON.parse(uploadedJSON);
console.log(`Importing Backup, User ID: ${socket.userID}, Version: ${backupData.version}`) console.log(`Importing Backup, User ID: ${socket.userID}, Version: ${backupData.version}`);
let notificationListData = backupData.notificationList; let notificationListData = backupData.notificationList;
let monitorListData = backupData.monitorList; let monitorListData = backupData.monitorList;
let version17x = compareVersions.compare(backupData.version, '1.7.0', '>=') let version17x = compareVersions.compare(backupData.version, "1.7.0", ">=");
// If the import option is "overwrite" it'll clear most of the tables, except "settings" and "user" // If the import option is "overwrite" it'll clear most of the tables, except "settings" and "user"
if (importHandle == "overwrite") { if (importHandle == "overwrite") {
// Stops every monitor first, so it doesn't execute any heartbeat while importing // Stops every monitor first, so it doesn't execute any heartbeat while importing
@ -1050,38 +1050,38 @@ exports.entryPage = "dashboard";
// Only for backup files with the version 1.7.0 or higher, since there was the tag feature implemented // Only for backup files with the version 1.7.0 or higher, since there was the tag feature implemented
if (version17x) { if (version17x) {
// Only import if the specific monitor has tags assigned // Only import if the specific monitor has tags assigned
if (monitorListData[i].tags.length >= 1) { for (const oldTag of monitorListData[i].tags) {
for (let o = 0; o < monitorListData[i].tags.length; o++) {
// Check if tag already exists and get data ->
// Check if tag already exists and get data -> let tag = await R.findOne("tag", " name = ?", [
let tag = await R.findOne("tag", " name = ?", [ oldTag.name,
monitorListData[i].tags[o].name, ]);
])
let tagId;
// Set tagId to vaule from database if (! tag) {
let tagId = tag.id // -> If it doesn't exist, create new tag from backup file
let beanTag = R.dispense("tag");
// -> If it doesn't, create new tag from backup file beanTag.name = oldTag.name;
if (! tag) { beanTag.color = oldTag.color;
let beanTag = R.dispense("tag") await R.store(beanTag);
beanTag.name = monitorListData[i].tags[o].name
beanTag.color = monitorListData[i].tags[o].color tagId = beanTag.id;
await R.store(beanTag) } else {
// -> If it already exist, set tagId to value from database
tagId = beanTag.id tagId = tag.id;
}
// Assign the new created tag to the monitor
await R.exec("INSERT INTO monitor_tag (tag_id, monitor_id, value) VALUES (?, ?, ?)", [
tagId,
bean.id,
monitorListData[i].tags[o].value,
])
} }
// Assign the new created tag to the monitor
await R.exec("INSERT INTO monitor_tag (tag_id, monitor_id, value) VALUES (?, ?, ?)", [
tagId,
bean.id,
oldTag.value,
]);
} }
} }
await updateMonitorNotification(bean.id, notificationIDList) await updateMonitorNotification(bean.id, notificationIDList);
// If monitor was active start it immediately, otherwise pause it // If monitor was active start it immediately, otherwise pause it
if (monitorListData[i].active == 1) { if (monitorListData[i].active == 1) {

Loading…
Cancel
Save