UNPKG

node-red-contrib-mongoql

Version:

MongoDB Query for Node-Red

67 lines (54 loc) 2.43 kB
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); }