1
0
mirror of https://github.com/node-red/node-red.git synced 2023-10-10 13:36:53 +02:00

Merge remote-tracking branch 'upstream/master'

This commit is contained in:
Ben Hardill 2013-10-02 11:04:26 +01:00
commit 0b1c14c07e
7 changed files with 202 additions and 49 deletions

View File

@ -76,7 +76,7 @@
outputs:1, outputs:1,
icon: "white-globe.png", icon: "white-globe.png",
label: function() { label: function() {
return this.name||"["+this.method+"] "+this.url; return this.name||(this.url?("["+this.method+"] "+this.url):"http");
}, },
labelStyle: function() { labelStyle: function() {
return this.name?"node_label_italic":""; return this.name?"node_label_italic":"";
@ -85,14 +85,19 @@
</script> </script>
<script type="text/x-red" data-template-name="http response"> <script type="text/x-red" data-template-name="http response">
<div class="form-tips">The messages sent to this node must originate from an HTTP input node</div> <div class="form-row">
<label for="node-input-name"><i class="icon-tag"></i> Name</label>
<input type="text" id="node-input-name" placeholder="Name">
</div>
<div class="form-tips">The messages sent to this node <b>must</b> originate from an <i>http input</i> node</div>
</script> </script>
<script type="text/x-red" data-help-name="http response"> <script type="text/x-red" data-help-name="http response">
<p>Provides an response node for http requests received from an http input node.</p> <p>Sends responses back to http requests received from an HTTP Input node.</p>
<p>The response can be customised using the following message properties:</p>
<ul> <ul>
<li><code>payload</code> is sent as the body of the reponse</li> <li><code>payload</code> is sent as the body of the reponse</li>
<li><code>rc</code>, if set, is used as the response code (default: 200)</li> <li><code>statusCode</code>, if set, is used as the response status code (default: 200)</li>
<li><code>headers</code>, if set, should be an object containing field/value <li><code>headers</code>, if set, should be an object containing field/value
pairs to be added as response headers.</li> pairs to be added as response headers.</li>
</ul> </ul>
@ -102,17 +107,89 @@
RED.nodes.registerType('http response',{ RED.nodes.registerType('http response',{
category: 'output', category: 'output',
color:"rgb(231, 231, 174)", color:"rgb(231, 231, 174)",
defaults: {}, defaults: {
name: {value:""}
},
inputs:1, inputs:1,
outputs:0, outputs:0,
align: "right", align: "right",
icon: "white-globe.png", icon: "white-globe.png",
label: function() { label: function() {
return "http" return this.name||"http";
}, },
labelStyle: function() { labelStyle: function() {
return ""; return this.name?"node_label_italic":"";
} }
}); });
</script> </script>
<script type="text/x-red" data-template-name="http request">
<div class="form-row">
<label for="node-input-method"><i class="icon-tasks"></i> Method</label>
<select type="text" id="node-input-method" style="width: 150px;">
<option value="GET">GET</option>
<option value="POST">POST</option>
<option value="PUT">PUT</option>
<option value="DELETE">DELETE</option>
</select>
</div>
<div class="form-row">
<label for="node-input-url"><i class="icon-tasks"></i> URL</label>
<input type="text" id="node-input-url" placeholder="http://">
</div>
<div class="form-row">
<label for="node-input-name"><i class="icon-tag"></i> Name</label>
<input type="text" id="node-input-name" placeholder="Name">
</div>
</script>
<script type="text/x-red" data-help-name="http request">
<p>Provides a node for making http requests.</p>
<p>The URL and HTTP method can be configured in the node, but also
overridden by the incoming message:
<ul>
<li><code>url</code>, if set, is used as the url of the request</li>
<li><code>method</code>, if set, is used as the HTTP method of the request. Must be one of <code>GET</code>, <code>PUT</code>, <code>POST</code> or <code>DELETE</code> (default: GET)</li>
<li><code>headers</code>, if set, should be an object containing field/value
pairs to be added as request headers</li>
<li><code>payload</code> is sent as the body of the request</li>
</ul>
The output message contains the following properties:
<ul>
<li><code>payload</code> is the body of the response</li>
<li><code>statusCode</code> is the status code of the response, or the error code if the request could not be completed</li>
<li><code>headers</code> is an object containing the response headers</li>
</ul>
</script>
<script type="text/javascript">
RED.nodes.registerType('http request',{
category: 'function',
color:"rgb(231, 231, 174)",
defaults: {
name: {value:""},
method:{value:"GET"},
url:{value:""}
},
inputs:1,
outputs:1,
align: "right",
icon: "white-globe.png",
label: function() {
return this.name||"http request";
},
labelStyle: function() {
return this.name?"node_label_italic":"";
}
});
</script>

View File

@ -16,6 +16,10 @@
var RED = require("../../red/red"); var RED = require("../../red/red");
var util = require("util"); var util = require("util");
var http = require("http");
var https = require("https");
var urllib = require("url");
var bodyParser = require("express").bodyParser();
function HTTPIn(n) { function HTTPIn(n) {
RED.nodes.createNode(this,n); RED.nodes.createNode(this,n);
@ -24,14 +28,15 @@ function HTTPIn(n) {
var node = this; var node = this;
this.callback = function(req,res) { this.callback = function(req,res) {
console.log(arguments.length);
node.send({req:req,res:res}); node.send({req:req,res:res});
} }
if (this.method == "get") { if (this.method == "get") {
RED.app.get(this.url,this.callback); RED.app.get(this.url,this.callback);
} else if (this.method == "post") { } else if (this.method == "post") {
RED.app.post(this.url,this.callback); RED.app.post(this.url,bodyParser,this.callback);
} else if (this.method == "put") { } else if (this.method == "put") {
RED.app.put(this.url,this.callback); RED.app.put(this.url,bodyParser,this.callback);
} else if (this.method == "delete") { } else if (this.method == "delete") {
RED.app.delete(this.url,this.callback); RED.app.delete(this.url,this.callback);
} }
@ -41,7 +46,7 @@ function HTTPIn(n) {
for (var i in routes) { for (var i in routes) {
if (routes[i].path == this.url) { if (routes[i].path == this.url) {
routes.splice(i,1); routes.splice(i,1);
break; //break;
} }
} }
}); });
@ -58,10 +63,59 @@ function HTTPOut(n) {
if (msg.headers) { if (msg.headers) {
res.set(msg.headers); res.set(msg.headers);
} }
var rc = msg.rc || 200; var statusCode = msg.statusCode || 200;
msg.res.send(rc,msg.payload); msg.res.send(statusCode,msg.payload);
} }
}); });
} }
RED.nodes.registerType("http response",HTTPOut); RED.nodes.registerType("http response",HTTPOut);
function HTTPRequest(n) {
RED.nodes.createNode(this,n);
var url = n.url;
var method = n.method || "GET";
var httplib = (/^https/.test(url))?https:http;
var node = this;
this.on("input",function(msg) {
var opts = urllib.parse(msg.url||url);
opts.method = msg.method||method;
if (msg.headers) {
opts.header = headers;
}
var req = httplib.request(opts,function(res) {
res.setEncoding('utf8');
var message = {
statusCode: res.statusCode,
headers: res.headers,
payload: ""
};
res.on('data',function(chunk) {
message.payload += chunk;
});
res.on('end',function() {
node.send(message);
});
});
req.on('error',function(err) {
msg.payload = err.toString();
msg.statusCode = err.code;
node.send(msg);
});
if (msg.payload) {
if (typeof msg.payload === "string" || Buffer.isBuffer(msg.payload)) {
req.write(msg.payload);
} else if (typeof msg.payload == "number") {
req.write(msg.payload+"");
} else {
req.write(JSON.stringify(msg.payload));
}
}
req.end();
});
}
RED.nodes.registerType("http request",HTTPRequest);

