node-red-contrib-mongoql
Version:
MongoDB Query for Node-Red
60 lines (47 loc) • 2.08 kB
JavaScript
module.exports = function (RED) {
const mongoClient = require('mongodb');
function insertOne(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 data = msg.payload;
if (url === 'undefined' || db_name === 'undefined' || db_collection === 'undefined' || data === 'undefined') {
delete msg.url;
delete msg.db_name;
delete msg.db_collection;
delete msg.payload;
msg.status = "error";
msg.payload = "Please provide msg.url, msg.db_name, msg.db_collection and msg.payload";
node.send(msg);
} else {
delete msg.url;
delete msg.db_name;
delete msg.db_collection;
delete msg.payload;
mongoClient.connect(url, { useNewUrlParser: true }).then((client) => {
var db = client.db(db_name).collection(db_collection);
db.insertOne(data).then((result) => {
client.close();
msg.status = "success";
msg.payload = result.ops;
msg.insertedCount = result.insertedCount;
node.send(msg);
}).catch(() => {
client.close();
msg.status = "error";
msg.payload = "Failed to Insert"
node.send(msg);
});
}).catch(() => {
msg.status = "error";
msg.payload = "Database or Collection Not Available";
node.send(msg);
});
}
});
}
RED.nodes.registerType("insertOne", insertOne);
}