node-red-contrib-mongoql
Version:
MongoDB Query for Node-Red
67 lines (54 loc) • 2.43 kB
JavaScript
module.exports = function (RED) {
const mongoClient = require('mongodb');
var ObjectId = require('mongodb').ObjectId;
function updateMany(config) {
RED.nodes.createNode(this, config);
var node = this;
node.on('input', function (msg) {
var url = msg.url;
var db_name = msg.db_name;
var db_collection = msg.db_collection;
var filter = msg.filter || {};
var data = msg.payload;
if (url === 'undefined' || db_name === 'undefined' || db_collection === 'undefined' || filter === 'undefined' || data === 'undefined') {
delete msg.url;
delete msg.db_name;
delete msg.db_collection;
delete msg.filter;
delete msg.payload;
msg.status = "error";
msg.payload = "Please provide msg.url, msg.db_name, msg.db_collection, msg.filter and msg.payload";
node.send(msg);
} else {
delete msg.url;
delete msg.db_name;
delete msg.db_collection;
delete msg.filter;
delete msg.payload;
mongoClient.connect(url, { useNewUrlParser: true }).then((client) => {
var db = client.db(db_name).collection(db_collection);
db.updateMany(filter, { $set: data }).then((result) => {
client.close();
msg.status = "success";
msg.payload = {
"updatedFilter": filter,
"updatedData": data,
"updatedCount": result.modifiedCount
};
node.send(msg);
}).catch(() => {
client.close();
msg.status = "error";
msg.payload = "Failed to Update"
node.send(msg);
});
}).catch(() => {
msg.status = "error";
msg.payload = "Database or Collection Not Available";
node.send(msg);
});
}
});
}
RED.nodes.registerType("updateMany", updateMany);
}