node-red-contrib-mongoql
Version:
MongoDB Query for Node-Red
65 lines (51 loc) • 2.23 kB
JavaScript
module.exports = function (RED) {
const mongoClient = require('mongodb');
var ObjectId = require('mongodb').ObjectId;
function deleteById(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 id = msg.id;
if (url === 'undefined' || db_name === 'undefined' || db_collection === 'undefined' || id === 'undefined') {
delete msg.url;
delete msg.db_name;
delete msg.db_collection;
delete msg.id;
msg.status = "error";
msg.payload = "Please provide msg.url, msg.db_name, msg.db_collection and msg.id";
node.send(msg);
} else {
delete msg.url;
delete msg.db_name;
delete msg.db_collection;
delete msg.id;
var oid = new ObjectId(id);
mongoClient.connect(url, { useNewUrlParser: true }).then((client) => {
var db = client.db(db_name).collection(db_collection);
db.deleteOne({ _id: oid }).then((result) => {
client.close();
msg.status = "success";
msg.payload = {
"deletedId": id,
"deletedCount": result.deletedCount
};
node.send(msg);
}).catch(() => {
client.close();
msg.status = "error";
msg.payload = "Failed to Delete"
node.send(msg);
});
}).catch(() => {
msg.status = "error";
msg.payload = "Database or Collection Not Available";
node.send(msg);
});
}
});
}
RED.nodes.registerType("deleteById", deleteById);
}