From 7ea744fdfe3d74ed2d07973ba8024423432dc605 Mon Sep 17 00:00:00 2001 From: Simon Smith Date: Thu, 7 Sep 2023 19:31:26 +0100 Subject: [PATCH 1/2] use new nedb instead of old --- db.js | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/db.js b/db.js index 4fd9fbb4..353d18f5 100644 --- a/db.js +++ b/db.js @@ -3181,7 +3181,10 @@ module.exports.CreateDB = function (parent, func) { // Transfer NeDB data into the current database obj.nedbtodb = function (func) { - var nedbDatastore = require('nedb'); + var nedbDatastore = null; + try { nedbDatastore = require('@yetzt/nedb'); } catch (ex) { } // This is the NeDB with fixed security dependencies. + if (nedbDatastore == null) { nedbDatastore = require('nedb'); } // So not to break any existing installations, if the old NeDB is present, use it. + var datastoreOptions = { filename: parent.getConfigFilePath('meshcentral.db'), autoload: true }; // If a DB encryption key is provided, perform database encryption From 23c2627b3bee1f6b4a86113039042d6e802e7100 Mon Sep 17 00:00:00 2001 From: Simon Smith Date: Thu, 7 Sep 2023 19:35:03 +0100 Subject: [PATCH 2/2] fix nedb to sqlite migrate --- db.js | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/db.js b/db.js index 353d18f5..4dd88f70 100644 --- a/db.js +++ b/db.js @@ -1470,7 +1470,14 @@ module.exports.CreateDB = function (parent, func) { obj.StoreEvent = function (event, func) { obj.dbCounters.eventsSet++; sqlDbQuery('INSERT INTO events VALUES (NULL, $1, $2, $3, $4, $5, $6) RETURNING id', [event.time, ((typeof event.domain == 'string') ? event.domain : null), event.action, event.nodeid ? event.nodeid : null, event.userid ? event.userid : null, JSON.stringify(event)], function (err, docs) { - if ((err == null) && (docs[0].id)) { for (var i in event.ids) { if (event.ids[i] != '*') { sqlDbQuery('INSERT INTO eventids VALUES ($1, $2)', [docs[0].id, event.ids[i]]); } } } + if(func){ func(); } + if ((err == null) && (docs[0].id)) { + for (var i in event.ids) { + if (event.ids[i] != '*') { + sqlDbQuery('INSERT INTO eventids VALUES ($1, $2)', [docs[0].id, event.ids[i]], function(){ if(func){ func(); } }); + } + } + } }); }; obj.GetEvents = function (ids, domain, func) { @@ -3239,6 +3246,7 @@ module.exports.CreateDB = function (parent, func) { for (var i in docs) { pendingTransfer++; eventRecordsTransferCount++; + for (var b in docs[i].ids) { if (docs[i].ids[b] != '*') { pendingTransfer++; } } obj.StoreEvent(docs[i], function () { pendingTransfer--; }); } }