View File

@ -15,6 +15,8 @@
--> -->
<script type="text/x-red" data-template-name="httpget"> <script type="text/x-red" data-template-name="httpget">
<div class="form-tips"><b>Deprecated</b>: please use the <i>http request</i> node.</div>
<br>
<div class="form-row"> <div class="form-row">
<label for="node-input-baseurl"><i class="icon-tasks"></i> Base URL</label> <label for="node-input-baseurl"><i class="icon-tasks"></i> Base URL</label>
<input type="text" id="node-input-baseurl" placeholder="http(s)://url"> <input type="text" id="node-input-baseurl" placeholder="http(s)://url">

View File

@ -32,8 +32,10 @@
<script type="text/x-red" data-help-name="prowl"> <script type="text/x-red" data-help-name="prowl">
<p>Uses Prowl to push the <b>msg.payload</b> to an Apple device that has the prowl app installed.</p> <p>Uses Prowl to push the <b>msg.payload</b> to an Apple device that has the prowl app installed.</p>
<p>Optionally uses <b>msg.topic</b> to set the title. You can also set <b>msg.priority</b> to confgure the urgency from -2 (low), through 0 (normal) to 2 (urgent).</p> <p>Optionally uses <b>msg.topic</b> to set the title. You can also set <b>msg.priority</b> to confgure the urgency from -2 (low), through 0 (normal) to 2 (urgent).</p>
<p>You MUST configure your prowl API key into the pushkey.js file in the directory above node-red.</p> <p>You MUST configure your prowl API key into either the settings.js file like this</p>
<p><pre>module.exports = { prowl:'My-API-KEY' }</pre></p> <p><pre>prowl: { prowlkey:'My-API-KEY' },</pre></p>
<p>Or into a pushkey.js file in the directory <b>above</b> node-red.</p>
<p><pre>module.exports = { prowlkey:'My-API-KEY' }</pre></p>
<p>Uses Prowl so see <i><a href="https://www.prowlapp.com" target="_new">this link</a></i> for more details.</p> <p>Uses Prowl so see <i><a href="https://www.prowlapp.com" target="_new">this link</a></i> for more details.</p>
</script> </script>

