2013-12-20 10:00:35 +01:00
|
|
|
/**
|
2013-12-20 10:33:06 +01:00
|
|
|
* Copyright 2013 Kris Daniels.
|
2013-12-20 10:00:35 +01:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
**/
|
|
|
|
|
|
|
|
var RED = require(process.env.NODE_RED_HOME+"/red/red");
|
|
|
|
var pg=require('pg');
|
|
|
|
var named=require('node-postgres-named');
|
2013-12-21 11:01:19 +01:00
|
|
|
var querystring = require('querystring');
|
|
|
|
|
|
|
|
RED.app.get('/postgresdb/:id',function(req,res) {
|
|
|
|
var credentials = RED.nodes.getCredentials(req.params.id);
|
|
|
|
if (credentials) {
|
|
|
|
res.send(JSON.stringify({user:credentials.user,hasPassword:(credentials.password&&credentials.password!="")}));
|
|
|
|
} else {
|
|
|
|
res.send(JSON.stringify({}));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
RED.app.delete('/postgresdb/:id',function(req,res) {
|
|
|
|
RED.nodes.deleteCredentials(req.params.id);
|
|
|
|
res.send(200);
|
|
|
|
});
|
|
|
|
|
|
|
|
RED.app.post('/postgresdb/:id',function(req,res) {
|
|
|
|
var body = "";
|
|
|
|
req.on('data', function(chunk) {
|
|
|
|
body+=chunk;
|
|
|
|
});
|
|
|
|
req.on('end', function(){
|
|
|
|
var newCreds = querystring.parse(body);
|
|
|
|
var credentials = RED.nodes.getCredentials(req.params.id)||{};
|
|
|
|
if (newCreds.user == null || newCreds.user == "") {
|
|
|
|
delete credentials.user;
|
|
|
|
} else {
|
|
|
|
credentials.user = newCreds.user;
|
|
|
|
}
|
|
|
|
if (newCreds.password == "") {
|
|
|
|
delete credentials.password;
|
|
|
|
} else {
|
|
|
|
credentials.password = newCreds.password||credentials.password;
|
|
|
|
}
|
|
|
|
RED.nodes.addCredentials(req.params.id,credentials);
|
|
|
|
res.send(200);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2013-12-20 10:00:35 +01:00
|
|
|
|
|
|
|
function PostgresDatabaseNode(n) {
|
|
|
|
RED.nodes.createNode(this,n);
|
|
|
|
this.hostname = n.hostname;
|
|
|
|
this.port = n.port;
|
|
|
|
this.db = n.db;
|
2013-12-21 11:01:19 +01:00
|
|
|
|
|
|
|
var credentials = RED.nodes.getCredentials(n.id);
|
|
|
|
if (credentials) {
|
|
|
|
this.user = credentials.user;
|
|
|
|
this.password = credentials.password;
|
|
|
|
}
|
2013-12-20 10:00:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
RED.nodes.registerType("postgresdb",PostgresDatabaseNode);
|
|
|
|
|
|
|
|
function PostgresNode(n) {
|
|
|
|
RED.nodes.createNode(this,n);
|
|
|
|
|
|
|
|
this.topic = n.topic;
|
|
|
|
this.postgresdb = n.postgresdb;
|
|
|
|
this.postgresConfig = RED.nodes.getNode(this.postgresdb);
|
|
|
|
this.sqlquery = n.sqlquery;
|
2013-12-21 09:23:46 +01:00
|
|
|
this.output = n.output;
|
2013-12-20 10:00:35 +01:00
|
|
|
|
|
|
|
var node = this;
|
2013-12-21 11:01:19 +01:00
|
|
|
|
2013-12-20 10:00:35 +01:00
|
|
|
if(this.postgresConfig)
|
|
|
|
{
|
|
|
|
|
2013-12-21 11:01:19 +01:00
|
|
|
var conString = 'postgres://'+this.postgresConfig.user +':' + this.postgresConfig.password + '@' + this.postgresConfig.hostname + ':' + this.postgresConfig.port + '/' + this.postgresConfig.db;
|
2013-12-20 10:00:35 +01:00
|
|
|
node.clientdb = new pg.Client(conString);
|
|
|
|
named.patch(node.clientdb);
|
|
|
|
|
|
|
|
node.clientdb.connect(function(err){
|
|
|
|
if(err) { node.error(err); }
|
|
|
|
else {
|
|
|
|
node.on('input',
|
|
|
|
function(msg){
|
2013-12-21 09:23:46 +01:00
|
|
|
if(!msg.queryParameters) msg.queryParameters={};
|
|
|
|
node.clientdb.query(msg.payload,
|
|
|
|
msg.queryParameters,
|
2013-12-20 10:00:35 +01:00
|
|
|
function (err, results) {
|
|
|
|
if(err) { node.error(err); }
|
|
|
|
else {
|
2013-12-21 09:23:46 +01:00
|
|
|
if(node.output)
|
2013-12-20 10:00:35 +01:00
|
|
|
{
|
|
|
|
msg.payload = results.rows;
|
|
|
|
node.send(msg);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
this.error("missing postgres configuration");
|
|
|
|
}
|
|
|
|
|
|
|
|
this.on("close", function() {
|
|
|
|
if(node.clientdb) node.clientdb.end();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
RED.nodes.registerType("postgres",PostgresNode);
|