View File

@ -16,17 +16,23 @@
var RED = require("../../red/red"); var RED = require("../../red/red");
var Prowl = require('node-prowl'); var Prowl = require('node-prowl');
var util = require('util');
// pushkey.js just needs to be like (with the quotes) // Either add a line like this to settings.js
// module.exports = {prowl:'My-API-KEY'} // prowl: {prowlkey:'My-API-KEY'},
// or create pushkey.js in dir ABOVE node-red, it just needs to be like
// module.exports = {prowlkey:'My-API-KEY'}
try { try {
var pushkey = require("../../settings").prowl || require("../../../pushkey.js"); var pushkey = require("../../settings").prowl || require("../../../pushkey.js");
} catch(err) { }
throw new Error("Failed to load Prowl credentials"); catch(err) {
util.log("[57-prowl.js] Error: Failed to load Prowl credentials");
} }
var prowl = new Prowl(pushkey.prowl); if (pushkey) {
var prowl = new Prowl(pushkey.prowlkey);
}
function ProwlNode(n) { function ProwlNode(n) {
RED.nodes.createNode(this,n); RED.nodes.createNode(this,n);
@ -41,6 +47,7 @@ function ProwlNode(n) {
if (typeof(msg.payload) == 'object') { if (typeof(msg.payload) == 'object') {
msg.payload = JSON.stringify(msg.payload); msg.payload = JSON.stringify(msg.payload);
} }
if (pushkey) {
try { try {
prowl.push(msg.payload, titl, { priority: pri }, function(err, remaining) { prowl.push(msg.payload, titl, { priority: pri }, function(err, remaining) {
if (err) node.error(err); if (err) node.error(err);
@ -50,6 +57,10 @@ function ProwlNode(n) {
catch (err) { catch (err) {
node.error(err); node.error(err);
} }
}
else {
node.warn("Prowl credentials not set/found. See node info.");
}
}); });
} }

View File

@ -16,13 +16,9 @@
<script type="text/x-red" data-template-name="pushbullet"> <script type="text/x-red" data-template-name="pushbullet">
<div class="form-row"> <div class="form-row">
<label for="node-input-title"><i class="icon-tag"></i> Title</label> <label for="node-input-title"><i class="icon-flag"></i> Title</label>
<input type="text" id="node-input-title" placeholder="Node-RED"> <input type="text" id="node-input-title" placeholder="Node-RED">
</div> </div>
<div class="form-row">
<label for="node-input-priority"><i class="icon-tag"></i> Priority</label>
<input type="text" id="node-input-priority" placeholder="0">
</div>
<div class="form-row"> <div class="form-row">
<label for="node-input-name"><i class="icon-tag"></i> Name</label> <label for="node-input-name"><i class="icon-tag"></i> Name</label>
<input type="text" id="node-input-name" placeholder="Name"> <input type="text" id="node-input-name" placeholder="Name">
@ -31,9 +27,11 @@
<script type="text/x-red" data-help-name="pushbullet"> <script type="text/x-red" data-help-name="pushbullet">
<p>Uses PushBullet to push the <b>msg.payload</b> to an Android device that has PushBullet app installed.</p> <p>Uses PushBullet to push the <b>msg.payload</b> to an Android device that has PushBullet app installed.</p>
<p>Optionally uses <b>msg.topic</b> to set the title.</p> <p>Optionally uses <b>msg.topic</b> to set the title, if not already set in the properties.</p>
<p>You MUST configure both your API key and the target device ID into the pushkey.js file in the directory above node-red.<p> <p>You MUST configure both your API key and the target device ID. Either into settings.js like this</p>
<p><pre>>module.exports = { pushbullet:'My-API-KEY', deviceid:'12345' }</pre</p> <p><pre>pushbullet: { pushbullet:'My-API-KEY', deviceid:'12345' },</pre></p>
<p>Or as a pushkey.js file in the directory <b>above</b> node-red.<p>
<p><pre>module.exports = { pushbullet:'My-API-KEY', deviceid:'12345' }</pre></p>
</script> </script>
<script type="text/javascript"> <script type="text/javascript">
@ -41,7 +39,6 @@
category: 'output', category: 'output',
defaults: { defaults: {
title: {value:""}, title: {value:""},
priority: {value:0,required:true,validate:RED.validators.number()},
name: {value:""} name: {value:""}
}, },
color:"#a7c9a0", color:"#a7c9a0",

View File

@ -16,38 +16,48 @@
var RED = require("../../red/red"); var RED = require("../../red/red");
var PushBullet = require('pushbullet'); var PushBullet = require('pushbullet');
var util = require('util');
// pushkey.js just needs to be like (with the quotes) // Either add a line like this to settings.js
// pushbullet: {pushbullet:'My-API-KEY', deviceid:'12345'},
// or create pushkey.js in dir ABOVE node-red, it just needs to be like
// module.exports = {pushbullet:'My-API-KEY', deviceid:'12345'} // module.exports = {pushbullet:'My-API-KEY', deviceid:'12345'}
try { try {
var pushkey = require("../../settings").pushbullet || require("../../../pushkey.js"); var pushkey = require("../../settings").pushbullet || require("../../../pushkey.js");
} catch(err) { }
throw new Error("Failed to load PushBullet credentials"); catch(err) {
util.log("[57-pushbullet.js] Error: Failed to load PushBullet credentials");
} }
if (pushkey) {
var pusher = new PushBullet(pushkey.pushbullet); var pusher = new PushBullet(pushkey.pushbullet);
var deviceId = pushkey.deviceid; var deviceId = pushkey.deviceid;
}
function PushbulletNode(n) { function PushbulletNode(n) {
RED.nodes.createNode(this,n); RED.nodes.createNode(this,n);
this.title = n.title; this.title = n.title;
this.device
var node = this; var node = this;
this.on("input",function(msg) { this.on("input",function(msg) {
var titl = this.title||msg.topic||"Node-RED"; var titl = this.title||msg.topic||"Node-RED";
if (typeof(msg.payload) == 'object') { if (typeof(msg.payload) == 'object') {
msg.payload = JSON.stringify(msg.payload); msg.payload = JSON.stringify(msg.payload);
} }
if (pushkey) {
try { try {
pusher.note(deviceId, titl, msg.payload, function(err, response) { pusher.note(deviceId, titl, msg.payload, function(err, response) {
if (err) node.error(err); if (err) node.error(err);
node.log( JSON.stringify(response) ); console.log(response);
}); });
} }
catch (err) { catch (err) {
node.error(err); node.error(err);
} }
}
else {
node.warn("Pushbullet credentials not set/found. See node info.");
}
}); });
} }